#ifndef ARGPARSER_HPP #define ARGPARSER_HPP #include #include #include class ArgParser { public: ArgParser() : m_print_to_console(false) , m_print_timestamp(false) , m_logFile() {} void printUsage(bool cout = true) { std::ostringstream oss; oss << "Usage: cpplogger [OPTION]\n" << "Logs the input (till EOF) to the console or to a file.\n" << "\n" << "Options:\n" << " -t, prefix lines with timestamp\n" << " -c, log to console\n" << " -f FILE log to FILE\n" << " -h print this help\n" << "\n" << "Option -c and -f are mutually exclusive.\n" << "\n" << "Denes Matetelki \n"; if (cout) std::cout << oss.str(); else std::cerr << oss.str(); } int parse(int argc, char* argv[]) { int c; while ((c = getopt (argc, argv, "ctf:h")) != -1) { switch (c) { case 'c': m_print_to_console = true; break; case 't': m_print_timestamp = true; break; case 'f': m_logFile = std::string(optarg); break; case 'h': printUsage(); return EXIT_SUCCESS; default: printUsage(false); return EXIT_FAILURE; } } if ((m_print_to_console && !m_logFile.empty()) || (!m_print_to_console && m_logFile.empty())) { printUsage(false); return EXIT_FAILURE; } return -1; } bool printToConsole() const { return m_print_to_console; } bool printTimestamp() const { return m_print_timestamp; } std::string logFile() const { return m_logFile; } private: int m_argc; char** m_argv; bool m_print_to_console; bool m_print_timestamp; std::string m_logFile; }; #define LOG *Logger::getInstance()->getStream() #endif // ARGPARSER_HPP