]> git.tdb.fi Git - builder.git/blobdiff - source/executable.cpp
Process ObjectFile dependencies correctly even when it's processed before some header...
[builder.git] / source / executable.cpp
index 2dfeee8affbbbce98ee5a812da75433ca60d32b2..630ac71f717e639173cc47ea3b74a7df28b84ffb 100644 (file)
@@ -1,5 +1,7 @@
+#include "builder.h"
 #include "component.h"
 #include "executable.h"
+#include "link.h"
 #include "objectfile.h"
 #include "package.h"
 
@@ -9,10 +11,29 @@ Executable::Executable(Builder &b, const Component &c, const list<ObjectFile *>
        Target(b, &c.get_package(), generate_target_name(c)),
        comp(c)
 {
+       buildable=true;
        for(list<ObjectFile *>::const_iterator i=objs.begin(); i!=objs.end(); ++i)
                add_depend(*i);
 }
 
+void Executable::find_depends()
+{
+       const list<string> &libs=comp.get_build_info().libs;
+       for(list<string>::const_iterator i=libs.begin(); i!=libs.end(); ++i)
+       {
+               Target *lib=builder.get_library(*i, comp.get_build_info().libpath);
+               if(lib)
+                       add_depend(lib);
+       }
+
+       deps_ready=true;
+}
+
+Action *Executable::build()
+{
+       return Target::build(new Link(builder, *this, comp));;
+}
+
 string Executable::generate_target_name(const Component &comp)
 {
        string prefix;