[llvm-commits] CVS: llvm/include/llvm/System/DynamicLibrary.h

Reid Spencer reid at x10sys.com
Wed Nov 17 20:33:53 PST 2004



Changes in directory llvm/include/llvm/System:

DynamicLibrary.h added (r1.1)
---
Log message:

Dynamic Library abstraction. This makes the abstraction of a single dynamic
library (shared library/shared object) whose symbols can be looked up 
dynamically. Used for plug-ins.


---
Diffs of the changes:  (+80 -0)

Index: llvm/include/llvm/System/DynamicLibrary.h
diff -c /dev/null llvm/include/llvm/System/DynamicLibrary.h:1.1
*** /dev/null	Wed Nov 17 22:33:50 2004
--- llvm/include/llvm/System/DynamicLibrary.h	Wed Nov 17 22:33:40 2004
***************
*** 0 ****
--- 1,80 ----
+ //===-- llvm/System/DynamicLibrary.h - Portable Dynamic Library -*- C++ -*-===//
+ // 
+ //                     The LLVM Compiler Infrastructure
+ //
+ // This file was developed by Reid Spencer and is distributed under the 
+ // University of Illinois Open Source License. See LICENSE.TXT for details.
+ // 
+ //===----------------------------------------------------------------------===//
+ //
+ // This file declares the sys::DynamicLibrary class.
+ //
+ //===----------------------------------------------------------------------===//
+ 
+ #ifndef LLVM_SYSTEM_DYNAMIC_LIBRARY_H
+ #define LLVM_SYSTEM_DYNAMIC_LIBRARY_H
+ 
+ #include "llvm/System/Path.h"
+ #include <string>
+ 
+ namespace llvm {
+ namespace sys {
+ 
+   /// This class provides a portable interface to dynamic libraries which also
+   /// might be known as shared libraries, shared objects, dynamic shared 
+   /// objects, or dynamic link libraries. Regardless of the terminology or the
+   /// operating system interface, this class provides a portable interface that
+   /// allows dynamic libraries to be loaded and and searched for externally 
+   /// defined symbols. This is typically used to provide "plug-in" support.
+   /// @since 1.4
+   /// @brief Portable dynamic library abstraction.
+   class DynamicLibrary {
+     /// @name Constructors
+     /// @{
+     public:
+       /// This is the constructor for DynamicLibrary instances. It will open
+       /// the dynamic library specified by the \filename Path.
+       /// @throws std::string indicating why the library couldn't be opened.
+       /// @brief DynamicLibrary constructor
+       DynamicLibrary(const char* filename);
+ 
+       /// After destruction, the symbols of the library will no longer be
+       /// available to the program. It is important to make sure the lifespan
+       /// of a DynamicLibrary exceeds the lifetime of the pointers returned 
+       /// by the GetAddressOfSymbol otherwise the program may walk off into 
+       /// uncharted territory.
+       /// @see GetAddressOfSymbol.
+       /// @brief Closes the DynamicLibrary
+       ~DynamicLibrary();
+ 
+     /// @}
+     /// @name Accessors
+     /// @{
+     public:
+       /// Looks up a \p symbolName in the DynamicLibrary and returns its address
+       /// if it exists. If the symbol does not exist, returns (void*)0.
+       /// @returns the address of the symbol or 0.
+       /// @brief Get the address of a symbol in the DynamicLibrary.
+       void* GetAddressOfSymbol(const char* symbolName);
+ 
+       /// @brief Convenience function for C++ophiles.
+       void* GetAddressOfSymbol(const std::string& symbolName) {
+         return GetAddressOfSymbol(symbolName.c_str());
+       }
+ 
+     /// @}
+     /// @name Implementation
+     /// @{
+     protected:
+       void* handle;  // Opaque handle for information about the library
+ 
+       DynamicLibrary();  ///< Do not implement
+       DynamicLibrary(const DynamicLibrary&); ///< Do not implement
+       DynamicLibrary& operator=(const DynamicLibrary&); ///< Do not implement
+     /// @}
+   };
+ 
+ } // End sys namespace
+ } // End llvm namespace
+ 
+ #endif // LLVM_SYSTEM_DYNAMIC_LIBRARY_H






More information about the llvm-commits mailing list