Добро пожаловать, гость ( Вход | Регистрация )
| Siberian GRemlin |
Jun 29 2007, 16:52
Сообщение
#1
|
|
Advanced Member ![]() ![]() ![]() Группа: CTPAX-X Сообщений: 537 Регистрация: 4-February 08 Пользователь №: 2 Спасибо сказали: 222 раз(а) |
Уважаемые.
Добрался я до той ситуации, когда необходимо изменить длину строк в EXE, в частности под DOS. Как я понимаю, в бинарнике есть таблица с адресами и если мне нужно изменить длину первой строки (считаем от начала бинарника) на один символ (байт), то необходимо в таблице увеличить все значения адресов на единицу, кроме самого первого адреса (в смысле, адреса первой строки). Единственное, что мне пока неизвестно, где находится эта таблица в бинарнике и как там идёт индексация, а также адресация и есть ли где-то значение размера этой таблицы? Ещё в интернете ища информацию, натыкался на информацию о том, что существует прога для автоматического изменения текста с его длинной, ремаппингом и т.п., а также что люди сами писали подобные программы. Гипотетически это возможно, но как бы это выяснить... Может кто-от посоветует какие-нибудь статьи по данному вопросу (локализации текстовых констант в ЕХЕ) P.S.: Опытного человека, моё сообщение может показаться ламерским бредом... но хочется расти в творческом плане и в одиночку без глупых вопросов не обойтись. P.P.S.: Я доделываю русскую локализацию одной игры. |
![]() ![]() |
| -=CHE@TER=- |
Jun 29 2007, 18:54
Сообщение
#2
|
|
Walter Sullivan ![]() ![]() ![]() Группа: Root Admin Сообщений: 1,402 Регистрация: 4-February 08 Пользователь №: 3 Спасибо сказали: 325 раз(а) |
P.P.S.: Я доделываю русскую локализацию одной игры. Хех, я так понимаю Кирандию первую добиваешь? (*улыбается*)Тут, ИМХО, проблема такая, что без полной декомпиляции игры ты её не решишь. Понимаешь, строка, скажем так, вшита в .EXE файл. Ты можешь только: 1) уменьшить её (забить неиспользуемые символы в конце нулями, а лучше, пробелами) и 2) изменить её не меняя её длинны Всё. Увеличить длинну нельзя по одной простой причине: если ты увеличить строку на 1 байт - это значит, что ВСЕ конструкции-переходы (CALL, JMP, J*) в программе, которые ссылаются на адреса выше/ниже того места, где ты вставил байт, будут ссылаться на один байт раньше/позже того места, куда должны бы. Проблема в том, что все инструкции перехода записываются как инструкция и на_сколько_ ОТНОСИТЕЛЬНО_ТЕКУЩЕГО_АДРЕСА_перейти Например: jmp +5 // перейти на адрес на 5 байт после текущей инструкции call -60 // перейти на адрес на 60 байт выше данной инструкции Т.е. если ты всунул 1 байт между этими двумя командами, то: 1) jmp будет уже на +6 2) call будет уже -61 Я думаю, что писать дизассмеблер это муторно, да и отловить все такие ситуации очень и очень сложно. Это не просто изменить длинну строки - это, можно считать, переколбасить всю программу. Более того, я тут разобрал самый простой случий, без всяких структур (представь, что твоя строчка входила в структуру, или после неё стояла структура, адрес которой загружался при помощи команды lea). Моё скромное ИМХО: задача по удлинению строки, в общем случае, очень тяжёлая (если не сказать невыполнимая) и не факт, что после этого .EXE файл будет корректно работать. Если уж очень хочется, то можно сделать такой, малооправданный, трюк ушами (геммор, правда, чуть меньший, чем с правкой всех адресов в предыдущем способе): 1) Написать свой загрущик для оригинального .EXE-файла (типа виндового "запустить процесс спящим") 2) Выделить в загруженной программе дополнительную память, куда пихать свои, русские, строки 3) Перебить в памяти адреса, откуда берутся оригинальные строки, на те, где находятся загруженные соответствующие им русские 4) Дать оригинальной программе дальше работать (типа "ResumeThread") Хотя опять-таки, если строчка входила в структуру, то нужно менять и её размер... |
Siberian GRemlin Локализация EXE Jun 29 2007, 16:52
Siberian GRemlin Да. Её родимую. =)
Сокращать строки не приемлимо -... Jun 30 2007, 04:15
-=CHE@TER=- Siberian GRemlin!
А чем тебе не нравится SCUMM... Jun 30 2007, 12:20
Siberian GRemlin 'Если хочешь, чтобы что-то было сделано хорошо... Jul 2 2007, 05:04
-=CHE@TER=- Пока есть только 1 проблемка, когда адрес на начал... Jul 2 2007, 07:11
Siberian GRemlin http://img213.imageshack.us/img213/6595/kyrandiast... Jul 2 2007, 09:43
-=CHE@TER=- Так, у тебя какая версия IDA? У меня IDA Pro Adv 4... Jul 2 2007, 15:18
Siberian GRemlin У меня такая же IDA, хотя вчера нашёл в локальной ... Jul 2 2007, 23:03
-=CHE@TER=- У меня такая же IDA, хотя вчера нашёл в локальной ... Jul 3 2007, 08:21
Siberian GRemlin Прошлый был от Floppy версии, я перевожу полную CD... Jul 3 2007, 12:06
-=CHE@TER=- Понятно. Хотя этот .EXE файл тоже не лучше - на ст... Jul 3 2007, 16:40
Siberian GRemlin Понятно. Хотя этот .EXE файл тоже не лучше - на ст... Jul 4 2007, 04:50
Siberian GRemlin Я тут колупался. В итоге удалось изменить длины ст... Jul 4 2007, 08:11
-=CHE@TER=- А можно определение Overlay'я? :rolleyes:Если ... Jul 4 2007, 09:26
Siberian GRemlin
Не забывай, что ты изменяешь адрес начала строки.... Jul 4 2007, 15:10
-=CHE@TER=- Это как бы не ответ на мой вопрос.Тогда ставь вопр... Jul 4 2007, 16:15
Bourn Все просто - находим пустой адрес(можно и конец ех... Sep 2 2008, 18:22![]() ![]() |
| Упрощённая версия | Сейчас: 13th December 2025 - 12:23 |