X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fbinarypackage.h;h=b96015589e04ea45c164ecbb92fae08fc8c109e4;hb=564160e126f525dda52f27044d29b479088da191;hp=ff077f8c362ed385ce09152517038c0de3536977;hpb=43bd25ffcb0b4f7882773f4676b209a99cb73c04;p=builder.git diff --git a/source/binarypackage.h b/source/binarypackage.h index ff077f8..b960155 100644 --- a/source/binarypackage.h +++ b/source/binarypackage.h @@ -10,33 +10,31 @@ 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 &); }; + using Flags = std::vector; + private: - bool need_path; - Msp::FS::Path path; + Msp::FS::Path base_path; + std::list 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_pkgconfig(Builder &, const std::string &); + 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