ViewVC Help
View File | Revision Log | Show Annotations | View Changeset | Root Listing
root/OpenMD/trunk/src/utils/PropertyMap.cpp
Revision: 129
Committed: Wed Oct 20 22:54:30 2004 UTC (21 years ago) by tim
File size: 3074 byte(s)
Log Message:
GenericData and PropertyMap  pass unit test.

File Contents

# User Rev Content
1 tim 73 /*
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 tim 129
26     #include "utils/PropertyMap.hpp"
27 tim 73 #include <cassert>
28    
29 tim 129 namespace oopse {
30    
31 tim 73 PropertyMap::~PropertyMap(){
32     clearProperties();
33     }
34    
35    
36 tim 129 void PropertyMap::addProperty(GenericData* genData){
37     std::map<std::string, GenericData*>::iterator iter;
38 tim 73
39 tim 129 iter = propMap_.find(genData->getID());
40 tim 73
41 tim 129 if (iter == propMap_.end()){
42     propMap_.insert(make_pair(genData->getID(), genData));
43     } else {
44     delete iter->second;
45     iter->second = genData;
46     }
47 tim 73 }
48    
49 tim 129 bool PropertyMap::removeProperty(const std::string& propName){
50 tim 73 std::map<std::string, GenericData*>::iterator iter;
51    
52 tim 129 iter = propMap_.find(propName);
53 tim 73
54 tim 129 if (iter != propMap_.end()){
55     delete iter->second;
56     propMap_.erase(iter);
57     return true;
58     } else {
59     //logger.warn("Can not find property with name: " + propName);
60     return false;
61     }
62 tim 73 }
63    
64     void PropertyMap::clearProperties(){
65 tim 129 std::map<std::string, GenericData*>::iterator iter;
66 tim 73
67 tim 129 for (iter = propMap_.begin(); iter != propMap_.end(); ++iter)
68     delete iter->second;
69    
70     propMap_.clear();
71 tim 73 }
72    
73     std::vector<std::string> PropertyMap::getPropertyNames(){
74 tim 129 std::vector<std::string> propNames;
75     std::map<std::string, GenericData*>::iterator iter;
76 tim 73
77 tim 129 for (iter = propMap_.begin(); iter != propMap_.end(); ++iter)
78     propNames.push_back(iter->first);
79 tim 73
80 tim 129 return propNames;
81 tim 73 }
82    
83     std::vector<GenericData*> PropertyMap::getProperties(){
84 tim 129 std::vector<GenericData*> properties;
85     std::map<std::string, GenericData*>::iterator iter;
86 tim 73
87 tim 129 for (iter = propMap_.begin(); iter != propMap_.end(); ++iter)
88     properties.push_back(iter->second);
89 tim 73
90 tim 129 return properties;
91 tim 73 }
92    
93 tim 129 GenericData* PropertyMap::getPropertyByName(const std::string& propName){
94     std::map<std::string, GenericData*>::iterator iter;
95 tim 73
96 tim 129 iter = propMap_.find(propName);
97 tim 73
98 tim 129 if (iter != propMap_.end())
99     return iter->second;
100     else
101     return NULL;
102     }
103    
104     }//end namepace oopse