Menu

[r1567]: / cppdb / trunk / cppdb / shared_object.h  Maximize  Restore  History

Download this file

81 lines (72 with data), 2.6 kB

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
///////////////////////////////////////////////////////////////////////////////
//
// Copyright (C) 2010 Artyom Beilis (Tonkikh) <artyomtnk@yahoo.com>
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
//
///////////////////////////////////////////////////////////////////////////////
#ifndef CPPDB_SHARED_OBJECT_H
#define CPPDB_SHARED_OBJECT_H
#include <cppdb/defs.h>
#include <cppdb/ref_ptr.h>
namespace cppdb {
///
/// \brief This class allows to load and unload shared objects in simple and exception safe way.
///
class CPPDB_API shared_object : public ref_counted {
shared_object() : handle_(0) {}
shared_object(std::string name,void *h);
shared_object(shared_object const &);
void operator=(shared_object const &);
public:
~shared_object();
///
/// Load shared object, returns empty pointer if the object does not exits or not loadable
///
static ref_ptr<shared_object> open(std::string const &name);
///
/// Resolve symbol \a name and return pointer on it, throws cppdb_error if the symbol can't be resolved
///
void *safe_sym(std::string const &name);
///
/// Resolve symbol \a name and return pointer on it, returns NULL if the symbol can't be resolved
///
void *sym(std::string const &name);
///
/// Resolve symbol \a name and assign it to \a v, returns false if the symbol can't be resolved
///
template<typename T>
bool resolve(std::string const &s,T *&v)
{
void *p=sym(s);
if(!p) {
return false;
}
v=(T*)(p);
return true;
}
///
/// Resolve symbol \a name and assign it to v, throws cppdb_error if the symbol can't be resolved
///
template<typename T>
void safe_resolve(std::string const &s,T *&v)
{
v=(T*)(sym(s));
}
private:
std::string dlname_;
void *handle_;
};
}
#endif
MongoDB Logo MongoDB