X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgnulinker.h;h=9964ffa146277551d2413b8adc8f0cfcac89566d;hb=dd5f5ca28944ed2f8ddd62f8af672ed003938a8f;hp=2fdaa3a58061f80c8de2c8319d2b79c25ad2d8dd;hpb=3e8f3a5e852e9dd5b78ec3d89c722ef1bae6bef5;p=builder.git diff --git a/source/gnulinker.h b/source/gnulinker.h index 2fdaa3a..9964ffa 100644 --- a/source/gnulinker.h +++ b/source/gnulinker.h @@ -3,27 +3,27 @@ #include "tool.h" -class GnuLinker: public Tool -{ -private: - class Linker: public SubTool - { - public: - Linker(GnuLinker &, const std::string &); - - virtual Target *create_target(const std::list &, const std::string &) const; - virtual Task *run(const Target &) const; - }; +class Binary; - Linker *default_linker; - Linker *cxx_linker; +/** +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 +{ public: - GnuLinker(Builder &); - ~GnuLinker(); + GnuLinker(Builder &, const Architecture &); - virtual Target *create_target(const std::list &, const std::string &) const; - virtual Task *run(const Target &) const; + Target *create_target(const std::vector &, const std::string &) override; + Target *create_install(Target &) const override; + std::string create_build_signature(const BuildInfo &) const override; +protected: + void do_prepare(ToolData &) const override; +private: + static Task *_run(const Binary &); }; #endif