More Changes!
This commit is contained in:
parent
cf6989bed2
commit
a305cf9e38
2
dependencies/symbol-processor/src
vendored
2
dependencies/symbol-processor/src
vendored
@ -1 +1 @@
|
|||||||
Subproject commit 67c4adaa772445f919f37131d7605bd374c67845
|
Subproject commit 6ee26aad80aa697fc332a51b38cf1c2e8d4513ed
|
@ -5,7 +5,7 @@
|
|||||||
#include <mods/misc/misc.h>
|
#include <mods/misc/misc.h>
|
||||||
|
|
||||||
// The Actual Mod
|
// The Actual Mod
|
||||||
HOOK(chat_handle_packet_send, void, (Minecraft *minecraft, ChatPacket *packet)) {
|
HOOK(_Z23chat_handle_packet_sendP9MinecraftP10ChatPacket, void, (Minecraft *minecraft, ChatPacket *packet)) {
|
||||||
// Get Message
|
// Get Message
|
||||||
const char *message = packet->message.c_str();
|
const char *message = packet->message.c_str();
|
||||||
if (message[0] == '/') {
|
if (message[0] == '/') {
|
||||||
@ -15,10 +15,10 @@ HOOK(chat_handle_packet_send, void, (Minecraft *minecraft, ChatPacket *packet))
|
|||||||
if (out.length() > 0 && out[out.length() - 1] == '\n') {
|
if (out.length() > 0 && out[out.length() - 1] == '\n') {
|
||||||
out[out.length() - 1] = '\0';
|
out[out.length() - 1] = '\0';
|
||||||
}
|
}
|
||||||
misc_add_message(gui, out.c_str());
|
gui->addMessage(&out);
|
||||||
} else {
|
} else {
|
||||||
// Call Original Method
|
// Call Original Method
|
||||||
ensure_chat_handle_packet_send();
|
ensure__Z23chat_handle_packet_sendP9MinecraftP10ChatPacket();
|
||||||
real_chat_handle_packet_send(minecraft, packet);
|
real__Z23chat_handle_packet_sendP9MinecraftP10ChatPacket(minecraft, packet);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
// Get Cache Path
|
// Get Cache Path
|
||||||
static std::string get_cache_path() {
|
static std::string get_cache_path() {
|
||||||
const char *home = getenv("HOME");
|
const char *home = getenv("HOME");
|
||||||
if (home == NULL) {
|
if (home == nullptr) {
|
||||||
IMPOSSIBLE();
|
IMPOSSIBLE();
|
||||||
}
|
}
|
||||||
return std::string(home) + HOME_SUBDIRECTORY_FOR_GAME_DATA "/.launcher-cache";
|
return std::string(home) + HOME_SUBDIRECTORY_FOR_GAME_DATA "/.launcher-cache";
|
||||||
|
@ -10,55 +10,72 @@ extern "C" {
|
|||||||
|
|
||||||
void reborn_init_patch();
|
void reborn_init_patch();
|
||||||
|
|
||||||
|
// Replace Call Located At start With A Call To target
|
||||||
void _overwrite_call(const char *file, int line, void *start, void *target);
|
void _overwrite_call(const char *file, int line, void *start, void *target);
|
||||||
#define overwrite_call(start, target) _overwrite_call(__FILE__, __LINE__, start, target)
|
#define overwrite_call(start, target) _overwrite_call(__FILE__, __LINE__, start, target)
|
||||||
|
|
||||||
#define _setup_fancy_overwrite(start, name, target) \
|
#define _check_if_method_is_new(name) \
|
||||||
if (!_is_new_method_##name()) { \
|
|
||||||
ERR("Method Is Not \"New\""); \
|
|
||||||
} \
|
|
||||||
static name##_t _original_for_##target = start; \
|
|
||||||
static name##_t _helper_for_##target = _overwrite_helper_for_##name(target, _original_for_##target)
|
|
||||||
|
|
||||||
#define _update_references(from, to) \
|
|
||||||
{ \
|
{ \
|
||||||
void *old_reference = (void *) from; \
|
if (!__is_new_method_##name()) { \
|
||||||
for (int i = 0; _all_method_symbols[i] != nullptr; i++) { \
|
ERR("Method Is Not \"New\""); \
|
||||||
if (_all_method_symbols[i] == old_reference) { \
|
|
||||||
_all_method_symbols[i] = (void *) to; \
|
|
||||||
} \
|
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define _setup_fancy_overwrite(start, name, target) \
|
||||||
|
_check_if_method_is_new(name); \
|
||||||
|
static name##_t _original_for_##target = start; \
|
||||||
|
static name##_t _helper_for_##target = __overwrite_helper_for_##name(target, _original_for_##target)
|
||||||
|
|
||||||
|
// Replace All Calls To Method start With target
|
||||||
void _overwrite_calls(const char *file, int line, void *start, void *target);
|
void _overwrite_calls(const char *file, int line, void *start, void *target);
|
||||||
#define overwrite_calls_manual(start, target) _overwrite_calls(__FILE__, __LINE__, start, target)
|
#define overwrite_calls_manual(start, target) _overwrite_calls(__FILE__, __LINE__, start, target)
|
||||||
#define overwrite_calls(start, target) \
|
#define overwrite_calls(start, target) \
|
||||||
{ \
|
{ \
|
||||||
_setup_fancy_overwrite(start, start, target); \
|
_setup_fancy_overwrite(start, start, target); \
|
||||||
overwrite_calls_manual((void *) start, (void *) _helper_for_##target); \
|
overwrite_calls_manual((void *) start, (void *) _helper_for_##target); \
|
||||||
_update_references(start, _helper_for_##target); \
|
start = _helper_for_##target; \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Replace All Calls To Virtual Method start With target
|
||||||
#define overwrite_virtual_calls(start, target) \
|
#define overwrite_virtual_calls(start, target) \
|
||||||
{ \
|
{ \
|
||||||
_setup_fancy_overwrite(*start##_vtable_addr, start, target); \
|
_setup_fancy_overwrite(*start##_vtable_addr, start, target); \
|
||||||
overwrite_calls_manual((void *) *start##_vtable_addr, (void *) _helper_for_##target); \
|
overwrite_calls_manual((void *) *start##_vtable_addr, (void *) _helper_for_##target); \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Replace All Calls To start With target Within [to, from)
|
||||||
void _overwrite_calls_within(const char *file, int line, void *from, void *to, void *start, void *target);
|
void _overwrite_calls_within(const char *file, int line, void *from, void *to, void *start, void *target);
|
||||||
#define overwrite_calls_within(from, to, start, target) _overwrite_calls_within(__FILE__, __LINE__, from, to, start, target)
|
#define overwrite_calls_within(from, to, start, target) _overwrite_calls_within(__FILE__, __LINE__, from, to, start, target)
|
||||||
|
|
||||||
|
// Get Target Address From BL Instruction
|
||||||
void *extract_from_bl_instruction(unsigned char *from);
|
void *extract_from_bl_instruction(unsigned char *from);
|
||||||
|
|
||||||
|
// Replace Method start With target
|
||||||
void _overwrite(const char *file, int line, void *start, void *target);
|
void _overwrite(const char *file, int line, void *start, void *target);
|
||||||
#define overwrite(start, target) _overwrite(__FILE__, __LINE__, (void *) start, (void *) target)
|
#define overwrite_manual(start, target) _overwrite(__FILE__, __LINE__, (void *) start, (void *) target)
|
||||||
|
#define overwrite(start, target) \
|
||||||
|
{ \
|
||||||
|
_check_if_method_is_new(start); \
|
||||||
|
start##_t type_check = target; \
|
||||||
|
overwrite_manual(start, (void *) type_check); \
|
||||||
|
}
|
||||||
|
|
||||||
|
// Patch Instruction
|
||||||
void _patch(const char *file, int line, void *start, unsigned char patch[4]);
|
void _patch(const char *file, int line, void *start, unsigned char patch[4]);
|
||||||
#define patch(start, patch) _patch(__FILE__, __LINE__, start, patch)
|
#define patch(start, patch) _patch(__FILE__, __LINE__, start, patch)
|
||||||
|
|
||||||
|
// Patch 4 Bytes Of Data
|
||||||
void _patch_address(const char *file, int line, void *start, void *target);
|
void _patch_address(const char *file, int line, void *start, void *target);
|
||||||
#define patch_address(start, target) _patch_address(__FILE__, __LINE__, (void *) start, (void *) target)
|
#define patch_address(start, target) _patch_address(__FILE__, __LINE__, (void *) start, (void *) target)
|
||||||
|
|
||||||
|
// Patch VTable Entry
|
||||||
|
// This does not affect sub-classes.
|
||||||
|
#define patch_vtable(start, target) \
|
||||||
|
{ \
|
||||||
|
start##_t type_check = target; \
|
||||||
|
patch_address(start##_vtable_addr, (void *) type_check); \
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@ -116,7 +116,7 @@ void init_chat() {
|
|||||||
// Manually Send (And Loopback) ChatPacket
|
// Manually Send (And Loopback) ChatPacket
|
||||||
overwrite_call((void *) 0x6b518, (void *) CommandServer_parse_CommandServer_dispatchPacket_injection);
|
overwrite_call((void *) 0x6b518, (void *) CommandServer_parse_CommandServer_dispatchPacket_injection);
|
||||||
// Re-Broadcast ChatPacket
|
// Re-Broadcast ChatPacket
|
||||||
patch_address(ServerSideNetworkHandler_handle_ChatPacket_vtable_addr, ServerSideNetworkHandler_handle_ChatPacket_injection);
|
patch_vtable(ServerSideNetworkHandler_handle_ChatPacket, ServerSideNetworkHandler_handle_ChatPacket_injection);
|
||||||
#ifndef MCPI_HEADLESS_MODE
|
#ifndef MCPI_HEADLESS_MODE
|
||||||
// Send Messages On Input Tick
|
// Send Messages On Input Tick
|
||||||
input_run_on_tick(send_queued_messages);
|
input_run_on_tick(send_queued_messages);
|
||||||
|
@ -73,11 +73,10 @@ static bool Mob_hurt_injection(Mob_hurt_t original, Mob *mob, Entity *source, in
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Death Message Logic
|
// Death Message Logic
|
||||||
#define Player_die_injections(type) \
|
#define Player_die_injections(type, original_method_self) \
|
||||||
static type##_die_t original_##type##_die; \
|
static void type##_die_injection(original_method_self##_die_t original, type *player, Entity *cause) { \
|
||||||
static void type##_die_injection(type *player, Entity *cause) { \
|
|
||||||
/* Call Original Method */ \
|
/* Call Original Method */ \
|
||||||
original_##type##_die(player, cause); \
|
original((original_method_self *) player, cause); \
|
||||||
\
|
\
|
||||||
/* Get Variable */ \
|
/* Get Variable */ \
|
||||||
RakNetInstance *rak_net_instance = player->minecraft->rak_net_instance; \
|
RakNetInstance *rak_net_instance = player->minecraft->rak_net_instance; \
|
||||||
@ -119,8 +118,8 @@ static bool Mob_hurt_injection(Mob_hurt_t original, Mob *mob, Entity *source, in
|
|||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
Player_die_injections(LocalPlayer)
|
Player_die_injections(LocalPlayer, LocalPlayer)
|
||||||
Player_die_injections(ServerPlayer)
|
Player_die_injections(ServerPlayer, Player)
|
||||||
|
|
||||||
Player_actuallyHurt_injections(LocalPlayer)
|
Player_actuallyHurt_injections(LocalPlayer)
|
||||||
Player_actuallyHurt_injections(ServerPlayer)
|
Player_actuallyHurt_injections(ServerPlayer)
|
||||||
@ -129,10 +128,12 @@ Player_actuallyHurt_injections(ServerPlayer)
|
|||||||
void init_death() {
|
void init_death() {
|
||||||
// Death Messages
|
// Death Messages
|
||||||
if (feature_has("Implement Death Messages", server_auto)) {
|
if (feature_has("Implement Death Messages", server_auto)) {
|
||||||
patch_address(ServerPlayer_die_vtable_addr, ServerPlayer_die_injection);
|
patch_vtable(ServerPlayer_die, [](ServerPlayer *player, Entity *cause) {
|
||||||
patch_address(LocalPlayer_die_vtable_addr, LocalPlayer_die_injection);
|
ServerPlayer_die_injection(*Player_die_vtable_addr, player, cause);
|
||||||
patch_address(LocalPlayer_actuallyHurt_vtable_addr, LocalPlayer_actuallyHurt_injection);
|
});
|
||||||
patch_address(ServerPlayer_actuallyHurt_vtable_addr, ServerPlayer_actuallyHurt_injection);
|
overwrite_virtual_calls(LocalPlayer_die, LocalPlayer_die_injection);
|
||||||
|
patch_vtable(LocalPlayer_actuallyHurt, LocalPlayer_actuallyHurt_injection);
|
||||||
|
patch_vtable(ServerPlayer_actuallyHurt, ServerPlayer_actuallyHurt_injection);
|
||||||
overwrite_virtual_calls(Mob_hurt, Mob_hurt_injection);
|
overwrite_virtual_calls(Mob_hurt, Mob_hurt_injection);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -84,12 +84,12 @@ CUSTOM_VTABLE(create_world_screen, Screen) {
|
|||||||
original_render(super, x, y, param_1);
|
original_render(super, x, y, param_1);
|
||||||
// Title
|
// Title
|
||||||
std::string title = "Create world";
|
std::string title = "Create world";
|
||||||
Screen_drawCenteredString(super, super->font, &title, super->width / 2, title_padding, 0xffffffff);
|
super->drawCenteredString(super->font, &title, super->width / 2, title_padding, 0xffffffff);
|
||||||
// Game Mode Description
|
// Game Mode Description
|
||||||
CreateWorldScreen *self = (CreateWorldScreen *) super;
|
CreateWorldScreen *self = (CreateWorldScreen *) super;
|
||||||
bool is_creative = self->game_mode->text == CREATIVE_STR;
|
bool is_creative = self->game_mode->text == CREATIVE_STR;
|
||||||
std::string description = is_creative ? Strings_creative_mode_description : Strings_survival_mode_description;
|
std::string description = is_creative ? Strings_creative_mode_description : Strings_survival_mode_description;
|
||||||
Screen_drawString(super, super->font, &description, self->game_mode->x, self->game_mode->y + self->game_mode->height + description_padding, 0xa0a0a0);
|
super->drawString(super->font, &description, self->game_mode->x, self->game_mode->y + self->game_mode->height + description_padding, 0xa0a0a0);
|
||||||
};
|
};
|
||||||
// Positioning
|
// Positioning
|
||||||
static Screen_setupPositions_t original_setupPositions = vtable->setupPositions;
|
static Screen_setupPositions_t original_setupPositions = vtable->setupPositions;
|
||||||
|
@ -19,7 +19,7 @@ static void _handle_bow(Minecraft *minecraft) {
|
|||||||
if (fix_bow && !is_right_click) {
|
if (fix_bow && !is_right_click) {
|
||||||
GameMode *game_mode = minecraft->game_mode;
|
GameMode *game_mode = minecraft->game_mode;
|
||||||
LocalPlayer *player = minecraft->player;
|
LocalPlayer *player = minecraft->player;
|
||||||
if (player != nullptr && game_mode != nullptr && LocalPlayer_isUsingItem(player)) {
|
if (player != nullptr && game_mode != nullptr && player->isUsingItem()) {
|
||||||
game_mode->vtable->releaseUsingItem(game_mode, (Player *) player);
|
game_mode->vtable->releaseUsingItem(game_mode, (Player *) player);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -59,8 +59,8 @@ static void _handle_drop(Minecraft *minecraft) {
|
|||||||
|
|
||||||
// Empty Slot If Needed
|
// Empty Slot If Needed
|
||||||
if (inventory_item->count < 1) {
|
if (inventory_item->count < 1) {
|
||||||
Inventory_release(inventory, selected_slot);
|
inventory->release(selected_slot);
|
||||||
Inventory_compressLinkedSlotList(inventory, selected_slot);
|
inventory->compressLinkedSlotList(selected_slot);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Drop
|
// Drop
|
||||||
|
@ -103,9 +103,9 @@ void _init_misc() {
|
|||||||
enable_misc = feature_has("Miscellaneous Input Fixes", server_disabled);
|
enable_misc = feature_has("Miscellaneous Input Fixes", server_disabled);
|
||||||
if (enable_misc) {
|
if (enable_misc) {
|
||||||
// Fix OptionsScreen Ignoring The Back Button
|
// Fix OptionsScreen Ignoring The Back Button
|
||||||
patch_address(OptionsScreen_handleBackEvent_vtable_addr, OptionsScreen_handleBackEvent_injection);
|
patch_vtable(OptionsScreen_handleBackEvent, OptionsScreen_handleBackEvent_injection);
|
||||||
// Fix "Sleeping Beauty" Bug
|
// Fix "Sleeping Beauty" Bug
|
||||||
patch_address(InBedScreen_handleBackEvent_vtable_addr, InBedScreen_handleBackEvent_injection);
|
patch_vtable(InBedScreen_handleBackEvent, InBedScreen_handleBackEvent_injection);
|
||||||
// Disable Opening Inventory Using The Cursor When Cursor Is Hidden
|
// Disable Opening Inventory Using The Cursor When Cursor Is Hidden
|
||||||
overwrite_calls(Gui_handleClick, Gui_handleClick_injection);
|
overwrite_calls(Gui_handleClick, Gui_handleClick_injection);
|
||||||
}
|
}
|
||||||
|
@ -24,7 +24,51 @@
|
|||||||
#include "misc-internal.h"
|
#include "misc-internal.h"
|
||||||
#include <mods/misc/misc.h>
|
#include <mods/misc/misc.h>
|
||||||
|
|
||||||
// Heart food overlay
|
// Classic HUD
|
||||||
|
#define DEFAULT_HUD_PADDING 2
|
||||||
|
#define NEW_HUD_PADDING 1
|
||||||
|
#define HUD_ELEMENT_WIDTH 82
|
||||||
|
#define HUD_ELEMENT_HEIGHT 9
|
||||||
|
#define TOOLBAR_HEIGHT 22
|
||||||
|
#define SLOT_WIDTH 20
|
||||||
|
#define DEFAULT_BUBBLES_PADDING 1
|
||||||
|
#define NUMBER_OF_SLOTS 9
|
||||||
|
static int use_classic_hud = 0;
|
||||||
|
static void Gui_renderHearts_GuiComponent_blit_hearts_injection(GuiComponent *component, int32_t x_dest, int32_t y_dest, int32_t x_src, int32_t y_src, int32_t width_dest, int32_t height_dest, int32_t width_src, int32_t height_src) {
|
||||||
|
Minecraft *minecraft = ((Gui *) component)->minecraft;
|
||||||
|
x_dest -= DEFAULT_HUD_PADDING;
|
||||||
|
float width = ((float) minecraft->screen_width) * Gui_InvGuiScale;
|
||||||
|
float height = ((float) minecraft->screen_height) * Gui_InvGuiScale;
|
||||||
|
x_dest += (width - (NUMBER_OF_SLOTS * SLOT_WIDTH)) / 2;
|
||||||
|
y_dest -= DEFAULT_HUD_PADDING;
|
||||||
|
y_dest += height - HUD_ELEMENT_HEIGHT - TOOLBAR_HEIGHT - NEW_HUD_PADDING;
|
||||||
|
// Call Original Method
|
||||||
|
component->blit(x_dest, y_dest, x_src, y_src, width_dest, height_dest, width_src, height_src);
|
||||||
|
}
|
||||||
|
static void Gui_renderHearts_GuiComponent_blit_armor_injection(Gui *component, int32_t x_dest, int32_t y_dest, int32_t x_src, int32_t y_src, int32_t width_dest, int32_t height_dest, int32_t width_src, int32_t height_src) {
|
||||||
|
Minecraft *minecraft = component->minecraft;
|
||||||
|
x_dest -= DEFAULT_HUD_PADDING + HUD_ELEMENT_WIDTH;
|
||||||
|
float width = ((float) minecraft->screen_width) * Gui_InvGuiScale;
|
||||||
|
float height = ((float) minecraft->screen_height) * Gui_InvGuiScale;
|
||||||
|
x_dest += width - ((width - (NUMBER_OF_SLOTS * SLOT_WIDTH)) / 2) - HUD_ELEMENT_WIDTH;
|
||||||
|
y_dest -= DEFAULT_HUD_PADDING;
|
||||||
|
y_dest += height - HUD_ELEMENT_HEIGHT - TOOLBAR_HEIGHT - NEW_HUD_PADDING;
|
||||||
|
// Call Original Method
|
||||||
|
component->blit(x_dest, y_dest, x_src, y_src, width_dest, height_dest, width_src, height_src);
|
||||||
|
}
|
||||||
|
static void Gui_renderBubbles_GuiComponent_blit_injection(Gui *component, int32_t x_dest, int32_t y_dest, int32_t x_src, int32_t y_src, int32_t width_dest, int32_t height_dest, int32_t width_src, int32_t height_src) {
|
||||||
|
Minecraft *minecraft = component->minecraft;
|
||||||
|
x_dest -= DEFAULT_HUD_PADDING;
|
||||||
|
float width = ((float) minecraft->screen_width) * Gui_InvGuiScale;
|
||||||
|
float height = ((float) minecraft->screen_height) * Gui_InvGuiScale;
|
||||||
|
x_dest += (width - (NUMBER_OF_SLOTS * SLOT_WIDTH)) / 2;
|
||||||
|
y_dest -= DEFAULT_HUD_PADDING + DEFAULT_BUBBLES_PADDING + HUD_ELEMENT_HEIGHT;
|
||||||
|
y_dest += height - HUD_ELEMENT_HEIGHT - TOOLBAR_HEIGHT - HUD_ELEMENT_HEIGHT - NEW_HUD_PADDING;
|
||||||
|
// Call Original Method
|
||||||
|
component->blit(x_dest, y_dest, x_src, y_src, width_dest, height_dest, width_src, height_src);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Heart Food Overlay
|
||||||
static int heal_amount = 0, heal_amount_drawing = 0;
|
static int heal_amount = 0, heal_amount_drawing = 0;
|
||||||
static void Gui_renderHearts_injection(Gui_renderHearts_t original, Gui *gui) {
|
static void Gui_renderHearts_injection(Gui_renderHearts_t original, Gui *gui) {
|
||||||
// Get heal_amount
|
// Get heal_amount
|
||||||
@ -45,86 +89,42 @@ static void Gui_renderHearts_injection(Gui_renderHearts_t original, Gui *gui) {
|
|||||||
// Call original
|
// Call original
|
||||||
original(gui);
|
original(gui);
|
||||||
}
|
}
|
||||||
|
static GuiComponent_blit_t get_blit_with_classic_hud_offset() {
|
||||||
|
return use_classic_hud ? Gui_renderHearts_GuiComponent_blit_hearts_injection : GuiComponent_blit;
|
||||||
|
}
|
||||||
#define PINK_HEART_FULL 70
|
#define PINK_HEART_FULL 70
|
||||||
#define PINK_HEART_HALF 79
|
#define PINK_HEART_HALF 79
|
||||||
static Gui_blit_t Gui_blit_renderHearts_original = nullptr;
|
|
||||||
static void Gui_renderHearts_GuiComponent_blit_overlay_empty_injection(Gui *gui, int32_t x1, int32_t y1, int32_t x2, int32_t y2, int32_t w1, int32_t h1, int32_t w2, int32_t h2) {
|
static void Gui_renderHearts_GuiComponent_blit_overlay_empty_injection(Gui *gui, int32_t x1, int32_t y1, int32_t x2, int32_t y2, int32_t w1, int32_t h1, int32_t w2, int32_t h2) {
|
||||||
// Call original
|
// Call Original Method
|
||||||
Gui_blit_renderHearts_original(gui, x1, y1, x2, y2, w1, h1, w2, h2);
|
get_blit_with_classic_hud_offset()((GuiComponent *) gui, x1, y1, x2, y2, w1, h1, w2, h2);
|
||||||
// Render the overlay
|
// Render The Overlay
|
||||||
if (heal_amount_drawing == 1) {
|
if (heal_amount_drawing == 1) {
|
||||||
// Half heart
|
// Half Heart
|
||||||
Gui_blit_renderHearts_original(gui, x1, y1, PINK_HEART_HALF, 0, w1, h1, w2, h2);
|
get_blit_with_classic_hud_offset()((GuiComponent *) gui, x1, y1, PINK_HEART_HALF, 0, w1, h1, w2, h2);
|
||||||
heal_amount_drawing = 0;
|
heal_amount_drawing = 0;
|
||||||
} else if (heal_amount_drawing > 0) {
|
} else if (heal_amount_drawing > 0) {
|
||||||
// Full heart
|
// Full Heart
|
||||||
Gui_blit_renderHearts_original(gui, x1, y1, PINK_HEART_FULL, 0, w1, h1, w2, h2);
|
get_blit_with_classic_hud_offset()((GuiComponent *) gui, x1, y1, PINK_HEART_FULL, 0, w1, h1, w2, h2);
|
||||||
heal_amount_drawing -= 2;
|
heal_amount_drawing -= 2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Gui_renderHearts_GuiComponent_blit_overlay_hearts_injection(Gui *gui, int32_t x1, int32_t y1, int32_t x2, int32_t y2, int32_t w1, int32_t h1, int32_t w2, int32_t h2) {
|
static void Gui_renderHearts_GuiComponent_blit_overlay_hearts_injection(Gui *gui, int32_t x1, int32_t y1, int32_t x2, int32_t y2, int32_t w1, int32_t h1, int32_t w2, int32_t h2) {
|
||||||
// Offset the overlay
|
// Offset the overlay
|
||||||
if (x2 == 52) {
|
if (x2 == 52) {
|
||||||
heal_amount_drawing += 2;
|
heal_amount_drawing += 2;
|
||||||
} else if (x2 == 61 && heal_amount) {
|
} else if (x2 == 61 && heal_amount) {
|
||||||
// Half heart, flipped
|
// Half heart, flipped
|
||||||
Gui_blit_renderHearts_original(gui, x1, y1, PINK_HEART_FULL, 0, w1, h1, w2, h2);
|
get_blit_with_classic_hud_offset()((GuiComponent *) gui, x1, y1, PINK_HEART_FULL, 0, w1, h1, w2, h2);
|
||||||
heal_amount_drawing += 1;
|
heal_amount_drawing += 1;
|
||||||
};
|
}
|
||||||
// Call original
|
// Call Original Method
|
||||||
Gui_blit_renderHearts_original(gui, x1, y1, x2, y2, w1, h1, w2, h2);
|
get_blit_with_classic_hud_offset()((GuiComponent *) gui, x1, y1, x2, y2, w1, h1, w2, h2);
|
||||||
heal_amount_drawing = fmin(heal_amount_drawing, heal_amount);
|
heal_amount_drawing = fmin(heal_amount_drawing, heal_amount);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Classic HUD
|
|
||||||
#define DEFAULT_HUD_PADDING 2
|
|
||||||
#define NEW_HUD_PADDING 1
|
|
||||||
#define HUD_ELEMENT_WIDTH 82
|
|
||||||
#define HUD_ELEMENT_HEIGHT 9
|
|
||||||
#define TOOLBAR_HEIGHT 22
|
|
||||||
#define SLOT_WIDTH 20
|
|
||||||
#define DEFAULT_BUBBLES_PADDING 1
|
|
||||||
#define NUMBER_OF_SLOTS 9
|
|
||||||
static int use_classic_hud = 0;
|
|
||||||
static void Gui_renderHearts_GuiComponent_blit_hearts_injection(Gui *component, int32_t x_dest, int32_t y_dest, int32_t x_src, int32_t y_src, int32_t width_dest, int32_t height_dest, int32_t width_src, int32_t height_src) {
|
|
||||||
Minecraft *minecraft = component->minecraft;
|
|
||||||
x_dest -= DEFAULT_HUD_PADDING;
|
|
||||||
float width = ((float) minecraft->screen_width) * Gui_InvGuiScale;
|
|
||||||
float height = ((float) minecraft->screen_height) * Gui_InvGuiScale;
|
|
||||||
x_dest += (width - (NUMBER_OF_SLOTS * SLOT_WIDTH)) / 2;
|
|
||||||
y_dest -= DEFAULT_HUD_PADDING;
|
|
||||||
y_dest += height - HUD_ELEMENT_HEIGHT - TOOLBAR_HEIGHT - NEW_HUD_PADDING;
|
|
||||||
// Call Original Method
|
|
||||||
Gui_blit(component, x_dest, y_dest, x_src, y_src, width_dest, height_dest, width_src, height_src);
|
|
||||||
}
|
|
||||||
static void Gui_renderHearts_GuiComponent_blit_armor_injection(Gui *component, int32_t x_dest, int32_t y_dest, int32_t x_src, int32_t y_src, int32_t width_dest, int32_t height_dest, int32_t width_src, int32_t height_src) {
|
|
||||||
Minecraft *minecraft = component->minecraft;
|
|
||||||
x_dest -= DEFAULT_HUD_PADDING + HUD_ELEMENT_WIDTH;
|
|
||||||
float width = ((float) minecraft->screen_width) * Gui_InvGuiScale;
|
|
||||||
float height = ((float) minecraft->screen_height) * Gui_InvGuiScale;
|
|
||||||
x_dest += width - ((width - (NUMBER_OF_SLOTS * SLOT_WIDTH)) / 2) - HUD_ELEMENT_WIDTH;
|
|
||||||
y_dest -= DEFAULT_HUD_PADDING;
|
|
||||||
y_dest += height - HUD_ELEMENT_HEIGHT - TOOLBAR_HEIGHT - NEW_HUD_PADDING;
|
|
||||||
// Call Original Method
|
|
||||||
Gui_blit(component, x_dest, y_dest, x_src, y_src, width_dest, height_dest, width_src, height_src);
|
|
||||||
}
|
|
||||||
static void Gui_renderBubbles_GuiComponent_blit_injection(Gui *component, int32_t x_dest, int32_t y_dest, int32_t x_src, int32_t y_src, int32_t width_dest, int32_t height_dest, int32_t width_src, int32_t height_src) {
|
|
||||||
Minecraft *minecraft = component->minecraft;
|
|
||||||
x_dest -= DEFAULT_HUD_PADDING;
|
|
||||||
float width = ((float) minecraft->screen_width) * Gui_InvGuiScale;
|
|
||||||
float height = ((float) minecraft->screen_height) * Gui_InvGuiScale;
|
|
||||||
x_dest += (width - (NUMBER_OF_SLOTS * SLOT_WIDTH)) / 2;
|
|
||||||
y_dest -= DEFAULT_HUD_PADDING + DEFAULT_BUBBLES_PADDING + HUD_ELEMENT_HEIGHT;
|
|
||||||
y_dest += height - HUD_ELEMENT_HEIGHT - TOOLBAR_HEIGHT - HUD_ELEMENT_HEIGHT - NEW_HUD_PADDING;
|
|
||||||
// Call Original Method
|
|
||||||
Gui_blit(component, x_dest, y_dest, x_src, y_src, width_dest, height_dest, width_src, height_src);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Additional GUI Rendering
|
// Additional GUI Rendering
|
||||||
static int hide_chat_messages = 0;
|
static int hide_chat_messages = 0;
|
||||||
bool is_in_chat = 0;
|
bool is_in_chat = false;
|
||||||
static int render_selected_item_text = 0;
|
static int render_selected_item_text = 0;
|
||||||
static void Gui_renderChatMessages_injection(Gui_renderChatMessages_t original, Gui *gui, int32_t y_offset, uint32_t max_messages, bool disable_fading, Font *font) {
|
static void Gui_renderChatMessages_injection(Gui_renderChatMessages_t original, Gui *gui, int32_t y_offset, uint32_t max_messages, bool disable_fading, Font *font) {
|
||||||
// Handle Classic HUD
|
// Handle Classic HUD
|
||||||
@ -417,7 +417,7 @@ static int32_t get_color(LevelSource *level_source, int32_t x, int32_t z) {
|
|||||||
return biome->color;
|
return biome->color;
|
||||||
}
|
}
|
||||||
#define BIOME_BLEND_SIZE 7
|
#define BIOME_BLEND_SIZE 7
|
||||||
static int32_t GrassTile_getColor_injection(__attribute__((unused)) Tile *tile, LevelSource *level_source, int32_t x, __attribute__((unused)) int32_t y, int32_t z) {
|
static int32_t GrassTile_getColor_injection(__attribute__((unused)) GrassTile *tile, LevelSource *level_source, int32_t x, __attribute__((unused)) int32_t y, int32_t z) {
|
||||||
int r_sum = 0;
|
int r_sum = 0;
|
||||||
int g_sum = 0;
|
int g_sum = 0;
|
||||||
int b_sum = 0;
|
int b_sum = 0;
|
||||||
@ -441,7 +441,7 @@ static int32_t GrassTile_getColor_injection(__attribute__((unused)) Tile *tile,
|
|||||||
static int32_t TallGrass_getColor_injection(TallGrass_getColor_t original, TallGrass *tile, LevelSource *level_source, int32_t x, int32_t y, int32_t z) {
|
static int32_t TallGrass_getColor_injection(TallGrass_getColor_t original, TallGrass *tile, LevelSource *level_source, int32_t x, int32_t y, int32_t z) {
|
||||||
int32_t original_color = original(tile, level_source, x, y, z);
|
int32_t original_color = original(tile, level_source, x, y, z);
|
||||||
if (original_color == 0x339933) {
|
if (original_color == 0x339933) {
|
||||||
return GrassTile_getColor_injection((Tile *) tile, level_source, x, y, z);
|
return GrassTile_getColor_injection(nullptr, level_source, x, y, z);
|
||||||
} else {
|
} else {
|
||||||
return original_color;
|
return original_color;
|
||||||
}
|
}
|
||||||
@ -463,7 +463,8 @@ static void RandomLevelSource_buildSurface_injection(RandomLevelSource_buildSurf
|
|||||||
}
|
}
|
||||||
|
|
||||||
// No Block Tinting
|
// No Block Tinting
|
||||||
static int32_t Tile_getColor_injection() {
|
template <typename T, typename S>
|
||||||
|
static int32_t Tile_getColor_injection(__attribute__((unused)) T original, __attribute__((unused)) S *self, __attribute__((unused)) LevelSource *level_source, __attribute__((unused)) int x, __attribute__((unused)) int y, __attribute__((unused)) int z) {
|
||||||
return 0xffffff;
|
return 0xffffff;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -620,7 +621,7 @@ static void Player_stopUsingItem_injection(Player_stopUsingItem_t original, Play
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Java Light Ramp
|
// Java Light Ramp
|
||||||
static void Dimension_updateLightRamp_injection(Dimension *self) {
|
static void Dimension_updateLightRamp_injection(__attribute__((unused)) Dimension_updateLightRamp_t original, Dimension *self) {
|
||||||
// https://github.com/ReMinecraftPE/mcpe/blob/d7a8b6baecf8b3b050538abdbc976f690312aa2d/source/world/level/Dimension.cpp#L92-L105
|
// https://github.com/ReMinecraftPE/mcpe/blob/d7a8b6baecf8b3b050538abdbc976f690312aa2d/source/world/level/Dimension.cpp#L92-L105
|
||||||
for (int i = 0; i <= 15; i++) {
|
for (int i = 0; i <= 15; i++) {
|
||||||
float f1 = 1.0f - (((float) i) / 15.0f);
|
float f1 = 1.0f - (((float) i) / 15.0f);
|
||||||
@ -632,9 +633,9 @@ static void Dimension_updateLightRamp_injection(Dimension *self) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Read Asset File
|
// Read Asset File
|
||||||
static AppPlatform_readAssetFile_return_value AppPlatform_readAssetFile_injection(__attribute__((unused)) AppPlatform *app_platform, std::string const& path) {
|
static AppPlatform_readAssetFile_return_value AppPlatform_readAssetFile_injection(__attribute__((unused)) AppPlatform_readAssetFile_t original, __attribute__((unused)) AppPlatform *app_platform, std::string *path) {
|
||||||
// Open File
|
// Open File
|
||||||
std::ifstream stream("data/" + path, std::ios_base::binary | std::ios_base::ate);
|
std::ifstream stream("data/" + *path, std::ios_base::binary | std::ios_base::ate);
|
||||||
if (!stream) {
|
if (!stream) {
|
||||||
// Does Not Exist
|
// Does Not Exist
|
||||||
AppPlatform_readAssetFile_return_value ret;
|
AppPlatform_readAssetFile_return_value ret;
|
||||||
@ -700,7 +701,7 @@ void PaneCraftingScreen_craftSelectedItem_PaneCraftingScreen_recheckRecipes_inje
|
|||||||
PaneCraftingScreen_recheckRecipes(self);
|
PaneCraftingScreen_recheckRecipes(self);
|
||||||
}
|
}
|
||||||
|
|
||||||
ItemInstance *Item_getCraftingRemainingItem_injection(Item *self, ItemInstance *item_instance) {
|
ItemInstance *Item_getCraftingRemainingItem_injection(__attribute__((unused)) Item_getCraftingRemainingItem_t original, Item *self, ItemInstance *item_instance) {
|
||||||
if (self->craftingRemainingItem != nullptr) {
|
if (self->craftingRemainingItem != nullptr) {
|
||||||
ItemInstance *ret = alloc_ItemInstance();
|
ItemInstance *ret = alloc_ItemInstance();
|
||||||
ret->id = self->craftingRemainingItem->id;
|
ret->id = self->craftingRemainingItem->id;
|
||||||
@ -765,7 +766,6 @@ void init_misc() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Classic HUD
|
// Classic HUD
|
||||||
Gui_blit_renderHearts_original = Gui_blit;
|
|
||||||
if (feature_has("Classic HUD", server_disabled)) {
|
if (feature_has("Classic HUD", server_disabled)) {
|
||||||
use_classic_hud = 1;
|
use_classic_hud = 1;
|
||||||
overwrite_call((void *) 0x26758, (void *) Gui_renderHearts_GuiComponent_blit_hearts_injection);
|
overwrite_call((void *) 0x26758, (void *) Gui_renderHearts_GuiComponent_blit_hearts_injection);
|
||||||
@ -773,7 +773,6 @@ void init_misc() {
|
|||||||
overwrite_call((void *) 0x268c4, (void *) Gui_renderBubbles_GuiComponent_blit_injection);
|
overwrite_call((void *) 0x268c4, (void *) Gui_renderBubbles_GuiComponent_blit_injection);
|
||||||
overwrite_call((void *) 0x266f8, (void *) Gui_renderHearts_GuiComponent_blit_hearts_injection);
|
overwrite_call((void *) 0x266f8, (void *) Gui_renderHearts_GuiComponent_blit_hearts_injection);
|
||||||
overwrite_call((void *) 0x267c8, (void *) Gui_renderHearts_GuiComponent_blit_hearts_injection);
|
overwrite_call((void *) 0x267c8, (void *) Gui_renderHearts_GuiComponent_blit_hearts_injection);
|
||||||
Gui_blit_renderHearts_original = Gui_renderHearts_GuiComponent_blit_hearts_injection;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Food overlay
|
// Food overlay
|
||||||
@ -823,10 +822,10 @@ void init_misc() {
|
|||||||
|
|
||||||
#ifdef MCPI_HEADLESS_MODE
|
#ifdef MCPI_HEADLESS_MODE
|
||||||
// Don't Render Game In Headless Mode
|
// Don't Render Game In Headless Mode
|
||||||
overwrite(GameRenderer_render, nop);
|
overwrite_manual(GameRenderer_render, nop);
|
||||||
overwrite(NinecraftApp_initGLStates, nop);
|
overwrite_manual(NinecraftApp_initGLStates, nop);
|
||||||
overwrite(Gui_onConfigChanged, nop);
|
overwrite_manual(Gui_onConfigChanged, nop);
|
||||||
overwrite(LevelRenderer_generateSky, nop);
|
overwrite_manual(LevelRenderer_generateSky, nop);
|
||||||
#else
|
#else
|
||||||
// Improved Cursor Rendering
|
// Improved Cursor Rendering
|
||||||
if (feature_has("Improved Cursor Rendering", server_disabled)) {
|
if (feature_has("Improved Cursor Rendering", server_disabled)) {
|
||||||
@ -850,7 +849,7 @@ void init_misc() {
|
|||||||
|
|
||||||
// Remove Forced GUI Lag
|
// Remove Forced GUI Lag
|
||||||
if (feature_has("Remove Forced GUI Lag (Can Break Joining Servers)", server_enabled)) {
|
if (feature_has("Remove Forced GUI Lag (Can Break Joining Servers)", server_enabled)) {
|
||||||
overwrite(Common_sleepMs, nop);
|
overwrite_manual(Common_sleepMs, nop);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef MCPI_HEADLESS_MODE
|
#ifndef MCPI_HEADLESS_MODE
|
||||||
@ -859,7 +858,7 @@ void init_misc() {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Fix Graphics Bug When Switching To First-Person While Sneaking
|
// Fix Graphics Bug When Switching To First-Person While Sneaking
|
||||||
patch_address(PlayerRenderer_render_vtable_addr, PlayerRenderer_render_injection);
|
patch_vtable(PlayerRenderer_render, PlayerRenderer_render_injection);
|
||||||
|
|
||||||
// Disable Speed Bridging
|
// Disable Speed Bridging
|
||||||
if (feature_has("Disable Speed Bridging", server_disabled)) {
|
if (feature_has("Disable Speed Bridging", server_disabled)) {
|
||||||
@ -875,7 +874,7 @@ void init_misc() {
|
|||||||
|
|
||||||
// Change Grass Color
|
// Change Grass Color
|
||||||
if (feature_has("Add Biome Colors To Grass", server_disabled)) {
|
if (feature_has("Add Biome Colors To Grass", server_disabled)) {
|
||||||
patch_address(GrassTile_getColor_vtable_addr, GrassTile_getColor_injection);
|
patch_vtable(GrassTile_getColor, GrassTile_getColor_injection);
|
||||||
overwrite_virtual_calls(TallGrass_getColor, TallGrass_getColor_injection);
|
overwrite_virtual_calls(TallGrass_getColor, TallGrass_getColor_injection);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -886,11 +885,11 @@ void init_misc() {
|
|||||||
|
|
||||||
// Disable Block Tinting
|
// Disable Block Tinting
|
||||||
if (feature_has("Disable Block Tinting", server_disabled)) {
|
if (feature_has("Disable Block Tinting", server_disabled)) {
|
||||||
patch_address(GrassTile_getColor_vtable_addr, Tile_getColor_injection);
|
overwrite_virtual_calls(GrassTile_getColor, Tile_getColor_injection);
|
||||||
patch_address(TallGrass_getColor_vtable_addr, Tile_getColor_injection);
|
overwrite_virtual_calls(TallGrass_getColor, Tile_getColor_injection);
|
||||||
patch_address(StemTile_getColor_vtable_addr, Tile_getColor_injection);
|
overwrite_virtual_calls(StemTile_getColor, Tile_getColor_injection);
|
||||||
patch_address(LeafTile_getColor_vtable_addr, Tile_getColor_injection);
|
overwrite_virtual_calls(LeafTile_getColor, Tile_getColor_injection);
|
||||||
overwrite(*LiquidTile_getColor_vtable_addr, Tile_getColor_injection);
|
overwrite_virtual_calls(LiquidTile_getColor, Tile_getColor_injection);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Custom GUI Scale
|
// Custom GUI Scale
|
||||||
@ -932,7 +931,7 @@ void init_misc() {
|
|||||||
#ifndef MCPI_HEADLESS_MODE
|
#ifndef MCPI_HEADLESS_MODE
|
||||||
// Replace Block Highlight With Outline
|
// Replace Block Highlight With Outline
|
||||||
if (feature_has("Replace Block Highlight With Outline", server_disabled)) {
|
if (feature_has("Replace Block Highlight With Outline", server_disabled)) {
|
||||||
overwrite((void *) LevelRenderer_renderHitSelect, (void *) LevelRenderer_renderHitOutline);
|
overwrite(LevelRenderer_renderHitSelect, LevelRenderer_renderHitOutline);
|
||||||
unsigned char fix_outline_patch[4] = {0x00, 0xf0, 0x20, 0xe3}; // "nop"
|
unsigned char fix_outline_patch[4] = {0x00, 0xf0, 0x20, 0xe3}; // "nop"
|
||||||
patch((void *) 0x4d830, fix_outline_patch);
|
patch((void *) 0x4d830, fix_outline_patch);
|
||||||
overwrite_call((void *) 0x4d764, (void *) glColor4f_injection);
|
overwrite_call((void *) 0x4d764, (void *) glColor4f_injection);
|
||||||
@ -952,7 +951,7 @@ void init_misc() {
|
|||||||
|
|
||||||
// Java Light Ramp
|
// Java Light Ramp
|
||||||
if (feature_has("Use Java Beta 1.3 Light Ramp", server_disabled)) {
|
if (feature_has("Use Java Beta 1.3 Light Ramp", server_disabled)) {
|
||||||
overwrite(*Dimension_updateLightRamp_vtable_addr, Dimension_updateLightRamp_injection);
|
overwrite_virtual_calls(Dimension_updateLightRamp, Dimension_updateLightRamp_injection);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fix used items transferring durability
|
// Fix used items transferring durability
|
||||||
@ -971,7 +970,7 @@ void init_misc() {
|
|||||||
|
|
||||||
// Implement AppPlatform::readAssetFile So Translations Work
|
// Implement AppPlatform::readAssetFile So Translations Work
|
||||||
if (feature_has("Load Language Files", server_enabled)) {
|
if (feature_has("Load Language Files", server_enabled)) {
|
||||||
overwrite(*AppPlatform_readAssetFile_vtable_addr, AppPlatform_readAssetFile_injection);
|
overwrite_virtual_calls(AppPlatform_readAssetFile, AppPlatform_readAssetFile_injection);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fix Pause Menu
|
// Fix Pause Menu
|
||||||
@ -982,16 +981,16 @@ void init_misc() {
|
|||||||
|
|
||||||
// Implement Crafting Remainders
|
// Implement Crafting Remainders
|
||||||
overwrite_call((void *) 0x2e230, (void *) PaneCraftingScreen_craftSelectedItem_PaneCraftingScreen_recheckRecipes_injection);
|
overwrite_call((void *) 0x2e230, (void *) PaneCraftingScreen_craftSelectedItem_PaneCraftingScreen_recheckRecipes_injection);
|
||||||
overwrite(*Item_getCraftingRemainingItem_vtable_addr, Item_getCraftingRemainingItem_injection);
|
overwrite_virtual_calls(Item_getCraftingRemainingItem, Item_getCraftingRemainingItem_injection);
|
||||||
|
|
||||||
// Replace 2011 std::sort With Optimized(TM) Code
|
// Replace 2011 std::sort With Optimized(TM) Code
|
||||||
if (feature_has("Optimized Chunk Sorting", server_enabled)) {
|
if (feature_has("Optimized Chunk Sorting", server_enabled)) {
|
||||||
overwrite((void *) 0x51fac, (void *) sort_chunks);
|
overwrite_manual((void *) 0x51fac, (void *) sort_chunks);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Display Date In Select World Screen
|
// Display Date In Select World Screen
|
||||||
if (feature_has("Display Date In Select World Screen", server_disabled)) {
|
if (feature_has("Display Date In Select World Screen", server_disabled)) {
|
||||||
patch_address(AppPlatform_linux_getDateString_vtable_addr, AppPlatform_linux_getDateString_injection);
|
patch_vtable(AppPlatform_linux_getDateString, AppPlatform_linux_getDateString_injection);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Init Logging
|
// Init Logging
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
#include <mods/home/home.h>
|
#include <mods/home/home.h>
|
||||||
|
|
||||||
// Force Mob Spawning
|
// Force Mob Spawning
|
||||||
static bool LevelData_getSpawnMobs_injection(__attribute__((unused)) unsigned char *level_data) {
|
static bool LevelData_getSpawnMobs_injection(__attribute__((unused)) LevelData *level_data) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -238,7 +238,7 @@ static void OptionButton_toggle_Options_save_injection(Options *self) {
|
|||||||
void init_options() {
|
void init_options() {
|
||||||
// Force Mob Spawning
|
// Force Mob Spawning
|
||||||
if (feature_has("Force Mob Spawning", server_auto)) {
|
if (feature_has("Force Mob Spawning", server_auto)) {
|
||||||
overwrite((void *) LevelData_getSpawnMobs, (void *) LevelData_getSpawnMobs_injection);
|
overwrite(LevelData_getSpawnMobs, LevelData_getSpawnMobs_injection);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Render Distance
|
// Render Distance
|
||||||
|
@ -223,7 +223,7 @@ static void handle_server_stop(Minecraft *minecraft) {
|
|||||||
// Save And Exit
|
// Save And Exit
|
||||||
Level *level = get_level(minecraft);
|
Level *level = get_level(minecraft);
|
||||||
if (level != nullptr) {
|
if (level != nullptr) {
|
||||||
Level_saveLevelData_injection(level);
|
Level_saveLevelData(level);
|
||||||
}
|
}
|
||||||
Minecraft_leaveGame(minecraft, false);
|
Minecraft_leaveGame(minecraft, false);
|
||||||
// Stop Game
|
// Stop Game
|
||||||
@ -236,7 +236,7 @@ static void handle_server_stop(Minecraft *minecraft) {
|
|||||||
// Track TPS
|
// Track TPS
|
||||||
#define NANOSECONDS_IN_SECOND 1000000000ll
|
#define NANOSECONDS_IN_SECOND 1000000000ll
|
||||||
static long long int get_time() {
|
static long long int get_time() {
|
||||||
struct timespec ts;
|
timespec ts = {};
|
||||||
clock_gettime(CLOCK_MONOTONIC_RAW, &ts);
|
clock_gettime(CLOCK_MONOTONIC_RAW, &ts);
|
||||||
long long int a = (long long int) ts.tv_nsec;
|
long long int a = (long long int) ts.tv_nsec;
|
||||||
long long int b = ((long long int) ts.tv_sec) * NANOSECONDS_IN_SECOND;
|
long long int b = ((long long int) ts.tv_sec) * NANOSECONDS_IN_SECOND;
|
||||||
@ -266,7 +266,7 @@ static volatile bool stdin_buffer_complete = false;
|
|||||||
static volatile char *stdin_buffer = nullptr;
|
static volatile char *stdin_buffer = nullptr;
|
||||||
static void *read_stdin_thread(__attribute__((unused)) void *data) {
|
static void *read_stdin_thread(__attribute__((unused)) void *data) {
|
||||||
// Loop
|
// Loop
|
||||||
while (1) {
|
while (true) {
|
||||||
int bytes_available;
|
int bytes_available;
|
||||||
if (ioctl(fileno(stdin), FIONREAD, &bytes_available) == -1) {
|
if (ioctl(fileno(stdin), FIONREAD, &bytes_available) == -1) {
|
||||||
bytes_available = 0;
|
bytes_available = 0;
|
||||||
@ -433,7 +433,7 @@ static bool is_ip_in_blacklist(const char *ip) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Ban Players
|
// Ban Players
|
||||||
static bool RakNet_RakPeer_IsBanned_injection(__attribute__((unused)) RakNet_RakPeer *rakpeer, const char *ip) {
|
static bool RakNet_RakPeer_IsBanned_injection(__attribute__((unused)) RakNet_RakPeer_IsBanned_t original, __attribute__((unused)) RakNet_RakPeer *rakpeer, const char *ip) {
|
||||||
// Check List
|
// Check List
|
||||||
bool ret = is_ip_in_blacklist(ip);
|
bool ret = is_ip_in_blacklist(ip);
|
||||||
if (is_whitelist()) {
|
if (is_whitelist()) {
|
||||||
@ -576,7 +576,7 @@ static void server_init() {
|
|||||||
unsigned char max_players_patch[4] = {get_max_players(), 0x30, 0xa0, 0xe3}; // "mov r3, #MAX_PLAYERS"
|
unsigned char max_players_patch[4] = {get_max_players(), 0x30, 0xa0, 0xe3}; // "mov r3, #MAX_PLAYERS"
|
||||||
patch((void *) 0x166d0, max_players_patch);
|
patch((void *) 0x166d0, max_players_patch);
|
||||||
// Custom Banned IP List
|
// Custom Banned IP List
|
||||||
patch_address(RakNet_RakPeer_IsBanned_vtable_addr, (void *) RakNet_RakPeer_IsBanned_injection);
|
overwrite_virtual_calls(RakNet_RakPeer_IsBanned, RakNet_RakPeer_IsBanned_injection);
|
||||||
|
|
||||||
// Show The MineCon Icon Next To MOTD In Server List
|
// Show The MineCon Icon Next To MOTD In Server List
|
||||||
if (get_server_properties().get_bool("show-minecon-badge", DEFAULT_SHOW_MINECON_BADGE)) {
|
if (get_server_properties().get_bool("show-minecon-badge", DEFAULT_SHOW_MINECON_BADGE)) {
|
||||||
|
@ -49,7 +49,7 @@ void sign_key_press(char key) {
|
|||||||
void init_sign() {
|
void init_sign() {
|
||||||
if (feature_has("Fix Sign Placement", server_disabled)) {
|
if (feature_has("Fix Sign Placement", server_disabled)) {
|
||||||
// Fix Signs
|
// Fix Signs
|
||||||
patch_address(LocalPlayer_openTextEdit_vtable_addr, (void *) LocalPlayer_openTextEdit_injection);
|
patch_vtable(LocalPlayer_openTextEdit, LocalPlayer_openTextEdit_injection);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Handle Backspace
|
// Handle Backspace
|
||||||
|
@ -66,11 +66,11 @@ static void play(std::string name, float x, float y, float z, float volume, floa
|
|||||||
media_audio_play(source.c_str(), resolved_name.c_str(), x, y, z, pitch, volume, is_ui);
|
media_audio_play(source.c_str(), resolved_name.c_str(), x, y, z, pitch, volume, is_ui);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
static void SoundEngine_playUI_injection(__attribute__((unused)) unsigned char *sound_engine, std::string const& name, float volume, float pitch) {
|
static void SoundEngine_playUI_injection(__attribute__((unused)) SoundEngine *sound_engine, std::string *name, float volume, float pitch) {
|
||||||
play(name, 0, 0, 0, volume, pitch, true);
|
play(*name, 0, 0, 0, volume, pitch, true);
|
||||||
}
|
}
|
||||||
static void SoundEngine_play_injection(__attribute__((unused)) unsigned char *sound_engine, std::string const& name, float x, float y, float z, float volume, float pitch) {
|
static void SoundEngine_play_injection(__attribute__((unused)) SoundEngine *sound_engine, std::string *name, float x, float y, float z, float volume, float pitch) {
|
||||||
play(name, x, y, z, volume, pitch, false);
|
play(*name, x, y, z, volume, pitch, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Refresh Data
|
// Refresh Data
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#include <mods/init/init.h>
|
#include <mods/init/init.h>
|
||||||
|
|
||||||
// Disable Texture Loading
|
// Disable Texture Loading
|
||||||
static Texture AppPlatform_linux_loadTexture_injection(__attribute__((unused)) AppPlatform_linux *app_platform, __attribute__((unused)) std::string *path, __attribute__((unused)) bool b) {
|
static Texture AppPlatform_linux_loadTexture_injection(__attribute__((unused)) AppPlatform_linux_loadTexture_t original, __attribute__((unused)) AppPlatform_linux *app_platform, __attribute__((unused)) std::string *path, __attribute__((unused)) bool b) {
|
||||||
Texture out;
|
Texture out;
|
||||||
out.width = 0;
|
out.width = 0;
|
||||||
out.height = 0;
|
out.height = 0;
|
||||||
@ -19,5 +19,5 @@ static Texture AppPlatform_linux_loadTexture_injection(__attribute__((unused)) A
|
|||||||
// Init
|
// Init
|
||||||
void init_textures() {
|
void init_textures() {
|
||||||
// Disable Texture Loading
|
// Disable Texture Loading
|
||||||
overwrite((void *) AppPlatform_linux_loadTexture_non_virtual, (void *) AppPlatform_linux_loadTexture_injection);
|
overwrite_virtual_calls(AppPlatform_linux_loadTexture, AppPlatform_linux_loadTexture_injection);
|
||||||
}
|
}
|
||||||
|
@ -170,7 +170,7 @@ static void Textures_tick_glTexSubImage2D_injection(GLenum target, GLint level,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Load Textures
|
// Load Textures
|
||||||
static Texture AppPlatform_linux_loadTexture_injection(__attribute__((unused)) AppPlatform_linux *app_platform, std::string *path, bool b) {
|
static Texture AppPlatform_linux_loadTexture_injection(__attribute__((unused)) AppPlatform_linux_loadTexture_t original, __attribute__((unused)) AppPlatform_linux *app_platform, std::string *path, bool b) {
|
||||||
Texture out;
|
Texture out;
|
||||||
std::string real_path = *path;
|
std::string real_path = *path;
|
||||||
if (b) {
|
if (b) {
|
||||||
@ -234,5 +234,5 @@ void init_textures() {
|
|||||||
overwrite_call((void *) 0x53274, (void *) Textures_tick_glTexSubImage2D_injection);
|
overwrite_call((void *) 0x53274, (void *) Textures_tick_glTexSubImage2D_injection);
|
||||||
|
|
||||||
// Load Textures
|
// Load Textures
|
||||||
overwrite(*AppPlatform_linux_loadTexture_vtable_addr, AppPlatform_linux_loadTexture_injection);
|
overwrite_virtual_calls(AppPlatform_linux_loadTexture, AppPlatform_linux_loadTexture_injection);
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,7 @@ static void StartMenuScreen_render_Screen_renderBackground_injection(Screen *scr
|
|||||||
Textures *textures = minecraft->textures;
|
Textures *textures = minecraft->textures;
|
||||||
std::string texture = "gui/titleBG.png";
|
std::string texture = "gui/titleBG.png";
|
||||||
Textures_loadAndBindTexture(textures, &texture);
|
Textures_loadAndBindTexture(textures, &texture);
|
||||||
Screen_blit(screen, 0, 0, 0, 0, screen->width, screen->height, 0x100, 0x100);
|
screen->blit(0, 0, 0, 0, screen->width, screen->height, 0x100, 0x100);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add Buttons Back To Classic Start Screen
|
// Add Buttons Back To Classic Start Screen
|
||||||
@ -109,7 +109,7 @@ static void StartMenuScreen_render_Screen_render_injection(Screen *screen, int x
|
|||||||
glScalef(scale, scale, scale);
|
glScalef(scale, scale, scale);
|
||||||
// Render
|
// Render
|
||||||
static int line_height = 8;
|
static int line_height = 8;
|
||||||
Screen_drawCenteredString(screen, screen->font, ¤t_splash, 0, -(float(line_height) / 2), 0xffff00);
|
screen->drawCenteredString(screen->font, ¤t_splash, 0, -(float(line_height) / 2), 0xffff00);
|
||||||
// Finish
|
// Finish
|
||||||
glPopMatrix();
|
glPopMatrix();
|
||||||
}
|
}
|
||||||
|
@ -65,7 +65,7 @@ void init_touch() {
|
|||||||
int touch_buttons = touch_gui;
|
int touch_buttons = touch_gui;
|
||||||
if (touch_gui) {
|
if (touch_gui) {
|
||||||
// Main UI
|
// Main UI
|
||||||
overwrite((void *) Minecraft_isTouchscreen, (void *) Minecraft_isTouchscreen_injection);
|
overwrite(Minecraft_isTouchscreen, Minecraft_isTouchscreen_injection);
|
||||||
|
|
||||||
// Force Correct Toolbar Size
|
// Force Correct Toolbar Size
|
||||||
unsigned char toolbar_patch[4] = {0x01, 0x00, 0x50, 0xe3}; // "cmp r0, #0x1"
|
unsigned char toolbar_patch[4] = {0x01, 0x00, 0x50, 0xe3}; // "cmp r0, #0x1"
|
||||||
@ -98,7 +98,7 @@ void init_touch() {
|
|||||||
|
|
||||||
// Improved Button Hover Behavior
|
// Improved Button Hover Behavior
|
||||||
if (touch_buttons && feature_has("Improved Button Hover Behavior", server_disabled)) {
|
if (touch_buttons && feature_has("Improved Button Hover Behavior", server_disabled)) {
|
||||||
overwrite((void *) Button_hovered, (void *) Button_hovered_injection);
|
overwrite(Button_hovered, Button_hovered_injection);
|
||||||
overwrite_call((void *) 0x1ebd4, (void *) LargeImageButton_render_GuiComponent_drawCenteredString_injection);
|
overwrite_call((void *) 0x1ebd4, (void *) LargeImageButton_render_GuiComponent_drawCenteredString_injection);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@ __attribute__((destructor)) static void _free_version() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Injection For Touch GUI Version
|
// Injection For Touch GUI Version
|
||||||
static std::string Common_getGameVersionString_injection(__attribute__((unused)) std::string const& version_suffix) {
|
static std::string Common_getGameVersionString_injection(__attribute__((unused)) std::string *version_suffix) {
|
||||||
// Set Version
|
// Set Version
|
||||||
return version_get();
|
return version_get();
|
||||||
}
|
}
|
||||||
@ -28,7 +28,7 @@ static std::string Common_getGameVersionString_injection(__attribute__((unused))
|
|||||||
// Init
|
// Init
|
||||||
void init_version() {
|
void init_version() {
|
||||||
// Touch GUI
|
// Touch GUI
|
||||||
overwrite((void *) Common_getGameVersionString, (void *) Common_getGameVersionString_injection);
|
overwrite(Common_getGameVersionString, Common_getGameVersionString_injection);
|
||||||
// Normal GUI
|
// Normal GUI
|
||||||
patch_address((void *) Strings_minecraft_pi_version_pointer, version_get());
|
patch_address((void *) Strings_minecraft_pi_version_pointer, version_get());
|
||||||
|
|
||||||
|
@ -228,6 +228,8 @@ target_include_directories(
|
|||||||
|
|
||||||
# Disable C++11 String ABI
|
# Disable C++11 String ABI
|
||||||
target_compile_definitions(symbols PUBLIC -D_GLIBCXX_USE_CXX11_ABI=0)
|
target_compile_definitions(symbols PUBLIC -D_GLIBCXX_USE_CXX11_ABI=0)
|
||||||
|
# Fix Warning
|
||||||
|
target_compile_options(symbols PUBLIC -Wno-missing-field-initializers)
|
||||||
|
|
||||||
# Install
|
# Install
|
||||||
install(TARGETS symbols DESTINATION "${MCPI_LIB_DIR}")
|
install(TARGETS symbols DESTINATION "${MCPI_LIB_DIR}")
|
||||||
|
@ -38,7 +38,7 @@ property Item *craftingRemainingItem = 0x1c;
|
|||||||
property std::string description_id = 0x20;
|
property std::string description_id = 0x20;
|
||||||
|
|
||||||
// Globals
|
// Globals
|
||||||
static-property-array Item *items = 0x17b250;
|
static-property Item *items[256] = 0x17b250;
|
||||||
|
|
||||||
// Items
|
// Items
|
||||||
static-property Item *flintAndSteel = 0x17ba70;
|
static-property Item *flintAndSteel = 0x17ba70;
|
||||||
|
@ -17,4 +17,4 @@ property int color = 0x2c;
|
|||||||
property int leaf_color = 0x34;
|
property int leaf_color = 0x34;
|
||||||
|
|
||||||
// This is a Biome*[64x64], temp x humidity
|
// This is a Biome*[64x64], temp x humidity
|
||||||
static-property-array Biome *map = 0x17c970;
|
static-property Biome *map[4096] = 0x17c970;
|
||||||
|
@ -46,3 +46,4 @@ property bool done_generating = 0x12;
|
|||||||
property std::vector<Entity *> entities = 0x20;
|
property std::vector<Entity *> entities = 0x20;
|
||||||
property std::vector<TileEntity *> tileentities = 0x50;
|
property std::vector<TileEntity *> tileentities = 0x50;
|
||||||
property std::vector<Player *> players = 0x60;
|
property std::vector<Player *> players = 0x60;
|
||||||
|
property Dimension *dimension = 0x74;
|
@ -1 +1 @@
|
|||||||
method uint getSpawnMobs() = 0xbabec;
|
method bool getSpawnMobs() = 0xbabec;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
static-method std::string *getGameVersionString(std::string *version_suffix) = 0x15068;
|
static-method std::string getGameVersionString(std::string *version_suffix) = 0x15068;
|
||||||
|
|
||||||
// These are not actually part of "Common", but they have to go somewhere.
|
// These are not actually part of "Common", but they have to go somewhere.
|
||||||
static-method void renderCursor(float x, float y, Minecraft *minecraft) = 0x480c4;
|
static-method void renderCursor(float x, float y, Minecraft *minecraft) = 0x480c4;
|
||||||
|
@ -7,5 +7,5 @@ static-property char *options_txt_fopen_mode_when_loading = 0x19d24; // w
|
|||||||
static-property char *feedback_vibration_options_txt_name = 0x135d70; // feedback_vibration
|
static-property char *feedback_vibration_options_txt_name = 0x135d70; // feedback_vibration
|
||||||
static-property char *gfx_lowquality_options_txt_name = 0x135d88; // gfx_lowquality
|
static-property char *gfx_lowquality_options_txt_name = 0x135d88; // gfx_lowquality
|
||||||
static-property char *classic_create_button_text = 0x39bec; // Create
|
static-property char *classic_create_button_text = 0x39bec; // Create
|
||||||
static-property-array char creative_mode_description = 0x104492; // Unlimited resources and flying
|
static-property char creative_mode_description[31] = 0x104492; // Unlimited resources and flying
|
||||||
static-property-array char survival_mode_description = 0x104470; // Mobs, health and gather resources
|
static-property char survival_mode_description[34] = 0x104470; // Mobs, health and gather resources
|
||||||
|
@ -67,9 +67,9 @@ property int category = 0x3c;
|
|||||||
property AABB aabb = 0x40;
|
property AABB aabb = 0x40;
|
||||||
|
|
||||||
// Globals, all of theses are 256 elements long
|
// Globals, all of theses are 256 elements long
|
||||||
static-property-array Tile *tiles = 0x180e08;
|
static-property Tile *tiles[256] = 0x180e08;
|
||||||
static-property-array float lightEmission = 0x181214;
|
static-property float lightEmission[256] = 0x181214;
|
||||||
static-property-array bool isEntityTile = 0x181f20;
|
static-property bool isEntityTile[256] = 0x181f20;
|
||||||
|
|
||||||
// Tiles
|
// Tiles
|
||||||
static-property Tile *grass = 0x181b14;
|
static-property Tile *grass = 0x181b14;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user