MSJunctionLogic.h

Go to the documentation of this file.
00001 /****************************************************************************/
00007 // kinds of logic-implementations.
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 #ifndef MSJunctionLogic_h
00020 #define MSJunctionLogic_h
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 "MSLogicJunction.h"
00033 #include <string>
00034 
00035 
00036 // ===========================================================================
00037 // class definitions
00038 // ===========================================================================
00042 class MSJunctionLogic {
00043 public:
00045     virtual ~MSJunctionLogic();
00046 
00048     virtual void respond(const MSLogicJunction::Request& request,
00049                          const MSLogicJunction::InnerState& innerState,
00050                          MSLogicJunction::Respond& respond) const = 0;
00051 
00053     unsigned int nLinks();
00054 
00056     unsigned int nInLanes();
00057 
00059     virtual const MSLogicJunction::LinkFoes &getFoesFor(unsigned int linkIndex) const throw() {
00060         return myDummyFoes;
00061     }
00062 
00063     virtual const std::bitset<64> &getInternalFoesFor(unsigned int linkIndex) const throw() {
00064         return myDummyFoes;
00065     }
00066     virtual bool getIsCont(unsigned int linkIndex) const throw() {
00067         return false;
00068     }
00069 
00070 
00071     unsigned int getLogicSize() const throw() {
00072         return myNLinks;
00073     }
00074 
00075     virtual bool isCrossing() const throw() {
00076         return false;
00077     }
00078 
00079 
00080 
00081 
00082 protected:
00084     MSJunctionLogic(unsigned int nLinks, unsigned int nInLanes);
00085 
00087     unsigned int myNLinks;
00088 
00090     unsigned int myNInLanes;
00091 
00093     static MSLogicJunction::LinkFoes myDummyFoes;
00094 
00095 private:
00097     MSJunctionLogic();
00098 
00100     MSJunctionLogic(const MSJunctionLogic&);
00101 
00103     MSJunctionLogic& operator=(const MSJunctionLogic&);
00104 
00105 };
00106 
00107 
00108 #endif
00109 
00110 /****************************************************************************/
00111 

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