traci::TraCIHandler Class Reference

#include <TraCIHandler.h>

Inheritance diagram for traci::TraCIHandler:

SUMOSAXHandler GenericSAXHandler

Detailed Description

Definition at line 50 of file TraCIHandler.h.


Public Member Functions

void characters (const XMLCh *const chars, const XERCES3_SIZE_t length)
 The inherited method called when characters occured.
void endElement (const XMLCh *const uri, const XMLCh *const localname, const XMLCh *const qname)
 The inherited method called when a tag is being closed.
const std::string & getFileName () const throw ()
 returns the current file name
int getTotalVehicleCount ()
 Get the determined maxmimum number of vehicles that will be emitted during the simulation.
void registerParent (const SumoXMLTag tag, GenericSAXHandler *handler)
 Assigning a parent handler which is enabled when the specified tag is closed.
void resetTotalVehicleCount ()
 Reset number of counted vehicles to 0.
void setFileName (const std::string &name) throw ()
 Sets the current file name.
void startElement (const XMLCh *const uri, const XMLCh *const localname, const XMLCh *const qname, const Attributes &attrs)
 The inherited method called when a new tag opens.
 TraCIHandler (const std::string &file="") throw ()
 Constructor.
virtual ~TraCIHandler () throw ()
 Destructor.
SAX ErrorHandler callbacks
void error (const SAXParseException &exception) throw (ProcessError)
 Handler for XML-errors.
void fatalError (const SAXParseException &exception) throw (ProcessError)
 Handler for XML-errors.
void warning (const SAXParseException &exception) throw ()
 Handler for XML-warnings.

Protected Member Functions

std::string buildErrorMessage (const SAXParseException &exception) throw ()
 Builds an error message.
virtual void myCharacters (SumoXMLTag element, const std::string &chars) throw (ProcessError)
 Callback method for characters to implement by derived classes.
inherited from GenericSAXHandler
virtual void myEndElement (SumoXMLTag element) throw (ProcessError)
 Called when a closing tag occurs.
virtual void myStartElement (SumoXMLTag element, const SUMOSAXAttributes &attributes) throw (ProcessError)
 Called on the opening of a tag;.

Private Member Functions

void openVehicleTag (const SUMOSAXAttributes &attributes)

Private Attributes

int currentVehCount
int totalVehicleCount

Constructor & Destructor Documentation

TraCIHandler::TraCIHandler ( const std::string &  file = ""  )  throw ()

Constructor.

Parameters:
file the name of the parsed file

Definition at line 40 of file TraCIHandler.cpp.

00042         :SUMOSAXHandler(file),
00043         totalVehicleCount(0),
00044         currentVehCount(0) {}

TraCIHandler::~TraCIHandler (  )  throw () [virtual]

Destructor.

Definition at line 46 of file TraCIHandler.cpp.

00047         {}


Member Function Documentation

std::string SUMOSAXHandler::buildErrorMessage ( const SAXParseException &  exception  )  throw () [protected, inherited]

Builds an error message.

The error message includes the file name and the line/column information as supported by the given SAXParseException

Parameters:
[in] exception The name of the currently processed file
Returns:
A string describing the given exception

Definition at line 55 of file SUMOSAXHandler.cpp.

References GenericSAXHandler::getFileName().

Referenced by SUMOSAXHandler::error(), SUMOSAXHandler::fatalError(), and SUMOSAXHandler::warning().

00055                                                                             {
00056     std::ostringstream buf;
00057     char *pMsg = XMLString::transcode(exception.getMessage());
00058     buf << pMsg << std::endl;
00059     buf << " In file '" << getFileName() << "'" << std::endl;
00060     buf << " At line/column " << exception.getLineNumber()+1
00061     << '/' << exception.getColumnNumber() << "." << std::endl;
00062     XMLString::release(&pMsg);
00063     return buf.str();
00064 }

void GenericSAXHandler::characters ( const XMLCh *const   chars,
const XERCES3_SIZE_t  length 
) [inherited]

The inherited method called when characters occured.

The retrieved characters are converted into a string and appended into a private buffer. They are reported as soon as the element ends.

Todo:
recheck/describe what happens with characters when a new element is opened
Todo:
describe characters processing in the class' head

