Project::OSiRiON - Git repositories
Project::OSiRiON
News . About . Screenshots . Downloads . Forum . Wiki . Tracker . Git
summaryrefslogtreecommitdiff
path: root/src/core
diff options
context:
space:
mode:
authorStijn Buys <ingar@osirion.org>2009-08-17 11:40:15 +0000
committerStijn Buys <ingar@osirion.org>2009-08-17 11:40:15 +0000
commit5636fad174f0bcff857c357c394c4cc8d424b302 (patch)
treed41807018da962a930ef087b73ce4ac89a90c6f8 /src/core
parent80aaacbaef16b4eba33428aec268f80e7466cbb1 (diff)
reload entity/info models on r_restart
Diffstat (limited to 'src/core')
-rw-r--r--src/core/info.cc16
-rw-r--r--src/core/info.h5
2 files changed, 12 insertions, 9 deletions
diff --git a/src/core/info.cc b/src/core/info.cc
index 4e0cb53..93837c0 100644
--- a/src/core/info.cc
+++ b/src/core/info.cc
@@ -12,7 +12,7 @@
namespace core
{
-Info::Registry Info::registry;
+Info::Registry Info::info_registry;
Info::Info(const std::string & label)
{
@@ -137,12 +137,12 @@ void Info::add(Info *info)
if (find(info->label()))
return;
- registry[info->label()] = info;
+ info_registry[info->label()] = info;
}
Info *Info::find(const char *label)
{
- for (Registry::iterator it = registry.begin(); it != registry.end(); it++) {
+ for (Registry::iterator it = info_registry.begin(); it != info_registry.end(); it++) {
Info *info = (*it).second;
if (info->label().compare(label) == 0) {
return info;
@@ -153,7 +153,7 @@ Info *Info::find(const char *label)
Info *Info::find(const std::string & label)
{
- for (Registry::iterator it = registry.begin(); it != registry.end(); it++) {
+ for (Registry::iterator it = info_registry.begin(); it != info_registry.end(); it++) {
Info *info = (*it).second;
if (info->label().compare(label) == 0) {
return info;
@@ -164,20 +164,20 @@ Info *Info::find(const std::string & label)
void Info::clear()
{
- for (Registry::iterator it = registry.begin(); it != registry.end(); it++) {
+ for (Registry::iterator it = info_registry.begin(); it != info_registry.end(); it++) {
Info *info = (*it).second;;
delete info;
}
- registry.clear();
+ info_registry.clear();
}
void Info::list()
{
- for (Registry::iterator it = registry.begin(); it != registry.end(); it++) {
+ for (Registry::iterator it = info_registry.begin(); it != info_registry.end(); it++) {
Info *info = (*it).second;;
con_print << info->label() << std::endl;
}
- con_print << registry.size() << " registered info " << aux::plural("record", registry.size()) << std::endl;
+ con_print << info_registry.size() << " registered info " << aux::plural("record", info_registry.size()) << std::endl;
}
}
diff --git a/src/core/info.h b/src/core/info.h
index 678c48d..1bc62a9 100644
--- a/src/core/info.h
+++ b/src/core/info.h
@@ -92,6 +92,9 @@ public:
/// list the info registry
static void list();
+ /// the info registry
+ static inline Registry & registry() { return info_registry; }
+
private:
std::string info_label;
std::string info_name;
@@ -99,7 +102,7 @@ private:
Text info_text;
long info_credits;
- static Registry registry;
+ static Registry info_registry;
unsigned long info_timestamp;
};