Mercurial > pub > dyncall > dyncall
annotate dynload/dynload_unix.c @ 232:76ed51a690a6
- todo comment
author | Tassilo Philipp |
---|---|
date | Sun, 16 Apr 2017 15:08:50 +0200 |
parents | 011b5e3a8548 |
children | 85b61e8facfe |
rev | line source |
---|---|
0 | 1 /* |
2 | |
3 Package: dyncall | |
4 Library: dynload | |
5 File: dynload/dynload_unix.c | |
6 Description: | |
7 License: | |
8 | |
9 Copyright (c) 2007-2015 Daniel Adler <dadler@uni-goettingen.de>, | |
10 Tassilo Philipp <tphilipp@potion-studios.com> | |
11 | |
12 Permission to use, copy, modify, and distribute this software for any | |
13 purpose with or without fee is hereby granted, provided that the above | |
14 copyright notice and this permission notice appear in all copies. | |
15 | |
16 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | |
17 WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | |
18 MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | |
19 ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | |
20 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | |
21 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | |
22 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | |
23 | |
24 */ | |
25 | |
26 | |
27 | |
28 /* | |
29 | |
30 dynload_unix.c | |
31 | |
32 dynload module for .so (unix) and .dylib (mach-o darwin/OS X) files | |
33 | |
34 */ | |
35 | |
36 | |
37 #include "dynload.h" | |
38 | |
39 #include <dlfcn.h> | |
40 | |
41 | |
42 DLLib* dlLoadLibrary(const char* libPath) | |
43 { | |
232 | 44 return (DLLib*)dlopen(libPath, RTLD_NOW|RTLD_GLOBAL); //@@@ should use RTLD_LAZY, maybe? |
0 | 45 } |
46 | |
47 | |
48 void* dlFindSymbol(DLLib* libHandle, const char* symbol) | |
49 { | |
50 return dlsym((void*)libHandle, symbol); | |
51 } | |
52 | |
53 | |
54 void dlFreeLibrary(DLLib* libHandle) | |
55 { | |
56 | |
171
011b5e3a8548
- compatibility for older platforms - use ANSI comments
cslag
parents:
0
diff
changeset
|
57 /* Check for NULL for cross-platform consistency. *BSD seems to do that in |
011b5e3a8548
- compatibility for older platforms - use ANSI comments
cslag
parents:
0
diff
changeset
|
58 dlclose, Linux does not. POSIX states "if handle does not refer to an open |
011b5e3a8548
- compatibility for older platforms - use ANSI comments
cslag
parents:
0
diff
changeset
|
59 object, dlclose() returns a non-zero value", which unfortunately sounds |
011b5e3a8548
- compatibility for older platforms - use ANSI comments
cslag
parents:
0
diff
changeset
|
60 like it's not explicitly specified. */ |
0 | 61 if(libHandle) |
62 dlclose((void*)libHandle); | |
63 } | |
64 |