Definition at line 168 of file GenericSAXHandler.cpp.

References GenericSAXHandler::myCharactersVector.

00169                                                            {
00170     myCharactersVector.push_back(TplConvert<XMLCh>::_2str(chars, length));
00171 }

void GenericSAXHandler::endElement ( const XMLCh *const  uri,
const XMLCh *const  localname,
const XMLCh *const   qname 
) [inherited]

The inherited method called when a tag is being closed.

This method calls the user-implemented methods myCharacters with the previously collected and converted characters.

Then, myEndElement is called, supplying it the qname converted to its enum- and string-representations.

Todo:
recheck/describe encoding of the string-representation
Todo:
do not generate and report the string-representation

Definition at line 118 of file GenericSAXHandler.cpp.

References TplConvert< E >::_2str(), GenericSAXHandler::convertTag(), GenericSAXHandler::myCharacters(), GenericSAXHandler::myCharactersVector, GenericSAXHandler::myEndElement(), GenericSAXHandler::myParentHandler, GenericSAXHandler::myParentIndicator, XMLSubSys::setHandler(), SUMO_TAG_INCLUDE, and SUMO_TAG_NOTHING.

00120                                                         {
00121     std::string name = TplConvert<XMLCh>::_2str(qname);
00122     SumoXMLTag element = convertTag(name);
00123     // collect characters
00124     if (myCharactersVector.size()!=0) {
00125         size_t len = 0;
00126         unsigned i;
00127         for (i=0; i<myCharactersVector.size(); ++i) {
00128             len += myCharactersVector[i].length();
00129         }
00130         char *buf = new char[len+1];
00131         size_t pos = 0;
00132         for (i=0; i<myCharactersVector.size(); ++i) {
00133             memcpy((unsigned char*) buf+pos, (unsigned char*) myCharactersVector[i].c_str(),
00134                    sizeof(char)*myCharactersVector[i].length());
00135             pos += myCharactersVector[i].length();
00136         }
00137         buf[pos] = 0;
00138 
00139         // call user handler
00140         try {
00141             myCharacters(element, buf);
00142         } catch (std::runtime_error &) {
00143             delete[] buf;
00144             throw;
00145         }
00146         delete[] buf;
00147     }
00148     if (element != SUMO_TAG_INCLUDE) {
00149         myEndElement(element);
00150         if (myParentHandler && myParentIndicator == element) {
00151             XMLSubSys::setHandler(*myParentHandler);
00152             myParentIndicator = SUMO_TAG_NOTHING;
00153             myParentHandler = 0;
00154         }
00155     }
00156 }

void SUMOSAXHandler::error ( const SAXParseException &  exception  )  throw (ProcessError) [inherited]

Handler for XML-errors.

The message is built using buildErrorMessage and thrown within a ProcessError.

Parameters:
[in] exception The occured exception to process
Exceptions:
ProcessError On any call

Definition at line 74 of file SUMOSAXHandler.cpp.

References SUMOSAXHandler::buildErrorMessage().

00074                                                                             {
00075     throw ProcessError(buildErrorMessage(exception));
00076 }

void SUMOSAXHandler::fatalError ( const SAXParseException &  exception  )  throw (ProcessError) [inherited]

Handler for XML-errors.

The message is built using buildErrorMessage and thrown within a ProcessError.

Exceptions:
ProcessError On any call
Parameters:
[in] exception The occured exception to process

Definition at line 80 of file SUMOSAXHandler.cpp.

References SUMOSAXHandler::buildErrorMessage().

00080                                                                                  {
00081     throw ProcessError(buildErrorMessage(exception));
00082 }

const std::string & GenericSAXHandler::getFileName (  )  const throw () [inherited]

int TraCIHandler::getTotalVehicleCount (  ) 

Get the determined maxmimum number of vehicles that will be emitted during the simulation.

Definition at line 116 of file TraCIHandler.cpp.

Referenced by traci::TraCIServer::TraCIServer().

00116                                    {
00117     return totalVehicleCount;
00118 }

void GenericSAXHandler::myCharacters ( SumoXMLTag  element,
const std::string &  chars 
) throw (ProcessError) [protected, virtual, inherited]

Callback method for characters to implement by derived classes.

