X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fdatatransform.cpp;h=055587a71bc7d290343f4674173dc625f087a3f8;hb=aa053d637e8259755af7d2e4b510a242f4d29c7b;hp=67b892ede81de5f8ce1fda4db26dfff666870a35;hpb=d334fc1d04b7f83c7a2e9f16439fec884f4de471;p=builder.git diff --git a/source/datatransform.cpp b/source/datatransform.cpp index 67b892e..055587a 100644 --- a/source/datatransform.cpp +++ b/source/datatransform.cpp @@ -1,4 +1,5 @@ #include +#include #include #include #include @@ -16,33 +17,44 @@ DataTransform::DataTransform(Builder &b, const Component &c, const FS::Path &p): FileTarget(b, c.get_package(), p) { component = &c; + + if(FS::Stat st = FS::lstat(FS::dirname(path))) + dir_mtime = st.get_modify_time(); } void DataTransform::find_dependencies() { - list files; + vector files; Cache &cache = component->get_package().get_cache(); - // XXX Should check directory mtime as well - if(mtime dir_files = list_files(FS::dirname(path)); IO::File in(path.str()); DataFile::Parser parser(in, path.str()); + + vector dir_files; while(!in.eof()) { DataFile::Statement st = parser.parse(); if(st.keyword=="for_each") { - for(DataFile::Statement::Arguments::const_iterator i=st.args.begin(); i!=st.args.end(); ++i) + // There's bound to be at least one file: the transform itself + if(dir_files.empty()) + { + FS::Path dir = FS::dirname(path); + builder.get_logger().log("files", format("Traversing %s", dir.str())); + dir_files = list_files(dir); + } + + for(const DataFile::Value &a: st.args) { - Regex re(i->get()); - for(list::const_iterator j=dir_files.begin(); j!=dir_files.end(); ++j) - if(re.match(*j)) - files.push_back(*j); + Regex re(a.get()); + for(const string &f: dir_files) + if(re.match(f)) + files.push_back(f); } } else if(st.keyword=="file" && st.args.size()==1) @@ -52,12 +64,12 @@ void DataTransform::find_dependencies() cache.set_values(this, "files", files); } - for(list::iterator i=files.begin(); i!=files.end(); ++i) + for(const string &f: files) { - FS::Path file_path = FS::dirname(path)/ *i; + FS::Path file_path = FS::dirname(path)/f; if(Target *tgt = builder.get_vfs().get_target(file_path)) - add_dependency(*tgt); + add_transitive_dependency(*tgt); else - add_dependency(*new File(builder, *package, file_path)); + add_transitive_dependency(*new File(builder, *package, file_path)); } }