SUMO - Simulation of Urban MObility
|
00001 /****************************************************************************/ 00008 // 00009 /****************************************************************************/ 00010 // SUMO, Simulation of Urban MObility; see http://sumo.sourceforge.net/ 00011 // Copyright (C) 2001-2012 DLR (http://www.dlr.de/) and contributors 00012 /****************************************************************************/ 00013 // 00014 // This file is part of SUMO. 00015 // SUMO is free software: you can redistribute it and/or modify 00016 // it under the terms of the GNU General Public License as published by 00017 // the Free Software Foundation, either version 3 of the License, or 00018 // (at your option) any later version. 00019 // 00020 /****************************************************************************/ 00021 00022 00023 // =========================================================================== 00024 // included modules 00025 // =========================================================================== 00026 #ifdef _MSC_VER 00027 #include <windows_config.h> 00028 #else 00029 #include <config.h> 00030 #endif 00031 00032 #include <iostream> 00033 #include <utils/common/TplConvert.h> 00034 #include "../NIImporter_Vissim.h" 00035 #include "../tempstructs/NIVissimClosures.h" 00036 #include "NIVissimSingleTypeParser_Kantensperrung.h" 00037 00038 #ifdef CHECK_MEMORY_LEAKS 00039 #include <foreign/nvwa/debug_new.h> 00040 #endif // CHECK_MEMORY_LEAKS 00041 00042 00043 // =========================================================================== 00044 // method definitions 00045 // =========================================================================== 00046 NIVissimSingleTypeParser_Kantensperrung::NIVissimSingleTypeParser_Kantensperrung(NIImporter_Vissim& parent) 00047 : NIImporter_Vissim::VissimSingleTypeParser(parent) {} 00048 00049 00050 NIVissimSingleTypeParser_Kantensperrung::~NIVissimSingleTypeParser_Kantensperrung() {} 00051 00052 00053 bool 00054 NIVissimSingleTypeParser_Kantensperrung::parse(std::istream& from) { 00055 std::string tag; 00056 from >> tag; 00057 // 00058 std::string id; 00059 from >> id; 00060 // 00061 from >> tag; 00062 from >> tag; 00063 int from_node; 00064 from >> from_node; 00065 // 00066 from >> tag; 00067 from >> tag; 00068 int to_node; 00069 from >> to_node; 00070 // 00071 from >> tag; 00072 from >> tag; 00073 std::vector<int> edges; 00074 while (tag != "DATAEND") { 00075 tag = readEndSecure(from); 00076 if (tag != "DATAEND") { 00077 edges.push_back(TplConvert<char>::_2int(tag.c_str())); 00078 } 00079 } 00080 NIVissimClosures::dictionary(id, from_node, to_node, edges); 00081 return true; 00082 } 00083 00084 00085 00086 /****************************************************************************/ 00087