| // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 
 | // Use of this source code is governed by a BSD-style license that can be | 
 | // found in the LICENSE file. | 
 |  | 
 | #ifndef BASE_NATIVE_LIBRARY_H_ | 
 | #define BASE_NATIVE_LIBRARY_H_ | 
 |  | 
 | // This file defines a cross-platform "NativeLibrary" type which represents | 
 | // a loadable module. | 
 |  | 
 | #include <string> | 
 |  | 
 | #include "starboard/types.h" | 
 |  | 
 | #include "base/base_export.h" | 
 | #include "base/strings/string_piece.h" | 
 | #include "build/build_config.h" | 
 |  | 
 | #if !defined(STARBOARD) | 
 |  | 
 | #if defined(OS_WIN) | 
 | #include <windows.h> | 
 | #elif defined(OS_MACOSX) | 
 | #import <CoreFoundation/CoreFoundation.h> | 
 | #endif  // OS_* | 
 |  | 
 | namespace base { | 
 |  | 
 | class FilePath; | 
 |  | 
 | #if defined(OS_WIN) | 
 | using NativeLibrary = HMODULE; | 
 | #elif defined(OS_MACOSX) | 
 | enum NativeLibraryType { | 
 |   BUNDLE, | 
 |   DYNAMIC_LIB | 
 | }; | 
 | enum NativeLibraryObjCStatus { | 
 |   OBJC_UNKNOWN, | 
 |   OBJC_PRESENT, | 
 |   OBJC_NOT_PRESENT, | 
 | }; | 
 | struct NativeLibraryStruct { | 
 |   NativeLibraryType type; | 
 |   CFBundleRefNum bundle_resource_ref; | 
 |   NativeLibraryObjCStatus objc_status; | 
 |   union { | 
 |     CFBundleRef bundle; | 
 |     void* dylib; | 
 |   }; | 
 | }; | 
 | using NativeLibrary = NativeLibraryStruct*; | 
 | #elif defined(OS_POSIX) || defined(OS_FUCHSIA) | 
 | using NativeLibrary = void*; | 
 | #endif  // OS_* | 
 |  | 
 | struct BASE_EXPORT NativeLibraryLoadError { | 
 | #if defined(OS_WIN) | 
 |   NativeLibraryLoadError() : code(0) {} | 
 | #endif  // OS_WIN | 
 |  | 
 |   // Returns a string representation of the load error. | 
 |   std::string ToString() const; | 
 |  | 
 | #if defined(OS_WIN) | 
 |   DWORD code; | 
 | #elif defined(OS_POSIX) || defined(OS_FUCHSIA) | 
 |   std::string message; | 
 | #endif  // OS_WIN | 
 | }; | 
 |  | 
 | struct BASE_EXPORT NativeLibraryOptions { | 
 |   NativeLibraryOptions() = default; | 
 |   NativeLibraryOptions(const NativeLibraryOptions& options) = default; | 
 |  | 
 |   // If |true|, a loaded library is required to prefer local symbol resolution | 
 |   // before considering global symbols. Note that this is already the default | 
 |   // behavior on most systems. Setting this to |false| does not guarantee the | 
 |   // inverse, i.e., it does not force a preference for global symbols over local | 
 |   // ones. | 
 |   bool prefer_own_symbols = false; | 
 | }; | 
 |  | 
 | // Loads a native library from disk.  Release it with UnloadNativeLibrary when | 
 | // you're done.  Returns NULL on failure. | 
 | // If |error| is not NULL, it may be filled in on load error. | 
 | BASE_EXPORT NativeLibrary LoadNativeLibrary(const FilePath& library_path, | 
 |                                             NativeLibraryLoadError* error); | 
 |  | 
 | // Loads a native library from disk.  Release it with UnloadNativeLibrary when | 
 | // you're done.  Returns NULL on failure. | 
 | // If |error| is not NULL, it may be filled in on load error. | 
 | BASE_EXPORT NativeLibrary LoadNativeLibraryWithOptions( | 
 |     const FilePath& library_path, | 
 |     const NativeLibraryOptions& options, | 
 |     NativeLibraryLoadError* error); | 
 |  | 
 | // Unloads a native library. | 
 | BASE_EXPORT void UnloadNativeLibrary(NativeLibrary library); | 
 |  | 
 | // Gets a function pointer from a native library. | 
 | BASE_EXPORT void* GetFunctionPointerFromNativeLibrary(NativeLibrary library, | 
 |                                                       StringPiece name); | 
 |  | 
 | // Returns the full platform-specific name for a native library. |name| must be | 
 | // ASCII. This is also the default name for the output of a gn |shared_library| | 
 | // target. See tools/gn/docs/reference.md#shared_library. | 
 | // For example for "mylib", it returns: | 
 | // - "mylib.dll" on Windows | 
 | // - "libmylib.so" on Linux | 
 | // - "libmylib.dylib" on Mac | 
 | BASE_EXPORT std::string GetNativeLibraryName(StringPiece name); | 
 |  | 
 | // Returns the full platform-specific name for a gn |loadable_module| target. | 
 | // See tools/gn/docs/reference.md#loadable_module | 
 | // The returned name is the same as GetNativeLibraryName() on all platforms | 
 | // except for Mac where for "mylib" it returns "mylib.so". | 
 | BASE_EXPORT std::string GetLoadableModuleName(StringPiece name); | 
 |  | 
 | }  // namespace base | 
 |  | 
 | #endif  // !defined(STARBOARD) | 
 | #endif  // BASE_NATIVE_LIBRARY_H_ |