GL Studio C++ Runtime API
dynamic_library.h
Go to the documentation of this file.
1 /*! \file
2  \brief A cross-platform class for loading dynamic link libraries and shared objects.
3 
4  \par Copyright Information
5 
6  Copyright (c) 2017 by The DiSTI Corporation.<br>
7  11301 Corporate Blvd; Suite 100<br>
8  Orlando, Florida 32817<br>
9  USA<br>
10  <br>
11  All rights reserved.<br>
12 
13  This Software contains proprietary trade secrets of DiSTI and may not be
14 reproduced, in whole or part, in any form, or by any means of electronic,
15 mechanical, or otherwise, without the written permission of DiSTI. Said
16 permission may be derived through the purchase of applicable DiSTI product
17 licenses which detail the distribution rights of this content and any
18 Derivative Works based on this or other copyrighted DiSTI Software.
19 
20  NO WARRANTY. THE SOFTWARE IS PROVIDED "AS-IS," WITHOUT WARRANTY OF ANY KIND,
21 AND ANY USE OF THIS SOFTWARE PRODUCT IS AT YOUR OWN RISK. TO THE MAXIMUM EXTENT
22 PERMITTED BY APPLICABLE LAW, DISTI AND ITS SUPPLIERS DISCLAIM ALL WARRANTIES
23 AND CONDITIONS, EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
24 IMPLIED WARRANTIES AND CONDITIONS OF MERCHANTABILITY AND/OR FITNESS FOR A
25 PARTICULAR PURPOSE, TITLE, AND NON-INFRINGEMENT, WITH REGARD TO THE SOFTWARE.
26 
27  LIMITATION OF LIABILITY. TO THE MAXIMUM EXTENT PERMITTED BY APPLICABLE LAW,
28 IN NO EVENT SHALL DISTI OR ITS SUPPLIERS BE LIABLE FOR ANY SPECIAL, INCIDENTAL,
29 INDIRECT, OR CONSEQUENTIAL DAMAGES WHATSOEVER (INCLUDING, WITHOUT LIMITATION,
30 DAMAGES FOR LOSS OF BUSINESS PROFITS, BUSINESS INTERRUPTION, LOSS OF BUSINESS
31 INFORMATION, OR ANY OTHER PECUNIARY LOSS) ARISING OUT OF THE USE OF OR
32 INABILITY TO USE THE SOFTWARE, EVEN IF DISTI HAS BEEN ADVISED OF THE POSSIBILITY
33 OF SUCH DAMAGES. DISTI'S ENTIRE LIABILITY AND YOUR EXCLUSIVE REMEDY SHALL NOT
34 EXCEED FIVE DOLLARS (US$5.00).
35 
36  The aforementioned terms and restrictions are governed by the laws of the
37 State of Florida and the United States of America.
38 
39 */
40 #ifndef _DYNAMIC_LIBRARY_H
41 #define _DYNAMIC_LIBRARY_H
42 
43 #include "disti_include.h"
44 #include <string>
45 
46 #if defined( _WIN32 )
47 # include <windows.h>
48 #endif
49 
50 namespace disti
51 {
52 typedef void* ( *FunctionPointer )( ... );
53 
54 /** The DynamicLibrary class. A cross-platform class for loading dynamic link libraries
55 * and shared objects
56 */
58 {
59 public:
60  /** Error Enum */
61  typedef enum
62  {
63  ERROR_NONE,
64  ERROR_VERSION_MISMATCH, ///< Load failed due to incompatible GL Studio or compiler versions
65  ERROR_UNKNOWN ///< Load failed for unknown reason (see DynamicLibrary::ErrorString())
66  } ErrorEnum;
67 
68 #if defined( _WIN32 )
69  typedef HMODULE LibHandle_t; /** Windows uses a handle to the Open Dynamic Library */
70 #else
71  typedef void* LibHandle_t; /** UNIX uses a pointer to the Open Dynamic Library */
72 #endif
73 
74  /**
75  * Constructor for dynamic library object. Causes the dynamic library
76  * which is passed in by filename to be opened.
77  * \param lib_name_arg A pointer to a string which is a library name to be opened, may include the path, can not be NULL
78  * \param quiet Whether this class emits error messages or fails silently.
79  * \param searchLibPath UNUSED
80  * \param tryStandardExtensions If this is true, the file extension, if any, will be stripped off and the appropriate
81  * standard extension for the current OS will be appended. If the changed filename cannot be
82  * found, then the original filename will be used as a last resort.
83  * \param matchVersion
84  */
85  DISTI_EXPORT DynamicLibrary(
86  const char* lib_name_arg,
87  bool quiet = false,
88  bool searchLibPath = false,
89  bool tryStandardExtensions = false,
90  bool matchVersion = false );
91 
92  /** Destructor for dynamic library object. Closes the library so the OS can cleanup. */
93  virtual DISTI_EXPORT ~DynamicLibrary();
94 
95  /**
96  * Dynamically resolves a function from the library. The name of the
97  * function is passed in.
98  * \param function_name A pointer to a string, which represents the Name of a Function to find.
99  * \return Returns a pointer to the function if it is found or NULL otherwise
100  */
101  virtual DISTI_EXPORT FunctionPointer DynamicFunction( const char* function_name );
102 
103  /** \return True if the library can be found somewhere on the system, false otherwise */
104  static DISTI_EXPORT bool Exists( const char* libName, bool tryStandardExtensions = true );
105 
106  /** \return The path to the given file name */
107  static DISTI_EXPORT std::string Find( const std::string& name );
108 
109  /** \return True if the library successfully loaded, false otherwise */
110  virtual DISTI_EXPORT bool Loaded( void ) const;
111 
112  /** Call LastError() when Loaded() is false to determine to determine
113  * if load failure occured due to a version mismatch.
114  */
115  DISTI_EXPORT ErrorEnum LastError() const;
116 
117  /** Returns the last error string or NULL if no error has occured.
118  * When tryStandardExtensions == true, this may be a very long string
119  * since it contains the error information for each attempted filename.
120  */
121  DISTI_EXPORT const char* ErrorString() const;
122 
123  /**
124  * Removes the extension, if any, from the specified path
125  */
126  static DISTI_EXPORT void RemoveExtension( std::string& libpath );
127 
128 private:
129  bool _quiet;
130  bool _tryStandardExtensions;
131  LibHandle_t _dlHandle;
132  ErrorEnum _lastError;
133 
134  char* _errorString;
135 
136  DISTI_EXPORT void SetErrorString( const char* );
137 
138  /**
139  * Attempts to find the specified library file on the system.
140  * If the file doesn't exist as named, any path will be stripped off and
141  * this will try to open the library file, which uses the standard OS search
142  * algorithm to find the file. If the open is successful, the file was
143  * found.
144  *
145  * \returns true if the library is found.
146  */
147  static bool FoundOnSystem( const std::string& libname );
148 
149  /**
150  * Opens the specified library searching the library paths if specified.
151  */
152  static LibHandle_t Open( const std::string& libpath, ErrorEnum& errorCode /*returned*/, bool searchLibPath = true, bool matchVersion = false, bool quiet = false );
153 };
154 
155 } // namespace disti
156 
157 #endif
virtual FunctionPointer DynamicFunction(const char *function_name)
Load failed for unknown reason (see DynamicLibrary::ErrorString())
Definition: dynamic_library.h:65
static bool Exists(const char *libName, bool tryStandardExtensions=true)
const char * ErrorString() const
ErrorEnum LastError() const
static std::string Find(const std::string &name)
A file for all GL Studio files to include.
virtual bool Loaded(void) const
Load failed due to incompatible GL Studio or compiler versions.
Definition: dynamic_library.h:64
Definition: dynamic_library.h:57
DynamicLibrary(const char *lib_name_arg, bool quiet=false, bool searchLibPath=false, bool tryStandardExtensions=false, bool matchVersion=false)
ErrorEnum
Definition: dynamic_library.h:61
Definition: bmpimage.h:46
static void RemoveExtension(std::string &libpath)