X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgnulinker.h;h=07e6a0ca0c322fb3ee6deb711b968cffbc019c2a;hb=486adc75285b8b5d62a990dd9f9cd4737c8ab7f6;hp=9f0475adf7202de215696716a10e35ccd14424ba;hpb=37ffa892c453a91f06d34068e239e1ba316d7700;p=builder.git diff --git a/source/gnulinker.h b/source/gnulinker.h index 9f0475a..07e6a0c 100644 --- a/source/gnulinker.h +++ b/source/gnulinker.h @@ -3,18 +3,24 @@ #include "tool.h" +/** +The GNU linker. Turns ObjectFiles into Executables and SharedLibraries. To +create a shared library, specify "shared" as the second argument to +create_target. + +Uses either gcc or g++ depending on what was used to compile the object files. +*/ class GnuLinker: public Tool { private: class Linker: public SubTool { - private: - std::string command; - public: Linker(GnuLinker &, const std::string &); virtual Target *create_target(const std::list &, const std::string &) const; + virtual Target *create_install(Target &) const; + virtual std::string create_build_signature(const BuildInfo &) const; virtual Task *run(const Target &) const; }; @@ -22,10 +28,11 @@ private: Linker *cxx_linker; public: - GnuLinker(Builder &); + GnuLinker(Builder &, const Architecture &); ~GnuLinker(); virtual Target *create_target(const std::list &, const std::string &) const; + virtual Target *create_install(Target &) const; virtual Task *run(const Target &) const; };