Called by "endElement" (see there).

Parameters:
[in] element The opened element, given as a SumoXMLTag
[in] chars The complete embedded character string ProcessError These method may throw a ProcessError if something fails

Reimplemented in ROJTRTurnDefLoader, MSRouteHandler, NIImporter_OpenDrive, NIImporter_SUMO, NLHandler, PCLoaderXML, PCNetProjectionLoader, and RORDLoader_SUMOBase.

Definition at line 189 of file GenericSAXHandler.cpp.

Referenced by GenericSAXHandler::endElement().

00189 {}

void TraCIHandler::myEndElement ( SumoXMLTag  element  )  throw (ProcessError) [protected, virtual]

Called when a closing tag occurs.

Parameters:
[in] element ID of the currently opened element
Exceptions:
ProcessError If something fails
See also:
GenericSAXHandler::myEndElement

Reimplemented from GenericSAXHandler.

Definition at line 58 of file TraCIHandler.cpp.

References SUMO_TAG_VEHICLE.

00059                     {
00060     if (element == SUMO_TAG_VEHICLE) {
00061         totalVehicleCount += currentVehCount;
00062     }
00063 }

void TraCIHandler::myStartElement ( SumoXMLTag  element,
const SUMOSAXAttributes attributes 
) throw (ProcessError) [protected, virtual]

Called on the opening of a tag;.

Parameters:
[in] element ID of the currently opened element
[in] attrs Attributes within the currently opened element
Exceptions:
ProcessError If something fails
See also:
GenericSAXHandler::myStartElement

Reimplemented from GenericSAXHandler.

Definition at line 50 of file TraCIHandler.cpp.

References SUMO_TAG_VEHICLE.

00051                     {
00052     if (element == SUMO_TAG_VEHICLE) {
00053         openVehicleTag(attributes);
00054     }
00055 }

void TraCIHandler::openVehicleTag ( const SUMOSAXAttributes attributes  )  [private]

Count each vehicle and all possibly emitted vehicles defined in each tag.

Definition at line 66 of file TraCIHandler.cpp.

References SUMOSAXAttributes::getInt(), OptionsCont::getOptions(), OptionsCont::getString(), string2time(), SUMO_ATTR_DEPART, SUMO_ATTR_PERIOD, SUMO_ATTR_REPNUMBER, and SUMOTime_MAX.

00066                                                                 {
00067     int repNo;
00068     int period;
00069     int depart;
00070     OptionsCont& optCont = OptionsCont::getOptions();
00071     SUMOTime simStart = string2time(optCont.getString("begin"));
00072     SUMOTime simEnd = string2time(optCont.getString("end"));
00073     if(simEnd<0) {
00074         simEnd = SUMOTime_MAX;
00075     }
00076     // every found vehicle tag counts for one vehicle
00077     currentVehCount = 1;
00078     // read value for emit period and number (if any)
00079     try {
00080         repNo = attributes.getInt(SUMO_ATTR_REPNUMBER);
00081         period = attributes.getInt(SUMO_ATTR_PERIOD);
00082     } catch (...) {
00083         repNo = 0;
00084         period = 0;
00085     }
00086 
00087     // read depart time
00088     try {
00089         depart = attributes.getInt(SUMO_ATTR_DEPART);
00090     } catch (...) {
00091         // no depart time: error, don't count vehicle
00092         currentVehCount = 0;
00093 //      std::cerr << "no depart time, vehicle = 0" << std::endl;
00094         return;
00095     }
00096 
00097     while ((depart < simStart) && (repNo >= 0)) {
00098         depart += period;
00099         repNo--;
00100 //      std::cerr << "removing 1 vehicle from repno (depart before sim start)" << std::endl;
00101     }
00102 
00103     // don't count vehicles that depart / are emitted after the sim ends
00104     while (((depart + (repNo * period)) > simEnd) && (repNo >= 0)) {
00105         repNo--;
00106 //      std::cerr << "removing 1 vehicle from repno (depart after sim end)" << std::endl;
00107 
00108     }
00109 
00110     // add number of vehicles, that will be emitted until sim end, to total count
00111     currentVehCount += repNo;
00112 //  std::cerr << "result: " << currentVehCount << " vehicles" << std::endl;
00113 }

