X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=tool%2Fcompiler.cpp;h=8725bea3e90c9c2eff8e3e85f21212220e26115c;hb=ae5c70255ce06515224299985672c540d0b237a7;hp=ed5710b97d3bd8d3ffac53d88f4c41855b2866fd;hpb=4371289ed39d8135d407bc7bbbfbedea0cfd6dde;p=libs%2Fdatafile.git diff --git a/tool/compiler.cpp b/tool/compiler.cpp index ed5710b..8725bea 100644 --- a/tool/compiler.cpp +++ b/tool/compiler.cpp @@ -1,10 +1,3 @@ -/* $Id$ - -This file is part of libmspdatafile -Copyright © 2008 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - #include #include #include @@ -40,10 +33,10 @@ void Compiler::write(const DataFile::Statement &st) if(reset_src) { writer.write((DataFile::Statement("__src"), string())); - reset_src=false; + reset_src = false; } - for(list::const_iterator i=st.sub.begin(); i!=st.sub.end(); ++i) + for(list::const_iterator i = st.sub.begin(); i!=st.sub.end(); ++i) writer.write(*i); } @@ -52,26 +45,27 @@ bool Compiler::process_statement(const FS::Path &fn, DataFile::Statement &st) if(st.keyword=="_content") return true; - for(vector::iterator i=st.args.begin(); i!=st.args.end(); ++i) - if(i->get_type()==DataFile::STRING) + for(vector::iterator i = st.args.begin(); i!=st.args.end(); ++i) + if(i->get_signature()==DataFile::StringType::signature) { - if(i->get_raw()=="$filename") - *i=DataFile::Value(FS::basename(fn.str())); - else if(i->get_raw()=="$content") + string value = i->get(); + if(value=="$filename") + *i = DataFile::Value(FS::basename(fn.str())); + else if(value=="$content") { IO::File in(fn.str()); string data; while(!in.eof()) { char buf[4096]; - unsigned len=in.read(buf, sizeof(buf)); + unsigned len = in.read(buf, sizeof(buf)); data.append(buf, len); } - *i=DataFile::Value(data); + *i = DataFile::Value(data); } } - for(list::iterator i=st.sub.begin(); i!=st.sub.end();) + for(list::iterator i = st.sub.begin(); i!=st.sub.end();) { if(process_statement(fn, *i)) { @@ -81,11 +75,11 @@ bool Compiler::process_statement(const FS::Path &fn, DataFile::Statement &st) DataFile::Parser parser(in, fn.str()); while(parser) { - DataFile::Statement ss=parser.parse(); + DataFile::Statement ss = parser.parse(); if(ss.valid) st.sub.insert(i, ss); } - i=st.sub.erase(i); + i = st.sub.erase(i); } else ++i; @@ -97,19 +91,19 @@ bool Compiler::process_statement(const FS::Path &fn, DataFile::Statement &st) void Compiler::process_file(const FS::Path &fn, const list &st) { writer.write((DataFile::Statement("__src"), FS::basename(fn.str()))); - reset_src=true; + reset_src = true; if(st.empty()) process_file(fn); else { - for(list::const_iterator i=st.begin(); i!=st.end(); ++i) + for(list::const_iterator i = st.begin(); i!=st.end(); ++i) { if(i->keyword=="_content") process_file(fn); else { - DataFile::Statement s=*i; + DataFile::Statement s = *i; process_statement(fn, s); writer.write(s); } @@ -125,7 +119,7 @@ void Compiler::process_file(const FS::Path &fn) DataFile::Parser parser(in, fn.str()); while(parser) { - DataFile::Statement st=parser.parse(); + DataFile::Statement st = parser.parse(); if(st.valid) writer.write(st); } @@ -162,14 +156,14 @@ ForEach::ForEach(Compiler &c, const FS::Path &b, const list &p): void ForEach::finish() { - list files=FS::list_files(base); - for(list::iterator i=files.begin(); i!=files.end(); ++i) + list files = FS::list_files(base); + for(list::iterator i = files.begin(); i!=files.end(); ++i) { - bool match=false; - for(list::const_iterator j=patterns.begin(); (j!=patterns.end() && !match); ++j) - match=Regex(*j).match(*i); - for(list::const_iterator j=excludes.begin(); (j!=excludes.end() && match); ++j) - match=!Regex(*j).match(*i); + bool match = false; + for(list::const_iterator j = patterns.begin(); (j!=patterns.end() && !match); ++j) + match = Regex(*j).match(*i); + for(list::const_iterator j = excludes.begin(); (j!=excludes.end() && match); ++j) + match = !Regex(*j).match(*i); if(match) compiler.process_file(base / *i, write_st); }