]> git.stg.codes - stg.git/blob - projects/stargazer/store_loader.cpp
Split SETTINGS to interface and implementation
[stg.git] / projects / stargazer / store_loader.cpp
1 /*
2  *    This program is free software; you can redistribute it and/or modify
3  *    it under the terms of the GNU General Public License as published by
4  *    the Free Software Foundation; either version 2 of the License, or
5  *    (at your option) any later version.
6  *
7  *    This program is distributed in the hope that it will be useful,
8  *    but WITHOUT ANY WARRANTY; without even the implied warranty of
9  *    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10  *    GNU General Public License for more details.
11  *
12  *    You should have received a copy of the GNU General Public License
13  *    along with this program; if not, write to the Free Software
14  *    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
15  */
16
17 /*
18  *    Author : Maxim Mamontov <faust@stargazer.dp.ua>
19  */
20
21 /*
22  $Revision: 1.6 $
23  $Date: 2010/03/04 12:24:19 $
24  $Author: faust $
25  */
26
27 /*
28  *  An implementation of RAII store plugin loader
29  */
30
31 #include <dlfcn.h>
32
33 #include "store_loader.h"
34 #include "common.h"
35 #include "store.h"
36 #include "settings.h"
37
38 STORE_LOADER::STORE_LOADER(const SETTINGS & settings)
39     : isLoaded(false),
40       handle(NULL),
41       plugin(NULL),
42       errorStr(),
43       storeSettings(settings.GetStoreModuleSettings()),
44       pluginFileName(settings.GetModulesPath() + "/mod_" + storeSettings.moduleName + ".so")
45 {
46 }
47
48 STORE_LOADER::~STORE_LOADER()
49 {
50 Unload();
51 }
52
53 bool STORE_LOADER::Load()
54 {
55 printfd(__FILE__, "STORE_LOADER::Load()\n");
56 if (isLoaded)
57     {
58     return false;
59     }
60
61 if (pluginFileName.empty())
62     {
63     errorStr = "Empty store plugin filename";
64     printfd(__FILE__, "STORE_LOADER::Load - %s\n", errorStr.c_str());
65     return true;
66     }
67
68 handle = dlopen(pluginFileName.c_str(), RTLD_NOW);
69
70 if (!handle)
71     {
72     errorStr = "Error loading plugin '"
73         + pluginFileName + "': '" + dlerror() + "'";
74     printfd(__FILE__, "STORE_LOADER::Load - %s\n", errorStr.c_str());
75     return true;
76     }
77
78 isLoaded = true;
79
80 STORE * (*GetStore)();
81 GetStore = (STORE * (*)())dlsym(handle, "GetStore");
82 if (!GetStore)
83     {
84     errorStr = "GetStore not found.";
85     printfd(__FILE__, "STORE_LOADER::Load - %s\n", errorStr.c_str());
86     return true;
87     }
88
89 plugin = GetStore();
90
91 if (!plugin)
92     {
93     errorStr = "NULL store plugin";
94     printfd(__FILE__, "STORE_LOADER::Load - %s\n");
95     return true;
96     }
97
98 plugin->SetSettings(storeSettings);
99 if (plugin->ParseSettings())
100     {
101     errorStr = plugin->GetStrError();
102     printfd(__FILE__, "Failed to parse settings. Plugin reports: '%s'\n", errorStr.c_str());
103     return true;
104     }
105
106 return false;
107 }
108
109 bool STORE_LOADER::Unload()
110 {
111 printfd(__FILE__, "STORE_LOADER::Unload()\n");
112 if (!isLoaded)
113     {
114     return false;
115     }
116
117 if (dlclose(handle))
118     {
119     errorStr = "Failed to unload plugin: '";
120     errorStr += dlerror();
121     errorStr += "'";
122     printfd(__FILE__, "STORE_LOADER::Unload - %s\n", errorStr.c_str());
123     return true;
124     }
125
126 isLoaded = false;
127
128 return false;
129 }