X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fbinarypackage.h;h=b8c29de772e45610d9078de5ea0225c8ce961349;hb=21ca3e98081c0dc0430d8e5301591aa71ec4fca2;hp=8c0d0e9ec39c7a741c94fe908a8f92aa08d74803;hpb=1d687970cc35e54c3335f4aa2fdef23424fe0a06;p=builder.git diff --git a/source/binarypackage.h b/source/binarypackage.h index 8c0d0e9..b8c29de 100644 --- a/source/binarypackage.h +++ b/source/binarypackage.h @@ -10,33 +10,33 @@ Builder. class BinaryPackage: public Package { public: - class Loader: public Package::Loader + class Loader: public Msp::DataFile::DerivedObjectLoader { public: Loader(BinaryPackage &); - BinaryPackage &get_object() { return static_cast(pkg); } private: void build_info(); + void header(const std::string &); }; + typedef std::vector Flags; + private: - bool need_path; - Msp::FS::Path path; + typedef std::list HeaderList; + + Msp::FS::Path base_path; + HeaderList headers; + BuildInfo static_binfo; public: BinaryPackage(Builder &, const std::string &); - /** - Sets the path where the package's files were installed. This is only useful - if the package doesn't use pkg-config. - */ - void set_path(const Msp::FS::Path &); - - bool get_need_path() const { return need_path; } + const BuildInfo &get_static_build_info() const { return static_binfo; } - static BinaryPackage *from_flags(Builder &, const std::string &, const std::vector &); + static BinaryPackage *from_flags(Builder &, const std::string &, const Flags &, const Flags & = Flags()); private: - virtual void create_build_info(); + static void process_flags(const Flags &, BuildInfo &); + virtual void do_prepare(); }; #endif