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