/* * Copyright (c) 2021, Linus Groh * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include #include #include ErrorOr format_file(StringView, bool); ErrorOr format_file(StringView path, bool inplace) { auto read_from_stdin = path == "-"; RefPtr file; if (read_from_stdin) { file = Core::File::standard_input(); } else { auto open_mode = inplace ? Core::OpenMode::ReadWrite : Core::OpenMode::ReadOnly; file = TRY(Core::File::open(path, open_mode)); } auto contents = file->read_all(); auto formatted_gml_or_error = GUI::GML::format_gml(contents); if (formatted_gml_or_error.is_error()) { warnln("Failed to parse GML: {}", formatted_gml_or_error.error()); return false; } auto formatted_gml = formatted_gml_or_error.release_value(); if (inplace && !read_from_stdin) { if (formatted_gml == contents) return true; if (!file->seek(0) || !file->truncate(0)) { warnln("Could not truncate {}: {}", path, file->error_string()); return false; } if (!file->write(formatted_gml)) { warnln("Could not write to {}: {}", path, file->error_string()); return false; } } else { out("{}", formatted_gml); } return formatted_gml == contents; } ErrorOr serenity_main(Main::Arguments args) { #ifdef __serenity__ TRY(Core::System::pledge("stdio rpath wpath cpath")); #endif bool inplace = false; Vector files; Core::ArgsParser args_parser; args_parser.set_general_help("Format GML files."); args_parser.add_option(inplace, "Write formatted contents back to file rather than standard output", "inplace", 'i'); args_parser.add_positional_argument(files, "File(s) to process", "path", Core::ArgsParser::Required::No); args_parser.parse(args); #ifdef __serenity__ if (!inplace) TRY(Core::System::pledge("stdio rpath")); #endif if (files.is_empty()) files.append("-"); auto formatting_changed = false; for (auto& file : files) { if (!TRY(format_file(file, inplace))) formatting_changed = true; } if (formatting_changed) { dbgln("Some GML formatting issues were encountered."); return 1; } return 0; }