5#include "absl/flags/declare.h"
6#include "absl/flags/flag.h"
7#include "absl/strings/ascii.h"
8#include "absl/strings/match.h"
9#include "absl/strings/numbers.h"
10#include "absl/strings/str_format.h"
11#include "absl/strings/str_join.h"
31 return absl::OkStatus();
39 return absl::OkStatus();
50 return absl::OkStatus();
57 return absl::FailedPreconditionError(
63 return absl::OkStatus();
67 std::string rom_path = absl::GetFlag(FLAGS_rom);
68 if (!rom_path.empty()) {
71 return absl::FailedPreconditionError(absl::StrFormat(
72 "Failed to load ROM from '%s': %s", rom_path, status.message()));
76 return absl::OkStatus();
79 return absl::FailedPreconditionError(
80 "No ROM loaded. Use --rom=<path> or --mock-rom for testing.");
92 return absl::FailedPreconditionError(
"ROM not loaded");
100 return absl::FailedPreconditionError(
"ROM has no resource label manager");
109 if (labels_status.ok()) {
113 return labels_status;
117 return absl::OkStatus();
128 const std::string& name)
const {
129 std::string flag =
"--" + name;
130 std::string equals_form = flag +
"=";
132 for (
size_t i = 0; i <
args_.size(); ++i) {
133 const std::string& arg =
args_[i];
136 if (absl::StartsWith(arg, equals_form)) {
137 return arg.substr(equals_form.length());
141 if (arg == flag && i + 1 <
args_.size()) {
150 const std::string& name)
const {
156 if (!value.has_value()) {
157 return absl::NotFoundError(
158 absl::StrFormat(
"Argument '--%s' not found", name));
162 if (absl::StartsWith(*value,
"0x") || absl::StartsWith(*value,
"0X")) {
164 if (absl::SimpleHexAtoi(value->substr(2), &result)) {
167 return absl::InvalidArgumentError(
168 absl::StrFormat(
"Invalid hex integer for '--%s': %s", name, *value));
173 if (absl::SimpleAtoi(*value, &result)) {
177 return absl::InvalidArgumentError(
178 absl::StrFormat(
"Invalid integer for '--%s': %s", name, *value));
183 if (!value.has_value()) {
184 return absl::NotFoundError(
185 absl::StrFormat(
"Argument '--%s' not found", name));
189 std::string hex_str = *value;
190 if (absl::StartsWith(hex_str,
"0x") || absl::StartsWith(hex_str,
"0X")) {
191 hex_str = hex_str.substr(2);
195 if (absl::SimpleHexAtoi(hex_str, &result)) {
199 return absl::InvalidArgumentError(
200 absl::StrFormat(
"Invalid hex value for '--%s': %s", name, *value));
204 std::string flag =
"--" + name;
205 for (
const auto& arg :
args_) {
214 std::vector<std::string> positional;
215 for (
size_t i = 0; i <
args_.size(); ++i) {
216 const std::string& arg =
args_[i];
217 if (!absl::StartsWith(arg,
"--")) {
218 positional.push_back(arg);
219 }
else if (arg.find(
'=') == std::string::npos && i + 1 <
args_.size()) {
228 const std::vector<std::string>& required)
const {
229 std::vector<std::string> missing;
230 for (
const auto& arg : required) {
232 missing.push_back(
"--" + arg);
236 if (!missing.empty()) {
237 return absl::InvalidArgumentError(absl::StrFormat(
238 "Missing required arguments: %s", absl::StrJoin(missing,
", ")));
241 return absl::OkStatus();
249 const std::string& format) {
250 std::string lower = absl::AsciiStrToLower(format);
251 if (lower ==
"json") {
253 }
else if (lower ==
"text") {
256 return absl::InvalidArgumentError(absl::StrFormat(
257 "Unknown format: %s (expected 'json' or 'text')", format));
266 }
else if (
IsText() && !title.empty()) {
267 buffer_ += absl::StrFormat(
"=== %s ===\n", title);
281 const std::string& value) {
291 buffer_ += absl::StrFormat(
" %-20s : %s\n", key, value);
304 buffer_ += absl::StrFormat(
" %-20s : %d\n", key, value);
317 buffer_ += absl::StrFormat(
" %-20s : %llu\n", key, value);
329 value ?
"true" :
"false");
331 buffer_ += absl::StrFormat(
" %-20s : %s\n", key, value ?
"yes" :
"no");
344 absl::StrFormat(
"\"%s\": \"0x%0*X\"",
EscapeJson(key), width, value);
346 buffer_ += absl::StrFormat(
" %-20s : 0x%0*X\n", key, width, value);
363 buffer_ += absl::StrFormat(
" %s:\n", key);
386 buffer_ += absl::StrFormat(
" - %s\n", item);
410 result.reserve(str.size() + 10);
437 result += absl::StrFormat(
"\\u%04x",
static_cast<int>(c));
The Rom class is used to load, save, and modify Rom data. This is a generic SNES ROM container and do...
project::ResourceLabelManager * resource_label()
absl::Status LoadFromFile(const std::string &filename, const LoadOptions &options=LoadOptions::Defaults())
std::optional< std::string > FindArgValue(const std::string &name) const
std::vector< std::string > args_
ArgumentParser(const std::vector< std::string > &args)
std::vector< std::string > GetPositional() const
Get all remaining positional arguments.
std::optional< std::string > GetString(const std::string &name) const
Parse a named argument (e.g., –format=json or –format json)
bool HasFlag(const std::string &name) const
Check if a flag is present.
absl::Status RequireArgs(const std::vector< std::string > &required) const
Validate that required arguments are present.
absl::StatusOr< int > GetHex(const std::string &name) const
Parse a hex integer argument.
absl::StatusOr< int > GetInt(const std::string &name) const
Parse an integer argument (supports hex with 0x prefix)
absl::StatusOr< Rom * > GetRom()
Get the ROM instance (loads if not already loaded)
absl::Status EnsureLabelsLoaded(Rom *rom)
Ensure resource labels are loaded.
absl::Status Initialize()
Initialize the context and load ROM if needed.
CommandContext(const Config &config)
ABSL_DECLARE_FLAG(std::string, rom)
absl::Status InitializeMockRom(Rom &rom)
Initialize a mock ROM for testing without requiring an actual ROM file.
Configuration for command context.
std::optional< std::string > rom_path
Rom * external_rom_context
std::unordered_map< std::string, std::unordered_map< std::string, std::string > > labels_
Modern project structure with comprehensive settings consolidation.
std::unordered_map< std::string, std::unordered_map< std::string, std::string > > resource_labels
absl::Status InitializeEmbeddedLabels(const std::unordered_map< std::string, std::unordered_map< std::string, std::string > > &labels)
static std::unordered_map< std::string, std::unordered_map< std::string, std::string > > ToResourceLabels()
Convert all labels to a structured map for project embedding.