]> git.tdb.fi Git - builder.git/blobdiff - source/gnulinker.h
Avoid a memory leak if Builder::set_architecture is called again
[builder.git] / source / gnulinker.h
index 9f0475adf7202de215696716a10e35ccd14424ba..9964ffa146277551d2413b8adc8f0cfcac89566d 100644 (file)
@@ -3,30 +3,27 @@
 
 #include "tool.h"
 
-class GnuLinker: public Tool
-{
-private:
-       class Linker: public SubTool
-       {
-       private:
-               std::string command;
-
-       public:
-               Linker(GnuLinker &, const std::string &);
+class Binary;
 
-               virtual Target *create_target(const std::list<Target *> &, const std::string &) const;
-               virtual Task *run(const Target &) const;
-       };
-
-       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<Target *> &, const std::string &) const;
-       virtual Task *run(const Target &) const;
+       Target *create_target(const std::vector<Target *> &, 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