/* * Copyright (C) 2016 Charybdis Development Team * Copyright (C) 2016 Jason Volk * * Permission to use, copy, modify, and/or distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice is present in all copies. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */ #pragma once #define HAVE_IRCD_MODS_H namespace ircd { namespace mapi { using magic_t = uint16_t; using version_t = uint16_t; struct header; } // namespace mapi } // namespace ircd namespace ircd { namespace mods { using mapi::magic_t; using mapi::version_t; IRCD_EXCEPTION(ircd::error, error) IRCD_EXCEPTION(error, filesystem_error) IRCD_EXCEPTION(error, invalid_export) extern struct log::log log; struct paths :std::vector { bool added(const std::string &dir) const; bool del(const std::string &dir); bool add(const std::string &dir, std::nothrow_t); bool add(const std::string &dir); paths(); } extern paths; struct mod; struct module :std::shared_ptr { std::string name() const; std::string path() const; bool has(const std::string &name) const; template const T *ptr(const std::string &name) const; template T *ptr(const std::string &name); template const T &get(const std::string &name) const; template T &get(const std::string &name); module() = default; module(const std::string &name); ~module() noexcept; }; template<> const uint8_t *module::ptr(const std::string &name) const; template<> uint8_t *module::ptr(const std::string &name); std::vector symbols(const std::string &fullpath, const std::string §ion); std::vector symbols(const std::string &fullpath); std::vector sections(const std::string &fullpath); // Find module names where symbol resides bool has_symbol(const std::string &name, const std::string &symbol); std::vector find_symbol(const std::string &symbol); // returns dir/name of first dir containing 'name' (and this will be a loadable module) // Unlike libltdl, the reason each individual candidate failed is presented in a vector. std::string search(const std::string &name, std::vector &why); std::string search(const std::string &name); // Potential modules available to load std::forward_list available(); bool available(const std::string &name); bool loaded(const std::string &name); // Initialization and destruction singleton held by ircd::main() struct init { init(); ~init() noexcept; }; } // namespace mods } // namespace ircd namespace ircd { using mods::module; // Bring struct module into main ircd:: } // namespace ircd template T & ircd::mods::module::get(const std::string &name) { return *ptr(name); } template const T & ircd::mods::module::get(const std::string &name) const { return *ptr(name); } template T * ircd::mods::module::ptr(const std::string &name) { return reinterpret_cast(ptr(name)); } template const T * ircd::mods::module::ptr(const std::string &name) const { return reinterpret_cast(ptr(name)); }