From 3d80a69b478c7c435f19de3b69747458d216f914 Mon Sep 17 00:00:00 2001 From: Maksym H Date: Mon, 18 Sep 2023 17:17:57 +0300 Subject: [PATCH 1/4] Drop only 1 item if sneak is pressed --- builtin/game/item.lua | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/builtin/game/item.lua b/builtin/game/item.lua index bc42eb0fe..6ba42c2f2 100644 --- a/builtin/game/item.lua +++ b/builtin/game/item.lua @@ -6,6 +6,7 @@ local abs, atan2, cos, floor, max, sin, random = math.abs, math.atan2, math.cos, math.floor, math.max, math.sin, math.random local vadd, vnew, vmultiply, vnormalize, vsubtract = vector.add, vector.new, vector.multiply, vector.normalize, vector.subtract +local tcopy = table.copy local creative_mode = core.settings:get_bool("creative_mode") local node_drop = core.settings:get_bool("node_drop") @@ -529,14 +530,15 @@ end function core.item_drop(itemstack, dropper, pos) local dropper_is_player = dropper and dropper:is_player() - local p = table.copy(pos) - local cnt = itemstack:get_count() + local p = tcopy(pos) if not core.is_valid_pos(p) then return end if dropper_is_player then p.y = p.y + 1.2 end + local sneak = dropper_is_player and dropper:get_player_control().sneak + local cnt = sneak and 1 or itemstack:get_count() local item = itemstack:take_item(cnt) local obj = core.add_item(p, item) if obj then From 8a93f5492ed04fa66a0982a673838de4fa4f08d8 Mon Sep 17 00:00:00 2001 From: Maksym H Date: Thu, 21 Sep 2023 01:50:55 +0300 Subject: [PATCH 2/4] Apple: Xcode 15 support --- Apple/MultiCraft/MultiCraft.xcodeproj/project.pbxproj | 3 ++- Apple/scripts/SDL2.sh | 2 +- Apple/scripts/freetype.sh | 2 +- Apple/scripts/luajit.sh | 1 + 4 files changed, 5 insertions(+), 3 deletions(-) diff --git a/Apple/MultiCraft/MultiCraft.xcodeproj/project.pbxproj b/Apple/MultiCraft/MultiCraft.xcodeproj/project.pbxproj index 026216d41..f13ec878d 100644 --- a/Apple/MultiCraft/MultiCraft.xcodeproj/project.pbxproj +++ b/Apple/MultiCraft/MultiCraft.xcodeproj/project.pbxproj @@ -2215,6 +2215,7 @@ ENABLE_HARDENED_RUNTIME = YES; GCC_PREPROCESSOR_DEFINITIONS = ( "$(inherited)", + _LIBCPP_ENABLE_CXX17_REMOVED_UNARY_BINARY_FUNCTION, "RUN_IN_PLACE=0", "USE_GETTEXT=1", "USE_CURL=1", @@ -2283,8 +2284,8 @@ ENABLE_HARDENED_RUNTIME = YES; GCC_PREPROCESSOR_DEFINITIONS = ( "$(inherited)", - "COCOAPODS=1", "NDEBUG=1", + _LIBCPP_ENABLE_CXX17_REMOVED_UNARY_BINARY_FUNCTION, "RUN_IN_PLACE=0", "USE_GETTEXT=1", "USE_CURL=1", diff --git a/Apple/scripts/SDL2.sh b/Apple/scripts/SDL2.sh index 9c47bebf2..c1401a7e4 100755 --- a/Apple/scripts/SDL2.sh +++ b/Apple/scripts/SDL2.sh @@ -1,6 +1,6 @@ #!/bin/bash -e -SDL2_VERSION=release-2.28.2 +SDL2_VERSION=release-2.28.3 . scripts/sdk.sh mkdir -p deps; cd deps diff --git a/Apple/scripts/freetype.sh b/Apple/scripts/freetype.sh index a3e7e60bd..7976e48a8 100755 --- a/Apple/scripts/freetype.sh +++ b/Apple/scripts/freetype.sh @@ -1,6 +1,6 @@ #!/bin/bash -e -FREETYPE_VERSION=2.13.1 +FREETYPE_VERSION=2.13.2 . scripts/sdk.sh mkdir -p deps; cd deps diff --git a/Apple/scripts/luajit.sh b/Apple/scripts/luajit.sh index 4c7f6cdf6..33f866184 100755 --- a/Apple/scripts/luajit.sh +++ b/Apple/scripts/luajit.sh @@ -29,6 +29,7 @@ rm templib_*.a mkdir -p ../luajit/include cp -v src/*.h ../luajit/include +cp -v ../luajit/include/luajit_rolling.h ../luajit/include/luajit.h cp -v libluajit.a ../luajit echo "LuaJIT build successful" From 6cc875cc32a83dc1c532af68970705a28c0887a2 Mon Sep 17 00:00:00 2001 From: Maksym H Date: Thu, 21 Sep 2023 01:48:29 +0300 Subject: [PATCH 3/4] MainMenu: minor cleanup --- builtin/mainmenu/init.lua | 19 +- builtin/mainmenu/tab_settings_simple.lua | 286 ----------------------- 2 files changed, 6 insertions(+), 299 deletions(-) delete mode 100644 builtin/mainmenu/tab_settings_simple.lua diff --git a/builtin/mainmenu/init.lua b/builtin/mainmenu/init.lua index bb4545ce6..641f203bc 100644 --- a/builtin/mainmenu/init.lua +++ b/builtin/mainmenu/init.lua @@ -23,7 +23,6 @@ mt_color_orange = "#FF8800" local menupath = core.get_mainmenu_path() local basepath = core.get_builtin_path() -local mobile = PLATFORM == "Android" or PLATFORM == "iOS" defaulttexturedir = core.get_texturepath_share() .. DIR_DELIM .. "base" .. DIR_DELIM .. "pack" .. DIR_DELIM defaulttexturedir_esc = core.formspec_escape(defaulttexturedir) @@ -42,26 +41,17 @@ dofile(menupath .. DIR_DELIM .. "serverlistmgr.lua") dofile(menupath .. DIR_DELIM .. "textures.lua") dofile(menupath .. DIR_DELIM .. "dlg_config_world.lua") +dofile(menupath .. DIR_DELIM .. "dlg_settings_advanced.lua") dofile(menupath .. DIR_DELIM .. "dlg_contentstore.lua") dofile(menupath .. DIR_DELIM .. "dlg_create_world.lua") dofile(menupath .. DIR_DELIM .. "dlg_delete_content.lua") dofile(menupath .. DIR_DELIM .. "dlg_delete_world.lua") dofile(menupath .. DIR_DELIM .. "dlg_rename_modpack.lua") - -if not mobile then - dofile(menupath .. DIR_DELIM .. "dlg_settings_advanced.lua") -end - dofile(menupath .. DIR_DELIM .. "dlg_version_info.lua") local tabs = {} -if not mobile then - tabs.settings = dofile(menupath .. DIR_DELIM .. "tab_settings.lua") -else - tabs.settings = dofile(menupath .. DIR_DELIM .. "tab_settings_simple.lua") -end - +tabs.settings = dofile(menupath .. DIR_DELIM .. "tab_settings.lua") tabs.content = dofile(menupath .. DIR_DELIM .. "tab_content.lua") tabs.credits = dofile(menupath .. DIR_DELIM .. "tab_credits.lua") tabs.local_game = dofile(menupath .. DIR_DELIM .. "tab_local.lua") @@ -135,6 +125,7 @@ function menudata.init_tabs() texture_prefix = "authors" }) + tv_main:set_autosave_tab(true) tv_main:add(tabs.local_game) if func then func(tv_main) @@ -145,7 +136,6 @@ function menudata.init_tabs() tv_main:add(tabs.settings) tv_main:add(tabs.credits) - tv_main:set_autosave_tab(true) tv_main:set_global_event_handler(main_event_handler) tv_main:set_fixed_size(false) @@ -172,7 +162,10 @@ function menudata.init_tabs() check_new_version() tv_main:show() + ui.update() + +-- core.sound_play("main_menu", true) end menudata.init_tabs() diff --git a/builtin/mainmenu/tab_settings_simple.lua b/builtin/mainmenu/tab_settings_simple.lua deleted file mode 100644 index aba7e5683..000000000 --- a/builtin/mainmenu/tab_settings_simple.lua +++ /dev/null @@ -1,286 +0,0 @@ ---Minetest ---Copyright (C) 2020-2022 MultiCraft Development Team ---Copyright (C) 2013 sapier --- ---This program is free software; you can redistribute it and/or modify ---it under the terms of the GNU Lesser General Public License as published by ---the Free Software Foundation; either version 3.0 of the License, or ---(at your option) any later version. --- ---This program is distributed in the hope that it will be useful, ---but WITHOUT ANY WARRANTY; without even the implied warranty of ---MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ---GNU Lesser General Public License for more details. --- ---You should have received a copy of the GNU Lesser General Public License along ---with this program; if not, write to the Free Software Foundation, Inc., ---51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. - -local function create_confirm_reset_dlg() - return dialog_create("reset_all_settings", - function() - return table.concat({ - "real_coordinates[true]", - "image[6.5,0.8;2.5,2.5;", defaulttexturedir_esc, "attention.png]", - - "style[msg;content_offset=0]", - "image_button[1,3.5;13.5,0.8;;msg;", - fgettext("Reset all settings?"), ";false;false]", - - btn_style("reset_confirm", "red"), - "image_button[4.1,5.3;3.5,0.8;;reset_confirm;", - fgettext("Reset"), ";true;false]", - - btn_style("reset_cancel"), - "image_button[7.9,5.3;3.5,0.8;;reset_cancel;", - fgettext("Cancel"), ";true;false]", - }) - end, - function(this, fields) - if fields["reset_confirm"] then - for _, setting_name in ipairs(core.settings:get_names()) do - if not setting_name:find(".", 1, true) and - setting_name ~= "maintab_LAST" then - core.settings:remove(setting_name) - end - end - - -- Reload the entire main menu - dofile(core.get_builtin_path() .. "init.lua") - return true - end - - if fields["reset_cancel"] then - this:delete() - return true - end - end, - nil, true) -end - --------------------------------------------------------------------------------- - -local languages, lang_idx, language_labels = get_language_list() - -local node_highlighting_labels = { - fgettext("Node Outlining"), - fgettext("Node Highlighting"), - fgettext("None") -} - -local fps_max_labels = {"30", "60", "90", [-1] = "45"} - -local dd_options = { - -- "30 FPS" actually sets 35 FPS for some reason - fps_max = {"35", "60", "90"}, - language = languages, - node_highlighting = {"box", "halo", "none"}, - viewing_range = {"30", "40", "60", "80", "100", "125", "150", "175", "200"}, -} - -local getSettingIndex = { - NodeHighlighting = function() - local style = core.settings:get("node_highlighting") - for idx, name in pairs(dd_options.node_highlighting) do - if style == name then return idx end - end - return 1 - end -} - -local function setting_cb(x, y, setting, label) - return checkbox(x, y, "cb_" .. setting, label, core.settings:get_bool(setting), true) -end - -local function disabled_cb(x, y, _, label) - return ("label[%s,%s;%s]"):format(x + 0.6, y, core.colorize("#888", label)) -end - -local open_dropdown -local guitexturedir = defaulttexturedir_esc .. "gui" .. DIR_DELIM_esc -local function formspec(tabview, name, tabdata) - local fps = tonumber(core.settings:get("fps_max")) - local range = tonumber(core.settings:get("viewing_range")) - local sensitivity = tonumber(core.settings:get("touch_sensitivity") or 0) * 2000 - local touchtarget = core.settings:get_bool("touchtarget", false) - local fancy_leaves = core.settings:get("leaves_style") == "fancy" - local sound = tonumber(core.settings:get("sound_volume")) ~= 0 - - local video_driver = core.settings:get("video_driver") - local shaders_enabled = video_driver == "opengl" or video_driver == "ogles2" - core.settings:set_bool("enable_shaders", shaders_enabled) - - local open_dropdown_fs - local function dropdown(x, y, w, name, items, selected_idx, max_items, container_pos) - local dd = get_dropdown(x, y, w, name, items, selected_idx, open_dropdown == name, max_items) - if open_dropdown == name then - open_dropdown_fs = dd - -- Items positioned inside scroll containers are very slightly - -- offset from the same item in a regular container - if container_pos then - open_dropdown_fs = "scroll_container[" .. container_pos .. ";" .. w + x + 1 .. ",10;;vertical;0]" .. - open_dropdown_fs .. - "scroll_container_end[]" - end - return "" - end - return dd - end - - local shader_cb = shaders_enabled and setting_cb or disabled_cb - local fs = { - "formspec_version[4]", - "real_coordinates[true]", - "background9[0.5,0.5;4.8,6.4;", defaulttexturedir_esc, "desc_bg.png;false;32]", - - -- A scroll container is used so that long labels are clipped - "scroll_container[0.5,0.5;4.8,6.4;;vertical;0]", - - setting_cb(0.3, 0.5, "smooth_lighting", fgettext("Smooth Lighting")), - setting_cb(0.3, 1.175, "enable_particles", fgettext("Particles")), - setting_cb(0.3, 1.85, "enable_3d_clouds", fgettext("3D Clouds")), - -- setting_cb(0.3, y, "opaque_water", fgettext("Opaque Water")), - -- setting_cb(0.3, y, "connected_glass", fgettext("Connected Glass")), - setting_cb(0.3, 2.525, "enable_fog", fgettext("Fog")), - setting_cb(0.3, 3.2, "inventory_items_animations", fgettext("Inv. animations")), - - -- Some checkboxes don't directly have a boolean setting so they need - -- to be handled separately - checkbox(0.3, 3.875, "fancy_leaves", fgettext("Fancy Leaves"), fancy_leaves, true), - checkbox(0.3, 4.55, "crosshair", fgettext("Crosshair"), not touchtarget, true), - setting_cb(0.3, 5.225, "arm_inertia", fgettext("Arm inertia")), - checkbox(0.3, 5.9, "sound", fgettext("Sound"), sound, true), - - "scroll_container_end[]", - - -- Middle column - "background9[5.6,0.5;4.8,6.4;", defaulttexturedir_esc, "desc_bg.png;false;32]", - "scroll_container[5.6,0.5;4.8,6.4;;vertical;0]", - "label[0.3,0.5;", fgettext("Maximum FPS"), ":]", - dropdown(0.3, 0.8, 4.2, "dd_fps_max", fps_max_labels, - fps <= 35 and 1 or fps == 45 and -1 or fps == 60 and 2 or 3, nil, "5.6,0.5"), - - "label[0.3,2;", fgettext("Viewing range"), ":]", - dropdown(0.3, 2.3, 4.2, "dd_viewing_range", dd_options.viewing_range, - range <= 30 and 1 or range == 40 and 2 or range == 60 and 3 or - range == 80 and 4 or range == 100 and 5 or range == 125 and 6 or - range == 150 and 7 or range == 175 and 8 or 9, 4.5, "5.6,0.5"), - - "label[0.3,3.5;", fgettext("Node highlighting"), ":]", - dropdown(0.3, 3.8, 4.2, "dd_node_highlighting", node_highlighting_labels, - getSettingIndex.NodeHighlighting(), nil, "5.6,0.5"), - - "label[0.3,5;", fgettext("Mouse sensitivity"), ":]", - "scrollbar[0.3,5.3;4.2,0.8;horizontal;sb_sensitivity;", tostring(sensitivity), ";", - guitexturedir, "scrollbar_horiz_bg.png,", guitexturedir, "scrollbar_slider.png,", - guitexturedir, "scrollbar_minus.png,", guitexturedir, "scrollbar_plus.png]", - "scroll_container_end[]", - - -- Right column - "background9[10.7,0.5;4.8,1.9;", defaulttexturedir_esc, "desc_bg.png;false;32]", - "label[11,1;", fgettext("Language"), ":]", - dropdown(11, 1.3, 4.2, "dd_language", language_labels, lang_idx, 6.4), - - "background9[10.7,2.6;4.8,4.3;", defaulttexturedir_esc, "desc_bg.png;false;32]", - "scroll_container[10.7,2.6;4.8,4.3;;vertical;0]", - "label[0.3,0.5;", shaders_enabled and fgettext("Shaders") or - core.colorize("#888888", fgettext("Shaders (unavailable)")), "]", - shader_cb(0.3, 1, "tone_mapping", fgettext("Tone Mapping")), - shader_cb(0.3, 1.6, "enable_waving_water", fgettext("Waving liquids")), - shader_cb(0.3, 2.2, "enable_waving_leaves", fgettext("Waving leaves")), - shader_cb(0.3, 2.8, "enable_waving_plants", fgettext("Waving plants")), - "scroll_container_end[]", - - btn_style("btn_reset"), - "button[11,5.8;4.2,0.8;btn_reset;", fgettext("Reset all settings"), "]", - } - - -- Show the open dropdown (if any) last - fs[#fs + 1] = open_dropdown_fs - fs[#fs + 1] = "real_coordinates[false]" - - return table.concat(fs) -end - --------------------------------------------------------------------------------- -local function handle_settings_buttons(this, fields, tabname, tabdata) ---[[if fields["btn_advanced_settings"] ~= nil then - local adv_settings_dlg = create_adv_settings_dlg() - adv_settings_dlg:set_parent(this) - this:hide() - adv_settings_dlg:show() - return true - end]] - - for field in pairs(fields) do - if field:sub(1, 3) == "cb_" then - -- Checkboxes - local setting_name = field:sub(4) - core.settings:set_bool(setting_name, not core.settings:get_bool(setting_name)) - return true - elseif field:sub(1, 3) == "dd_" then - -- Dropdown buttons - open_dropdown = field - return true - elseif open_dropdown and field:sub(1, 9) == "dropdown_" then - -- Dropdown fields - local i = tonumber(field:sub(10)) - local setting = open_dropdown:sub(4) - if i and dd_options[setting] then - core.settings:set(setting, dd_options[setting][i]) - - -- Reload the main menu so that everything uses the new language - if setting == "language" then - dofile(core.get_builtin_path() .. "init.lua") - end - end - - open_dropdown = nil - return true - end - end - - -- Special checkboxes - if fields["fancy_leaves"] then - core.settings:set("leaves_style", core.settings:get("leaves_style") == "fancy" and "opaque" or "fancy") - return true - end - if fields["crosshair"] then - core.settings:set_bool("touchtarget", not core.settings:get_bool("touchtarget")) - return true - end - if fields["sound"] then - core.settings:set("sound_volume", tonumber(core.settings:get("sound_volume")) == 0 and "1.0" or "0.0") - return true - end - ---[[if fields["btn_change_keys"] then - core.show_keys_menu() - return true - end]] - - if fields["btn_reset"] then - local reset_dlg = create_confirm_reset_dlg() - reset_dlg:set_parent(this) - this:hide() - reset_dlg:show() - return true - end - - if fields["sb_sensitivity"] then - -- reset old setting - core.settings:remove("touchscreen_threshold") - - local event = core.explode_scrollbar_event(fields["sb_sensitivity"]) - if event.type == "CHG" then - core.settings:set("touch_sensitivity", event.value / 2000) - end - end -end - -return { - name = "settings", - caption = "", -- fgettext("Settings"), - cbf_formspec = formspec, - cbf_button_handler = handle_settings_buttons -} From 5b9ca22c572d1da3150f4e6023797cb75a51be96 Mon Sep 17 00:00:00 2001 From: Deve Date: Thu, 21 Sep 2023 23:14:00 +0200 Subject: [PATCH 4/4] Free loaded data after alBufferData() (#147) https://github.com/kcat/openal-soft/blob/master/examples/alplay.c#L266 --- src/client/sound_openal.cpp | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/client/sound_openal.cpp b/src/client/sound_openal.cpp index 434f3807f..5246c6dcf 100644 --- a/src/client/sound_openal.cpp +++ b/src/client/sound_openal.cpp @@ -109,7 +109,6 @@ struct SoundBuffer ALenum format; ALsizei freq; ALuint buffer_id; - std::vector buffer; }; SoundBuffer *load_opened_ogg_file(OggVorbis_File *oggFile, @@ -120,6 +119,7 @@ SoundBuffer *load_opened_ogg_file(OggVorbis_File *oggFile, long bytes; char array[BUFFER_SIZE]; // Local fixed size array vorbis_info *pInfo; + std::vector buffer; SoundBuffer *snd = new SoundBuffer; @@ -151,12 +151,12 @@ SoundBuffer *load_opened_ogg_file(OggVorbis_File *oggFile, } // Append to end of buffer - snd->buffer.insert(snd->buffer.end(), array, array + bytes); + buffer.insert(buffer.end(), array, array + bytes); } while (bytes > 0); alGenBuffers(1, &snd->buffer_id); alBufferData(snd->buffer_id, snd->format, - &(snd->buffer[0]), snd->buffer.size(), + &buffer[0], buffer.size(), snd->freq); ALenum error = alGetError(); @@ -170,6 +170,7 @@ SoundBuffer *load_opened_ogg_file(OggVorbis_File *oggFile, // << filename_for_logging << " loaded" << std::endl; // Clean up! + buffer.clear(); ov_clear(oggFile); return snd;