windows/SysLibrary.cpp
Go to the documentation of this file.
1
/*----------------------------------------------------------------------------*/
2
/* */
3
/* Copyright (c) 1995, 2004 IBM Corporation. All rights reserved. */
4
/* Copyright (c) 2005-2009 Rexx Language Association. All rights reserved. */
5
/* */
6
/* This program and the accompanying materials are made available under */
7
/* the terms of the Common Public License v1.0 which accompanies this */
8
/* distribution. A copy is also available at the following address: */
9
/* http://www.ibm.com/developerworks/oss/CPLv1.0.htm */
10
/* */
11
/* Redistribution and use in source and binary forms, with or */
12
/* without modification, are permitted provided that the following */
13
/* conditions are met: */
14
/* */
15
/* Redistributions of source code must retain the above copyright */
16
/* notice, this list of conditions and the following disclaimer. */
17
/* Redistributions in binary form must reproduce the above copyright */
18
/* notice, this list of conditions and the following disclaimer in */
19
/* the documentation and/or other materials provided with the distribution. */
20
/* */
21
/* Neither the name of Rexx Language Association nor the names */
22
/* of its contributors may be used to endorse or promote products */
23
/* derived from this software without specific prior written permission. */
24
/* */
25
/* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS */
26
/* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT */
27
/* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS */
28
/* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT */
29
/* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, */
30
/* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED */
31
/* TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, */
32
/* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY */
33
/* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING */
34
/* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS */
35
/* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */
36
/* */
37
/*----------------------------------------------------------------------------*/
38
/******************************************************************************/
39
/* REXX Shared runtime */
40
/* */
41
/* Windows implementation of the SysLibrary */
42
/* */
43
/******************************************************************************/
44
45
#include "
SysLibrary.hpp
"
46
47
SysLibrary::SysLibrary
()
48
{
49
libraryHandle
= NULL;
50
}
51
52
53
void
*
SysLibrary::getProcedure
(
54
const
char
*name)
/* required procedure name */
55
/******************************************************************************/
56
/* Function: Resolve a named procedure in a library */
57
/******************************************************************************/
58
{
59
return
(
void
*)GetProcAddress(
libraryHandle
, name);
60
}
61
62
63
/**
64
* Load a named library in this process.
65
*
66
* @param name Character string name of the library.
67
*
68
* @return True if able to load the library ok, false otherwise.
69
*/
70
bool
SysLibrary::load
(
const
char
*name)
71
{
72
if
(
libraryHandle
== NULL)
73
{
74
// we always use LoadLibrary to load this, to bump the reference count on
75
// the module if it is already loaded in this process.
76
libraryHandle
= LoadLibrary((LPCTSTR)name);
77
// and return the success/failure indicator
78
return
libraryHandle
!= NULL;
79
80
}
81
return
true
;
82
}
83
84
/**
85
* Free a loaded library if the library is still loaded.
86
*
87
* @return True if we unloaded ok, false otherwise.
88
*/
89
bool
SysLibrary::unload
()
90
{
91
if
(
libraryHandle
!= NULL)
92
{
93
return
FreeLibrary(
libraryHandle
) != FALSE;
94
}
95
return
false
;
96
}
SysLibrary::getProcedure
void * getProcedure(const char *name)
Definition:
unix/SysLibrary.cpp:65
SysLibrary::SysLibrary
SysLibrary()
Definition:
unix/SysLibrary.cpp:59
SysLibrary::unload
bool unload()
Definition:
unix/SysLibrary.cpp:111
SysLibrary::libraryHandle
void * libraryHandle
Definition:
unix/SysLibrary.hpp:60
SysLibrary::load
bool load(const char *name)
Definition:
unix/SysLibrary.cpp:75
SysLibrary.hpp
oorexx
executor
sandbox
jlf
trunk
common
platform
windows
SysLibrary.cpp
Generated by
1.9.2