]> git.tdb.fi Git - builder.git/blobdiff - source/csourcefile.cpp
Refactor transitive dependencies to work on all targets
[builder.git] / source / csourcefile.cpp
diff --git a/source/csourcefile.cpp b/source/csourcefile.cpp
deleted file mode 100644 (file)
index dee807b..0000000
+++ /dev/null
@@ -1,63 +0,0 @@
-#include <msp/core/maputils.h>
-#include <msp/fs/utils.h>
-#include <msp/io/print.h>
-#include <msp/strings/regex.h>
-#include "builder.h"
-#include "component.h"
-#include "csourcefile.h"
-#include "sourcepackage.h"
-
-using namespace std;
-using namespace Msp;
-
-CSourceFile::CSourceFile(Builder &b, const FS::Path &p):
-       SourceFile(b, 0, p)
-{ }
-
-CSourceFile::CSourceFile(Builder &b, const Component &c, const FS::Path &p):
-       SourceFile(b, &c, p)
-{
-       string ext = FS::extpart(FS::basename(path));
-       if(ext==".h" || ext==".H" || ext==".hpp")
-               install_location = "include/"+comp->get_name();
-}
-
-void CSourceFile::find_depends()
-{
-       if(!comp || !mtime)
-               return;
-
-       const SourcePackage &spkg = comp->get_package();
-       string relname = FS::relative(path, spkg.get_source()).str();
-
-       DependencyCache &deps_cache = spkg.get_deps_cache();
-       if(mtime<deps_cache.get_mtime() && deps_cache.has_deps(relname))
-               includes = deps_cache.get_deps(relname);
-       else
-       {
-               IO::BufferedFile in(path.str());
-
-               if(builder.get_verbose()>=4)
-                       IO::print("Reading includes from %s\n", path.str());
-
-               Regex r_include("^[ \t]*#include[ \t]+([\"<].*)[\">]");
-
-               string line;
-               while(in.getline(line))
-                       if(RegMatch match = r_include.match(line))
-                               includes.push_back(match[1].str);
-
-               deps_cache.set_deps(relname, includes);
-       }
-
-       const StringList &incpath = comp->get_build_info().incpath;
-       StringList local_incpath = incpath;
-       local_incpath.push_front(FS::dirname(path).str());
-
-       for(list<string>::iterator i=includes.begin(); i!=includes.end(); ++i)
-       {
-               Target *hdr = builder.get_vfs().find_header(i->substr(1), ((*i)[0]=='"' ? local_incpath : incpath));
-               if(hdr)
-                       add_depend(hdr);
-       }
-}