#define COMPONENT_H_
#include <string>
-#include <msp/parser/loader.h>
-#include <msp/path/path.h>
+#include <msp/datafile/objectloader.h>
+#include <msp/fs/path.h>
#include "buildinfo.h"
+#include "installmap.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
+may also build none), as well as install a bunch of headers. Components inherit
+dependencies and build info from the package they belong to, and may also add
+their own.
+*/
class Component
{
public:
- class Loader: public Msp::Parser::Loader
+ class Loader: public Msp::DataFile::ObjectLoader<Component>
{
public:
Loader(Component &);
- Component &get_object() { return comp; }
private:
- Component ∁
-
void source(const std::string &);
void require(const std::string &);
void build_info();
+ void install_map();
};
-
+
enum Type
{
- PROGRAM,
LIBRARY,
+ PROGRAM,
MODULE,
- HEADERS
+ DATAFILE,
+ INSTALL,
+ TARBALL
};
- Component(Package &, Type, const std::string &);
- const Package &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; }
- const BuildInfo &get_build_info() const { return build_info; }
- bool get_install() const { return install; }
- const std::string &get_install_headers() const { return install_headers; }
- void resolve_refs();
- void create_build_info();
protected:
- Package &pkg;
- Type type;
+ SourcePackage &package;
+ Type type;
std::string name;
- PathList sources;
- bool install;
- std::string install_headers;
- BuildInfo build_info;
- std::list<PackageRef> requires;
+ StringList sources;
+ bool install;
+ BuildInfo build_info;
+ PackageList requires;
+ bool deflt;
+ InstallMap install_map;
+
+public:
+ Component(SourcePackage &, Type, const std::string &);
+
+ const SourcePackage &get_package() const { return package; }
+ Type get_type() const { return type; }
+ const std::string &get_name() const { return name; }
+
+ /** Returns a list of sources for the component. They may refer to
+ directories or individual files. */
+ const StringList &get_sources() const { return sources; }
+
+protected:
+ /** Returns a list of all source files for the component. */
+ PathList collect_source_files() const;
+
+public:
+ bool get_install() const { return install; }
+ const InstallMap &get_install_map() const { return install_map; }
+ const PackageList &get_required_packages() const { return requires; }
+ bool is_default() const { return deflt; }
+
+ /** Prepares any required packages. */
+ void prepare();
+
+ /** Prepares the build information for building. Pulls build info from the
+ parent and dependency packages, and adds any component-specific flags. */
+ void create_build_info();
+
+ const BuildInfo &get_build_info() const { return build_info; }
+
+ void create_targets() const;
};
-typedef std::list<Component> ComponentList;
#endif