X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcomponent.h;h=6fb231d1d247899103172aaab1720c06377cdbd8;hb=a2adbd9c0a8d7a7567848c4c6bdbf0de6ba32bb1;hp=e1df73a5b232aefd9c554010b2767f9f7697c297;hpb=09325a99816a966bc17a0ec9a0a197efc6ce0349;p=builder.git diff --git a/source/component.h b/source/component.h index e1df73a..6fb231d 100644 --- a/source/component.h +++ b/source/component.h @@ -1,14 +1,21 @@ +/* $Id$ + +This file is part of builder +Copyright © 2006-2007 Mikko Rasa, Mikkosoft Productions +Distributed under the LGPL +*/ + #ifndef COMPONENT_H_ #define COMPONENT_H_ #include -#include -#include +#include +#include #include "buildinfo.h" #include "misc.h" -#include "packageref.h" +#include "package.h" -class Package; +class SourcePackage; /** Components specify things to be built. Each component may build one binary (it @@ -20,7 +27,7 @@ class Component { public: /// Loads a Component from file. Used from Package::Loader. - class Loader: public Msp::Parser::Loader + class Loader: public Msp::DataFile::Loader { public: Loader(Component &); @@ -34,7 +41,7 @@ public: void host(const std::string &); void build_info(); }; - + enum Type { PROGRAM, @@ -43,8 +50,8 @@ public: HEADERS }; - Component(Package &, Type, const std::string &); - const Package &get_package() const { return pkg; } + Component(SourcePackage &, Type, const std::string &); + const SourcePackage &get_package() const { return pkg; } Type get_type() const { return type; } const std::string &get_name() const { return name; } const PathList &get_sources() const { return sources; } @@ -52,11 +59,12 @@ public: bool get_install() const { return install; } const std::string &get_install_headers() const { return install_headers; } bool get_modular() const { return modular; } - const PkgRefList &get_requires() const { return requires; } - void resolve_refs(); + const PackageList &get_requires() const { return requires; } + bool get_default() const { return deflt; } void create_build_info(); + void create_targets() const; protected: - Package &pkg; + SourcePackage &pkg; Type type; std::string name; PathList sources; @@ -65,7 +73,10 @@ protected: const Component *module_host; bool modular; BuildInfo build_info; - PkgRefList requires; + PackageList requires; + bool deflt; + + PathList collect_source_files() const; }; typedef std::list ComponentList;