/***************************************************************************************** * * * OpenSpace * * * * Copyright (c) 2014-2018 * * * * Permission is hereby granted, free of charge, to any person obtaining a copy of this * * software and associated documentation files (the "Software"), to deal in the Software * * without restriction, including without limitation the rights to use, copy, modify, * * merge, publish, distribute, sublicense, and/or sell copies of the Software, and to * * permit persons to whom the Software is furnished to do so, subject to the following * * conditions: * * * * The above copyright notice and this permission notice shall be included in all copies * * or substantial portions of the Software. * * * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, * * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A * * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT * * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF * * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE * * OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * ****************************************************************************************/ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include namespace { const std::string ConfigurationFile = "openspace.cfg"; const std::string _loggerCat = "TaskRunner Main"; } void initTextureReaders() { #ifdef GHOUL_USE_DEVIL ghoul::io::TextureReader::ref().addReader( std::make_unique() ); #endif // GHOUL_USE_DEVIL #ifdef GHOUL_USE_FREEIMAGE ghoul::io::TextureReader::ref().addReader( std::make_unique() ); #endif // GHOUL_USE_FREEIMAGE } void performTasks(const std::string& path) { using namespace openspace; TaskLoader taskLoader; std::vector> tasks = taskLoader.tasksFromFile(path); size_t nTasks = tasks.size(); if (nTasks == 1) { LINFO("Task queue has 1 item"); } else { LINFO(fmt::format("Task queue has {} items", tasks.size())); } for (size_t i = 0; i < tasks.size(); i++) { Task& task = *tasks[i].get(); LINFO(fmt::format( "Performing task {} out of {}: {}", i + 1, tasks.size(), task.description() )); ProgressBar progressBar(100); auto onProgress = [&progressBar](float progress) { progressBar.print(static_cast(progress * 100.f)); }; task.perform(onProgress); } std::cout << "Done performing tasks." << std::endl; } int main(int argc, char** argv) { using namespace openspace; ghoul::initialize(); std::string configFile = configuration::findConfiguration(); global::configuration = configuration::loadConfigurationFromFile(configFile); openspace::global::openSpaceEngine.registerPathTokens(); global::openSpaceEngine.initialize(); ghoul::cmdparser::CommandlineParser commandlineParser( "OpenSpace TaskRunner", ghoul::cmdparser::CommandlineParser::AllowUnknownCommands::Yes ); std::string tasksPath = ""; commandlineParser.addCommand( std::make_unique>( tasksPath, "--task", "-t", "Provides the path to a task file to execute" ) ); commandlineParser.setCommandLine({ argv, argv + argc }); commandlineParser.execute(); //FileSys.setCurrentDirectory(launchDirectory); if (tasksPath != "") { performTasks(tasksPath); return 0; } // If no task file was specified in as argument, run in CLI mode. LINFO(fmt::format("Task root: {}", absPath("${TASKS}"))); FileSys.setCurrentDirectory(ghoul::filesystem::Directory(absPath("${TASKS}"))); std::cout << "TASK > "; while (std::cin >> tasksPath) { performTasks(tasksPath); std::cout << "TASK > "; } return 0; };