X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fstaticlibrary.h;h=98d299026bc366aed45ab21568530b02e82b84f2;hb=1ed833343bc83b83c5f61cbfd74423bbba677a04;hp=cd0342ea47b950ef88c0b25bc3c5427569018e13;hpb=7aeaa4ba965f596edad438c02e345a8843f7469a;p=builder.git diff --git a/source/staticlibrary.h b/source/staticlibrary.h index cd0342e..98d2990 100644 --- a/source/staticlibrary.h +++ b/source/staticlibrary.h @@ -1,14 +1,7 @@ -/* $Id$ +#ifndef STATICLIBRARY_H_ +#define STATICLIBRARY_H_ -This file is part of builder -Copyright © 2006-2007 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - -#ifndef STATICLIB_H_ -#define STATICLIB_H_ - -#include "target.h" +#include "filetarget.h" class Component; class ObjectFile; @@ -16,17 +9,26 @@ class ObjectFile; /** A static library target. */ -class StaticLibrary: public Target +class StaticLibrary: public FileTarget { +private: + /* TODO this really belongs in a Component, but some refactoring is required + to allow non-builder packages to have components. Rename BinaryPackage to + ExternalPackage, add BuildableComponent and ExternalComponent classes. */ + BuildInfo build_info; + public: - StaticLibrary(Builder &, const Component &, const std::list &); - const char *get_type() const { return "StaticLibrary"; } - const Component &get_component() const { return comp; } - Action *build(); + StaticLibrary(Builder &b, const Msp::FS::Path &p): FileTarget(b, p) { } + StaticLibrary(Builder &, const Component &, const std::vector &); private: - const Component ∁ + static std::string generate_filename(const Component &); + +public: + const char *get_type() const override { return "StaticLibrary"; } - std::string generate_target_name(const Component &); + void add_required_library(const std::string &); + void add_library_path(const Msp::FS::Path &); + void collect_build_info(BuildInfo &) const override; }; #endif