/* Copyright 2015, Michele Santullo * This file is part of "dindexer". * * "dindexer" is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * "dindexer" 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with "dindexer". If not, see . */ #include "commandline.hpp" #include "dindexerConfig.h" #include "helpers/lengthof.h" #include #include #include #define STRINGIZE_IMPL(s) #s #define STRINGIZE(s) STRINGIZE_IMPL(s) namespace po = boost::program_options; namespace din { namespace { const char g_allowed_types[] = { static_cast(MediaType_CDRom), static_cast(MediaType_Directory), static_cast(MediaType_DVD), static_cast(MediaType_BluRay), static_cast(MediaType_FloppyDisk), static_cast(MediaType_HardDisk), static_cast(MediaType_IomegaZip), static_cast(MediaType_Other) }; const char* const g_version_string = PROGRAM_NAME " v" STRINGIZE(VERSION_MAJOR) "." STRINGIZE(VERSION_MINOR) "." STRINGIZE(VERSION_PATCH) #if VERSION_BETA "b" #endif ; } //unnamed namespace bool parse_commandline (int parArgc, char* parArgv[], po::variables_map& parVarMap) { std::string type_param_help; { std::ostringstream oss; oss << "Default set type. Valid values are "; oss << g_allowed_types[0]; for (std::size_t z = 1; z < lengthof(g_allowed_types); ++z) { oss << ", " << g_allowed_types[z]; } oss << '.'; #if defined(WITH_MEDIA_AUTODETECT) oss << " Default is 'autodetect'."; #endif type_param_help = oss.str(); } po::options_description desc("General"); desc.add_options() ("help,h", "Produces this help message") ("version", "Prints the program's version and quits") //("dump-raw,D", po::value(), "Saves the retrieved html to the named file; use - for stdout") #if defined(WITH_PROGRESS_FEEDBACK) ("quiet,q", "Hide progress messages and print nothing at all") #endif ; po::options_description set_options("Set options"); set_options.add_options() ("setname,n", po::value()->default_value("New set"), "Name to be given to the new set being scanned.") #if defined(WITH_MEDIA_AUTODETECT) ("type,t", po::value(), type_param_help.c_str()) #else ("type,t", po::value()->default_value('V'), type_param_help.c_str()) #endif ("ignore-errors", "Move on even if reading a file fails. Unreadable files are marked as such in the db.") ; po::options_description positional_options("Positional options"); positional_options.add_options() ("search-path", po::value(), "Search path") ; po::options_description all("Available options"); all.add(desc).add(positional_options).add(set_options); po::positional_options_description pd; pd.add("search-path", 1);//.add("xpath", 1); try { po::store(po::command_line_parser(parArgc, parArgv).options(all).positional(pd).run(), parVarMap); } catch (const po::unknown_option& err) { throw std::invalid_argument(err.what()); } po::notify(parVarMap); if (parVarMap.count("help")) { #if !defined(NDEBUG) std::cout << "*******************\n"; std::cout << "*** DEBUG BUILD ***\n"; std::cout << "*******************\n"; std::cout << '\n'; #endif po::options_description visible("Available options"); visible.add(desc).add(set_options); std::cout << PROGRAM_NAME << " Copyright (C) 2015 Michele Santullo\n"; std::cout << "This program comes with ABSOLUTELY NO WARRANTY.\n"; //for details type `show w'. std::cout << "This is free software, and you are welcome to\n"; std::cout << "redistribute it under certain conditions.\n"; //type `show c' for details. std::cout << '\n'; std::cout << "Usage: " << PROGRAM_NAME << " [options...] \n"; std::cout << visible; return true; } else if (parVarMap.count("version")) { std::cout << g_version_string << '\n'; return true; } if (parVarMap.count("search-path") == 0) { throw std::invalid_argument("No search path specified"); } #if defined(WITH_MEDIA_AUTODETECT) if (parVarMap.count("type")) { #endif if (g_allowed_types + lengthof(g_allowed_types) == std::find(g_allowed_types, g_allowed_types + lengthof(g_allowed_types), parVarMap["type"].as())) { throw std::invalid_argument("Invalid value for parameter \"type\""); } #if defined(WITH_MEDIA_AUTODETECT) } #endif return false; } } //namespace din