Allow `{patch offset length}` (necessary for pokegold)

This commit is contained in:
Rangi 2022-03-12 22:50:42 -05:00
parent f33a041930
commit 732acf1d4f
2 changed files with 13 additions and 5 deletions

View File

@ -88,11 +88,11 @@ Any other characters are output as-is.
## Patch template commands ## Patch template commands
### <code>{patch[ <i>offset</i>]}</code> ### <code>{patch[ <i>offset</i>[ <i>length</i>]]}</code>
Outputs the bytes of the current patch as a value series, or as a hexadecimal number if there is only one byte. The bytes are found between the current patch label, and the label which is the current patch label plus "`_End`". An optional argument is an *offset* to add to the current patch label before gathering the contents between it and the end label. Outputs the bytes of the current patch as a value series, or as a hexadecimal number if there is only one byte. The bytes are found between the current patch label, and the label which is the current patch label plus "`_End`". An optional first argument is an *offset* to add to the current patch label before gathering the contents between it and the end label. An optional second argument is a *length* of bytes to output instead of the length between the start and end labels.
For example, if "`{patch}`" outputs "`a3:ab cd ef`", then "`{patch +1}`" outputs "`a2:cd ef`", and "`{patch +2}`" outputs "`0xef`". For example, if "`{patch}`" outputs "`a3:ab cd ef`", then "`{patch +1}`" outputs "`a2:cd ef`", and "`{patch +1 1}`" outputs "`0xcd`".
Converting the patch template will print a warning if any differences exist between the original and patched ROMs, which are not covered by "`patch`" commands. Converting the patch template will print a warning if any differences exist between the original and patched ROMs, which are not covered by "`patch`" commands.

View File

@ -214,6 +214,9 @@ void interpret_command(char *command, const struct Symbol *current_hook, const s
// Use the arguments // Use the arguments
if (!strcmp(command, "patch") || !strcmp(command, "PATCH") || !strcmp(command, "patch_") || !strcmp(command, "PATCH_")) { if (!strcmp(command, "patch") || !strcmp(command, "PATCH") || !strcmp(command, "patch_") || !strcmp(command, "PATCH_")) {
if (argc > 2) {
error_exit("Error: Invalid arguments for command: \"%s\"", command);
}
if (!current_hook) { if (!current_hook) {
error_exit("Error: No current patch for command: \"%s\"", command); error_exit("Error: No current patch for command: \"%s\"", command);
} }
@ -224,8 +227,13 @@ void interpret_command(char *command, const struct Symbol *current_hook, const s
if (fseek(new_rom, current_offset, SEEK_SET)) { if (fseek(new_rom, current_offset, SEEK_SET)) {
error_exit("Error: Cannot seek to \"vc_patch %s\" in the new ROM\n", current_hook->name); error_exit("Error: Cannot seek to \"vc_patch %s\" in the new ROM\n", current_hook->name);
} }
int length;
if (argc == 2) {
length = parse_number(argv[1], 0);
} else {
const struct Symbol *current_hook_end = symbol_find_cat(symbols, current_hook->name, "_End"); const struct Symbol *current_hook_end = symbol_find_cat(symbols, current_hook->name, "_End");
int length = current_hook_end->offset - current_offset; length = current_hook_end->offset - current_offset;
}
buffer_append(patches, &(struct Patch){current_offset, length}); buffer_append(patches, &(struct Patch){current_offset, length});
bool modified = false; bool modified = false;
if (length == 1) { if (length == 1) {