X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgnulinker.h;h=e8a4e3ce996f749659485aa7133ec9ec82fcf58e;hb=f41742cb2b21241634c123561b71ee1667cb1ff4;hp=2fdaa3a58061f80c8de2c8319d2b79c25ad2d8dd;hpb=3e8f3a5e852e9dd5b78ec3d89c722ef1bae6bef5;p=builder.git diff --git a/source/gnulinker.h b/source/gnulinker.h index 2fdaa3a..e8a4e3c 100644 --- a/source/gnulinker.h +++ b/source/gnulinker.h @@ -3,15 +3,28 @@ #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 compiler_tag; + public: Linker(GnuLinker &, const std::string &); - virtual Target *create_target(const std::list &, const std::string &) const; + virtual std::string create_build_signature(const BuildInfo &) const; + private: + virtual void do_prepare(); + public: virtual Task *run(const Target &) const; }; @@ -19,10 +32,14 @@ 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_target(const std::list &, const std::string &); + virtual Target *create_install(Target &) const; +protected: + virtual void do_prepare(); +public: virtual Task *run(const Target &) const; };