Mercurial > hg > orthanc-stone
view Deprecated/Resources/CodeGeneration/testCppHandler/main.cpp @ 1491:c5627b8493f3
merge
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Wed, 24 Jun 2020 17:17:24 +0200 |
parents | 828a9b4ee1b7 |
children |
line wrap: on
line source
/** * Stone of Orthanc * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics * Department, University Hospital of Liege, Belgium * Copyright (C) 2017-2020 Osimis S.A., Belgium * * This program is free software: you can redistribute it and/or * modify it under the terms of the GNU Affero General Public License * as published by the Free Software Foundation, either version 3 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. **/ #include <string> #include <fstream> #include <filesystem> #include <regex> using namespace std; namespace fs = std::filesystem; #include <boost/program_options.hpp> using namespace boost::program_options; #include "TestStoneCodeGen_generated.hpp" /** Transforms `str` by replacing occurrences of `oldStr` with `newStr`, using plain text (*not* regular expressions.) */ static inline void ReplaceInString( string& str, const std::string& oldStr, const std::string& newStr) { std::string::size_type pos = 0u; while ((pos = str.find(oldStr, pos)) != std::string::npos) { str.replace(pos, oldStr.length(), newStr); pos += newStr.length(); } } string SlurpFile(const string& fileName) { ifstream ifs(fileName.c_str(), ios::in | ios::binary | ios::ate); ifstream::pos_type fileSize = ifs.tellg(); ifs.seekg(0, ios::beg); vector<char> bytes(fileSize); ifs.read(bytes.data(), fileSize); return string(bytes.data(), fileSize); } class MyHandler : public TestStoneCodeGen::IHandler { public: virtual bool Handle(const TestStoneCodeGen::A& value) override { TestStoneCodeGen::StoneDumpValue(cout, value); return true; } virtual bool Handle(const TestStoneCodeGen::B& value) override { TestStoneCodeGen::StoneDumpValue(cout, value); return true; } virtual bool Handle(const TestStoneCodeGen::C& value) override { TestStoneCodeGen::StoneDumpValue(cout, value); return true; } virtual bool Handle(const TestStoneCodeGen::Message1& value) override { TestStoneCodeGen::StoneDumpValue(cout, value); return true; } virtual bool Handle(const TestStoneCodeGen::Message2& value) override { TestStoneCodeGen::StoneDumpValue(cout, value); return true; } }; template<typename T> void ProcessPath(T filePath) { cout << "+--------------------------------------------+\n"; cout << "| Processing: " << filePath.path().string() << "\n"; cout << "+--------------------------------------------+\n"; MyHandler handler; auto contents = SlurpFile(filePath.path().string()); TestStoneCodeGen::StoneDispatchToHandler(contents, &handler); } int main(int argc, char** argv) { try { options_description desc("Allowed options"); desc.add_options() // First parameter describes option name/short name // The second is parameter to option // The third is description ("help,h", "print usage message") ("pattern,p", value<string>(), "pattern for input") ; variables_map vm; store(parse_command_line(argc, argv, desc), vm); if (vm.count("help")) { cout << desc << "\n"; return 0; } notify(vm); string pattern = vm["pattern"].as<string>(); // tranform globbing pattern into regex // we should deal with -, ., *... string regexPatternStr = pattern; cout << "Pattern is: " << regexPatternStr << endl; ReplaceInString(regexPatternStr, "\\", "\\\\"); ReplaceInString(regexPatternStr, "-", "\\-"); ReplaceInString(regexPatternStr, ".", "\\."); ReplaceInString(regexPatternStr, "*", ".*"); ReplaceInString(regexPatternStr, "?", "."); cout << "Corresponding regex is: " << regexPatternStr << endl; regex regexPattern(regexPatternStr); for (auto& p : fs::directory_iterator(".")) { auto fileName = p.path().filename().string(); if (regex_match(fileName, regexPattern)) { ProcessPath(p); } } return 0; } catch (exception& e) { cerr << e.what() << "\n"; } }