- const list<string> &libs=c->get_build_info().libs;
- for(StringList::const_iterator i=libs.begin(); i!=libs.end(); ++i)
- {
- Target *lib=builder.get_library(*i, arch, libpath, libmode);
- if(lib)
- {
- dep_libs.push_back(lib);
-
- if(dynamic_cast<Install *>(lib))
- lib=lib->get_depends().front();
- if(StaticLibrary *stlib=dynamic_cast<StaticLibrary *>(lib))
- queue.push_back(&stlib->get_component());
- }
- else
- builder.problem(comp.get_package().get_name(), format("Couldn't find library %s for %s", *i, basename(name)));
- }
- }
-
- /* Add only the last occurrence of each library to the actual dependencies.
- This ensures that static library ordering is correct. */
- for(list<Target *>::iterator i=dep_libs.begin(); i!=dep_libs.end(); ++i)
- {
- bool last=true;
- for(list<Target *>::iterator j=i; (last && j!=dep_libs.end()); ++j)
- last=(j==i || *j!=*i);
- if(last)
- add_depend(*i);
- }
-
- deps_ready=true;
-}
-
-Action *Executable::build()
+Executable::Executable(Builder &b, const Component &c, const list<ObjectFile *> &objs):
+ Binary(b, c, generate_filename(c), objs)