Update Global Names
minecraft-pi-docker/pipeline/head This commit looks good Details

This commit is contained in:
TheBrokenRail 2020-11-02 09:58:43 -05:00
parent d1ba4e3cbb
commit 56d84d0133
1 changed files with 15 additions and 15 deletions

View File

@ -24,15 +24,15 @@ extern "C" {
typedef unsigned char *(*TextEditScreen_t)(unsigned char *, unsigned char *); typedef unsigned char *(*TextEditScreen_t)(unsigned char *, unsigned char *);
static TextEditScreen_t TextEditScreen = (TextEditScreen_t) 0x3a840; static TextEditScreen_t TextEditScreen = (TextEditScreen_t) 0x3a840;
typedef void (*setScreen_t)(unsigned char *, unsigned char *); typedef void (*Minecraft_setScreen_t)(unsigned char *, unsigned char *);
static setScreen_t setScreen = (setScreen_t) 0x15d6c; static Minecraft_setScreen_t Minecraft_setScreen = (Minecraft_setScreen_t) 0x15d6c;
static void openTextEdit(unsigned char *local_player, unsigned char *sign) { static void openTextEdit(unsigned char *local_player, unsigned char *sign) {
if (*(int *)(sign + 0x18) == 4) { if (*(int *)(sign + 0x18) == 4) {
unsigned char *minecraft = *(unsigned char **) (local_player + 0xc90); unsigned char *minecraft = *(unsigned char **) (local_player + 0xc90);
unsigned char *screen = (unsigned char *) ::operator new(0xd0); unsigned char *screen = (unsigned char *) ::operator new(0xd0);
screen = (*TextEditScreen)(screen, sign); screen = (*TextEditScreen)(screen, sign);
(*setScreen)(minecraft, screen); (*Minecraft_setScreen)(minecraft, screen);
} }
} }
@ -52,28 +52,28 @@ extern "C" {
input.clear(); input.clear();
} }
typedef void (*updateEvents_t)(unsigned char *screen); typedef void (*Screen_updateEvents_t)(unsigned char *screen);
static updateEvents_t updateEvents = (updateEvents_t) 0x28eb8; static Screen_updateEvents_t Screen_updateEvents = (Screen_updateEvents_t) 0x28eb8;
static void *updateEvents_original = NULL; static void *Screen_updateEvents_original = NULL;
typedef void (*keyboardNewChar_t)(unsigned char *screen, char key); typedef void (*Screen_keyboardNewChar_t)(unsigned char *screen, char key);
typedef void (*keyPressed_t)(unsigned char *screen, int32_t key); typedef void (*Screen_keyPressed_t)(unsigned char *screen, int32_t key);
static void updateEvents_injection(unsigned char *screen) { static void Screen_updateEvents_injection(unsigned char *screen) {
// Call Original // Call Original
revert_overwrite((void *) updateEvents, updateEvents_original); revert_overwrite((void *) Screen_updateEvents, Screen_updateEvents_original);
(*updateEvents)(screen); (*Screen_updateEvents)(screen);
revert_overwrite((void *) updateEvents, updateEvents_original); revert_overwrite((void *) Screen_updateEvents, Screen_updateEvents_original);
if (*(char *)(screen + 4) == '\0') { if (*(char *)(screen + 4) == '\0') {
uint32_t vtable = *((uint32_t *) screen); uint32_t vtable = *((uint32_t *) screen);
for (char key : input) { for (char key : input) {
if (key == BACKSPACE_KEY) { if (key == BACKSPACE_KEY) {
// Handle Backspace // Handle Backspace
(*(keyPressed_t *) (vtable + 0x6c))(screen, BACKSPACE_KEY); (*(Screen_keyPressed_t *) (vtable + 0x6c))(screen, BACKSPACE_KEY);
} else { } else {
// Handle Nrmal Key // Handle Nrmal Key
(*(keyboardNewChar_t *) (vtable + 0x70))(screen, key); (*(Screen_keyboardNewChar_t *) (vtable + 0x70))(screen, key);
} }
} }
} }
@ -87,7 +87,7 @@ extern "C" {
if (extra_has_feature("Fix Sign Placement")) { if (extra_has_feature("Fix Sign Placement")) {
// Fix Signs // Fix Signs
patch_address((void *) 0x106460, (void *) openTextEdit); patch_address((void *) 0x106460, (void *) openTextEdit);
updateEvents_original = overwrite((void *) updateEvents, (void *) updateEvents_injection); Screen_updateEvents_original = overwrite((void *) Screen_updateEvents, (void *) Screen_updateEvents_injection);
} }
} }
} }