refactoring variable names and layout to be more readable
This commit is contained in:
		
							parent
							
								
									c3e0b68399
								
							
						
					
					
						commit
						8b3c8f7093
					
				| @ -27,24 +27,32 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |||||||
| 
 | 
 | ||||||
| #include "BaseParser.h" | #include "BaseParser.h" | ||||||
| #include "ExtractorStructs.h" | #include "ExtractorStructs.h" | ||||||
|  | #include "ScriptingEnvironment.h" | ||||||
|  | 
 | ||||||
|  | #include "../Util/LuaUtil.h" | ||||||
|  | #include "../Util/OSRMException.h" | ||||||
|  | #include "../Util/SimpleLogger.h" | ||||||
| 
 | 
 | ||||||
| #include <boost/foreach.hpp> | #include <boost/foreach.hpp> | ||||||
| 
 | 
 | ||||||
| BaseParser::BaseParser(ExtractorCallbacks* ec, ScriptingEnvironment& se) : | BaseParser::BaseParser( | ||||||
| extractor_callbacks(ec), scriptingEnvironment(se), luaState(NULL), use_turn_restrictions(true) { |     ExtractorCallbacks   * extractor_callbacks, | ||||||
|     luaState = se.getLuaStateForThreadID(0); |     ScriptingEnvironment & scripting_environment | ||||||
|  | ) : extractor_callbacks(extractor_callbacks), | ||||||
|  |     lua_state(scripting_environment.getLuaStateForThreadID(0)), | ||||||
|  |     scripting_environment(scripting_environment), | ||||||
|  |     use_turn_restrictions(true) | ||||||
|  | { | ||||||
|     ReadUseRestrictionsSetting(); |     ReadUseRestrictionsSetting(); | ||||||
|     ReadRestrictionExceptions(); |     ReadRestrictionExceptions(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void BaseParser::ReadUseRestrictionsSetting() { | void BaseParser::ReadUseRestrictionsSetting() { | ||||||
|     if( 0 != luaL_dostring( luaState, "return use_turn_restrictions\n") ) { |     if( 0 != luaL_dostring( lua_state, "return use_turn_restrictions\n") ) { | ||||||
|         throw OSRMException( |         throw OSRMException("ERROR occured in scripting block"); | ||||||
|             /*lua_tostring( luaState, -1 ) + */"ERROR occured in scripting block" |  | ||||||
|         ); |  | ||||||
|     } |     } | ||||||
|     if( lua_isboolean( luaState, -1) ) { |     if( lua_isboolean( lua_state, -1) ) { | ||||||
|         use_turn_restrictions = lua_toboolean(luaState, -1); |         use_turn_restrictions = lua_toboolean(lua_state, -1); | ||||||
|     } |     } | ||||||
|     if( use_turn_restrictions ) { |     if( use_turn_restrictions ) { | ||||||
|         SimpleLogger().Write() << "Using turn restrictions"; |         SimpleLogger().Write() << "Using turn restrictions"; | ||||||
| @ -54,14 +62,16 @@ void BaseParser::ReadUseRestrictionsSetting() { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void BaseParser::ReadRestrictionExceptions() { | void BaseParser::ReadRestrictionExceptions() { | ||||||
|     if(lua_function_exists(luaState, "get_exceptions" )) { |     if(lua_function_exists(lua_state, "get_exceptions" )) { | ||||||
|         //get list of turn restriction exceptions
 |         //get list of turn restriction exceptions
 | ||||||
|         luabind::call_function<void>( |         luabind::call_function<void>( | ||||||
|             luaState, |             lua_state, | ||||||
|             "get_exceptions", |             "get_exceptions", | ||||||
|             boost::ref(restriction_exceptions) |             boost::ref(restriction_exceptions) | ||||||
|         ); |         ); | ||||||
|         SimpleLogger().Write() << "Found " << restriction_exceptions.size() << " exceptions to turn restriction"; |         const unsigned exception_count = restriction_exceptions.size(); | ||||||
|  |         SimpleLogger().Write() << | ||||||
|  |             "Found " << exception_count << " exceptions to turn restrictions:"; | ||||||
|         BOOST_FOREACH(const std::string & str, restriction_exceptions) { |         BOOST_FOREACH(const std::string & str, restriction_exceptions) { | ||||||
|             SimpleLogger().Write() << "  " << str; |             SimpleLogger().Write() << "  " << str; | ||||||
|         } |         } | ||||||
| @ -77,20 +87,32 @@ void BaseParser::report_errors(lua_State *L, const int status) const { | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void BaseParser::ParseNodeInLua(ImportNode& n, lua_State* localLuaState) { | void BaseParser::ParseNodeInLua(ImportNode& n, lua_State* local_lua_state) { | ||||||
|     luabind::call_function<void>( localLuaState, "node_function", boost::ref(n) ); |     luabind::call_function<void>( | ||||||
|  |         local_lua_state, | ||||||
|  |         "node_function", | ||||||
|  |         boost::ref(n) | ||||||
|  |     ); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void BaseParser::ParseWayInLua(ExtractionWay& w, lua_State* localLuaState) { | void BaseParser::ParseWayInLua(ExtractionWay& w, lua_State* local_lua_state) { | ||||||
|     luabind::call_function<void>( localLuaState, "way_function", boost::ref(w) ); |     luabind::call_function<void>( | ||||||
|  |         local_lua_state, | ||||||
|  |         "way_function", | ||||||
|  |         boost::ref(w) | ||||||
|  |     ); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool BaseParser::ShouldIgnoreRestriction(const std::string & except_tag_string) const { | bool BaseParser::ShouldIgnoreRestriction( | ||||||
|  |     const std::string & except_tag_string | ||||||
|  | ) const { | ||||||
|     //should this restriction be ignored? yes if there's an overlap between:
 |     //should this restriction be ignored? yes if there's an overlap between:
 | ||||||
|     //a) the list of modes in the except tag of the restriction (except_tag_string), ex: except=bus;bicycle
 |     // a) the list of modes in the except tag of the restriction
 | ||||||
|     //b) the lua profile defines a hierachy of modes, ex: [access, vehicle, bicycle]
 |     //    (except_tag_string), eg: except=bus;bicycle
 | ||||||
|  |     // b) the lua profile defines a hierachy of modes,
 | ||||||
|  |     //    eg: [access, vehicle, bicycle]
 | ||||||
| 
 | 
 | ||||||
|     if( "" == except_tag_string ) { |     if( except_tag_string.empty() ) { | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -98,8 +120,14 @@ bool BaseParser::ShouldIgnoreRestriction(const std::string & except_tag_string) | |||||||
|     //only a few exceptions are actually defined.
 |     //only a few exceptions are actually defined.
 | ||||||
|     std::vector<std::string> exceptions; |     std::vector<std::string> exceptions; | ||||||
|     boost::algorithm::split_regex(exceptions, except_tag_string, boost::regex("[;][ ]*")); |     boost::algorithm::split_regex(exceptions, except_tag_string, boost::regex("[;][ ]*")); | ||||||
|     BOOST_FOREACH(std::string& str, exceptions) { |     BOOST_FOREACH(std::string& current_string, exceptions) { | ||||||
|         if( restriction_exceptions.end() != std::find(restriction_exceptions.begin(), restriction_exceptions.end(), str) ) { |         std::vector<std::string>::const_iterator string_iterator; | ||||||
|  |         string_iterator = std::find( | ||||||
|  |             restriction_exceptions.begin(), | ||||||
|  |             restriction_exceptions.end(), | ||||||
|  |             current_string | ||||||
|  |         ); | ||||||
|  |         if( restriction_exceptions.end() != string_iterator ) { | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -28,11 +28,6 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |||||||
| #ifndef BASEPARSER_H_ | #ifndef BASEPARSER_H_ | ||||||
| #define BASEPARSER_H_ | #define BASEPARSER_H_ | ||||||
| 
 | 
 | ||||||
| // #include "ExtractorCallbacks.h"
 |  | ||||||
| #include "ScriptingEnvironment.h" |  | ||||||
| #include "../Util/OSRMException.h" |  | ||||||
| #include "../Util/SimpleLogger.h" |  | ||||||
| 
 |  | ||||||
| extern "C" { | extern "C" { | ||||||
|     #include <lua.h> |     #include <lua.h> | ||||||
|     #include <lauxlib.h> |     #include <lauxlib.h> | ||||||
| @ -40,33 +35,40 @@ extern "C" { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #include <boost/noncopyable.hpp> | #include <boost/noncopyable.hpp> | ||||||
|  | #include <string> | ||||||
|  | #include <vector> | ||||||
| 
 | 
 | ||||||
| class ExtractorCallbacks; | class ExtractorCallbacks; | ||||||
|  | class ScriptingEnvironment; | ||||||
| struct ExtractionWay; | struct ExtractionWay; | ||||||
| struct ImportNode; | struct ImportNode; | ||||||
| 
 | 
 | ||||||
| class BaseParser : boost::noncopyable { | class BaseParser : boost::noncopyable { | ||||||
| public: | public: | ||||||
|     BaseParser(ExtractorCallbacks* ec, ScriptingEnvironment& se); |     BaseParser( | ||||||
|  |         ExtractorCallbacks * extractor_callbacks, | ||||||
|  |         ScriptingEnvironment & scripting_environment | ||||||
|  |     ); | ||||||
|     virtual ~BaseParser() {} |     virtual ~BaseParser() {} | ||||||
|     virtual bool ReadHeader() = 0; |     virtual bool ReadHeader() = 0; | ||||||
|     virtual bool Parse() = 0; |     virtual bool Parse() = 0; | ||||||
| 
 | 
 | ||||||
|     virtual void ParseNodeInLua(ImportNode& n, lua_State* luaStateForThread); |     virtual void ParseNodeInLua(ImportNode & n, lua_State* thread_lua_state); | ||||||
|     virtual void ParseWayInLua(ExtractionWay& n, lua_State* luaStateForThread); |     virtual void ParseWayInLua(ExtractionWay & n, lua_State* thread_lua_state); | ||||||
|     virtual void report_errors(lua_State *L, const int status) const; |     virtual void report_errors(lua_State * lua_state, const int status) const; | ||||||
| 
 | 
 | ||||||
| protected: | protected: | ||||||
|     virtual void ReadUseRestrictionsSetting(); |     virtual void ReadUseRestrictionsSetting(); | ||||||
|     virtual void ReadRestrictionExceptions(); |     virtual void ReadRestrictionExceptions(); | ||||||
|     virtual bool ShouldIgnoreRestriction(const std::string& except_tag_string) const; |     virtual bool ShouldIgnoreRestriction( | ||||||
|  |         const std::string & except_tag_string | ||||||
|  |     ) const; | ||||||
| 
 | 
 | ||||||
|     ExtractorCallbacks* extractor_callbacks; |     ExtractorCallbacks     * extractor_callbacks; | ||||||
|     ScriptingEnvironment& scriptingEnvironment; |     lua_State              * lua_state; | ||||||
|     lua_State* luaState; |     ScriptingEnvironment   & scripting_environment; | ||||||
|     std::vector<std::string> restriction_exceptions; |     std::vector<std::string> restriction_exceptions; | ||||||
|     bool use_turn_restrictions; |     bool use_turn_restrictions; | ||||||
| 
 |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| #endif /* BASEPARSER_H_ */ | #endif /* BASEPARSER_H_ */ | ||||||
|  | |||||||
| @ -28,6 +28,8 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |||||||
| #include "ExtractorCallbacks.h" | #include "ExtractorCallbacks.h" | ||||||
| #include "ExtractorStructs.h" | #include "ExtractorStructs.h" | ||||||
| #include "PBFParser.h" | #include "PBFParser.h" | ||||||
|  | #include "ScriptingEnvironment.h" | ||||||
|  | 
 | ||||||
| #include "../DataStructures/HashTable.h" | #include "../DataStructures/HashTable.h" | ||||||
| #include "../Util/MachineInfo.h" | #include "../Util/MachineInfo.h" | ||||||
| #include "../Util/OpenMPWrapper.h" | #include "../Util/OpenMPWrapper.h" | ||||||
| @ -43,7 +45,11 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |||||||
| 
 | 
 | ||||||
| #include <zlib.h> | #include <zlib.h> | ||||||
| 
 | 
 | ||||||
| PBFParser::PBFParser(const char * fileName, ExtractorCallbacks* ec, ScriptingEnvironment& se) : BaseParser( ec, se ) { | PBFParser::PBFParser( | ||||||
|  | 	const char * fileName, | ||||||
|  | 	ExtractorCallbacks* ec, | ||||||
|  | 	ScriptingEnvironment& se | ||||||
|  | ) : BaseParser( ec, se ) { | ||||||
| 	GOOGLE_PROTOBUF_VERIFY_VERSION; | 	GOOGLE_PROTOBUF_VERIFY_VERSION; | ||||||
| 	//TODO: What is the bottleneck here? Filling the queue or reading the stuff from disk?
 | 	//TODO: What is the bottleneck here? Filling the queue or reading the stuff from disk?
 | ||||||
| 	//NOTE: With Lua scripting, it is parsing the stuff. I/O is virtually for free.
 | 	//NOTE: With Lua scripting, it is parsing the stuff. I/O is virtually for free.
 | ||||||
| @ -207,7 +213,7 @@ inline void PBFParser::parseDenseNode(_ThreadData * threadData) { | |||||||
| #pragma omp parallel for schedule ( guided ) | #pragma omp parallel for schedule ( guided ) | ||||||
| 	for(int i = 0; i < number_of_nodes; ++i) { | 	for(int i = 0; i < number_of_nodes; ++i) { | ||||||
| 	    ImportNode &n = extracted_nodes_vector[i]; | 	    ImportNode &n = extracted_nodes_vector[i]; | ||||||
| 	    ParseNodeInLua( n, scriptingEnvironment.getLuaStateForThreadID(omp_get_thread_num()) ); | 	    ParseNodeInLua( n, scripting_environment.getLuaStateForThreadID(omp_get_thread_num()) ); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	BOOST_FOREACH(const ImportNode &n, extracted_nodes_vector) { | 	BOOST_FOREACH(const ImportNode &n, extracted_nodes_vector) { | ||||||
| @ -342,7 +348,7 @@ inline void PBFParser::parseWay(_ThreadData * threadData) { | |||||||
| 		if(2 > w.path.size()) { | 		if(2 > w.path.size()) { | ||||||
|         	continue; |         	continue; | ||||||
|     	} |     	} | ||||||
| 	    ParseWayInLua( w, scriptingEnvironment.getLuaStateForThreadID( omp_get_thread_num()) ); | 	    ParseWayInLua( w, scripting_environment.getLuaStateForThreadID( omp_get_thread_num()) ); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	BOOST_FOREACH(ExtractionWay & w, parsed_way_vector) { | 	BOOST_FOREACH(ExtractionWay & w, parsed_way_vector) { | ||||||
|  | |||||||
| @ -29,6 +29,7 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |||||||
| #include "ExtractorStructs.h" | #include "ExtractorStructs.h" | ||||||
| #include "ScriptingEnvironment.h" | #include "ScriptingEnvironment.h" | ||||||
| #include "../DataStructures/ImportNode.h" | #include "../DataStructures/ImportNode.h" | ||||||
|  | #include "../Util/LuaUtil.h" | ||||||
| #include "../Util/OpenMPWrapper.h" | #include "../Util/OpenMPWrapper.h" | ||||||
| #include "../Util/OSRMException.h" | #include "../Util/OSRMException.h" | ||||||
| #include "../Util/SimpleLogger.h" | #include "../Util/SimpleLogger.h" | ||||||
|  | |||||||
| @ -28,10 +28,10 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |||||||
| #ifndef SCRIPTINGENVIRONMENT_H_ | #ifndef SCRIPTINGENVIRONMENT_H_ | ||||||
| #define SCRIPTINGENVIRONMENT_H_ | #define SCRIPTINGENVIRONMENT_H_ | ||||||
| 
 | 
 | ||||||
| #include "../Util/LuaUtil.h" |  | ||||||
| 
 |  | ||||||
| #include <vector> | #include <vector> | ||||||
| 
 | 
 | ||||||
|  | struct lua_State; | ||||||
|  | 
 | ||||||
| class ScriptingEnvironment { | class ScriptingEnvironment { | ||||||
| public: | public: | ||||||
|     ScriptingEnvironment(); |     ScriptingEnvironment(); | ||||||
|  | |||||||
| @ -64,7 +64,7 @@ bool XMLParser::Parse() { | |||||||
| 
 | 
 | ||||||
| 		if ( xmlStrEqual( currentName, ( const xmlChar* ) "node" ) == 1 ) { | 		if ( xmlStrEqual( currentName, ( const xmlChar* ) "node" ) == 1 ) { | ||||||
| 			ImportNode n = _ReadXMLNode(); | 			ImportNode n = _ReadXMLNode(); | ||||||
| 			ParseNodeInLua( n, luaState ); | 			ParseNodeInLua( n, lua_state ); | ||||||
| 			extractor_callbacks->nodeFunction(n); | 			extractor_callbacks->nodeFunction(n); | ||||||
| //			if(!extractor_callbacks->nodeFunction(n))
 | //			if(!extractor_callbacks->nodeFunction(n))
 | ||||||
| //				std::cerr << "[XMLParser] dense node not parsed" << std::endl;
 | //				std::cerr << "[XMLParser] dense node not parsed" << std::endl;
 | ||||||
| @ -72,7 +72,7 @@ bool XMLParser::Parse() { | |||||||
| 
 | 
 | ||||||
| 		if ( xmlStrEqual( currentName, ( const xmlChar* ) "way" ) == 1 ) { | 		if ( xmlStrEqual( currentName, ( const xmlChar* ) "way" ) == 1 ) { | ||||||
| 			ExtractionWay way = _ReadXMLWay( ); | 			ExtractionWay way = _ReadXMLWay( ); | ||||||
| 			ParseWayInLua( way, luaState ); | 			ParseWayInLua( way, lua_state ); | ||||||
| 			extractor_callbacks->wayFunction(way); | 			extractor_callbacks->wayFunction(way); | ||||||
| //			if(!extractor_callbacks->wayFunction(way))
 | //			if(!extractor_callbacks->wayFunction(way))
 | ||||||
| //				std::cerr << "[PBFParser] way not parsed" << std::endl;
 | //				std::cerr << "[PBFParser] way not parsed" << std::endl;
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user