diff options
author | ISSOtm <eldredhabert0@gmail.com> | 2018-05-29 16:28:23 +0200 |
---|---|---|
committer | ISSOtm <eldredhabert0@gmail.com> | 2018-05-29 16:28:23 +0200 |
commit | cc4a3e7fe52b043900d7b2f9789cfe3cf1154f77 (patch) | |
tree | 19b29c88a95b8e444246c6f115da3f75654d1146 /tools/dump_text.py | |
parent | 39c56be66f34870fdcf0730163b13483f72e2c11 (diff) |
Add text extractor
Diffstat (limited to 'tools/dump_text.py')
-rw-r--r-- | tools/dump_text.py | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/tools/dump_text.py b/tools/dump_text.py new file mode 100644 index 0000000..9ba6687 --- /dev/null +++ b/tools/dump_text.py @@ -0,0 +1,50 @@ +#!/usr/bin/python3 + +from sys import argv, stdout + + +char_table = [ + "?", "イ゛", "ヴ", "エ゛", "オ゛", "ガ", "ギ", "グ", "ゲ", "ゴ", "ザ", "ジ", "ズ", "ゼ", "ゾ", "ダ", + "ヂ", "ヅ", "デ", "ド", "<PLAY_G>", "<0x15>", "<0x16>", "ネ゛", "ノ゛", "バ", "ビ", "ブ", "ボ", "<NI>", "<TTE>", "¯", + "ィ゛", "あ゛", "<LNBRK>", "<KOUGEKI>", "<POKE>", "%", "が", "ぎ", "ぐ", "げ", "ご", "ざ", "じ", "ず", "ぜ", "ぞ", + "だ", "ぢ", "づ", "で", "ど", "<ROUTE>", "<WATASHI>", "<KOKO_WA>", "<RED>", "<GREEN>", "ば", "び", "ぶ", "べ", "ぼ", "<ENEMY>", + "パ", "ピ", "プ", "ポ", "ぱ", "ぴ", "ぷ", "ぺ", "ぽ", "<MOM>", "<PKMN>", "<_CONT>", "<SCROLL>", "も゜", "<NEXT>", "<LINE>", + "@", "<PARA>", "<PLAYER>", "<RIVAL>", "#", "<CONT>", "<……>", "<DONE>", "<PROMPT>", "<TARGET>", "<USER>", "<PC>", "<TM>", "<TRAINER>", "<ROCKET>", "<DEXEND>", + "■", "▲", "☎", "D", "E", "F", "G", "H", "I", "V", "S", "L", "M", ":", "ぃ", "ぅ", + "「", "」", "『", "』", "・", "<・・・>", "ぁ", "ぇ", "ぉ", "<border top-left>", "<border horiz>", "<border top-right>", "<border vert>", "<border bottom-left>", "<border bottom-right>", " ", + "ア", "イ", "ウ", "エ", "オ", "カ", "キ", "ク", "ケ", "コ", "サ", "シ", "ス", "セ", "ソ", "タ", + "チ", "ツ", "テ", "ト", "ナ", "ニ", "ヌ", "ネ", "ノ", "ハ", "ヒ", "フ", "ホ", "マ", "ミ", "ム", + "メ", "モ", "ヤ", "ユ", "ヨ", "ラ", "ル", "レ", "ロ", "ワ", "ヲ", "ン", "ッ", "ャ", "ュ", "ョ", + "ィ", "あ", "い", "う", "え", "お", "か", "き", "く", "け", "こ", "さ", "し", "す", "せ", "そ", + "た", "ち", "つ", "て", "と", "な", "に", "ぬ", "ね", "の", "は", "ひ", "ふ", "へ", "ほ", "ま", + "み", "む", "め", "も", "や", "ゆ", "よ", "ら", "り", "る", "れ", "ろ", "わ", "を", "ん", "っ", + "ゃ", "ゅ", "ょ", "ー", "゜", "゛", "?", "!", "。", "ァ", "ゥ", "ェ", "▷", "▶", "▼", "♂", + "円", "×", ".", "/", "ォ", "♀", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9" +] + +if len(argv) != 4: + print(f"Usage: {argv[0]} path/to/ROM.gb start_offset end_offset\noffsets are in the form bank:address (both hex), and end_offset is *not* included.") + exit(1) + + +try: + start_bank,start_addr = [ int(s, 16) for s in argv[2].split(':') ] + end_bank, end_addr = [ int(s, 16) for s in argv[3].split(':') ] + if start_bank != 0: + start_addr += (start_bank - 1) * 0x4000 + if end_bank != 0: + end_addr += (end_bank - 1) * 0x4000 +except Error: + print("Please specify valid offsets (bank:address, both hex)") + exit(1) + + +with open(argv[1], "rb") as f: + f.seek(start_addr) + + string = "" + while start_addr < end_addr: + string += char_table[ int.from_bytes(f.read(1), "little") ] + start_addr += 1 + + stdout.buffer.write( f"db \"{string}\"\n".encode('utf-8') ) |