Line data Source code
1 : /* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
2 : Copyright (c) 2013-2019 The plumed team
3 : (see the PEOPLE file at the root of the distribution for a list of names)
4 :
5 : See http://www.plumed.org for more information.
6 :
7 : This file is part of plumed, version 2.
8 :
9 : plumed is free software: you can redistribute it and/or modify
10 : it under the terms of the GNU Lesser General Public License as published by
11 : the Free Software Foundation, either version 3 of the License, or
12 : (at your option) any later version.
13 :
14 : plumed is distributed in the hope that it will be useful,
15 : but WITHOUT ANY WARRANTY; without even the implied warranty of
16 : MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 : GNU Lesser General Public License for more details.
18 :
19 : You should have received a copy of the GNU Lesser General Public License
20 : along with plumed. If not, see <http://www.gnu.org/licenses/>.
21 : +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
22 : #include "LandmarkRegister.h"
23 : #include <iostream>
24 :
25 : namespace PLMD {
26 : namespace analysis {
27 :
28 3214 : LandmarkRegister::~LandmarkRegister() {
29 1607 : if(m.size()>0) {
30 0 : std::string names="";
31 0 : for(const auto & p : m) names+=p.first+" ";
32 0 : std::cerr<<"WARNING: ReferenceConfiguration "+ names +" has not been properly unregistered. This might lead to memory leak!!\n";
33 : }
34 1607 : }
35 :
36 3215 : LandmarkRegister& landmarkRegister() {
37 3215 : static LandmarkRegister ans;
38 3215 : return ans;
39 : }
40 :
41 1607 : void LandmarkRegister::remove(creator_pointer f) {
42 1607 : for(auto p=m.begin(); p!=m.end(); ++p) {
43 1607 : if((*p).second==f) {
44 1607 : m.erase(p); break;
45 : }
46 : }
47 1607 : }
48 :
49 1607 : void LandmarkRegister::add( std::string type, creator_pointer f ) {
50 1607 : plumed_massert(m.count(type)==0,"type has already been registered");
51 1607 : m.insert(std::pair<std::string,creator_pointer>(type,f));
52 1607 : }
53 :
54 1 : bool LandmarkRegister::check(std::string type) {
55 1 : if( m.count(type)>0 ) return true;
56 0 : return false;
57 : }
58 :
59 1 : LandmarkSelectionBase* LandmarkRegister::create( const LandmarkSelectionOptions& lo ) {
60 : LandmarkSelectionBase* lselect;
61 1 : if( check(lo.words[0]) ) {
62 1 : lselect=m[lo.words[0]](lo);
63 1 : lselect->checkRead();
64 0 : } else lselect=NULL;
65 1 : return lselect;
66 : }
67 :
68 : }
69 4821 : }
|