ViewVC Help
View File | Revision Log | Show Annotations | View Changeset | Root Listing
root/group/branches/new_design/OOPSE-2.0/src/integrators/IntegratorFactory.hpp
Revision: 1837
Committed: Thu Dec 2 22:15:31 2004 UTC (19 years, 7 months ago) by tim
File size: 4068 byte(s)
Log Message:
refine factory pattern to make it initialized correctly

File Contents

# Content
1 /*
2 * Copyright (C) 2000-2004 Object Oriented Parallel Simulation Engine (OOPSE) project
3 *
4 * Contact: oopse@oopse.org
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public License
8 * as published by the Free Software Foundation; either version 2.1
9 * of the License, or (at your option) any later version.
10 * All we ask is that proper credit is given for our work, which includes
11 * - but is not limited to - adding the above copyright notice to the beginning
12 * of your source code files, and to any copyright notice that you may distribute
13 * with programs based on this work.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Lesser General Public License for more details.
19 *
20 * You should have received a copy of the GNU Lesser General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
23 *
24 */
25
26 /**
27 * @file IntegratorFactory.hpp
28 * @author Teng Lin
29 * @date 10/24/2004
30 * @version 1.0
31 */
32 #ifndef INTEGRATORS_INTEGRATORFACTORY_HPP
33 #define INTEGRATORS_INTEGRATORFACTORY_HPP
34 #include <cassert>
35 #include <map>
36 #include <string>
37 #include <vector>
38 #include <iostream>
39 namespace oopse {
40
41 //forward declaration
42 class Integrator;
43 class IntegratorCreator;
44 class SimInfo;
45 /**
46 * @class IntegratorFactory IntegratorFactory.hpp "UseTheForce/IntegratorFactory.hpp"
47 * Factory pattern and Singleton Pattern are used to define an interface for creating an Integrator.
48 */
49 class IntegratorFactory {
50 public:
51
52 typedef std::map<std::string, IntegratorCreator*> CreatorMapType;
53 typedef std::vector<std::string> IdentVectorType;
54 typedef std::vector<std::string>::iterator IdentVectorIterator;
55
56 /**
57 * Returns an instance of Integrator factory
58 * @return an instance of Integrator factory
59 */
60 static IntegratorFactory* getInstance() {
61
62 if (instance_ == NULL) {
63 instance_ = new IntegratorFactory();
64 }
65 return instance_;
66
67 }
68
69 /**
70 * Registers a creator with a type identifier
71 * @return true if registration is succeed, otherwise return false
72 * @id the identification of the concrete object
73 * @creator the object responsible to create the concrete object
74 */
75 bool registerIntegrator(IntegratorCreator* creator);
76
77 /**
78 * Unregisters the creator for the given type identifier. If the type identifier
79 * was previously registered, the function returns true.
80 * @return truethe type identifier was previously registered and the creator is removed,
81 * otherwise return false
82 * @id the identification of the concrete object
83 */
84 bool unregisterIntegrator(const std::string& id);
85 /**
86 * Looks up the type identifier in the internal map. If it is found, it invokes the
87 * corresponding creator for the type identifier and returns its result.
88 * @return a pointer of the concrete object, return NULL if no creator is registed for
89 * creating this concrete object
90 * @param id the identification of the concrete object
91 */
92 Integrator* createIntegrator(const std::string& id, SimInfo* info);
93
94 /**
95 * Returns all of the registed type identifiers
96 * @return all of the registed type identifiers
97 */
98 IdentVectorType getIdents();
99
100 private:
101 static IntegratorFactory* instance_;
102 CreatorMapType creatorMap_;
103 };
104
105 /** write out all of the type identifiers to an output stream */
106 std::ostream& operator <<(std::ostream& o, IntegratorFactory& factory);
107
108 }//namespace oopse
109 #endif //INTEGRATORS_INTEGRATORFACTORY_HPP
110