SUMO - Simulation of Urban MObility
NIVissimSource.cpp
Go to the documentation of this file.
1 /****************************************************************************/
7 // -------------------
8 /****************************************************************************/
9 // SUMO, Simulation of Urban MObility; see http://sumo.dlr.de/
10 // Copyright (C) 2001-2017 DLR (http://www.dlr.de/) and contributors
11 /****************************************************************************/
12 //
13 // This file is part of SUMO.
14 // SUMO is free software: you can redistribute it and/or modify
15 // it under the terms of the GNU General Public License as published by
16 // the Free Software Foundation, either version 3 of the License, or
17 // (at your option) any later version.
18 //
19 /****************************************************************************/
20 
21 
22 // ===========================================================================
23 // included modules
24 // ===========================================================================
25 #ifdef _MSC_VER
26 #include <windows_config.h>
27 #else
28 #include <config.h>
29 #endif
30 
31 
32 #include <string>
33 #include <map>
34 #include "NIVissimSource.h"
35 
37 
38 NIVissimSource::NIVissimSource(const std::string& id, const std::string& name,
39  const std::string& edgeid)
40  : myID(id), myName(name), myEdgeID(edgeid) {}
41 
42 
44 
45 
46 bool
47 NIVissimSource::dictionary(const std::string& id, const std::string& name,
48  const std::string& edgeid) {
49  NIVissimSource* o = new NIVissimSource(id, name, edgeid);
50  if (!dictionary(id, o)) {
51  delete o;
52  return false;
53  }
54  return true;
55 }
56 
57 
58 bool
59 NIVissimSource::dictionary(const std::string& id, NIVissimSource* o) {
60  DictType::iterator i = myDict.find(id);
61  if (i == myDict.end()) {
62  myDict[id] = o;
63  return true;
64  }
65  return false;
66 }
67 
68 
70 NIVissimSource::dictionary(const std::string& id) {
71  DictType::iterator i = myDict.find(id);
72  if (i == myDict.end()) {
73  return 0;
74  }
75  return (*i).second;
76 }
77 
78 
79 void
81  for (DictType::iterator i = myDict.begin(); i != myDict.end(); i++) {
82  delete(*i).second;
83  }
84  myDict.clear();
85 }
86 
87 
88 
89 /****************************************************************************/
90 
static void clearDict()
static DictType myDict
NIVissimSource(const std::string &id, const std::string &name, const std::string &edgeid)
std::map< std::string, NIVissimSource * > DictType
static bool dictionary(const std::string &id, const std::string &name, const std::string &edgeid)