void GenericSAXHandler::registerParent ( const SumoXMLTag  tag,
GenericSAXHandler handler 
) [inherited]

Assigning a parent handler which is enabled when the specified tag is closed.

Definition at line 160 of file GenericSAXHandler.cpp.

References GenericSAXHandler::myParentHandler, GenericSAXHandler::myParentIndicator, and XMLSubSys::setHandler().

Referenced by NLTriggerBuilder::parseAndBuildLaneSpeedTrigger().

00160                                                                                   {
00161     myParentHandler = handler;
00162     myParentIndicator = tag;
00163     XMLSubSys::setHandler(*this);
00164 }

void TraCIHandler::resetTotalVehicleCount (  ) 

Reset number of counted vehicles to 0.

Definition at line 121 of file TraCIHandler.cpp.

Referenced by traci::TraCIServer::TraCIServer().

00121                                      {
00122     totalVehicleCount = 0;
00123 }

void GenericSAXHandler::setFileName ( const std::string &  name  )  throw () [inherited]

Sets the current file name.

Parameters:
[in] name The name of the currently processed file
Todo:
Hmmm - this is as unsafe as having a direct access to the variable; recheck

Definition at line 72 of file GenericSAXHandler.cpp.

References GenericSAXHandler::myFileName.

Referenced by PCNetProjectionLoader::loadIfSet(), ROLoader::loadNet(), NIImporter_OpenStreetMap::loadNetwork(), NILoader::loadXMLType(), and traci::TraCIServer::TraCIServer().

00072                                                             {
00073     myFileName = name;
00074 }

void GenericSAXHandler::startElement ( const XMLCh *const  uri,
const XMLCh *const  localname,
const XMLCh *const   qname,
const Attributes &  attrs 
) [inherited]

The inherited method called when a new tag opens.

The method parses the supplied XMLCh*-qname using the internal name/enum-map to obtain the enum representation of the attribute name.

Then, "myStartElement" is called supplying the enumeration value, the string-representation of the name and the attributes.

Todo:
recheck/describe encoding of the string-representation
Todo:
do not generate and report the string-representation

Definition at line 97 of file GenericSAXHandler.cpp.

References TplConvert< E >::_2str(), GenericSAXHandler::convertTag(), FileHelpers::getConfigurationRelative(), GenericSAXHandler::getFileName(), SUMOSAXAttributesImpl_Xerces::getString(), FileHelpers::isAbsolute(), GenericSAXHandler::myCharactersVector, GenericSAXHandler::myPredefinedTags, GenericSAXHandler::myPredefinedTagsMML, GenericSAXHandler::myStartElement(), XMLSubSys::runParser(), SUMO_ATTR_HREF, and SUMO_TAG_INCLUDE.

00100                                                          {
00101     std::string name = TplConvert<XMLCh>::_2str(qname);
00102     SumoXMLTag element = convertTag(name);
00103     myCharactersVector.clear();
00104     SUMOSAXAttributesImpl_Xerces na(attrs, myPredefinedTags, myPredefinedTagsMML);
00105     if (element == SUMO_TAG_INCLUDE) {
00106         std::string file = na.getString(SUMO_ATTR_HREF);
00107         if (!FileHelpers::isAbsolute(file)) {
00108             file = FileHelpers::getConfigurationRelative(getFileName(), file);
00109         }
00110         XMLSubSys::runParser(*this, file);
00111     } else {
00112         myStartElement(element, na);
00113     }
00114 }

void SUMOSAXHandler::warning ( const SAXParseException &  exception  )  throw () [inherited]

Handler for XML-warnings.

The message is built using buildErrorMessage and reported to the warning-instance of the MsgHandler.

Parameters:
[in] exception The occured exception to process

Definition at line 68 of file SUMOSAXHandler.cpp.

References SUMOSAXHandler::buildErrorMessage(), MsgHandler::getWarningInstance(), and MsgHandler::inform().


Field Documentation

Definition at line 101 of file TraCIHandler.h.

Definition at line 99 of file TraCIHandler.h.


The documentation for this class was generated from the following files:

Generated on Wed May 5 00:07:02 2010 for Sumo - Simulation of Urban MObility by  doxygen 1.5.6