.. _program_listing_file__tmp_ws_src_pluginlib_pluginlib_include_pluginlib_class_loader.hpp: Program Listing for File class_loader.hpp ========================================= |exhale_lsh| :ref:`Return to documentation for file ` (``/tmp/ws/src/pluginlib/pluginlib/include/pluginlib/class_loader.hpp``) .. |exhale_lsh| unicode:: U+021B0 .. UPWARDS ARROW WITH TIP LEFTWARDS .. code-block:: cpp /* * Copyright (c) 2009, Willow Garage, Inc. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * Neither the name of the Willow Garage, Inc. nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "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 COPYRIGHT OWNER OR CONTRIBUTORS 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. */ #ifndef PLUGINLIB__CLASS_LOADER_HPP_ #define PLUGINLIB__CLASS_LOADER_HPP_ #include #include #include #include #include "class_loader/multi_library_class_loader.hpp" #include "pluginlib/class_desc.hpp" #include "pluginlib/class_loader_base.hpp" #include "pluginlib/exceptions.hpp" #include "tinyxml2.h" // NOLINT namespace pluginlib { template using UniquePtr = class_loader::ClassLoader::UniquePtr; template class ClassLoader : public ClassLoaderBase { public: typedef typename std::map::iterator ClassMapIterator; public: ClassLoader( std::string package, std::string base_class, std::string attrib_name = std::string("plugin"), std::vector plugin_xml_paths = std::vector()); ~ClassLoader(); [[deprecated]] T * createClassInstance( const std::string & lookup_name, bool auto_load = true); std::shared_ptr createSharedInstance(const std::string & lookup_name); UniquePtr createUniqueInstance(const std::string & lookup_name); T * createUnmanagedInstance(const std::string & lookup_name); std::vector getPluginXmlPaths(); std::vector getDeclaredClasses(); virtual std::string getName(const std::string & lookup_name); virtual std::string getBaseClassType() const; virtual std::string getClassType(const std::string & lookup_name); virtual std::string getClassDescription(const std::string & lookup_name); virtual std::string getClassLibraryPath(const std::string & lookup_name); virtual std::string getClassPackage(const std::string & lookup_name); virtual std::string getPluginManifestPath(const std::string & lookup_name); virtual std::vector getRegisteredLibraries(); bool isClassLoaded(const std::string & lookup_name); virtual bool isClassAvailable(const std::string & lookup_name); virtual void loadLibraryForClass(const std::string & lookup_name); virtual void refreshDeclaredClasses(); virtual int unloadLibraryForClass(const std::string & lookup_name); private: std::vector getPluginXmlPaths( const std::string & package, const std::string & attrib_name); std::map determineAvailableClasses( const std::vector & plugin_xml_paths); std::string extractPackageNameFromPackageXML(const std::string & package_xml_path); std::vector getAllLibraryPathsToTry( const std::string & library_name, const std::string & exporting_package_name); std::string getErrorStringForUnknownClass(const std::string & lookup_name); std::string getPathSeparator(); std::string getPackageFromPluginXMLFilePath(const std::string & path); std::string joinPaths(const std::string & path1, const std::string & path2); void processSingleXMLPluginFile( const std::string & xml_file, std::map & class_available); std::string stripAllButFileFromPath(const std::string & path); int unloadClassLibraryInternal(const std::string & library_path); private: std::vector plugin_xml_paths_; // Map from library to class's descriptions described in XML. std::map classes_available_; std::string package_; std::string base_class_; std::string attrib_name_; class_loader::MultiLibraryClassLoader lowlevel_class_loader_; // The underlying classloader }; } // namespace pluginlib // Note: The implementation of the methods is in a separate file for clarity. #include "./class_loader_imp.hpp" #endif // PLUGINLIB__CLASS_LOADER_HPP_