X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fbinarypackage.h;h=f015ee55de9dbcf76386bfaa3b7aa9737d7dadc5;hb=bde362811368647047f3ca13bdec596f092ecffe;hp=8c0d0e9ec39c7a741c94fe908a8f92aa08d74803;hpb=1d687970cc35e54c3335f4aa2fdef23424fe0a06;p=builder.git diff --git a/source/binarypackage.h b/source/binarypackage.h index 8c0d0e9..f015ee5 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 &); + void do_prepare() override; }; #endif