-/* $Id$
-
-This file is part of builder
-Copyright © 2006-2009 Mikko Rasa, Mikkosoft Productions
-Distributed under the LGPL
-*/
-
-#include "archive.h"
+#include "builder.h"
#include "component.h"
#include "objectfile.h"
#include "sourcepackage.h"
#include "staticlibrary.h"
using namespace std;
+using namespace Msp;
+
+StaticLibrary::StaticLibrary(Builder &b, const FS::Path &p):
+ FileTarget(b, p)
+{ }
StaticLibrary::StaticLibrary(Builder &b, const Component &c, const list<ObjectFile *> &objs):
- FileTarget(b, &c.get_package(), generate_target_path(c)),
- Library(b, package, path, c.get_name()),
- comp(c)
+ FileTarget(b, c.get_package(), c.get_package().get_output_directory()/generate_filename(c))
{
- buildable=true;
+ component = &c;
for(list<ObjectFile *>::const_iterator i=objs.begin(); i!=objs.end(); ++i)
- add_depend(*i);
+ add_dependency(**i);
+
+ install_location = "lib";
+ nested_build_sig = true;
+ arch_in_build_sig = true;
+}
+
+string StaticLibrary::generate_filename(const Component &comp)
+{
+ const Architecture &arch = comp.get_package().get_builder().get_current_arch();
+ return arch.create_filename<StaticLibrary>(comp.get_name());
+}
+
+void StaticLibrary::add_required_library(const string &lib)
+{
+ build_info.libs.push_back(lib);
}
-Action *StaticLibrary::create_action()
+void StaticLibrary::add_library_path(const FS::Path &pth)
{
- return new Archive(builder, *this);
+ build_info.libpath.push_back(pth);
}
-Msp::FS::Path StaticLibrary::generate_target_path(const Component &c)
+void StaticLibrary::collect_build_info(BuildInfo &binfo) const
{
- return c.get_package().get_out_dir()/("lib"+c.get_name()+".a");
+ Target::collect_build_info(binfo);
+ binfo.update_from(build_info);
}