Use the Lexesis-file in the same directory as Parsodus-file
This commit is contained in:
		
							parent
							
								
									ecc187c51b
								
							
						
					
					
						commit
						a0ab7722b6
					
				|  | @ -18,12 +18,12 @@ namespace pds { | ||||||
|              * Constructor |              * Constructor | ||||||
|              * |              * | ||||||
|              * @param backends The backendmanager, prepared with all needed supported backends |              * @param backends The backendmanager, prepared with all needed supported backends | ||||||
|              * @param inputfile An istream which should be read to be used as token rules specifications |              * @param inputfile A string containing the path of the `pds` file. | ||||||
|              * @param outputdir A string representing the directory where generated files should be places |              * @param outputdir A string representing the directory where generated files should be places | ||||||
|              * @param language The language to generate output for (backends is queried for this language) |              * @param language The language to generate output for (backends is queried for this language) | ||||||
|              * @param parsername The name to give to the generated parser, this gets cleaned to only contains alphanumeric chars or underscore and start with a non-digit (AKA a valid identifier) |              * @param parsername The name to give to the generated parser, this gets cleaned to only contains alphanumeric chars or underscore and start with a non-digit (AKA a valid identifier) | ||||||
|              */ |              */ | ||||||
|             Driver(std::unique_ptr<BackendManager> backends, std::istream& inputfile, std::string outputdir, std::string language, std::string parsername, bool debug=true); |             Driver(std::unique_ptr<BackendManager> backends, std::string inputfile, std::string outputdir, std::string language, std::string parsername, bool debug=true); | ||||||
| 
 | 
 | ||||||
|             /**
 |             /**
 | ||||||
|              * Destructor |              * Destructor | ||||||
|  | @ -39,7 +39,7 @@ namespace pds { | ||||||
| 
 | 
 | ||||||
|         private: |         private: | ||||||
|             std::unique_ptr<BackendManager> m_backends; |             std::unique_ptr<BackendManager> m_backends; | ||||||
|             std::istream& m_inputfile; |             std::string m_inputfile; | ||||||
|             std::string m_outputdir; |             std::string m_outputdir; | ||||||
|             std::string m_language; |             std::string m_language; | ||||||
|             std::string m_parsername; |             std::string m_parsername; | ||||||
|  |  | ||||||
|  | @ -11,7 +11,7 @@ namespace pds { | ||||||
|     class InputParser { |     class InputParser { | ||||||
|         public: |         public: | ||||||
| 
 | 
 | ||||||
|             static Config parseInput(std::istream& is); |             static Config parseInput(std::istream& is, std::string current_dir); | ||||||
|              |              | ||||||
|     }; |     }; | ||||||
|      |      | ||||||
|  |  | ||||||
|  | @ -10,12 +10,20 @@ | ||||||
| #include <sys/stat.h> | #include <sys/stat.h> | ||||||
| 
 | 
 | ||||||
| #if defined(_WIN32) | #if defined(_WIN32) | ||||||
|  | 
 | ||||||
| #include <io.h> | #include <io.h> | ||||||
| #define isatty(x) _isatty(x) | #define isatty(x) _isatty(x) | ||||||
| #define fileno(x) _fileno(x) | #define fileno(x) _fileno(x) | ||||||
|  | #define mkdir(x) _mkdir(x) | ||||||
| #include <direct.h>   | #include <direct.h>   | ||||||
|  | #define PATHSEP '\\' | ||||||
|  | 
 | ||||||
| #else | #else | ||||||
|  | 
 | ||||||
|  | #define mkdir(x) mkdir(x, 0755) | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
|  | #define PATHSEP '/' | ||||||
|  | 
 | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| namespace { | namespace { | ||||||
|  | @ -31,6 +39,28 @@ namespace { | ||||||
|         return s; |         return s; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  |     std::string stripDirectory(std::string filename) { | ||||||
|  |         std::string dir = filename; | ||||||
|  | 
 | ||||||
|  |         std::size_t pos; | ||||||
|  |         // '/' can be used on most platforms (even windows)
 | ||||||
|  |         pos = dir.find_last_of('/'); | ||||||
|  |         if (pos != dir.npos) { | ||||||
|  |             dir = dir.substr(0,pos + 1); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // strip platform specific as well
 | ||||||
|  |         pos = dir.find_last_of(PATHSEP); | ||||||
|  |         if (pos != dir.npos) { | ||||||
|  |             dir = dir.substr(0,pos + 1); | ||||||
|  |         } | ||||||
|  |         if(dir == filename) { | ||||||
|  |             dir = ""; | ||||||
|  |         } | ||||||
|  |         return dir; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     /**
 |     /**
 | ||||||
|      * G3Log sink |      * G3Log sink | ||||||
|      */ |      */ | ||||||
|  | @ -63,7 +93,7 @@ namespace { | ||||||
| 
 | 
 | ||||||
| namespace pds { | namespace pds { | ||||||
|      |      | ||||||
|     Driver::Driver(std::unique_ptr<BackendManager> backends, std::istream& inputfile, std::string outputdir, std::string language, std::string parsername, bool debug): |     Driver::Driver(std::unique_ptr<BackendManager> backends, std::string inputfile, std::string outputdir, std::string language, std::string parsername, bool debug): | ||||||
|         m_backends(std::move(backends)), m_inputfile(inputfile), m_outputdir(outputdir), m_language(language), m_parsername(clean(parsername)), m_debug(debug) { |         m_backends(std::move(backends)), m_inputfile(inputfile), m_outputdir(outputdir), m_language(language), m_parsername(clean(parsername)), m_debug(debug) { | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | @ -73,11 +103,7 @@ namespace pds { | ||||||
|         struct stat sb; |         struct stat sb; | ||||||
|         if(stat(m_outputdir.c_str(), &sb) != 0) { |         if(stat(m_outputdir.c_str(), &sb) != 0) { | ||||||
|             int status;  |             int status;  | ||||||
| #if defined(_WIN32) |             status = mkdir(m_outputdir.c_str()); | ||||||
|             status = _mkdir(m_outputdir.c_str()); |  | ||||||
| #else |  | ||||||
|             status = mkdir(m_outputdir.c_str(), 0755); |  | ||||||
| #endif |  | ||||||
|             if(status !=0 && errno != EEXIST){ |             if(status !=0 && errno != EEXIST){ | ||||||
|                 throw DriverException("The folder " + m_outputdir + " does not exist and we're unable to create it."); |                 throw DriverException("The folder " + m_outputdir + " does not exist and we're unable to create it."); | ||||||
|             } |             } | ||||||
|  | @ -91,7 +117,17 @@ namespace pds { | ||||||
|         g3::initializeLogging(logworker.get()); |         g3::initializeLogging(logworker.get()); | ||||||
| 
 | 
 | ||||||
|         if (!m_parsername.length()) throw DriverException("no valid parser name possible");  |         if (!m_parsername.length()) throw DriverException("no valid parser name possible");  | ||||||
|         Config config = InputParser::parseInput(m_inputfile);        | 
 | ||||||
|  |          | ||||||
|  |         /* Open parsodus config file, if possible */ | ||||||
|  |         std::ifstream infile(m_inputfile); | ||||||
|  |         if (!infile.good()) { | ||||||
|  |             LOG(WARNING) << "Could not open file '" << m_inputfile << "' for reading" << std::endl; | ||||||
|  |             return 1; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |          | ||||||
|  |         Config config = InputParser::parseInput(infile, stripDirectory(m_inputfile));        | ||||||
|         Backend* back = m_backends->findBackend(m_language, config.parserType); |         Backend* back = m_backends->findBackend(m_language, config.parserType); | ||||||
|         if (!back) throw DriverException("Could not find a valid backend for language " + m_language + " and parser type: " + config.parserType); |         if (!back) throw DriverException("Could not find a valid backend for language " + m_language + " and parser type: " + config.parserType); | ||||||
| 		back->generateParser([this](std::string filename) -> std::unique_ptr<std::ostream> { | 		back->generateParser([this](std::string filename) -> std::unique_ptr<std::ostream> { | ||||||
|  |  | ||||||
|  | @ -14,13 +14,13 @@ namespace pds { | ||||||
|     const char* InputParserException::what() const throw() { |     const char* InputParserException::what() const throw() { | ||||||
|             return m_what.c_str(); |             return m_what.c_str(); | ||||||
|     }    |     }    | ||||||
|     Config InputParser::parseInput(std::istream& is) { |     Config InputParser::parseInput(std::istream& is, std::string current_dir) { | ||||||
|         ParsodusLexer lex(is); |         ParsodusLexer lex(is); | ||||||
|         Parser parser(lex); |         Parser parser(lex); | ||||||
|      |      | ||||||
|         Config cnf = *parser.parse();    |         Config cnf = *parser.parse();    | ||||||
|         if (!cnf.lexesisFile.empty()) { |         if (!cnf.lexesisFile.empty()) { | ||||||
| 			std::fstream file(cnf.lexesisFile); | 			std::fstream file(current_dir + cnf.lexesisFile); | ||||||
|             auto terminals = lxs::input::InputParser::getTokens(file); |             auto terminals = lxs::input::InputParser::getTokens(file); | ||||||
|             for(auto& terminal : terminals) |             for(auto& terminal : terminals) | ||||||
|                 cnf.grammar.terminals.insert(terminal); |                 cnf.grammar.terminals.insert(terminal); | ||||||
|  |  | ||||||
|  | @ -26,13 +26,6 @@ int main(int argc, char** argv) { | ||||||
|         return 1; |         return 1; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* Open parsodus config file, if possible */ |  | ||||||
|     std::ifstream infile(args[0]); |  | ||||||
|     if (!infile.good()) { |  | ||||||
|         std::cerr << "Could not open file '" << args[0] << "' for reading" << std::endl; |  | ||||||
|         return 1; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| #ifdef _WIN32 | #ifdef _WIN32 | ||||||
|     const char PATHSEP = '\\'; |     const char PATHSEP = '\\'; | ||||||
| #else | #else | ||||||
|  | @ -69,7 +62,7 @@ int main(int argc, char** argv) { | ||||||
| 
 | 
 | ||||||
|     /* Create parserfile, if possible */ |     /* Create parserfile, if possible */ | ||||||
|     try { |     try { | ||||||
|         pds::Driver driver(std::move(backendManager), infile, options["outputdir"], options["language"], parsername, options.get("debug")); |         pds::Driver driver(std::move(backendManager), args[0], options["outputdir"], options["language"], parsername, options.get("debug")); | ||||||
|         return driver.run(); |         return driver.run(); | ||||||
|     } catch (std::exception &err) { |     } catch (std::exception &err) { | ||||||
|         std::cout << err.what() << std::endl; |         std::cout << err.what() << std::endl; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue