X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpackagemanager.h;h=2fbaca1c37c03dc0afafb3fa36d63402ec1535f3;hb=9e3a8d36093be89242db0c472ffd8fe5c61ab0ec;hp=4017065d83299de2d0c880f5d6a61b8139343f6a;hpb=3b13563d75a8fd711a9cf87cae62960f90a5bc39;p=builder.git diff --git a/source/packagemanager.h b/source/packagemanager.h index 4017065..2fbaca1 100644 --- a/source/packagemanager.h +++ b/source/packagemanager.h @@ -24,6 +24,8 @@ private: Builder &builder; SearchPath pkg_path; SearchPath pkg_dirs; + SearchPath binpkg_path; + SearchPath binpkg_files; bool no_externals; PackageMap packages; bool env_set; @@ -32,6 +34,12 @@ public: PackageManager(Builder &); ~PackageManager(); + /// Adds a location to look for source packages from. + void append_package_path(const Msp::FS::Path &); + + /// Adds a location to look for binary packages from. + void append_binary_package_path(const Msp::FS::Path &); + /** Prevent creation of source packages. */ void set_no_externals(bool); @@ -43,15 +51,20 @@ public: const PackageMap &get_packages() const { return packages; } - /** Locates a package and creates it if necessary. */ + /** Locates a package and loads it if necessary. */ Package *find_package(const std::string &); private: std::string run_pkgconfig(const std::string &, const std::string &); /** Determines the source directory of a package. Pkg-config is consulted - first, and if it fails, the package path is searched for matches. */ + first, and if it fails, the package path is searched for matches. The + package is expected to be located in a directory named after itself. */ Msp::FS::Path get_package_location(const std::string &); + + /** Determines the file containing a binary package. The file is expected + to be named after the package. */ + Msp::FS::Path get_binary_package_file(const std::string &); }; #endif