| 1 |
/+ |
|---|
| 2 |
Copyright (c) 2005,2006 Eric Anderton |
|---|
| 3 |
|
|---|
| 4 |
Permission is hereby granted, free of charge, to any person |
|---|
| 5 |
obtaining a copy of this software and associated documentation |
|---|
| 6 |
files (the "Software"), to deal in the Software without |
|---|
| 7 |
restriction, including without limitation the rights to use, |
|---|
| 8 |
copy, modify, merge, publish, distribute, sublicense, and/or |
|---|
| 9 |
sell copies of the Software, and to permit persons to whom the |
|---|
| 10 |
Software is furnished to do so, subject to the following |
|---|
| 11 |
conditions: |
|---|
| 12 |
|
|---|
| 13 |
The above copyright notice and this permission notice shall be |
|---|
| 14 |
included in all copies or substantial portions of the Software. |
|---|
| 15 |
|
|---|
| 16 |
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
|---|
| 17 |
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES |
|---|
| 18 |
OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
|---|
| 19 |
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT |
|---|
| 20 |
HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, |
|---|
| 21 |
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING |
|---|
| 22 |
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR |
|---|
| 23 |
OTHER DEALINGS IN THE SOFTWARE. |
|---|
| 24 |
+/ |
|---|
| 25 |
/** |
|---|
| 26 |
Provides DynamicLibrary loading support. |
|---|
| 27 |
|
|---|
| 28 |
Authors: Eric Anderton |
|---|
| 29 |
License: BSD Derivative (see source for details) |
|---|
| 30 |
Copyright: 2005,2006 Eric Anderton |
|---|
| 31 |
*/ |
|---|
| 32 |
module ddl.DynamicLibraryLoader; |
|---|
| 33 |
|
|---|
| 34 |
private import ddl.DynamicLibrary; |
|---|
| 35 |
private import ddl.LoaderRegistry; |
|---|
| 36 |
private import ddl.FileBuffer; |
|---|
| 37 |
|
|---|
| 38 |
|
|---|
| 39 |
/** |
|---|
| 40 |
Base class for all dynamic library loaders. |
|---|
| 41 |
*/ |
|---|
| 42 |
abstract class DynamicLibraryLoader{ |
|---|
| 43 |
/** |
|---|
| 44 |
Returns: the type for this library. |
|---|
| 45 |
*/ |
|---|
| 46 |
public char[] getLibraryType(); |
|---|
| 47 |
|
|---|
| 48 |
/** |
|---|
| 49 |
The implementaiton is understood to check the file by inspecting its contents. |
|---|
| 50 |
The implementor must be sure to not advance the internal buffer pointer, so that |
|---|
| 51 |
future checks against the buffer can all begin at the same location. |
|---|
| 52 |
|
|---|
| 53 |
Returns: true if the file can be loaded by this loader, false if it cannot. |
|---|
| 54 |
*/ |
|---|
| 55 |
public bool canLoadLibrary(FileBuffer file); |
|---|
| 56 |
|
|---|
| 57 |
/** |
|---|
| 58 |
Loads a binary file. |
|---|
| 59 |
|
|---|
| 60 |
Returns: the library stored in the provided file. |
|---|
| 61 |
Params: |
|---|
| 62 |
file = the file that contains the binary library data. |
|---|
| 63 |
*/ |
|---|
| 64 |
public DynamicLibrary load(LoaderRegistry registry,FileBuffer file); |
|---|
| 65 |
} |
|---|