#include #include #include "simdjson.h" SIMDJSON_PUSH_DISABLE_ALL_WARNINGS #ifndef __cpp_exceptions #define CXXOPTS_NO_EXCEPTIONS #endif #include "cxxopts.hpp" SIMDJSON_POP_DISABLE_WARNINGS int main(int argc, char *argv[]) { #ifdef __cpp_exceptions try { #endif std::string progName = "json2json"; std::string progUsage = "json2json version "; progUsage += STRINGIFY(SIMDJSON_VERSION); progUsage += " ("; progUsage += simdjson::active_implementation->name(); progUsage += ")\n"; progUsage += "Reads json in, out the result of the parsing.\n"; progUsage += argv[0]; progUsage += " \n"; cxxopts::Options options(progName, progUsage); options.add_options() ("d,rawdump", "Dumps the raw content of the tape.", cxxopts::value()->default_value("false")) ("f,file", "File name.", cxxopts::value()) ("h,help", "Print usage.") ; // the first argument without an option name will be parsed into file options.parse_positional({"file"}); auto result = options.parse(argc, argv); if(result.count("help")) { std::cerr << options.help() << std::endl; return EXIT_SUCCESS; } bool rawdump = result["rawdump"].as(); if(!result.count("file")) { std::cerr << "No filename specified." << std::endl; std::cerr << options.help() << std::endl; return EXIT_FAILURE; } const char *filename = result["file"].as().c_str(); simdjson::dom::parser parser; simdjson::dom::element doc; auto error = parser.load(filename).get(doc); // do the parsing, return false on error if (error) { std::cerr << " Parsing failed. Error is '" << error << "'." << std::endl; return EXIT_FAILURE; } if(rawdump) { doc.dump_raw_tape(std::cout); } else { std::cout << doc; } return EXIT_SUCCESS; #ifdef __cpp_exceptions } catch (const cxxopts::OptionException& e) { std::cout << "error parsing options: " << e.what() << std::endl; return EXIT_FAILURE; } #endif }