yaze 0.3.2
Link to the Past ROM Editor
 
Loading...
Searching...
No Matches
hex_commands.h
Go to the documentation of this file.
1#ifndef YAZE_SRC_CLI_HANDLERS_HEX_COMMANDS_H_
2#define YAZE_SRC_CLI_HANDLERS_HEX_COMMANDS_H_
3
5
6namespace yaze {
7namespace cli {
8namespace handlers {
9
14 public:
15 std::string GetName() const { return "hex-read"; }
16 std::string GetDescription() const {
17 return "Read hex data from ROM at specified address";
18 }
19 std::string GetUsage() const {
20 return "hex-read --address <address> [--length <length>] [--format <format>]";
21 }
22
23 absl::Status ValidateArgs(const resources::ArgumentParser& parser) override {
24 return parser.RequireArgs({"address"});
25 }
26
27 absl::Status Execute(Rom* rom, const resources::ArgumentParser& parser,
28 resources::OutputFormatter& formatter) override;
29};
30
35 public:
36 std::string GetName() const { return "hex-write"; }
37 std::string GetDescription() const {
38 return "Write hex data to ROM at specified address";
39 }
40 std::string GetUsage() const {
41 return "hex-write --address <address> --data <data>";
42 }
43
44 absl::Status ValidateArgs(const resources::ArgumentParser& parser) override {
45 return parser.RequireArgs({"address", "data"});
46 }
47
48 absl::Status Execute(Rom* rom, const resources::ArgumentParser& parser,
49 resources::OutputFormatter& formatter) override;
50};
51
56 public:
57 std::string GetName() const { return "hex-search"; }
58 std::string GetDescription() const {
59 return "Search for hex patterns in ROM";
60 }
61 std::string GetUsage() const {
62 return "hex-search --pattern <pattern> [--start <start>] [--end <end>]";
63 }
64
65 absl::Status ValidateArgs(const resources::ArgumentParser& parser) override {
66 return parser.RequireArgs({"pattern"});
67 }
68
69 absl::Status Execute(Rom* rom, const resources::ArgumentParser& parser,
70 resources::OutputFormatter& formatter) override;
71};
72
73} // namespace handlers
74} // namespace cli
75} // namespace yaze
76
77#endif // YAZE_SRC_CLI_HANDLERS_HEX_COMMANDS_H_
The Rom class is used to load, save, and modify Rom data.
Definition rom.h:71
Command handler for reading hex data from ROM.
std::string GetUsage() const
Get the command usage string.
absl::Status ValidateArgs(const resources::ArgumentParser &parser) override
Validate command arguments.
absl::Status Execute(Rom *rom, const resources::ArgumentParser &parser, resources::OutputFormatter &formatter) override
Execute the command business logic.
std::string GetName() const
Get the command name.
Command handler for searching hex patterns in ROM.
absl::Status Execute(Rom *rom, const resources::ArgumentParser &parser, resources::OutputFormatter &formatter) override
Execute the command business logic.
std::string GetName() const
Get the command name.
std::string GetUsage() const
Get the command usage string.
absl::Status ValidateArgs(const resources::ArgumentParser &parser) override
Validate command arguments.
Command handler for writing hex data to ROM.
std::string GetUsage() const
Get the command usage string.
absl::Status ValidateArgs(const resources::ArgumentParser &parser) override
Validate command arguments.
absl::Status Execute(Rom *rom, const resources::ArgumentParser &parser, resources::OutputFormatter &formatter) override
Execute the command business logic.
std::string GetName() const
Get the command name.
Utility for parsing common CLI argument patterns.
absl::Status RequireArgs(const std::vector< std::string > &required) const
Validate that required arguments are present.
Base class for CLI command handlers.
Utility for consistent output formatting across commands.
Main namespace for the application.