X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgnulinker.h;h=713b978064747ab570b15f9cbc764ddaa149b014;hb=1ed833343bc83b83c5f61cbfd74423bbba677a04;hp=872234a6d33d645a36676309172c4c58e948a15d;hpb=82f1175238a94618b0cf1485b0132fb965996843;p=builder.git diff --git a/source/gnulinker.h b/source/gnulinker.h index 872234a..713b978 100644 --- a/source/gnulinker.h +++ b/source/gnulinker.h @@ -3,6 +3,8 @@ #include "tool.h" +class Binary; + /** The GNU linker. Turns ObjectFiles into Executables and SharedLibraries. To create a shared library, specify "shared" as the second argument to @@ -21,23 +23,25 @@ private: public: Linker(GnuLinker &, const std::string &); - virtual std::string create_build_signature(const BuildInfo &) const; + std::string create_build_signature(const BuildInfo &) const override; private: - virtual void do_prepare(); + void do_prepare() override; + public: - virtual Task *run(const Target &) const; + static Task *_run(const Binary &); }; - Linker *default_linker; - Linker *cxx_linker; + Linker *default_linker = 0; + Linker *cxx_linker = 0; public: - GnuLinker(Builder &, const Architecture &, const Msp::FS::Path & = Msp::FS::Path()); + GnuLinker(Builder &, const Architecture &); ~GnuLinker(); - virtual Target *create_target(const std::list &, const std::string &); - virtual Target *create_install(Target &) const; - virtual Task *run(const Target &) const; + Target *create_target(const std::vector &, const std::string &) override; + Target *create_install(Target &) const override; +protected: + void do_prepare() override; }; #endif