1 | #include "gmregistry.h"
|
---|
2 |
|
---|
3 | #include <assert.h>
|
---|
4 | #include <mars_log.h>
|
---|
5 |
|
---|
6 | namespace geoworld
|
---|
7 | {
|
---|
8 | GeoMorphRegistry::GeoMorphRegistry()
|
---|
9 | {
|
---|
10 | }
|
---|
11 |
|
---|
12 | GeoMorphRegistry::~GeoMorphRegistry()
|
---|
13 | {
|
---|
14 | }
|
---|
15 |
|
---|
16 | void GeoMorphRegistry::registerFactory( const std::string & name, IGeoFactoryBase * pFactory )
|
---|
17 | {
|
---|
18 | if (_factories.find(name) != _factories.end())
|
---|
19 | throw GMRegistryException("Factory has already registered");
|
---|
20 |
|
---|
21 | _factories[name] = pFactory;
|
---|
22 | }
|
---|
23 |
|
---|
24 | IGeoFactoryBase * GeoMorphRegistry::unregisterFactory( const std::string & name )
|
---|
25 | {
|
---|
26 | FactoryMap::iterator i = _factories.find(name);
|
---|
27 |
|
---|
28 | if (i != _factories.end())
|
---|
29 | {
|
---|
30 | for (GeoMorphRegistry::FactoryMap::iterator j = _factconf.begin(); j != _factconf.end(); ++j)
|
---|
31 | if (j->second == i->second)
|
---|
32 | j = _factconf.erase(j);
|
---|
33 |
|
---|
34 | IGeoFactoryBase * pRemoved = i->second;
|
---|
35 |
|
---|
36 | _factories.erase(name);
|
---|
37 |
|
---|
38 | {
|
---|
39 | GeoMorphFactory * pGMFact = dynamic_cast< GeoMorphFactory * > (pRemoved);
|
---|
40 | if (pGMFact != NULL)
|
---|
41 | _gmfact.erase(pGMFact);
|
---|
42 | }
|
---|
43 |
|
---|
44 | {
|
---|
45 | GeoTemplateFactory * pGTFact = dynamic_cast< GeoTemplateFactory * > (pRemoved);
|
---|
46 | if (pGTFact != NULL)
|
---|
47 | _gtfact[pGTFact->getPhase()].erase(pGTFact);
|
---|
48 | }
|
---|
49 |
|
---|
50 | return pRemoved;
|
---|
51 | } else
|
---|
52 | return NULL;
|
---|
53 | }
|
---|
54 |
|
---|
55 | void GeoMorphRegistry::configure( IFactoryConfigReader & reader )
|
---|
56 | {
|
---|
57 | IConfigFactoryBase * pFactoryConfig;
|
---|
58 | const std::string sStdMsg = "Failed to configure factory ";
|
---|
59 |
|
---|
60 | try {
|
---|
61 | while (NULL != (pFactoryConfig = reader.readNext()))
|
---|
62 | {
|
---|
63 | if (_factories.find(pFactoryConfig->factory) != _factories.end())
|
---|
64 | {
|
---|
65 | IGeoFactoryBase * pFact = _factories[pFactoryConfig->factory];
|
---|
66 |
|
---|
67 | try
|
---|
68 | {
|
---|
69 | pFact->configure(pFactoryConfig);
|
---|
70 |
|
---|
71 | if (_factconf.find(pFactoryConfig->nom) != _factconf.end())
|
---|
72 | throw GMInvalidFactoryConfigEx("Factory is already registered '" + pFactoryConfig->nom + "'");
|
---|
73 |
|
---|
74 | _factconf[pFactoryConfig->nom] = pFact;
|
---|
75 |
|
---|
76 | {
|
---|
77 | GeoMorphFactory * pGMFact = dynamic_cast< GeoMorphFactory * > (pFact);
|
---|
78 | if (pGMFact != NULL)
|
---|
79 | _gmfact.insert(pGMFact);
|
---|
80 | }
|
---|
81 |
|
---|
82 | {
|
---|
83 | GeoTemplateFactory * pGTFact = dynamic_cast< GeoTemplateFactory * > (pFact);
|
---|
84 | if (pGTFact != NULL)
|
---|
85 | _gtfact[pGTFact->getPhase()].insert(pGTFact);
|
---|
86 | }
|
---|
87 | }
|
---|
88 | catch (GMInvalidFactoryConfigEx & e)
|
---|
89 | {
|
---|
90 | LOG(mars::Log::Warn) << sStdMsg << pFactoryConfig->factory << " {" << e.what() << "}";
|
---|
91 | }
|
---|
92 | }
|
---|
93 | }
|
---|
94 | }
|
---|
95 | catch (GMMalformedConfigEx & e)
|
---|
96 | {
|
---|
97 | LOG(mars::Log::Warn) << "Configuration is malformed {" << e.what() << "}";
|
---|
98 | }
|
---|
99 | }
|
---|
100 |
|
---|
101 | const IGeoFactoryBase * GeoMorphRegistry::getFactory( const std::string & name ) const
|
---|
102 | {
|
---|
103 | FactoryMap::const_iterator i = _factories.find(name);
|
---|
104 |
|
---|
105 | if (i != _factories.end())
|
---|
106 | return i->second;
|
---|
107 | else
|
---|
108 | return NULL;
|
---|
109 | }
|
---|
110 |
|
---|
111 | void GeoMorphFactory::configure( IConfigFactoryBase * pFactoryConfig )
|
---|
112 | {
|
---|
113 | IConfigGMFactory * pGMFactoryConfig = dynamic_cast< IConfigGMFactory * > (pFactoryConfig);
|
---|
114 |
|
---|
115 | assert(pGMFactoryConfig != NULL && "Expected object of class IConfigGMFactory");
|
---|
116 | _settings = pGMFactoryConfig->settings;
|
---|
117 | configure(pGMFactoryConfig, _settings);
|
---|
118 | }
|
---|
119 |
|
---|
120 | void GeoTemplateFactory::configure( IConfigFactoryBase * pFactoryConfig )
|
---|
121 | {
|
---|
122 | IConfigGTFactory * pGTFactoryConfig = dynamic_cast< IConfigGTFactory * > (pFactoryConfig);
|
---|
123 |
|
---|
124 | assert(pGTFactoryConfig != NULL && "Expected object of class IConfigGTFactory");
|
---|
125 | _settings = pGTFactoryConfig->settings;
|
---|
126 | configure(pGTFactoryConfig, _settings);
|
---|
127 | }
|
---|
128 | } |
---|