]> git.tdb.fi Git - builder.git/blob - source/package.cpp
Better logging system
[builder.git] / source / package.cpp
1 #include <msp/io/print.h>
2 #include <msp/strings/lexicalcast.h>
3 #include <msp/strings/utils.h>
4 #include "builder.h"
5 #include "misc.h"
6 #include "package.h"
7
8 using namespace std;
9 using namespace Msp;
10
11 Package::Package(Builder &b, const string &n):
12         builder(b),
13         name(n),
14         conf_done(false),
15         use_pkgconfig(true)
16 {
17         builder.get_package_manager().add_package(this);
18 }
19
20 void Package::configure(const StringMap &opts, unsigned flag)
21 {
22         if(conf_done)
23                 return;
24
25         builder.get_logger().log("configure", format("Configuring %s", name));
26
27         do_configure(opts, flag);
28
29         requires.sort();
30         requires.unique();
31
32         for(PackageList::iterator i=requires.begin(); i!=requires.end(); ++i)
33                 (*i)->configure(opts, flag&2);
34
35         create_build_info();
36
37         conf_done = true;
38 }
39
40
41 Package::Loader::Loader(Package &p):
42         pkg(p)
43 {
44         add("require", &Loader::require);
45 }
46
47 void Package::Loader::require(const string &n)
48 {
49         Package *req = pkg.builder.get_package_manager().find_package(n);
50         if(req)
51                 pkg.requires.push_back(req);
52 }