From cef621d3d341296542d9d83ed2679ae1c847559c Mon Sep 17 00:00:00 2001
From: sumoomus <>
Date: Mon, 22 Jun 2020 15:08:05 -0400
Subject: [PATCH] 5.0.1 minetest release
downloaded from:
https://github.com/minetest/minetest/releases
---
.DS_Store | Bin 0 -> 6148 bytes
.clang-format | 30 +
.clang-tidy | 4 +
.gitattributes | 2 +
.github/ISSUE_TEMPLATE.md | 31 +
.gitignore | 113 +
.gitlab-ci.yml | 324 +
.mailmap | 33 +
.travis.yml | 109 +
CMakeLists.txt | 328 +
CONTRIBUTING.md | 111 +
Dockerfile | 40 +
LICENSE.txt | 171 +
build/android/Makefile | 766 ++
build/android/build.gradle | 170 +
.../android/gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 54731 bytes
.../gradle/wrapper/gradle-wrapper.properties | 6 +
build/android/gradlew | 172 +
build/android/gradlew.bat | 84 +
build/android/icons/aux_btn.svg | 411 +
build/android/icons/camera_btn.svg | 108 +
build/android/icons/chat_btn.svg | 96 +
build/android/icons/chat_hide_btn.svg | 139 +
build/android/icons/chat_show_btn.svg | 133 +
build/android/icons/checkbox_tick.svg | 93 +
build/android/icons/debug_btn.svg | 344 +
build/android/icons/down.svg | 542 ++
build/android/icons/drop_btn.svg | 173 +
build/android/icons/fast_btn.svg | 190 +
build/android/icons/fly_btn.svg | 168 +
build/android/icons/gear_icon.svg | 194 +
build/android/icons/inventory_btn.svg | 509 ++
build/android/icons/joystick_bg.svg | 876 ++
build/android/icons/joystick_center.svg | 877 ++
build/android/icons/joystick_off.svg | 882 ++
build/android/icons/jump_btn.svg | 547 ++
build/android/icons/minimap_btn.svg | 159 +
build/android/icons/noclip_btn.svg | 173 +
build/android/icons/rangeview_btn.svg | 456 +
build/android/icons/rare_controls.svg | 521 ++
build/android/icons/zoom.svg | 599 ++
build/android/jni/Android.mk | 434 +
build/android/jni/Application.mk | 9 +
build/android/jni/Deps.mk | 7 +
build/android/jni/Irrlicht.mk | 8 +
.../patches/irrlicht-back_button.patch | 20 +
.../patches/irrlicht-native_activity.patch | 13 +
.../patches/irrlicht-texturehack.patch | 240 +
.../android/patches/irrlicht-touchcount.patch | 30 +
build/android/patches/libiconv_android.patch | 39 +
build/android/patches/libiconv_stdio.patch | 13 +
.../patches/libvorbis-libogg-fpu.patch | 37 +
build/android/patches/openssl_arch.patch | 13 +
build/android/settings.gradle | 1 +
build/android/src/debug/AndroidManifest.xml | 5 +
build/android/src/main/AndroidManifest.xml | 59 +
.../net.minetest.minetest/MainActivity.java | 79 +
.../MinetestAssetCopy.java | 373 +
.../MinetestTextEntry.java | 87 +
.../MtNativeActivity.java | 111 +
.../src/main/res/drawable/background.png | Bin 0 -> 83 bytes
build/android/src/main/res/drawable/bg.xml | 4 +
.../android/src/main/res/layout/assetcopy.xml | 24 +
.../src/main/res/mipmap/ic_launcher.png | Bin 0 -> 5780 bytes
.../src/main/res/values-v21/styles.xml | 12 +
build/android/src/main/res/values/strings.xml | 5 +
build/android/src/main/res/values/styles.xml | 12 +
builtin/async/init.lua | 17 +
builtin/client/chatcommands.lua | 70 +
builtin/client/death_formspec.lua | 16 +
builtin/client/init.lua | 11 +
builtin/client/register.lua | 76 +
builtin/common/after.lua | 33 +
builtin/common/async_event.lua | 40 +
builtin/common/chatcommands.lua | 112 +
builtin/common/filterlist.lua | 320 +
builtin/common/misc_helpers.lua | 746 ++
builtin/common/serialize.lua | 221 +
builtin/common/strict.lua | 57 +
builtin/common/vector.lua | 124 +
builtin/fstk/buttonbar.lua | 215 +
builtin/fstk/dialog.lua | 69 +
builtin/fstk/tabview.lua | 273 +
builtin/fstk/ui.lua | 208 +
builtin/game/auth.lua | 185 +
builtin/game/chatcommands.lua | 1058 +++
builtin/game/constants.lua | 31 +
builtin/game/deprecated.lua | 72 +
builtin/game/detached_inventory.lua | 24 +
builtin/game/falling.lua | 327 +
builtin/game/features.lua | 34 +
builtin/game/forceloading.lua | 100 +
builtin/game/init.lua | 36 +
builtin/game/item.lua | 785 ++
builtin/game/item_entity.lua | 228 +
builtin/game/misc.lua | 272 +
builtin/game/privileges.lua | 101 +
builtin/game/register.lua | 603 ++
builtin/game/statbars.lua | 171 +
builtin/game/static_spawn.lua | 23 +
builtin/game/voxelarea.lua | 132 +
builtin/init.lua | 52 +
builtin/mainmenu/common.lua | 348 +
builtin/mainmenu/dlg_config_world.lua | 260 +
builtin/mainmenu/dlg_contentstore.lua | 607 ++
builtin/mainmenu/dlg_create_world.lua | 170 +
builtin/mainmenu/dlg_delete_content.lua | 74 +
builtin/mainmenu/dlg_delete_world.lua | 61 +
builtin/mainmenu/dlg_rename_modpack.lua | 73 +
builtin/mainmenu/dlg_settings_advanced.lua | 1079 +++
.../mainmenu/generate_from_settingtypes.lua | 129 +
builtin/mainmenu/init.lua | 160 +
builtin/mainmenu/pkgmgr.lua | 789 ++
builtin/mainmenu/tab_content.lua | 216 +
builtin/mainmenu/tab_credits.lua | 132 +
builtin/mainmenu/tab_local.lua | 327 +
builtin/mainmenu/tab_online.lua | 359 +
builtin/mainmenu/tab_settings.lua | 428 +
builtin/mainmenu/tab_simple_main.lua | 220 +
builtin/mainmenu/textures.lua | 185 +
builtin/profiler/init.lua | 80 +
builtin/profiler/instrumentation.lua | 232 +
builtin/profiler/reporter.lua | 277 +
builtin/profiler/sampling.lua | 206 +
builtin/settingtypes.txt | 1943 ++++
client/serverlist/.gitignore | 2 +
.../3d_interlaced_merge/opengl_fragment.glsl | 21 +
.../3d_interlaced_merge/opengl_vertex.glsl | 6 +
.../default_shader/opengl_fragment.glsl | 4 +
.../shaders/default_shader/opengl_vertex.glsl | 9 +
.../minimap_shader/opengl_fragment.glsl | 32 +
.../shaders/minimap_shader/opengl_vertex.glsl | 9 +
.../shaders/nodes_shader/opengl_fragment.glsl | 219 +
.../shaders/nodes_shader/opengl_vertex.glsl | 144 +
.../selection_shader/opengl_fragment.glsl | 9 +
.../selection_shader/opengl_vertex.glsl | 9 +
.../wielded_shader/opengl_fragment.glsl | 127 +
.../shaders/wielded_shader/opengl_vertex.glsl | 32 +
clientmods/preview/example.lua | 2 +
clientmods/preview/examples/first.lua | 1 +
clientmods/preview/init.lua | 207 +
cmake/Modules/FindCURL.cmake | 19 +
cmake/Modules/FindGMP.cmake | 27 +
cmake/Modules/FindGettextLib.cmake | 78 +
cmake/Modules/FindIrrlicht.cmake | 73 +
cmake/Modules/FindJson.cmake | 26 +
cmake/Modules/FindLua.cmake | 28 +
cmake/Modules/FindLuaJIT.cmake | 50 +
cmake/Modules/FindNcursesw.cmake | 204 +
cmake/Modules/FindOpenGLES2.cmake | 112 +
cmake/Modules/FindSQLite3.cmake | 9 +
cmake/Modules/FindVorbis.cmake | 46 +
cmake/Modules/GenerateVersion.cmake | 26 +
doc/Doxyfile.in | 53 +
doc/README.android | 128 +
doc/client_lua_api.txt | 1375 +++
doc/fst_api.txt | 171 +
doc/lgpl-2.1.txt | 502 ++
doc/lua_api.txt | 6938 +++++++++++++++
doc/main_page.dox | 8 +
doc/menu_lua_api.txt | 243 +
doc/minetest.6 | 134 +
doc/minetestserver.6 | 2 +
doc/mod_channels.png | Bin 0 -> 349332 bytes
doc/protocol.txt | 110 +
doc/texture_packs.txt | 211 +
doc/world_format.txt | 668 ++
fonts/Arimo-LICENSE.txt | 2 +
fonts/Arimo-Regular.ttf | Bin 0 -> 436876 bytes
fonts/Cousine-LICENSE.txt | 2 +
fonts/Cousine-Regular.ttf | Bin 0 -> 309040 bytes
fonts/DroidSansFallbackFull-LICENSE.txt | 13 +
fonts/DroidSansFallbackFull.ttf | Bin 0 -> 4529044 bytes
fonts/mono_dejavu_sans_10.xml | Bin 0 -> 257014 bytes
fonts/mono_dejavu_sans_100.png | Bin 0 -> 56121 bytes
fonts/mono_dejavu_sans_11.xml | Bin 0 -> 263644 bytes
fonts/mono_dejavu_sans_110.png | Bin 0 -> 67613 bytes
fonts/mono_dejavu_sans_12.xml | Bin 0 -> 268932 bytes
fonts/mono_dejavu_sans_120.png | Bin 0 -> 73938 bytes
fonts/mono_dejavu_sans_14.xml | Bin 0 -> 269188 bytes
fonts/mono_dejavu_sans_140.png | Bin 0 -> 89073 bytes
fonts/mono_dejavu_sans_16.xml | Bin 0 -> 275642 bytes
fonts/mono_dejavu_sans_160.png | Bin 0 -> 101939 bytes
fonts/mono_dejavu_sans_18.xml | Bin 0 -> 279962 bytes
fonts/mono_dejavu_sans_180.png | Bin 0 -> 122274 bytes
fonts/mono_dejavu_sans_20.xml | Bin 0 -> 282588 bytes
fonts/mono_dejavu_sans_200.png | Bin 0 -> 138662 bytes
fonts/mono_dejavu_sans_22.xml | Bin 0 -> 283950 bytes
fonts/mono_dejavu_sans_220.png | Bin 0 -> 152844 bytes
fonts/mono_dejavu_sans_24.xml | Bin 0 -> 286626 bytes
fonts/mono_dejavu_sans_240.png | Bin 0 -> 170247 bytes
fonts/mono_dejavu_sans_26.xml | Bin 0 -> 289710 bytes
fonts/mono_dejavu_sans_260.png | Bin 0 -> 190156 bytes
fonts/mono_dejavu_sans_28.xml | Bin 0 -> 292596 bytes
fonts/mono_dejavu_sans_280.png | Bin 0 -> 200848 bytes
fonts/mono_dejavu_sans_4.xml | Bin 0 -> 237740 bytes
fonts/mono_dejavu_sans_40.png | Bin 0 -> 15668 bytes
fonts/mono_dejavu_sans_6.xml | Bin 0 -> 245472 bytes
fonts/mono_dejavu_sans_60.png | Bin 0 -> 29291 bytes
fonts/mono_dejavu_sans_8.xml | Bin 0 -> 251876 bytes
fonts/mono_dejavu_sans_80.png | Bin 0 -> 45552 bytes
fonts/mono_dejavu_sans_9.xml | Bin 0 -> 254016 bytes
fonts/mono_dejavu_sans_90.png | Bin 0 -> 50995 bytes
games/minimal/game.conf | 2 +
games/minimal/menu/background.png | Bin 0 -> 392 bytes
games/minimal/menu/icon.png | Bin 0 -> 218 bytes
games/minimal/mods/bucket/init.lua | 95 +
games/minimal/mods/bucket/mod.conf | 3 +
games/minimal/mods/bucket/textures/bucket.png | Bin 0 -> 182 bytes
.../mods/bucket/textures/bucket_lava.png | Bin 0 -> 183 bytes
.../mods/bucket/textures/bucket_water.png | Bin 0 -> 180 bytes
games/minimal/mods/default/init.lua | 1898 ++++
games/minimal/mods/default/mapgen.lua | 137 +
games/minimal/mods/default/mod.conf | 2 +
.../sounds/default_grass_footstep.1.ogg | Bin 0 -> 7014 bytes
.../minimal/mods/default/textures/bubble.png | Bin 0 -> 273 bytes
.../mods/default/textures/crack_anylength.png | Bin 0 -> 255 bytes
.../mods/default/textures/default_apple.png | Bin 0 -> 109 bytes
.../mods/default/textures/default_book.png | Bin 0 -> 157 bytes
.../default/textures/default_bookshelf.png | Bin 0 -> 515 bytes
.../mods/default/textures/default_brick.png | Bin 0 -> 457 bytes
.../default/textures/default_cactus_side.png | Bin 0 -> 144 bytes
.../default/textures/default_cactus_top.png | Bin 0 -> 121 bytes
.../mods/default/textures/default_chest.png | Bin 0 -> 263 bytes
.../mods/default/textures/default_clay.png | Bin 0 -> 318 bytes
.../default/textures/default_clay_brick.png | Bin 0 -> 173 bytes
.../default/textures/default_clay_lump.png | Bin 0 -> 140 bytes
.../mods/default/textures/default_cloud.png | Bin 0 -> 83 bytes
.../default/textures/default_coal_lump.png | Bin 0 -> 138 bytes
.../mods/default/textures/default_cobble.png | Bin 0 -> 374 bytes
.../mods/default/textures/default_dirt.png | Bin 0 -> 1586 bytes
.../mods/default/textures/default_fence.png | Bin 0 -> 480 bytes
.../textures/default_furnace_fire_bg.png | Bin 0 -> 220 bytes
.../textures/default_furnace_fire_fg.png | Bin 0 -> 719 bytes
.../textures/default_furnace_front.png | Bin 0 -> 159 bytes
.../textures/default_furnace_front_active.png | Bin 0 -> 283 bytes
.../default/textures/default_furnace_side.png | Bin 0 -> 125 bytes
.../mods/default/textures/default_glass.png | Bin 0 -> 210 bytes
.../mods/default/textures/default_grass.png | Bin 0 -> 782 bytes
.../textures/default_grass_footsteps.png | Bin 0 -> 771 bytes
.../default/textures/default_grass_side.png | Bin 0 -> 878 bytes
.../mods/default/textures/default_gravel.png | Bin 0 -> 172 bytes
.../default/textures/default_iron_lump.png | Bin 0 -> 140 bytes
.../default/textures/default_junglegrass.png | Bin 0 -> 237 bytes
.../mods/default/textures/default_ladder.png | Bin 0 -> 368 bytes
.../mods/default/textures/default_lava.png | Bin 0 -> 172 bytes
.../default_lava_flowing_animated.png | Bin 0 -> 7818 bytes
.../textures/default_lava_source_animated.png | Bin 0 -> 3145 bytes
.../mods/default/textures/default_leaves.png | Bin 0 -> 1683 bytes
.../mods/default/textures/default_mese.png | Bin 0 -> 129 bytes
.../default/textures/default_mineral_coal.png | Bin 0 -> 142 bytes
.../default/textures/default_mineral_iron.png | Bin 0 -> 922 bytes
.../default/textures/default_mossycobble.png | Bin 0 -> 603 bytes
.../mods/default/textures/default_nc_back.png | Bin 0 -> 186 bytes
.../default/textures/default_nc_front.png | Bin 0 -> 204 bytes
.../mods/default/textures/default_nc_rb.png | Bin 0 -> 137 bytes
.../mods/default/textures/default_nc_side.png | Bin 0 -> 148 bytes
.../mods/default/textures/default_paper.png | Bin 0 -> 139 bytes
.../mods/default/textures/default_papyrus.png | Bin 0 -> 165 bytes
.../mods/default/textures/default_rail.png | Bin 0 -> 437 bytes
.../textures/default_rail_crossing.png | Bin 0 -> 388 bytes
.../default/textures/default_rail_curved.png | Bin 0 -> 375 bytes
.../textures/default_rail_t_junction.png | Bin 0 -> 374 bytes
.../default/textures/default_river_water.png | Bin 0 -> 716 bytes
.../mods/default/textures/default_sand.png | Bin 0 -> 762 bytes
.../default/textures/default_sandstone.png | Bin 0 -> 744 bytes
.../mods/default/textures/default_sapling.png | Bin 0 -> 328 bytes
.../textures/default_scorched_stuff.png | Bin 0 -> 164 bytes
.../default/textures/default_sign_wall.png | Bin 0 -> 416 bytes
.../default/textures/default_steel_block.png | Bin 0 -> 128 bytes
.../default/textures/default_steel_ingot.png | Bin 0 -> 144 bytes
.../mods/default/textures/default_stick.png | Bin 0 -> 120 bytes
.../mods/default/textures/default_stone.png | Bin 0 -> 389 bytes
.../default/textures/default_tnt_bottom.png | Bin 0 -> 98 bytes
.../default/textures/default_tnt_side.png | Bin 0 -> 129 bytes
.../mods/default/textures/default_tnt_top.png | Bin 0 -> 146 bytes
.../textures/default_tool_mesepick.png | Bin 0 -> 155 bytes
.../textures/default_tool_steelaxe.png | Bin 0 -> 140 bytes
.../textures/default_tool_steelpick.png | Bin 0 -> 163 bytes
.../textures/default_tool_steelshovel.png | Bin 0 -> 144 bytes
.../textures/default_tool_steelsword.png | Bin 0 -> 169 bytes
.../textures/default_tool_stoneaxe.png | Bin 0 -> 141 bytes
.../textures/default_tool_stonepick.png | Bin 0 -> 155 bytes
.../textures/default_tool_stoneshovel.png | Bin 0 -> 144 bytes
.../textures/default_tool_stonesword.png | Bin 0 -> 168 bytes
.../default/textures/default_tool_woodaxe.png | Bin 0 -> 134 bytes
.../textures/default_tool_woodpick.png | Bin 0 -> 149 bytes
.../textures/default_tool_woodshovel.png | Bin 0 -> 135 bytes
.../textures/default_tool_woodsword.png | Bin 0 -> 147 bytes
.../mods/default/textures/default_torch.png | Bin 0 -> 146 bytes
.../textures/default_torch_on_ceiling.png | Bin 0 -> 137 bytes
.../textures/default_torch_on_floor.png | Bin 0 -> 138 bytes
.../mods/default/textures/default_tree.png | Bin 0 -> 1445 bytes
.../default/textures/default_tree_top.png | Bin 0 -> 177 bytes
.../mods/default/textures/default_water.png | Bin 0 -> 302 bytes
.../mods/default/textures/default_wood.png | Bin 0 -> 1400 bytes
games/minimal/mods/default/textures/heart.png | Bin 0 -> 248 bytes
.../minimal/mods/default/textures/player.png | Bin 0 -> 157 bytes
.../mods/default/textures/player_back.png | Bin 0 -> 149 bytes
.../mods/default/textures/treeprop.png | Bin 0 -> 757 bytes
.../mods/default/textures/wieldhand.png | Bin 0 -> 212 bytes
games/minimal/mods/experimental/init.lua | 822 ++
games/minimal/mods/experimental/mod.conf | 3 +
.../minimal/mods/experimental/modchannels.lua | 16 +
.../textures/experimental_dummyball.png | Bin 0 -> 399 bytes
.../textures/experimental_tester_tool_1.png | Bin 0 -> 160 bytes
.../textures/experimental_tiled.png | Bin 0 -> 1041 bytes
.../minimal/mods/give_initial_stuff/init.lua | 16 +
.../minimal/mods/give_initial_stuff/mod.conf | 3 +
games/minimal/mods/legacy/init.lua | 128 +
games/minimal/mods/legacy/mod.conf | 3 +
.../mods/legacy/textures/apple_iron.png | Bin 0 -> 119 bytes
.../mods/legacy/textures/cooked_rat.png | Bin 0 -> 145 bytes
.../mods/legacy/textures/dungeon_master.png | Bin 0 -> 3007 bytes
.../minimal/mods/legacy/textures/fireball.png | Bin 0 -> 279 bytes
.../minimal/mods/legacy/textures/firefly.png | Bin 0 -> 99 bytes
.../minimal/mods/legacy/textures/oerkki1.png | Bin 0 -> 165 bytes
.../mods/legacy/textures/oerkki1_damaged.png | Bin 0 -> 210 bytes
games/minimal/mods/legacy/textures/rat.png | Bin 0 -> 141 bytes
games/minimal/mods/stairs/init.lua | 93 +
games/minimal/mods/stairs/mod.conf | 3 +
games/minimal/mods/test/init.lua | 83 +
games/minimal/mods/test/mod.conf | 2 +
lib/gmp/CMakeLists.txt | 3 +
lib/gmp/mini-gmp.c | 4130 +++++++++
lib/gmp/mini-gmp.h | 256 +
lib/jsoncpp/CMakeLists.txt | 3 +
lib/jsoncpp/json/UPDATING | 7 +
lib/jsoncpp/json/json-forwards.h | 333 +
lib/jsoncpp/json/json.h | 2207 +++++
lib/jsoncpp/jsoncpp.cpp | 5386 ++++++++++++
lib/lua/CMakeLists.txt | 77 +
lib/lua/COPYRIGHT | 34 +
lib/lua/src/CMakeLists.txt | 54 +
lib/lua/src/lapi.c | 1087 +++
lib/lua/src/lapi.h | 16 +
lib/lua/src/lauxlib.c | 652 ++
lib/lua/src/lauxlib.h | 174 +
lib/lua/src/lbaselib.c | 653 ++
lib/lua/src/lcode.c | 831 ++
lib/lua/src/lcode.h | 76 +
lib/lua/src/ldblib.c | 398 +
lib/lua/src/ldebug.c | 638 ++
lib/lua/src/ldebug.h | 33 +
lib/lua/src/ldo.c | 519 ++
lib/lua/src/ldo.h | 57 +
lib/lua/src/ldump.c | 164 +
lib/lua/src/lfunc.c | 174 +
lib/lua/src/lfunc.h | 34 +
lib/lua/src/lgc.c | 710 ++
lib/lua/src/lgc.h | 110 +
lib/lua/src/linit.c | 38 +
lib/lua/src/liolib.c | 556 ++
lib/lua/src/llex.c | 469 +
lib/lua/src/llex.h | 81 +
lib/lua/src/llimits.h | 128 +
lib/lua/src/lmathlib.c | 263 +
lib/lua/src/lmem.c | 86 +
lib/lua/src/lmem.h | 49 +
lib/lua/src/loadlib.c | 666 ++
lib/lua/src/lobject.c | 214 +
lib/lua/src/lobject.h | 381 +
lib/lua/src/lopcodes.c | 102 +
lib/lua/src/lopcodes.h | 268 +
lib/lua/src/loslib.c | 243 +
lib/lua/src/lparser.c | 1339 +++
lib/lua/src/lparser.h | 82 +
lib/lua/src/lstate.c | 214 +
lib/lua/src/lstate.h | 169 +
lib/lua/src/lstring.c | 111 +
lib/lua/src/lstring.h | 31 +
lib/lua/src/lstrlib.c | 871 ++
lib/lua/src/ltable.c | 588 ++
lib/lua/src/ltable.h | 40 +
lib/lua/src/ltablib.c | 287 +
lib/lua/src/ltm.c | 75 +
lib/lua/src/ltm.h | 54 +
lib/lua/src/lua.c | 392 +
lib/lua/src/lua.h | 388 +
lib/lua/src/luac.c | 200 +
lib/lua/src/luaconf.h | 763 ++
lib/lua/src/lualib.h | 53 +
lib/lua/src/lundump.c | 227 +
lib/lua/src/lundump.h | 36 +
lib/lua/src/lvm.c | 767 ++
lib/lua/src/lvm.h | 36 +
lib/lua/src/lzio.c | 82 +
lib/lua/src/lzio.h | 67 +
lib/lua/src/print.c | 227 +
minetest.conf.example | 3028 +++++++
minetest_readme.md | 500 ++
misc/CPACK_WIX_UI_BANNER.BMP | Bin 0 -> 114514 bytes
misc/CPACK_WIX_UI_DIALOG.BMP | Bin 0 -> 461882 bytes
misc/Info.plist | 14 +
misc/debpkg-control | 36 +
misc/kubernetes.yml | 53 +
misc/minetest-icon-24x24.png | Bin 0 -> 587 bytes
misc/minetest-icon.icns | Bin 0 -> 242668 bytes
misc/minetest-icon.ico | Bin 0 -> 9662 bytes
misc/minetest-xorg-icon-128.png | Bin 0 -> 11241 bytes
misc/minetest.exe.manifest | 15 +
misc/minetest.svg | 183 +
misc/net.minetest.minetest.appdata.xml | 61 +
misc/net.minetest.minetest.desktop | 17 +
misc/winresource.rc | 60 +
po/be/minetest.po | 7211 +++++++++++++++
po/ca/minetest.po | 6475 ++++++++++++++
po/cs/minetest.po | 6786 ++++++++++++++
po/da/minetest.po | 7073 +++++++++++++++
po/de/minetest.po | 7819 ++++++++++++++++
po/dv/minetest.po | 5882 +++++++++++++
po/eo/minetest.po | 6779 ++++++++++++++
po/es/minetest.po | 6841 ++++++++++++++
po/et/minetest.po | 6240 +++++++++++++
po/fr/minetest.po | 7825 +++++++++++++++++
po/he/minetest.po | 5841 ++++++++++++
po/hu/minetest.po | 7082 +++++++++++++++
po/id/minetest.po | 7088 +++++++++++++++
po/it/minetest.po | 7582 ++++++++++++++++
po/ja/minetest.po | 6914 +++++++++++++++
po/jbo/minetest.po | 5957 +++++++++++++
po/kk/minetest.po | 5763 ++++++++++++
po/kn/minetest.po | 5771 ++++++++++++
po/ko/minetest.po | 6697 ++++++++++++++
po/ky/minetest.po | 6112 +++++++++++++
po/lt/minetest.po | 6163 +++++++++++++
po/minetest.pot | 5764 ++++++++++++
po/ms/minetest.po | 7093 +++++++++++++++
po/nb/minetest.po | 6172 +++++++++++++
po/nl/minetest.po | 7824 ++++++++++++++++
po/pl/minetest.po | 7602 ++++++++++++++++
po/pt/minetest.po | 7445 ++++++++++++++++
po/pt_BR/minetest.po | 7682 ++++++++++++++++
po/ro/minetest.po | 6230 +++++++++++++
po/ru/minetest.po | 7360 ++++++++++++++++
po/sl/minetest.po | 5983 +++++++++++++
po/sr_Cyrl/minetest.po | 6169 +++++++++++++
po/sv/minetest.po | 6210 +++++++++++++
po/sw/minetest.po | 7234 +++++++++++++++
po/tr/minetest.po | 7251 +++++++++++++++
po/uk/minetest.po | 6034 +++++++++++++
po/zh_CN/minetest.po | 6609 ++++++++++++++
po/zh_TW/minetest.po | 7303 +++++++++++++++
src/CMakeLists.txt | 864 ++
src/activeobject.h | 103 +
src/activeobjectmgr.h | 65 +
src/ban.cpp | 142 +
src/ban.h | 49 +
src/chat.cpp | 775 ++
src/chat.h | 293 +
src/chat_interface.h | 79 +
src/chatmessage.h | 49 +
src/client/CMakeLists.txt | 62 +
src/client/activeobjectmgr.cpp | 106 +
src/client/activeobjectmgr.h | 41 +
src/client/camera.cpp | 658 ++
src/client/camera.h | 231 +
src/client/client.cpp | 1967 +++++
src/client/client.h | 606 ++
src/client/clientenvironment.cpp | 482 +
src/client/clientenvironment.h | 161 +
src/client/clientevent.h | 172 +
src/client/clientlauncher.cpp | 663 ++
src/client/clientlauncher.h | 70 +
src/client/clientmap.cpp | 671 ++
src/client/clientmap.h | 138 +
src/client/clientmedia.cpp | 615 ++
src/client/clientmedia.h | 147 +
src/client/clientobject.cpp | 66 +
src/client/clientobject.h | 108 +
src/client/clouds.cpp | 386 +
src/client/clouds.h | 144 +
src/client/content_cao.cpp | 1628 ++++
src/client/content_cao.h | 251 +
src/client/content_cso.cpp | 77 +
src/client/content_cso.h | 26 +
src/client/content_mapblock.cpp | 1430 +++
src/client/content_mapblock.h | 178 +
src/client/event_manager.h | 86 +
src/client/filecache.cpp | 89 +
src/client/filecache.h | 42 +
src/client/fontengine.cpp | 510 ++
src/client/fontengine.h | 128 +
src/client/game.cpp | 4233 +++++++++
src/client/game.h | 56 +
src/client/gameui.cpp | 303 +
src/client/gameui.h | 110 +
src/client/guiscalingfilter.cpp | 169 +
src/client/guiscalingfilter.h | 50 +
src/client/hud.cpp | 758 ++
src/client/hud.h | 136 +
src/client/imagefilters.cpp | 172 +
src/client/imagefilters.h | 43 +
src/client/inputhandler.cpp | 258 +
src/client/inputhandler.h | 410 +
src/client/joystick_controller.cpp | 258 +
src/client/joystick_controller.h | 173 +
src/client/keycode.cpp | 384 +
src/client/keycode.h | 67 +
src/client/keys.h | 123 +
src/client/localplayer.cpp | 1175 +++
src/client/localplayer.h | 199 +
src/client/mapblock_mesh.cpp | 1389 +++
src/client/mapblock_mesh.h | 228 +
src/client/mesh.cpp | 1135 +++
src/client/mesh.h | 129 +
src/client/mesh_generator_thread.cpp | 308 +
src/client/mesh_generator_thread.h | 131 +
src/client/meshgen/collector.cpp | 104 +
src/client/meshgen/collector.h | 65 +
src/client/minimap.cpp | 624 ++
src/client/minimap.h | 163 +
src/client/particles.cpp | 665 ++
src/client/particles.h | 229 +
src/client/render/anaglyph.cpp | 51 +
src/client/render/anaglyph.h | 34 +
src/client/render/core.cpp | 101 +
src/client/render/core.h | 75 +
src/client/render/factory.cpp | 49 +
src/client/render/factory.h | 25 +
src/client/render/interlaced.cpp | 116 +
src/client/render/interlaced.h | 43 +
src/client/render/pageflip.cpp | 59 +
src/client/render/pageflip.h | 43 +
src/client/render/plain.cpp | 76 +
src/client/render/plain.h | 38 +
src/client/render/sidebyside.cpp | 74 +
src/client/render/sidebyside.h | 43 +
src/client/render/stereo.cpp | 60 +
src/client/render/stereo.h | 38 +
src/client/renderingengine.cpp | 679 ++
src/client/renderingengine.h | 161 +
src/client/shader.cpp | 873 ++
src/client/shader.h | 156 +
src/client/sky.cpp | 768 ++
src/client/sky.h | 148 +
src/client/sound.cpp | 23 +
src/client/sound.h | 111 +
src/client/sound_openal.cpp | 689 ++
src/client/sound_openal.h | 31 +
src/client/tile.cpp | 2233 +++++
src/client/tile.h | 320 +
src/client/wieldmesh.cpp | 689 ++
src/client/wieldmesh.h | 141 +
src/clientiface.cpp | 909 ++
src/clientiface.h | 515 ++
src/clientsimpleobject.h | 35 +
src/cloudparams.h | 30 +
src/cmake_config.h.in | 35 +
src/cmake_config_githash.h.in | 6 +
src/collision.cpp | 592 ++
src/collision.h | 78 +
src/config.h | 40 +
src/constants.h | 119 +
src/content/CMakeLists.txt | 7 +
src/content/content.cpp | 117 +
src/content/content.h | 35 +
src/content/mods.cpp | 477 +
src/content/mods.h | 163 +
src/content/packages.cpp | 69 +
src/content/packages.h | 52 +
src/content/subgames.cpp | 338 +
src/content/subgames.h | 91 +
src/content_mapnode.cpp | 167 +
src/content_mapnode.h | 34 +
src/content_nodemeta.cpp | 191 +
src/content_nodemeta.h | 34 +
src/content_sao.cpp | 1539 ++++
src/content_sao.h | 456 +
src/convert_json.cpp | 79 +
src/convert_json.h | 27 +
src/craftdef.cpp | 1110 +++
src/craftdef.h | 432 +
src/database/CMakeLists.txt | 10 +
src/database/database-dummy.cpp | 59 +
src/database/database-dummy.h | 45 +
src/database/database-files.cpp | 290 +
src/database/database-files.h | 64 +
src/database/database-leveldb.cpp | 101 +
src/database/database-leveldb.h | 48 +
src/database/database-postgresql.cpp | 634 ++
src/database/database-postgresql.h | 146 +
src/database/database-redis.cpp | 203 +
src/database/database-redis.h | 51 +
src/database/database-sqlite3.cpp | 776 ++
src/database/database-sqlite3.h | 234 +
src/database/database.cpp | 69 +
src/database/database.h | 86 +
src/daynightratio.h | 66 +
src/debug.cpp | 197 +
src/debug.h | 102 +
src/defaultsettings.cpp | 486 +
src/defaultsettings.h | 35 +
src/emerge.cpp | 686 ++
src/emerge.h | 177 +
src/environment.cpp | 300 +
src/environment.h | 145 +
src/event.h | 71 +
src/exceptions.h | 131 +
src/face_position_cache.cpp | 110 +
src/face_position_cache.h | 41 +
src/filesys.cpp | 753 ++
src/filesys.h | 133 +
src/gamedef.h | 82 +
src/gameparams.h | 32 +
src/genericobject.cpp | 207 +
src/genericobject.h | 87 +
src/gettext.cpp | 248 +
src/gettext.h | 61 +
src/gettime.h | 43 +
src/gui/CMakeLists.txt | 16 +
src/gui/guiChatConsole.cpp | 642 ++
src/gui/guiChatConsole.h | 133 +
src/gui/guiConfirmRegistration.cpp | 265 +
src/gui/guiConfirmRegistration.h | 67 +
src/gui/guiEditBoxWithScrollbar.cpp | 1528 ++++
src/gui/guiEditBoxWithScrollbar.h | 199 +
src/gui/guiEngine.cpp | 614 ++
src/gui/guiEngine.h | 304 +
src/gui/guiFormSpecMenu.cpp | 3742 ++++++++
src/gui/guiFormSpecMenu.h | 569 ++
src/gui/guiKeyChangeMenu.cpp | 454 +
src/gui/guiKeyChangeMenu.h | 78 +
src/gui/guiMainMenu.h | 55 +
src/gui/guiPasswordChange.cpp | 304 +
src/gui/guiPasswordChange.h | 60 +
src/gui/guiPathSelectMenu.cpp | 113 +
src/gui/guiPathSelectMenu.h | 63 +
src/gui/guiTable.cpp | 1262 +++
src/gui/guiTable.h | 256 +
src/gui/guiVolumeChange.cpp | 196 +
src/gui/guiVolumeChange.h | 49 +
src/gui/intlGUIEditBox.cpp | 1591 ++++
src/gui/intlGUIEditBox.h | 210 +
src/gui/mainmenumanager.h | 166 +
src/gui/modalMenu.cpp | 289 +
src/gui/modalMenu.h | 81 +
src/gui/profilergraph.cpp | 167 +
src/gui/profilergraph.h | 61 +
src/gui/touchscreengui.cpp | 1301 +++
src/gui/touchscreengui.h | 313 +
src/httpfetch.cpp | 830 ++
src/httpfetch.h | 114 +
src/hud.cpp | 59 +
src/hud.h | 99 +
src/inventory.cpp | 978 ++
src/inventory.h | 313 +
src/inventorymanager.cpp | 922 ++
src/inventorymanager.h | 246 +
src/irr_aabb3d.h | 26 +
src/irr_v2d.h | 30 +
src/irr_v3d.h | 30 +
src/irrlicht_changes/CGUITTFont.cpp | 1197 +++
src/irrlicht_changes/CGUITTFont.h | 391 +
src/irrlicht_changes/CMakeLists.txt | 16 +
src/irrlicht_changes/irrUString.h | 3891 ++++++++
src/irrlicht_changes/static_text.cpp | 670 ++
src/irrlicht_changes/static_text.h | 283 +
src/irrlichttypes.h | 80 +
src/irrlichttypes_bloated.h | 28 +
src/irrlichttypes_extrabloated.h | 36 +
src/itemdef.cpp | 587 ++
src/itemdef.h | 179 +
src/itemgroup.h | 33 +
src/itemstackmetadata.cpp | 105 +
src/itemstackmetadata.h | 54 +
src/light.cpp | 86 +
src/light.h | 82 +
src/log.cpp | 369 +
src/log.h | 257 +
src/main.cpp | 997 +++
src/map.cpp | 2328 +++++
src/map.h | 507 ++
src/map_settings_manager.cpp | 192 +
src/map_settings_manager.h | 76 +
src/mapblock.cpp | 876 ++
src/mapblock.h | 663 ++
src/mapgen/CMakeLists.txt | 19 +
src/mapgen/cavegen.cpp | 906 ++
src/mapgen/cavegen.h | 244 +
src/mapgen/dungeongen.cpp | 677 ++
src/mapgen/dungeongen.h | 107 +
src/mapgen/mapgen.cpp | 1149 +++
src/mapgen/mapgen.h | 291 +
src/mapgen/mapgen_carpathian.cpp | 469 +
src/mapgen/mapgen_carpathian.h | 108 +
src/mapgen/mapgen_flat.cpp | 285 +
src/mapgen/mapgen_flat.h | 82 +
src/mapgen/mapgen_fractal.cpp | 416 +
src/mapgen/mapgen_fractal.h | 92 +
src/mapgen/mapgen_singlenode.cpp | 100 +
src/mapgen/mapgen_singlenode.h | 48 +
src/mapgen/mapgen_v5.cpp | 307 +
src/mapgen/mapgen_v5.h | 79 +
src/mapgen/mapgen_v6.cpp | 1125 +++
src/mapgen/mapgen_v6.h | 175 +
src/mapgen/mapgen_v7.cpp | 614 ++
src/mapgen/mapgen_v7.h | 120 +
src/mapgen/mapgen_valleys.cpp | 578 ++
src/mapgen/mapgen_valleys.h | 129 +
src/mapgen/mg_biome.cpp | 337 +
src/mapgen/mg_biome.h | 237 +
src/mapgen/mg_decoration.cpp | 404 +
src/mapgen/mg_decoration.h | 136 +
src/mapgen/mg_ore.cpp | 499 ++
src/mapgen/mg_ore.h | 186 +
src/mapgen/mg_schematic.cpp | 579 ++
src/mapgen/mg_schematic.h | 148 +
src/mapgen/treegen.cpp | 876 ++
src/mapgen/treegen.h | 94 +
src/mapnode.cpp | 870 ++
src/mapnode.h | 308 +
src/mapsector.cpp | 130 +
src/mapsector.h | 86 +
src/metadata.cpp | 115 +
src/metadata.h | 63 +
src/modchannels.cpp | 152 +
src/modchannels.h | 93 +
src/modifiedstate.h | 33 +
src/nameidmapping.cpp | 48 +
src/nameidmapping.h | 91 +
src/network/CMakeLists.txt | 23 +
src/network/address.cpp | 290 +
src/network/address.h | 79 +
src/network/clientopcodes.cpp | 214 +
src/network/clientopcodes.h | 50 +
src/network/clientpackethandler.cpp | 1476 ++++
src/network/connection.cpp | 1523 ++++
src/network/connection.h | 831 ++
src/network/connectionthreads.cpp | 1381 +++
src/network/connectionthreads.h | 149 +
src/network/networkexceptions.h | 106 +
src/network/networkpacket.cpp | 529 ++
src/network/networkpacket.h | 136 +
src/network/networkprotocol.h | 963 ++
src/network/peerhandler.h | 76 +
src/network/serveropcodes.cpp | 214 +
src/network/serveropcodes.h | 50 +
src/network/serverpackethandler.cpp | 1873 ++++
src/network/socket.cpp | 372 +
src/network/socket.h | 70 +
src/nodedef.cpp | 1654 ++++
src/nodedef.h | 750 ++
src/nodemetadata.cpp | 260 +
src/nodemetadata.h | 117 +
src/nodetimer.cpp | 150 +
src/nodetimer.h | 128 +
src/noise.cpp | 806 ++
src/noise.h | 234 +
src/objdef.cpp | 184 +
src/objdef.h | 94 +
src/object_properties.cpp | 170 +
src/object_properties.h | 69 +
src/pathfinder.cpp | 1370 +++
src/pathfinder.h | 63 +
src/player.cpp | 154 +
src/player.h | 196 +
src/porting.cpp | 714 ++
src/porting.h | 336 +
src/porting_android.cpp | 327 +
src/porting_android.h | 84 +
src/profiler.cpp | 54 +
src/profiler.h | 197 +
src/quicktune.cpp | 104 +
src/quicktune.h | 98 +
src/quicktune_shortcutter.h | 84 +
src/raycast.cpp | 137 +
src/raycast.h | 77 +
src/reflowscan.cpp | 205 +
src/reflowscan.h | 47 +
src/remoteplayer.cpp | 232 +
src/remoteplayer.h | 177 +
src/rollback.cpp | 971 ++
src/rollback.h | 104 +
src/rollback_interface.cpp | 231 +
src/rollback_interface.h | 157 +
src/script/CMakeLists.txt | 21 +
src/script/common/CMakeLists.txt | 11 +
src/script/common/c_content.cpp | 1964 +++++
src/script/common/c_content.h | 197 +
src/script/common/c_converter.cpp | 670 ++
src/script/common/c_converter.h | 139 +
src/script/common/c_internal.cpp | 175 +
src/script/common/c_internal.h | 106 +
src/script/common/c_types.cpp | 34 +
src/script/common/c_types.h | 61 +
src/script/common/helper.cpp | 127 +
src/script/common/helper.h | 54 +
src/script/cpp_api/CMakeLists.txt | 20 +
src/script/cpp_api/s_async.cpp | 289 +
src/script/cpp_api/s_async.h | 156 +
src/script/cpp_api/s_base.cpp | 418 +
src/script/cpp_api/s_base.h | 163 +
src/script/cpp_api/s_client.cpp | 248 +
src/script/cpp_api/s_client.h | 64 +
src/script/cpp_api/s_entity.cpp | 301 +
src/script/cpp_api/s_entity.h | 51 +
src/script/cpp_api/s_env.cpp | 255 +
src/script/cpp_api/s_env.h | 45 +
src/script/cpp_api/s_internal.h | 85 +
src/script/cpp_api/s_inventory.cpp | 225 +
src/script/cpp_api/s_inventory.h | 59 +
src/script/cpp_api/s_item.cpp | 264 +
src/script/cpp_api/s_item.h | 63 +
src/script/cpp_api/s_mainmenu.cpp | 93 +
src/script/cpp_api/s_mainmenu.h | 45 +
src/script/cpp_api/s_modchannels.cpp | 50 +
src/script/cpp_api/s_modchannels.h | 31 +
src/script/cpp_api/s_node.cpp | 272 +
src/script/cpp_api/s_node.h | 57 +
src/script/cpp_api/s_nodemeta.cpp | 232 +
src/script/cpp_api/s_nodemeta.h | 63 +
src/script/cpp_api/s_player.cpp | 362 +
src/script/cpp_api/s_player.h | 87 +
src/script/cpp_api/s_security.cpp | 820 ++
src/script/cpp_api/s_security.h | 76 +
src/script/cpp_api/s_server.cpp | 170 +
src/script/cpp_api/s_server.h | 50 +
src/script/lua_api/CMakeLists.txt | 37 +
src/script/lua_api/l_areastore.cpp | 395 +
src/script/lua_api/l_areastore.h | 64 +
src/script/lua_api/l_auth.cpp | 216 +
src/script/lua_api/l_auth.h | 54 +
src/script/lua_api/l_base.cpp | 167 +
src/script/lua_api/l_base.h | 81 +
src/script/lua_api/l_camera.cpp | 223 +
src/script/lua_api/l_camera.h | 60 +
src/script/lua_api/l_client.cpp | 394 +
src/script/lua_api/l_client.h | 98 +
src/script/lua_api/l_craft.cpp | 523 ++
src/script/lua_api/l_craft.h | 48 +
src/script/lua_api/l_env.cpp | 1337 +++
src/script/lua_api/l_env.h | 305 +
src/script/lua_api/l_http.cpp | 193 +
src/script/lua_api/l_http.h | 47 +
src/script/lua_api/l_internal.h | 45 +
src/script/lua_api/l_inventory.cpp | 553 ++
src/script/lua_api/l_inventory.h | 129 +
src/script/lua_api/l_item.cpp | 628 ++
src/script/lua_api/l_item.h | 148 +
src/script/lua_api/l_itemstackmeta.cpp | 139 +
src/script/lua_api/l_itemstackmeta.h | 69 +
src/script/lua_api/l_localplayer.cpp | 431 +
src/script/lua_api/l_localplayer.h | 93 +
src/script/lua_api/l_mainmenu.cpp | 1091 +++
src/script/lua_api/l_mainmenu.h | 159 +
src/script/lua_api/l_mapgen.cpp | 1787 ++++
src/script/lua_api/l_mapgen.h | 144 +
src/script/lua_api/l_metadata.cpp | 302 +
src/script/lua_api/l_metadata.h | 81 +
src/script/lua_api/l_minimap.cpp | 227 +
src/script/lua_api/l_minimap.h | 62 +
src/script/lua_api/l_modchannels.cpp | 153 +
src/script/lua_api/l_modchannels.h | 66 +
src/script/lua_api/l_nodemeta.cpp | 274 +
src/script/lua_api/l_nodemeta.h | 95 +
src/script/lua_api/l_nodetimer.cpp | 169 +
src/script/lua_api/l_nodetimer.h | 63 +
src/script/lua_api/l_noise.cpp | 714 ++
src/script/lua_api/l_noise.h | 194 +
src/script/lua_api/l_object.cpp | 1955 ++++
src/script/lua_api/l_object.h | 354 +
src/script/lua_api/l_particles.cpp | 283 +
src/script/lua_api/l_particles.h | 32 +
src/script/lua_api/l_particles_local.cpp | 206 +
src/script/lua_api/l_particles_local.h | 32 +
src/script/lua_api/l_playermeta.cpp | 123 +
src/script/lua_api/l_playermeta.h | 57 +
src/script/lua_api/l_rollback.cpp | 117 +
src/script/lua_api/l_rollback.h | 35 +
src/script/lua_api/l_server.cpp | 538 ++
src/script/lua_api/l_server.h | 111 +
src/script/lua_api/l_settings.cpp | 316 +
src/script/lua_api/l_settings.h | 85 +
src/script/lua_api/l_sound.cpp | 53 +
src/script/lua_api/l_sound.h | 33 +
src/script/lua_api/l_storage.cpp | 155 +
src/script/lua_api/l_storage.h | 60 +
src/script/lua_api/l_util.cpp | 565 ++
src/script/lua_api/l_util.h | 110 +
src/script/lua_api/l_vmanip.cpp | 479 +
src/script/lua_api/l_vmanip.h | 81 +
src/script/scripting_client.cpp | 94 +
src/script/scripting_client.h | 44 +
src/script/scripting_mainmenu.cpp | 98 +
src/script/scripting_mainmenu.h | 48 +
src/script/scripting_server.cpp | 128 +
src/script/scripting_server.h | 55 +
src/serialization.cpp | 269 +
src/serialization.h | 95 +
src/server.cpp | 3749 ++++++++
src/server.h | 671 ++
src/server/CMakeLists.txt | 4 +
src/server/activeobjectmgr.cpp | 167 +
src/server/activeobjectmgr.h | 45 +
src/server/mods.cpp | 110 +
src/server/mods.h | 43 +
src/serverenvironment.cpp | 2244 +++++
src/serverenvironment.h | 477 +
src/serverlist.cpp | 261 +
src/serverlist.h | 52 +
src/serverobject.cpp | 92 +
src/serverobject.h | 272 +
src/settings.cpp | 1051 +++
src/settings.h | 240 +
src/settings_translation_file.cpp | 994 +++
src/sound.h | 62 +
src/staticobject.cpp | 90 +
src/staticobject.h | 93 +
src/terminal_chat_console.cpp | 456 +
src/terminal_chat_console.h | 124 +
src/threading/CMakeLists.txt | 6 +
src/threading/event.cpp | 44 +
src/threading/event.h | 46 +
src/threading/mutex_auto_lock.h | 30 +
src/threading/semaphore.cpp | 162 +
src/threading/semaphore.h | 52 +
src/threading/thread.cpp | 344 +
src/threading/thread.h | 164 +
src/tileanimation.cpp | 110 +
src/tileanimation.h | 59 +
src/tool.cpp | 278 +
src/tool.h | 134 +
src/translation.cpp | 154 +
src/translation.h | 42 +
src/unittest/CMakeLists.txt | 50 +
src/unittest/test.cpp | 674 ++
src/unittest/test.h | 142 +
src/unittest/test_activeobject.cpp | 60 +
src/unittest/test_address.cpp | 67 +
src/unittest/test_areastore.cpp | 162 +
src/unittest/test_authdatabase.cpp | 296 +
src/unittest/test_ban.cpp | 167 +
src/unittest/test_clientactiveobjectmgr.cpp | 117 +
src/unittest/test_collision.cpp | 180 +
src/unittest/test_compression.cpp | 172 +
src/unittest/test_config.h.in | 6 +
src/unittest/test_connection.cpp | 343 +
src/unittest/test_eventmanager.cpp | 112 +
src/unittest/test_filepath.cpp | 264 +
src/unittest/test_gameui.cpp | 93 +
src/unittest/test_inventory.cpp | 143 +
src/unittest/test_keycode.cpp | 129 +
src/unittest/test_map_settings_manager.cpp | 261 +
src/unittest/test_mapnode.cpp | 57 +
src/unittest/test_modchannels.cpp | 76 +
src/unittest/test_nodedef.cpp | 67 +
src/unittest/test_noderesolver.cpp | 210 +
src/unittest/test_noise.cpp | 286 +
src/unittest/test_objdef.cpp | 106 +
src/unittest/test_player.cpp | 40 +
src/unittest/test_profiler.cpp | 73 +
src/unittest/test_random.cpp | 275 +
src/unittest/test_schematic.cpp | 280 +
src/unittest/test_serialization.cpp | 725 ++
src/unittest/test_server_shutdown_state.cpp | 122 +
src/unittest/test_serveractiveobjectmgr.cpp | 188 +
src/unittest/test_servermodmanager.cpp | 169 +
src/unittest/test_settings.cpp | 208 +
src/unittest/test_socket.cpp | 151 +
src/unittest/test_threading.cpp | 183 +
src/unittest/test_utilities.cpp | 510 ++
src/unittest/test_voxelalgorithms.cpp | 101 +
src/unittest/test_voxelarea.cpp | 374 +
src/unittest/test_voxelmanipulator.cpp | 108 +
src/util/CMakeLists.txt | 17 +
src/util/areastore.cpp | 297 +
src/util/areastore.h | 199 +
src/util/auth.cpp | 137 +
src/util/auth.h | 47 +
src/util/base64.cpp | 132 +
src/util/base64.h | 26 +
src/util/basic_macros.h | 58 +
src/util/container.h | 303 +
src/util/directiontables.cpp | 120 +
src/util/directiontables.h | 89 +
src/util/enriched_string.cpp | 165 +
src/util/enriched_string.h | 88 +
src/util/hex.h | 58 +
src/util/ieee_float.cpp | 136 +
src/util/ieee_float.h | 34 +
src/util/md32_common.h | 428 +
src/util/numeric.cpp | 211 +
src/util/numeric.h | 434 +
src/util/pointedthing.cpp | 134 +
src/util/pointedthing.h | 105 +
src/util/pointer.h | 218 +
src/util/serialize.cpp | 688 ++
src/util/serialize.h | 707 ++
src/util/sha1.cpp | 198 +
src/util/sha1.h | 54 +
src/util/sha2.h | 154 +
src/util/sha256.c | 399 +
src/util/srp.cpp | 1040 +++
src/util/srp.h | 191 +
src/util/strfnd.h | 78 +
src/util/string.cpp | 949 ++
src/util/string.h | 725 ++
src/util/thread.h | 228 +
src/util/timetaker.cpp | 63 +
src/util/timetaker.h | 50 +
src/version.cpp | 36 +
src/version.h | 24 +
src/voxel.cpp | 320 +
src/voxel.h | 508 ++
src/voxelalgorithms.cpp | 1334 +++
src/voxelalgorithms.h | 157 +
textures/base/pack/air.png | Bin 0 -> 225 bytes
textures/base/pack/aux_btn.png | Bin 0 -> 1900 bytes
textures/base/pack/blank.png | Bin 0 -> 95 bytes
textures/base/pack/camera_btn.png | Bin 0 -> 1859 bytes
textures/base/pack/chat_btn.png | Bin 0 -> 873 bytes
textures/base/pack/chat_hide_btn.png | Bin 0 -> 1089 bytes
textures/base/pack/chat_show_btn.png | Bin 0 -> 1082 bytes
textures/base/pack/checkbox_16.png | Bin 0 -> 288 bytes
textures/base/pack/checkbox_32.png | Bin 0 -> 436 bytes
textures/base/pack/checkbox_64.png | Bin 0 -> 766 bytes
textures/base/pack/debug_btn.png | Bin 0 -> 2484 bytes
textures/base/pack/down.png | Bin 0 -> 1690 bytes
textures/base/pack/drop_btn.png | Bin 0 -> 1269 bytes
textures/base/pack/error_screenshot.png | Bin 0 -> 971 bytes
textures/base/pack/fast_btn.png | Bin 0 -> 1212 bytes
textures/base/pack/fly_btn.png | Bin 0 -> 1559 bytes
textures/base/pack/gear_icon.png | Bin 0 -> 1858 bytes
textures/base/pack/halo.png | Bin 0 -> 144 bytes
textures/base/pack/ignore.png | Bin 0 -> 234 bytes
textures/base/pack/inventory_btn.png | Bin 0 -> 331 bytes
textures/base/pack/joystick_bg.png | Bin 0 -> 12481 bytes
textures/base/pack/joystick_center.png | Bin 0 -> 2574 bytes
textures/base/pack/joystick_off.png | Bin 0 -> 14363 bytes
textures/base/pack/jump_btn.png | Bin 0 -> 1710 bytes
textures/base/pack/loading_screenshot.png | Bin 0 -> 580 bytes
textures/base/pack/logo.png | Bin 0 -> 12188 bytes
textures/base/pack/menu_bg.png | Bin 0 -> 124 bytes
textures/base/pack/menu_header.png | Bin 0 -> 1628 bytes
textures/base/pack/minimap_btn.png | Bin 0 -> 1220 bytes
textures/base/pack/minimap_mask_round.png | Bin 0 -> 1858 bytes
textures/base/pack/minimap_mask_square.png | Bin 0 -> 420 bytes
textures/base/pack/minimap_overlay_round.png | Bin 0 -> 22044 bytes
textures/base/pack/minimap_overlay_square.png | Bin 0 -> 1686 bytes
textures/base/pack/no_screenshot.png | Bin 0 -> 586 bytes
textures/base/pack/noclip_btn.png | Bin 0 -> 1236 bytes
textures/base/pack/object_marker_red.png | Bin 0 -> 449 bytes
textures/base/pack/player_marker.png | Bin 0 -> 2166 bytes
textures/base/pack/progress_bar.png | Bin 0 -> 413 bytes
textures/base/pack/progress_bar_bg.png | Bin 0 -> 354 bytes
textures/base/pack/rangeview_btn.png | Bin 0 -> 2423 bytes
textures/base/pack/rare_controls.png | Bin 0 -> 227 bytes
textures/base/pack/refresh.png | Bin 0 -> 3660 bytes
textures/base/pack/server_flags_creative.png | Bin 0 -> 273 bytes
textures/base/pack/server_flags_damage.png | Bin 0 -> 713 bytes
textures/base/pack/server_flags_favorite.png | Bin 0 -> 916 bytes
textures/base/pack/server_flags_pvp.png | Bin 0 -> 1048 bytes
textures/base/pack/server_ping_1.png | Bin 0 -> 251 bytes
textures/base/pack/server_ping_2.png | Bin 0 -> 244 bytes
textures/base/pack/server_ping_3.png | Bin 0 -> 245 bytes
textures/base/pack/server_ping_4.png | Bin 0 -> 213 bytes
textures/base/pack/smoke_puff.png | Bin 0 -> 202 bytes
textures/base/pack/sunrisebg.png | Bin 0 -> 4435 bytes
textures/base/pack/unknown_item.png | Bin 0 -> 292 bytes
textures/base/pack/unknown_node.png | Bin 0 -> 193 bytes
textures/base/pack/unknown_object.png | Bin 0 -> 254 bytes
textures/base/pack/zoom.png | Bin 0 -> 1320 bytes
util/buildbot/buildwin32.sh | 157 +
util/buildbot/buildwin64.sh | 158 +
util/buildbot/toolchain_mingw.cmake | 17 +
util/buildbot/toolchain_mingw64.cmake | 17 +
util/bump_version.sh | 137 +
util/generate-texture-normals.sh | 255 +
util/test_multiplayer.sh | 43 +
util/travis/before_install.sh | 35 +
util/travis/clang-format-whitelist.txt | 479 +
util/travis/clangtidy.sh | 32 +
util/travis/common.sh | 54 +
util/travis/lint.sh | 45 +
util/travis/run-clang-tidy.py | 271 +
util/travis/script.sh | 69 +
util/travis/toolchain_mingw.cmake.in | 18 +
util/updatepo.sh | 78 +
util/wireshark/minetest.lua | 1375 +++
1080 files changed, 513659 insertions(+)
create mode 100644 .DS_Store
create mode 100644 .clang-format
create mode 100644 .clang-tidy
create mode 100644 .gitattributes
create mode 100644 .github/ISSUE_TEMPLATE.md
create mode 100644 .gitignore
create mode 100644 .gitlab-ci.yml
create mode 100644 .mailmap
create mode 100644 .travis.yml
create mode 100644 CMakeLists.txt
create mode 100644 CONTRIBUTING.md
create mode 100644 Dockerfile
create mode 100644 LICENSE.txt
create mode 100644 build/android/Makefile
create mode 100644 build/android/build.gradle
create mode 100644 build/android/gradle/wrapper/gradle-wrapper.jar
create mode 100644 build/android/gradle/wrapper/gradle-wrapper.properties
create mode 100755 build/android/gradlew
create mode 100644 build/android/gradlew.bat
create mode 100644 build/android/icons/aux_btn.svg
create mode 100644 build/android/icons/camera_btn.svg
create mode 100644 build/android/icons/chat_btn.svg
create mode 100644 build/android/icons/chat_hide_btn.svg
create mode 100644 build/android/icons/chat_show_btn.svg
create mode 100644 build/android/icons/checkbox_tick.svg
create mode 100644 build/android/icons/debug_btn.svg
create mode 100644 build/android/icons/down.svg
create mode 100644 build/android/icons/drop_btn.svg
create mode 100644 build/android/icons/fast_btn.svg
create mode 100644 build/android/icons/fly_btn.svg
create mode 100644 build/android/icons/gear_icon.svg
create mode 100644 build/android/icons/inventory_btn.svg
create mode 100644 build/android/icons/joystick_bg.svg
create mode 100644 build/android/icons/joystick_center.svg
create mode 100644 build/android/icons/joystick_off.svg
create mode 100644 build/android/icons/jump_btn.svg
create mode 100644 build/android/icons/minimap_btn.svg
create mode 100644 build/android/icons/noclip_btn.svg
create mode 100644 build/android/icons/rangeview_btn.svg
create mode 100644 build/android/icons/rare_controls.svg
create mode 100644 build/android/icons/zoom.svg
create mode 100644 build/android/jni/Android.mk
create mode 100644 build/android/jni/Application.mk
create mode 100644 build/android/jni/Deps.mk
create mode 100644 build/android/jni/Irrlicht.mk
create mode 100644 build/android/patches/irrlicht-back_button.patch
create mode 100644 build/android/patches/irrlicht-native_activity.patch
create mode 100644 build/android/patches/irrlicht-texturehack.patch
create mode 100644 build/android/patches/irrlicht-touchcount.patch
create mode 100644 build/android/patches/libiconv_android.patch
create mode 100644 build/android/patches/libiconv_stdio.patch
create mode 100644 build/android/patches/libvorbis-libogg-fpu.patch
create mode 100644 build/android/patches/openssl_arch.patch
create mode 100644 build/android/settings.gradle
create mode 100644 build/android/src/debug/AndroidManifest.xml
create mode 100644 build/android/src/main/AndroidManifest.xml
create mode 100644 build/android/src/main/java/net.minetest.minetest/MainActivity.java
create mode 100644 build/android/src/main/java/net.minetest.minetest/MinetestAssetCopy.java
create mode 100644 build/android/src/main/java/net.minetest.minetest/MinetestTextEntry.java
create mode 100644 build/android/src/main/java/net.minetest.minetest/MtNativeActivity.java
create mode 100644 build/android/src/main/res/drawable/background.png
create mode 100644 build/android/src/main/res/drawable/bg.xml
create mode 100644 build/android/src/main/res/layout/assetcopy.xml
create mode 100644 build/android/src/main/res/mipmap/ic_launcher.png
create mode 100644 build/android/src/main/res/values-v21/styles.xml
create mode 100644 build/android/src/main/res/values/strings.xml
create mode 100644 build/android/src/main/res/values/styles.xml
create mode 100644 builtin/async/init.lua
create mode 100644 builtin/client/chatcommands.lua
create mode 100644 builtin/client/death_formspec.lua
create mode 100644 builtin/client/init.lua
create mode 100644 builtin/client/register.lua
create mode 100644 builtin/common/after.lua
create mode 100644 builtin/common/async_event.lua
create mode 100644 builtin/common/chatcommands.lua
create mode 100644 builtin/common/filterlist.lua
create mode 100644 builtin/common/misc_helpers.lua
create mode 100644 builtin/common/serialize.lua
create mode 100644 builtin/common/strict.lua
create mode 100644 builtin/common/vector.lua
create mode 100644 builtin/fstk/buttonbar.lua
create mode 100644 builtin/fstk/dialog.lua
create mode 100644 builtin/fstk/tabview.lua
create mode 100644 builtin/fstk/ui.lua
create mode 100644 builtin/game/auth.lua
create mode 100644 builtin/game/chatcommands.lua
create mode 100644 builtin/game/constants.lua
create mode 100644 builtin/game/deprecated.lua
create mode 100644 builtin/game/detached_inventory.lua
create mode 100644 builtin/game/falling.lua
create mode 100644 builtin/game/features.lua
create mode 100644 builtin/game/forceloading.lua
create mode 100644 builtin/game/init.lua
create mode 100644 builtin/game/item.lua
create mode 100644 builtin/game/item_entity.lua
create mode 100644 builtin/game/misc.lua
create mode 100644 builtin/game/privileges.lua
create mode 100644 builtin/game/register.lua
create mode 100644 builtin/game/statbars.lua
create mode 100644 builtin/game/static_spawn.lua
create mode 100644 builtin/game/voxelarea.lua
create mode 100644 builtin/init.lua
create mode 100644 builtin/mainmenu/common.lua
create mode 100644 builtin/mainmenu/dlg_config_world.lua
create mode 100644 builtin/mainmenu/dlg_contentstore.lua
create mode 100644 builtin/mainmenu/dlg_create_world.lua
create mode 100644 builtin/mainmenu/dlg_delete_content.lua
create mode 100644 builtin/mainmenu/dlg_delete_world.lua
create mode 100644 builtin/mainmenu/dlg_rename_modpack.lua
create mode 100644 builtin/mainmenu/dlg_settings_advanced.lua
create mode 100644 builtin/mainmenu/generate_from_settingtypes.lua
create mode 100644 builtin/mainmenu/init.lua
create mode 100644 builtin/mainmenu/pkgmgr.lua
create mode 100644 builtin/mainmenu/tab_content.lua
create mode 100644 builtin/mainmenu/tab_credits.lua
create mode 100644 builtin/mainmenu/tab_local.lua
create mode 100644 builtin/mainmenu/tab_online.lua
create mode 100644 builtin/mainmenu/tab_settings.lua
create mode 100644 builtin/mainmenu/tab_simple_main.lua
create mode 100644 builtin/mainmenu/textures.lua
create mode 100644 builtin/profiler/init.lua
create mode 100644 builtin/profiler/instrumentation.lua
create mode 100644 builtin/profiler/reporter.lua
create mode 100644 builtin/profiler/sampling.lua
create mode 100644 builtin/settingtypes.txt
create mode 100644 client/serverlist/.gitignore
create mode 100644 client/shaders/3d_interlaced_merge/opengl_fragment.glsl
create mode 100644 client/shaders/3d_interlaced_merge/opengl_vertex.glsl
create mode 100644 client/shaders/default_shader/opengl_fragment.glsl
create mode 100644 client/shaders/default_shader/opengl_vertex.glsl
create mode 100644 client/shaders/minimap_shader/opengl_fragment.glsl
create mode 100644 client/shaders/minimap_shader/opengl_vertex.glsl
create mode 100644 client/shaders/nodes_shader/opengl_fragment.glsl
create mode 100644 client/shaders/nodes_shader/opengl_vertex.glsl
create mode 100644 client/shaders/selection_shader/opengl_fragment.glsl
create mode 100644 client/shaders/selection_shader/opengl_vertex.glsl
create mode 100644 client/shaders/wielded_shader/opengl_fragment.glsl
create mode 100644 client/shaders/wielded_shader/opengl_vertex.glsl
create mode 100644 clientmods/preview/example.lua
create mode 100644 clientmods/preview/examples/first.lua
create mode 100644 clientmods/preview/init.lua
create mode 100644 cmake/Modules/FindCURL.cmake
create mode 100644 cmake/Modules/FindGMP.cmake
create mode 100644 cmake/Modules/FindGettextLib.cmake
create mode 100644 cmake/Modules/FindIrrlicht.cmake
create mode 100644 cmake/Modules/FindJson.cmake
create mode 100644 cmake/Modules/FindLua.cmake
create mode 100644 cmake/Modules/FindLuaJIT.cmake
create mode 100644 cmake/Modules/FindNcursesw.cmake
create mode 100644 cmake/Modules/FindOpenGLES2.cmake
create mode 100644 cmake/Modules/FindSQLite3.cmake
create mode 100644 cmake/Modules/FindVorbis.cmake
create mode 100644 cmake/Modules/GenerateVersion.cmake
create mode 100644 doc/Doxyfile.in
create mode 100644 doc/README.android
create mode 100644 doc/client_lua_api.txt
create mode 100644 doc/fst_api.txt
create mode 100644 doc/lgpl-2.1.txt
create mode 100644 doc/lua_api.txt
create mode 100644 doc/main_page.dox
create mode 100644 doc/menu_lua_api.txt
create mode 100644 doc/minetest.6
create mode 100644 doc/minetestserver.6
create mode 100644 doc/mod_channels.png
create mode 100644 doc/protocol.txt
create mode 100644 doc/texture_packs.txt
create mode 100644 doc/world_format.txt
create mode 100644 fonts/Arimo-LICENSE.txt
create mode 100644 fonts/Arimo-Regular.ttf
create mode 100644 fonts/Cousine-LICENSE.txt
create mode 100644 fonts/Cousine-Regular.ttf
create mode 100644 fonts/DroidSansFallbackFull-LICENSE.txt
create mode 100644 fonts/DroidSansFallbackFull.ttf
create mode 100644 fonts/mono_dejavu_sans_10.xml
create mode 100644 fonts/mono_dejavu_sans_100.png
create mode 100644 fonts/mono_dejavu_sans_11.xml
create mode 100644 fonts/mono_dejavu_sans_110.png
create mode 100644 fonts/mono_dejavu_sans_12.xml
create mode 100644 fonts/mono_dejavu_sans_120.png
create mode 100644 fonts/mono_dejavu_sans_14.xml
create mode 100644 fonts/mono_dejavu_sans_140.png
create mode 100644 fonts/mono_dejavu_sans_16.xml
create mode 100644 fonts/mono_dejavu_sans_160.png
create mode 100644 fonts/mono_dejavu_sans_18.xml
create mode 100644 fonts/mono_dejavu_sans_180.png
create mode 100644 fonts/mono_dejavu_sans_20.xml
create mode 100644 fonts/mono_dejavu_sans_200.png
create mode 100644 fonts/mono_dejavu_sans_22.xml
create mode 100644 fonts/mono_dejavu_sans_220.png
create mode 100644 fonts/mono_dejavu_sans_24.xml
create mode 100644 fonts/mono_dejavu_sans_240.png
create mode 100644 fonts/mono_dejavu_sans_26.xml
create mode 100644 fonts/mono_dejavu_sans_260.png
create mode 100644 fonts/mono_dejavu_sans_28.xml
create mode 100644 fonts/mono_dejavu_sans_280.png
create mode 100644 fonts/mono_dejavu_sans_4.xml
create mode 100644 fonts/mono_dejavu_sans_40.png
create mode 100644 fonts/mono_dejavu_sans_6.xml
create mode 100644 fonts/mono_dejavu_sans_60.png
create mode 100644 fonts/mono_dejavu_sans_8.xml
create mode 100644 fonts/mono_dejavu_sans_80.png
create mode 100644 fonts/mono_dejavu_sans_9.xml
create mode 100644 fonts/mono_dejavu_sans_90.png
create mode 100644 games/minimal/game.conf
create mode 100644 games/minimal/menu/background.png
create mode 100644 games/minimal/menu/icon.png
create mode 100644 games/minimal/mods/bucket/init.lua
create mode 100644 games/minimal/mods/bucket/mod.conf
create mode 100644 games/minimal/mods/bucket/textures/bucket.png
create mode 100644 games/minimal/mods/bucket/textures/bucket_lava.png
create mode 100644 games/minimal/mods/bucket/textures/bucket_water.png
create mode 100644 games/minimal/mods/default/init.lua
create mode 100644 games/minimal/mods/default/mapgen.lua
create mode 100644 games/minimal/mods/default/mod.conf
create mode 100644 games/minimal/mods/default/sounds/default_grass_footstep.1.ogg
create mode 100644 games/minimal/mods/default/textures/bubble.png
create mode 100644 games/minimal/mods/default/textures/crack_anylength.png
create mode 100644 games/minimal/mods/default/textures/default_apple.png
create mode 100644 games/minimal/mods/default/textures/default_book.png
create mode 100644 games/minimal/mods/default/textures/default_bookshelf.png
create mode 100644 games/minimal/mods/default/textures/default_brick.png
create mode 100644 games/minimal/mods/default/textures/default_cactus_side.png
create mode 100644 games/minimal/mods/default/textures/default_cactus_top.png
create mode 100644 games/minimal/mods/default/textures/default_chest.png
create mode 100644 games/minimal/mods/default/textures/default_clay.png
create mode 100644 games/minimal/mods/default/textures/default_clay_brick.png
create mode 100644 games/minimal/mods/default/textures/default_clay_lump.png
create mode 100644 games/minimal/mods/default/textures/default_cloud.png
create mode 100644 games/minimal/mods/default/textures/default_coal_lump.png
create mode 100644 games/minimal/mods/default/textures/default_cobble.png
create mode 100644 games/minimal/mods/default/textures/default_dirt.png
create mode 100644 games/minimal/mods/default/textures/default_fence.png
create mode 100644 games/minimal/mods/default/textures/default_furnace_fire_bg.png
create mode 100644 games/minimal/mods/default/textures/default_furnace_fire_fg.png
create mode 100644 games/minimal/mods/default/textures/default_furnace_front.png
create mode 100644 games/minimal/mods/default/textures/default_furnace_front_active.png
create mode 100644 games/minimal/mods/default/textures/default_furnace_side.png
create mode 100644 games/minimal/mods/default/textures/default_glass.png
create mode 100644 games/minimal/mods/default/textures/default_grass.png
create mode 100644 games/minimal/mods/default/textures/default_grass_footsteps.png
create mode 100644 games/minimal/mods/default/textures/default_grass_side.png
create mode 100644 games/minimal/mods/default/textures/default_gravel.png
create mode 100644 games/minimal/mods/default/textures/default_iron_lump.png
create mode 100644 games/minimal/mods/default/textures/default_junglegrass.png
create mode 100644 games/minimal/mods/default/textures/default_ladder.png
create mode 100644 games/minimal/mods/default/textures/default_lava.png
create mode 100644 games/minimal/mods/default/textures/default_lava_flowing_animated.png
create mode 100644 games/minimal/mods/default/textures/default_lava_source_animated.png
create mode 100644 games/minimal/mods/default/textures/default_leaves.png
create mode 100644 games/minimal/mods/default/textures/default_mese.png
create mode 100644 games/minimal/mods/default/textures/default_mineral_coal.png
create mode 100644 games/minimal/mods/default/textures/default_mineral_iron.png
create mode 100644 games/minimal/mods/default/textures/default_mossycobble.png
create mode 100644 games/minimal/mods/default/textures/default_nc_back.png
create mode 100644 games/minimal/mods/default/textures/default_nc_front.png
create mode 100644 games/minimal/mods/default/textures/default_nc_rb.png
create mode 100644 games/minimal/mods/default/textures/default_nc_side.png
create mode 100644 games/minimal/mods/default/textures/default_paper.png
create mode 100644 games/minimal/mods/default/textures/default_papyrus.png
create mode 100644 games/minimal/mods/default/textures/default_rail.png
create mode 100644 games/minimal/mods/default/textures/default_rail_crossing.png
create mode 100644 games/minimal/mods/default/textures/default_rail_curved.png
create mode 100644 games/minimal/mods/default/textures/default_rail_t_junction.png
create mode 100644 games/minimal/mods/default/textures/default_river_water.png
create mode 100644 games/minimal/mods/default/textures/default_sand.png
create mode 100644 games/minimal/mods/default/textures/default_sandstone.png
create mode 100644 games/minimal/mods/default/textures/default_sapling.png
create mode 100644 games/minimal/mods/default/textures/default_scorched_stuff.png
create mode 100644 games/minimal/mods/default/textures/default_sign_wall.png
create mode 100644 games/minimal/mods/default/textures/default_steel_block.png
create mode 100644 games/minimal/mods/default/textures/default_steel_ingot.png
create mode 100644 games/minimal/mods/default/textures/default_stick.png
create mode 100644 games/minimal/mods/default/textures/default_stone.png
create mode 100644 games/minimal/mods/default/textures/default_tnt_bottom.png
create mode 100644 games/minimal/mods/default/textures/default_tnt_side.png
create mode 100644 games/minimal/mods/default/textures/default_tnt_top.png
create mode 100644 games/minimal/mods/default/textures/default_tool_mesepick.png
create mode 100644 games/minimal/mods/default/textures/default_tool_steelaxe.png
create mode 100644 games/minimal/mods/default/textures/default_tool_steelpick.png
create mode 100644 games/minimal/mods/default/textures/default_tool_steelshovel.png
create mode 100644 games/minimal/mods/default/textures/default_tool_steelsword.png
create mode 100644 games/minimal/mods/default/textures/default_tool_stoneaxe.png
create mode 100644 games/minimal/mods/default/textures/default_tool_stonepick.png
create mode 100644 games/minimal/mods/default/textures/default_tool_stoneshovel.png
create mode 100644 games/minimal/mods/default/textures/default_tool_stonesword.png
create mode 100644 games/minimal/mods/default/textures/default_tool_woodaxe.png
create mode 100644 games/minimal/mods/default/textures/default_tool_woodpick.png
create mode 100644 games/minimal/mods/default/textures/default_tool_woodshovel.png
create mode 100644 games/minimal/mods/default/textures/default_tool_woodsword.png
create mode 100644 games/minimal/mods/default/textures/default_torch.png
create mode 100644 games/minimal/mods/default/textures/default_torch_on_ceiling.png
create mode 100644 games/minimal/mods/default/textures/default_torch_on_floor.png
create mode 100644 games/minimal/mods/default/textures/default_tree.png
create mode 100644 games/minimal/mods/default/textures/default_tree_top.png
create mode 100644 games/minimal/mods/default/textures/default_water.png
create mode 100644 games/minimal/mods/default/textures/default_wood.png
create mode 100644 games/minimal/mods/default/textures/heart.png
create mode 100644 games/minimal/mods/default/textures/player.png
create mode 100644 games/minimal/mods/default/textures/player_back.png
create mode 100644 games/minimal/mods/default/textures/treeprop.png
create mode 100644 games/minimal/mods/default/textures/wieldhand.png
create mode 100644 games/minimal/mods/experimental/init.lua
create mode 100644 games/minimal/mods/experimental/mod.conf
create mode 100644 games/minimal/mods/experimental/modchannels.lua
create mode 100644 games/minimal/mods/experimental/textures/experimental_dummyball.png
create mode 100644 games/minimal/mods/experimental/textures/experimental_tester_tool_1.png
create mode 100644 games/minimal/mods/experimental/textures/experimental_tiled.png
create mode 100644 games/minimal/mods/give_initial_stuff/init.lua
create mode 100644 games/minimal/mods/give_initial_stuff/mod.conf
create mode 100644 games/minimal/mods/legacy/init.lua
create mode 100644 games/minimal/mods/legacy/mod.conf
create mode 100644 games/minimal/mods/legacy/textures/apple_iron.png
create mode 100644 games/minimal/mods/legacy/textures/cooked_rat.png
create mode 100644 games/minimal/mods/legacy/textures/dungeon_master.png
create mode 100644 games/minimal/mods/legacy/textures/fireball.png
create mode 100644 games/minimal/mods/legacy/textures/firefly.png
create mode 100644 games/minimal/mods/legacy/textures/oerkki1.png
create mode 100644 games/minimal/mods/legacy/textures/oerkki1_damaged.png
create mode 100644 games/minimal/mods/legacy/textures/rat.png
create mode 100644 games/minimal/mods/stairs/init.lua
create mode 100644 games/minimal/mods/stairs/mod.conf
create mode 100644 games/minimal/mods/test/init.lua
create mode 100644 games/minimal/mods/test/mod.conf
create mode 100644 lib/gmp/CMakeLists.txt
create mode 100644 lib/gmp/mini-gmp.c
create mode 100644 lib/gmp/mini-gmp.h
create mode 100644 lib/jsoncpp/CMakeLists.txt
create mode 100644 lib/jsoncpp/json/UPDATING
create mode 100644 lib/jsoncpp/json/json-forwards.h
create mode 100644 lib/jsoncpp/json/json.h
create mode 100644 lib/jsoncpp/jsoncpp.cpp
create mode 100644 lib/lua/CMakeLists.txt
create mode 100644 lib/lua/COPYRIGHT
create mode 100644 lib/lua/src/CMakeLists.txt
create mode 100644 lib/lua/src/lapi.c
create mode 100644 lib/lua/src/lapi.h
create mode 100644 lib/lua/src/lauxlib.c
create mode 100644 lib/lua/src/lauxlib.h
create mode 100644 lib/lua/src/lbaselib.c
create mode 100644 lib/lua/src/lcode.c
create mode 100644 lib/lua/src/lcode.h
create mode 100644 lib/lua/src/ldblib.c
create mode 100644 lib/lua/src/ldebug.c
create mode 100644 lib/lua/src/ldebug.h
create mode 100644 lib/lua/src/ldo.c
create mode 100644 lib/lua/src/ldo.h
create mode 100644 lib/lua/src/ldump.c
create mode 100644 lib/lua/src/lfunc.c
create mode 100644 lib/lua/src/lfunc.h
create mode 100644 lib/lua/src/lgc.c
create mode 100644 lib/lua/src/lgc.h
create mode 100644 lib/lua/src/linit.c
create mode 100644 lib/lua/src/liolib.c
create mode 100644 lib/lua/src/llex.c
create mode 100644 lib/lua/src/llex.h
create mode 100644 lib/lua/src/llimits.h
create mode 100644 lib/lua/src/lmathlib.c
create mode 100644 lib/lua/src/lmem.c
create mode 100644 lib/lua/src/lmem.h
create mode 100644 lib/lua/src/loadlib.c
create mode 100644 lib/lua/src/lobject.c
create mode 100644 lib/lua/src/lobject.h
create mode 100644 lib/lua/src/lopcodes.c
create mode 100644 lib/lua/src/lopcodes.h
create mode 100644 lib/lua/src/loslib.c
create mode 100644 lib/lua/src/lparser.c
create mode 100644 lib/lua/src/lparser.h
create mode 100644 lib/lua/src/lstate.c
create mode 100644 lib/lua/src/lstate.h
create mode 100644 lib/lua/src/lstring.c
create mode 100644 lib/lua/src/lstring.h
create mode 100644 lib/lua/src/lstrlib.c
create mode 100644 lib/lua/src/ltable.c
create mode 100644 lib/lua/src/ltable.h
create mode 100644 lib/lua/src/ltablib.c
create mode 100644 lib/lua/src/ltm.c
create mode 100644 lib/lua/src/ltm.h
create mode 100644 lib/lua/src/lua.c
create mode 100644 lib/lua/src/lua.h
create mode 100644 lib/lua/src/luac.c
create mode 100644 lib/lua/src/luaconf.h
create mode 100644 lib/lua/src/lualib.h
create mode 100644 lib/lua/src/lundump.c
create mode 100644 lib/lua/src/lundump.h
create mode 100644 lib/lua/src/lvm.c
create mode 100644 lib/lua/src/lvm.h
create mode 100644 lib/lua/src/lzio.c
create mode 100644 lib/lua/src/lzio.h
create mode 100644 lib/lua/src/print.c
create mode 100644 minetest.conf.example
create mode 100644 minetest_readme.md
create mode 100644 misc/CPACK_WIX_UI_BANNER.BMP
create mode 100644 misc/CPACK_WIX_UI_DIALOG.BMP
create mode 100644 misc/Info.plist
create mode 100644 misc/debpkg-control
create mode 100644 misc/kubernetes.yml
create mode 100644 misc/minetest-icon-24x24.png
create mode 100644 misc/minetest-icon.icns
create mode 100644 misc/minetest-icon.ico
create mode 100644 misc/minetest-xorg-icon-128.png
create mode 100644 misc/minetest.exe.manifest
create mode 100644 misc/minetest.svg
create mode 100644 misc/net.minetest.minetest.appdata.xml
create mode 100644 misc/net.minetest.minetest.desktop
create mode 100644 misc/winresource.rc
create mode 100644 po/be/minetest.po
create mode 100644 po/ca/minetest.po
create mode 100644 po/cs/minetest.po
create mode 100644 po/da/minetest.po
create mode 100644 po/de/minetest.po
create mode 100644 po/dv/minetest.po
create mode 100644 po/eo/minetest.po
create mode 100644 po/es/minetest.po
create mode 100644 po/et/minetest.po
create mode 100644 po/fr/minetest.po
create mode 100644 po/he/minetest.po
create mode 100644 po/hu/minetest.po
create mode 100644 po/id/minetest.po
create mode 100644 po/it/minetest.po
create mode 100644 po/ja/minetest.po
create mode 100644 po/jbo/minetest.po
create mode 100644 po/kk/minetest.po
create mode 100644 po/kn/minetest.po
create mode 100644 po/ko/minetest.po
create mode 100644 po/ky/minetest.po
create mode 100644 po/lt/minetest.po
create mode 100644 po/minetest.pot
create mode 100644 po/ms/minetest.po
create mode 100644 po/nb/minetest.po
create mode 100644 po/nl/minetest.po
create mode 100644 po/pl/minetest.po
create mode 100644 po/pt/minetest.po
create mode 100644 po/pt_BR/minetest.po
create mode 100644 po/ro/minetest.po
create mode 100644 po/ru/minetest.po
create mode 100644 po/sl/minetest.po
create mode 100644 po/sr_Cyrl/minetest.po
create mode 100644 po/sv/minetest.po
create mode 100644 po/sw/minetest.po
create mode 100644 po/tr/minetest.po
create mode 100644 po/uk/minetest.po
create mode 100644 po/zh_CN/minetest.po
create mode 100644 po/zh_TW/minetest.po
create mode 100644 src/CMakeLists.txt
create mode 100644 src/activeobject.h
create mode 100644 src/activeobjectmgr.h
create mode 100644 src/ban.cpp
create mode 100644 src/ban.h
create mode 100644 src/chat.cpp
create mode 100644 src/chat.h
create mode 100644 src/chat_interface.h
create mode 100644 src/chatmessage.h
create mode 100644 src/client/CMakeLists.txt
create mode 100644 src/client/activeobjectmgr.cpp
create mode 100644 src/client/activeobjectmgr.h
create mode 100644 src/client/camera.cpp
create mode 100644 src/client/camera.h
create mode 100644 src/client/client.cpp
create mode 100644 src/client/client.h
create mode 100644 src/client/clientenvironment.cpp
create mode 100644 src/client/clientenvironment.h
create mode 100644 src/client/clientevent.h
create mode 100644 src/client/clientlauncher.cpp
create mode 100644 src/client/clientlauncher.h
create mode 100644 src/client/clientmap.cpp
create mode 100644 src/client/clientmap.h
create mode 100644 src/client/clientmedia.cpp
create mode 100644 src/client/clientmedia.h
create mode 100644 src/client/clientobject.cpp
create mode 100644 src/client/clientobject.h
create mode 100644 src/client/clouds.cpp
create mode 100644 src/client/clouds.h
create mode 100644 src/client/content_cao.cpp
create mode 100644 src/client/content_cao.h
create mode 100644 src/client/content_cso.cpp
create mode 100644 src/client/content_cso.h
create mode 100644 src/client/content_mapblock.cpp
create mode 100644 src/client/content_mapblock.h
create mode 100644 src/client/event_manager.h
create mode 100644 src/client/filecache.cpp
create mode 100644 src/client/filecache.h
create mode 100644 src/client/fontengine.cpp
create mode 100644 src/client/fontengine.h
create mode 100644 src/client/game.cpp
create mode 100644 src/client/game.h
create mode 100644 src/client/gameui.cpp
create mode 100644 src/client/gameui.h
create mode 100644 src/client/guiscalingfilter.cpp
create mode 100644 src/client/guiscalingfilter.h
create mode 100644 src/client/hud.cpp
create mode 100644 src/client/hud.h
create mode 100644 src/client/imagefilters.cpp
create mode 100644 src/client/imagefilters.h
create mode 100644 src/client/inputhandler.cpp
create mode 100644 src/client/inputhandler.h
create mode 100644 src/client/joystick_controller.cpp
create mode 100644 src/client/joystick_controller.h
create mode 100644 src/client/keycode.cpp
create mode 100644 src/client/keycode.h
create mode 100644 src/client/keys.h
create mode 100644 src/client/localplayer.cpp
create mode 100644 src/client/localplayer.h
create mode 100644 src/client/mapblock_mesh.cpp
create mode 100644 src/client/mapblock_mesh.h
create mode 100644 src/client/mesh.cpp
create mode 100644 src/client/mesh.h
create mode 100644 src/client/mesh_generator_thread.cpp
create mode 100644 src/client/mesh_generator_thread.h
create mode 100644 src/client/meshgen/collector.cpp
create mode 100644 src/client/meshgen/collector.h
create mode 100644 src/client/minimap.cpp
create mode 100644 src/client/minimap.h
create mode 100644 src/client/particles.cpp
create mode 100644 src/client/particles.h
create mode 100644 src/client/render/anaglyph.cpp
create mode 100644 src/client/render/anaglyph.h
create mode 100644 src/client/render/core.cpp
create mode 100644 src/client/render/core.h
create mode 100644 src/client/render/factory.cpp
create mode 100644 src/client/render/factory.h
create mode 100644 src/client/render/interlaced.cpp
create mode 100644 src/client/render/interlaced.h
create mode 100644 src/client/render/pageflip.cpp
create mode 100644 src/client/render/pageflip.h
create mode 100644 src/client/render/plain.cpp
create mode 100644 src/client/render/plain.h
create mode 100644 src/client/render/sidebyside.cpp
create mode 100644 src/client/render/sidebyside.h
create mode 100644 src/client/render/stereo.cpp
create mode 100644 src/client/render/stereo.h
create mode 100644 src/client/renderingengine.cpp
create mode 100644 src/client/renderingengine.h
create mode 100644 src/client/shader.cpp
create mode 100644 src/client/shader.h
create mode 100644 src/client/sky.cpp
create mode 100644 src/client/sky.h
create mode 100644 src/client/sound.cpp
create mode 100644 src/client/sound.h
create mode 100644 src/client/sound_openal.cpp
create mode 100644 src/client/sound_openal.h
create mode 100644 src/client/tile.cpp
create mode 100644 src/client/tile.h
create mode 100644 src/client/wieldmesh.cpp
create mode 100644 src/client/wieldmesh.h
create mode 100644 src/clientiface.cpp
create mode 100644 src/clientiface.h
create mode 100644 src/clientsimpleobject.h
create mode 100644 src/cloudparams.h
create mode 100644 src/cmake_config.h.in
create mode 100644 src/cmake_config_githash.h.in
create mode 100644 src/collision.cpp
create mode 100644 src/collision.h
create mode 100644 src/config.h
create mode 100644 src/constants.h
create mode 100644 src/content/CMakeLists.txt
create mode 100644 src/content/content.cpp
create mode 100644 src/content/content.h
create mode 100644 src/content/mods.cpp
create mode 100644 src/content/mods.h
create mode 100644 src/content/packages.cpp
create mode 100644 src/content/packages.h
create mode 100644 src/content/subgames.cpp
create mode 100644 src/content/subgames.h
create mode 100644 src/content_mapnode.cpp
create mode 100644 src/content_mapnode.h
create mode 100644 src/content_nodemeta.cpp
create mode 100644 src/content_nodemeta.h
create mode 100644 src/content_sao.cpp
create mode 100644 src/content_sao.h
create mode 100644 src/convert_json.cpp
create mode 100644 src/convert_json.h
create mode 100644 src/craftdef.cpp
create mode 100644 src/craftdef.h
create mode 100644 src/database/CMakeLists.txt
create mode 100644 src/database/database-dummy.cpp
create mode 100644 src/database/database-dummy.h
create mode 100644 src/database/database-files.cpp
create mode 100644 src/database/database-files.h
create mode 100644 src/database/database-leveldb.cpp
create mode 100644 src/database/database-leveldb.h
create mode 100644 src/database/database-postgresql.cpp
create mode 100644 src/database/database-postgresql.h
create mode 100644 src/database/database-redis.cpp
create mode 100644 src/database/database-redis.h
create mode 100644 src/database/database-sqlite3.cpp
create mode 100644 src/database/database-sqlite3.h
create mode 100644 src/database/database.cpp
create mode 100644 src/database/database.h
create mode 100644 src/daynightratio.h
create mode 100644 src/debug.cpp
create mode 100644 src/debug.h
create mode 100644 src/defaultsettings.cpp
create mode 100644 src/defaultsettings.h
create mode 100644 src/emerge.cpp
create mode 100644 src/emerge.h
create mode 100644 src/environment.cpp
create mode 100644 src/environment.h
create mode 100644 src/event.h
create mode 100644 src/exceptions.h
create mode 100644 src/face_position_cache.cpp
create mode 100644 src/face_position_cache.h
create mode 100644 src/filesys.cpp
create mode 100644 src/filesys.h
create mode 100644 src/gamedef.h
create mode 100644 src/gameparams.h
create mode 100644 src/genericobject.cpp
create mode 100644 src/genericobject.h
create mode 100644 src/gettext.cpp
create mode 100644 src/gettext.h
create mode 100644 src/gettime.h
create mode 100644 src/gui/CMakeLists.txt
create mode 100644 src/gui/guiChatConsole.cpp
create mode 100644 src/gui/guiChatConsole.h
create mode 100644 src/gui/guiConfirmRegistration.cpp
create mode 100644 src/gui/guiConfirmRegistration.h
create mode 100644 src/gui/guiEditBoxWithScrollbar.cpp
create mode 100644 src/gui/guiEditBoxWithScrollbar.h
create mode 100644 src/gui/guiEngine.cpp
create mode 100644 src/gui/guiEngine.h
create mode 100644 src/gui/guiFormSpecMenu.cpp
create mode 100644 src/gui/guiFormSpecMenu.h
create mode 100644 src/gui/guiKeyChangeMenu.cpp
create mode 100644 src/gui/guiKeyChangeMenu.h
create mode 100644 src/gui/guiMainMenu.h
create mode 100644 src/gui/guiPasswordChange.cpp
create mode 100644 src/gui/guiPasswordChange.h
create mode 100644 src/gui/guiPathSelectMenu.cpp
create mode 100644 src/gui/guiPathSelectMenu.h
create mode 100644 src/gui/guiTable.cpp
create mode 100644 src/gui/guiTable.h
create mode 100644 src/gui/guiVolumeChange.cpp
create mode 100644 src/gui/guiVolumeChange.h
create mode 100644 src/gui/intlGUIEditBox.cpp
create mode 100644 src/gui/intlGUIEditBox.h
create mode 100644 src/gui/mainmenumanager.h
create mode 100644 src/gui/modalMenu.cpp
create mode 100644 src/gui/modalMenu.h
create mode 100644 src/gui/profilergraph.cpp
create mode 100644 src/gui/profilergraph.h
create mode 100644 src/gui/touchscreengui.cpp
create mode 100644 src/gui/touchscreengui.h
create mode 100644 src/httpfetch.cpp
create mode 100644 src/httpfetch.h
create mode 100644 src/hud.cpp
create mode 100644 src/hud.h
create mode 100644 src/inventory.cpp
create mode 100644 src/inventory.h
create mode 100644 src/inventorymanager.cpp
create mode 100644 src/inventorymanager.h
create mode 100644 src/irr_aabb3d.h
create mode 100644 src/irr_v2d.h
create mode 100644 src/irr_v3d.h
create mode 100644 src/irrlicht_changes/CGUITTFont.cpp
create mode 100644 src/irrlicht_changes/CGUITTFont.h
create mode 100644 src/irrlicht_changes/CMakeLists.txt
create mode 100644 src/irrlicht_changes/irrUString.h
create mode 100644 src/irrlicht_changes/static_text.cpp
create mode 100644 src/irrlicht_changes/static_text.h
create mode 100644 src/irrlichttypes.h
create mode 100644 src/irrlichttypes_bloated.h
create mode 100644 src/irrlichttypes_extrabloated.h
create mode 100644 src/itemdef.cpp
create mode 100644 src/itemdef.h
create mode 100644 src/itemgroup.h
create mode 100644 src/itemstackmetadata.cpp
create mode 100644 src/itemstackmetadata.h
create mode 100644 src/light.cpp
create mode 100644 src/light.h
create mode 100644 src/log.cpp
create mode 100644 src/log.h
create mode 100644 src/main.cpp
create mode 100644 src/map.cpp
create mode 100644 src/map.h
create mode 100644 src/map_settings_manager.cpp
create mode 100644 src/map_settings_manager.h
create mode 100644 src/mapblock.cpp
create mode 100644 src/mapblock.h
create mode 100644 src/mapgen/CMakeLists.txt
create mode 100644 src/mapgen/cavegen.cpp
create mode 100644 src/mapgen/cavegen.h
create mode 100644 src/mapgen/dungeongen.cpp
create mode 100644 src/mapgen/dungeongen.h
create mode 100644 src/mapgen/mapgen.cpp
create mode 100644 src/mapgen/mapgen.h
create mode 100644 src/mapgen/mapgen_carpathian.cpp
create mode 100644 src/mapgen/mapgen_carpathian.h
create mode 100644 src/mapgen/mapgen_flat.cpp
create mode 100644 src/mapgen/mapgen_flat.h
create mode 100644 src/mapgen/mapgen_fractal.cpp
create mode 100644 src/mapgen/mapgen_fractal.h
create mode 100644 src/mapgen/mapgen_singlenode.cpp
create mode 100644 src/mapgen/mapgen_singlenode.h
create mode 100644 src/mapgen/mapgen_v5.cpp
create mode 100644 src/mapgen/mapgen_v5.h
create mode 100644 src/mapgen/mapgen_v6.cpp
create mode 100644 src/mapgen/mapgen_v6.h
create mode 100644 src/mapgen/mapgen_v7.cpp
create mode 100644 src/mapgen/mapgen_v7.h
create mode 100644 src/mapgen/mapgen_valleys.cpp
create mode 100644 src/mapgen/mapgen_valleys.h
create mode 100644 src/mapgen/mg_biome.cpp
create mode 100644 src/mapgen/mg_biome.h
create mode 100644 src/mapgen/mg_decoration.cpp
create mode 100644 src/mapgen/mg_decoration.h
create mode 100644 src/mapgen/mg_ore.cpp
create mode 100644 src/mapgen/mg_ore.h
create mode 100644 src/mapgen/mg_schematic.cpp
create mode 100644 src/mapgen/mg_schematic.h
create mode 100644 src/mapgen/treegen.cpp
create mode 100644 src/mapgen/treegen.h
create mode 100644 src/mapnode.cpp
create mode 100644 src/mapnode.h
create mode 100644 src/mapsector.cpp
create mode 100644 src/mapsector.h
create mode 100644 src/metadata.cpp
create mode 100644 src/metadata.h
create mode 100644 src/modchannels.cpp
create mode 100644 src/modchannels.h
create mode 100644 src/modifiedstate.h
create mode 100644 src/nameidmapping.cpp
create mode 100644 src/nameidmapping.h
create mode 100644 src/network/CMakeLists.txt
create mode 100644 src/network/address.cpp
create mode 100644 src/network/address.h
create mode 100644 src/network/clientopcodes.cpp
create mode 100644 src/network/clientopcodes.h
create mode 100644 src/network/clientpackethandler.cpp
create mode 100644 src/network/connection.cpp
create mode 100644 src/network/connection.h
create mode 100644 src/network/connectionthreads.cpp
create mode 100644 src/network/connectionthreads.h
create mode 100644 src/network/networkexceptions.h
create mode 100644 src/network/networkpacket.cpp
create mode 100644 src/network/networkpacket.h
create mode 100644 src/network/networkprotocol.h
create mode 100644 src/network/peerhandler.h
create mode 100644 src/network/serveropcodes.cpp
create mode 100644 src/network/serveropcodes.h
create mode 100644 src/network/serverpackethandler.cpp
create mode 100644 src/network/socket.cpp
create mode 100644 src/network/socket.h
create mode 100644 src/nodedef.cpp
create mode 100644 src/nodedef.h
create mode 100644 src/nodemetadata.cpp
create mode 100644 src/nodemetadata.h
create mode 100644 src/nodetimer.cpp
create mode 100644 src/nodetimer.h
create mode 100644 src/noise.cpp
create mode 100644 src/noise.h
create mode 100644 src/objdef.cpp
create mode 100644 src/objdef.h
create mode 100644 src/object_properties.cpp
create mode 100644 src/object_properties.h
create mode 100644 src/pathfinder.cpp
create mode 100644 src/pathfinder.h
create mode 100644 src/player.cpp
create mode 100644 src/player.h
create mode 100644 src/porting.cpp
create mode 100644 src/porting.h
create mode 100644 src/porting_android.cpp
create mode 100644 src/porting_android.h
create mode 100644 src/profiler.cpp
create mode 100644 src/profiler.h
create mode 100644 src/quicktune.cpp
create mode 100644 src/quicktune.h
create mode 100644 src/quicktune_shortcutter.h
create mode 100644 src/raycast.cpp
create mode 100644 src/raycast.h
create mode 100644 src/reflowscan.cpp
create mode 100644 src/reflowscan.h
create mode 100644 src/remoteplayer.cpp
create mode 100644 src/remoteplayer.h
create mode 100644 src/rollback.cpp
create mode 100644 src/rollback.h
create mode 100644 src/rollback_interface.cpp
create mode 100644 src/rollback_interface.h
create mode 100644 src/script/CMakeLists.txt
create mode 100644 src/script/common/CMakeLists.txt
create mode 100644 src/script/common/c_content.cpp
create mode 100644 src/script/common/c_content.h
create mode 100644 src/script/common/c_converter.cpp
create mode 100644 src/script/common/c_converter.h
create mode 100644 src/script/common/c_internal.cpp
create mode 100644 src/script/common/c_internal.h
create mode 100644 src/script/common/c_types.cpp
create mode 100644 src/script/common/c_types.h
create mode 100644 src/script/common/helper.cpp
create mode 100644 src/script/common/helper.h
create mode 100644 src/script/cpp_api/CMakeLists.txt
create mode 100644 src/script/cpp_api/s_async.cpp
create mode 100644 src/script/cpp_api/s_async.h
create mode 100644 src/script/cpp_api/s_base.cpp
create mode 100644 src/script/cpp_api/s_base.h
create mode 100644 src/script/cpp_api/s_client.cpp
create mode 100644 src/script/cpp_api/s_client.h
create mode 100644 src/script/cpp_api/s_entity.cpp
create mode 100644 src/script/cpp_api/s_entity.h
create mode 100644 src/script/cpp_api/s_env.cpp
create mode 100644 src/script/cpp_api/s_env.h
create mode 100644 src/script/cpp_api/s_internal.h
create mode 100644 src/script/cpp_api/s_inventory.cpp
create mode 100644 src/script/cpp_api/s_inventory.h
create mode 100644 src/script/cpp_api/s_item.cpp
create mode 100644 src/script/cpp_api/s_item.h
create mode 100644 src/script/cpp_api/s_mainmenu.cpp
create mode 100644 src/script/cpp_api/s_mainmenu.h
create mode 100644 src/script/cpp_api/s_modchannels.cpp
create mode 100644 src/script/cpp_api/s_modchannels.h
create mode 100644 src/script/cpp_api/s_node.cpp
create mode 100644 src/script/cpp_api/s_node.h
create mode 100644 src/script/cpp_api/s_nodemeta.cpp
create mode 100644 src/script/cpp_api/s_nodemeta.h
create mode 100644 src/script/cpp_api/s_player.cpp
create mode 100644 src/script/cpp_api/s_player.h
create mode 100644 src/script/cpp_api/s_security.cpp
create mode 100644 src/script/cpp_api/s_security.h
create mode 100644 src/script/cpp_api/s_server.cpp
create mode 100644 src/script/cpp_api/s_server.h
create mode 100644 src/script/lua_api/CMakeLists.txt
create mode 100644 src/script/lua_api/l_areastore.cpp
create mode 100644 src/script/lua_api/l_areastore.h
create mode 100644 src/script/lua_api/l_auth.cpp
create mode 100644 src/script/lua_api/l_auth.h
create mode 100644 src/script/lua_api/l_base.cpp
create mode 100644 src/script/lua_api/l_base.h
create mode 100644 src/script/lua_api/l_camera.cpp
create mode 100644 src/script/lua_api/l_camera.h
create mode 100644 src/script/lua_api/l_client.cpp
create mode 100644 src/script/lua_api/l_client.h
create mode 100644 src/script/lua_api/l_craft.cpp
create mode 100644 src/script/lua_api/l_craft.h
create mode 100644 src/script/lua_api/l_env.cpp
create mode 100644 src/script/lua_api/l_env.h
create mode 100644 src/script/lua_api/l_http.cpp
create mode 100644 src/script/lua_api/l_http.h
create mode 100644 src/script/lua_api/l_internal.h
create mode 100644 src/script/lua_api/l_inventory.cpp
create mode 100644 src/script/lua_api/l_inventory.h
create mode 100644 src/script/lua_api/l_item.cpp
create mode 100644 src/script/lua_api/l_item.h
create mode 100644 src/script/lua_api/l_itemstackmeta.cpp
create mode 100644 src/script/lua_api/l_itemstackmeta.h
create mode 100644 src/script/lua_api/l_localplayer.cpp
create mode 100644 src/script/lua_api/l_localplayer.h
create mode 100644 src/script/lua_api/l_mainmenu.cpp
create mode 100644 src/script/lua_api/l_mainmenu.h
create mode 100644 src/script/lua_api/l_mapgen.cpp
create mode 100644 src/script/lua_api/l_mapgen.h
create mode 100644 src/script/lua_api/l_metadata.cpp
create mode 100644 src/script/lua_api/l_metadata.h
create mode 100644 src/script/lua_api/l_minimap.cpp
create mode 100644 src/script/lua_api/l_minimap.h
create mode 100644 src/script/lua_api/l_modchannels.cpp
create mode 100644 src/script/lua_api/l_modchannels.h
create mode 100644 src/script/lua_api/l_nodemeta.cpp
create mode 100644 src/script/lua_api/l_nodemeta.h
create mode 100644 src/script/lua_api/l_nodetimer.cpp
create mode 100644 src/script/lua_api/l_nodetimer.h
create mode 100644 src/script/lua_api/l_noise.cpp
create mode 100644 src/script/lua_api/l_noise.h
create mode 100644 src/script/lua_api/l_object.cpp
create mode 100644 src/script/lua_api/l_object.h
create mode 100644 src/script/lua_api/l_particles.cpp
create mode 100644 src/script/lua_api/l_particles.h
create mode 100644 src/script/lua_api/l_particles_local.cpp
create mode 100644 src/script/lua_api/l_particles_local.h
create mode 100644 src/script/lua_api/l_playermeta.cpp
create mode 100644 src/script/lua_api/l_playermeta.h
create mode 100644 src/script/lua_api/l_rollback.cpp
create mode 100644 src/script/lua_api/l_rollback.h
create mode 100644 src/script/lua_api/l_server.cpp
create mode 100644 src/script/lua_api/l_server.h
create mode 100644 src/script/lua_api/l_settings.cpp
create mode 100644 src/script/lua_api/l_settings.h
create mode 100644 src/script/lua_api/l_sound.cpp
create mode 100644 src/script/lua_api/l_sound.h
create mode 100644 src/script/lua_api/l_storage.cpp
create mode 100644 src/script/lua_api/l_storage.h
create mode 100644 src/script/lua_api/l_util.cpp
create mode 100644 src/script/lua_api/l_util.h
create mode 100644 src/script/lua_api/l_vmanip.cpp
create mode 100644 src/script/lua_api/l_vmanip.h
create mode 100644 src/script/scripting_client.cpp
create mode 100644 src/script/scripting_client.h
create mode 100644 src/script/scripting_mainmenu.cpp
create mode 100644 src/script/scripting_mainmenu.h
create mode 100644 src/script/scripting_server.cpp
create mode 100644 src/script/scripting_server.h
create mode 100644 src/serialization.cpp
create mode 100644 src/serialization.h
create mode 100644 src/server.cpp
create mode 100644 src/server.h
create mode 100644 src/server/CMakeLists.txt
create mode 100644 src/server/activeobjectmgr.cpp
create mode 100644 src/server/activeobjectmgr.h
create mode 100644 src/server/mods.cpp
create mode 100644 src/server/mods.h
create mode 100644 src/serverenvironment.cpp
create mode 100644 src/serverenvironment.h
create mode 100644 src/serverlist.cpp
create mode 100644 src/serverlist.h
create mode 100644 src/serverobject.cpp
create mode 100644 src/serverobject.h
create mode 100644 src/settings.cpp
create mode 100644 src/settings.h
create mode 100644 src/settings_translation_file.cpp
create mode 100644 src/sound.h
create mode 100644 src/staticobject.cpp
create mode 100644 src/staticobject.h
create mode 100644 src/terminal_chat_console.cpp
create mode 100644 src/terminal_chat_console.h
create mode 100644 src/threading/CMakeLists.txt
create mode 100644 src/threading/event.cpp
create mode 100644 src/threading/event.h
create mode 100644 src/threading/mutex_auto_lock.h
create mode 100644 src/threading/semaphore.cpp
create mode 100644 src/threading/semaphore.h
create mode 100644 src/threading/thread.cpp
create mode 100644 src/threading/thread.h
create mode 100644 src/tileanimation.cpp
create mode 100644 src/tileanimation.h
create mode 100644 src/tool.cpp
create mode 100644 src/tool.h
create mode 100644 src/translation.cpp
create mode 100644 src/translation.h
create mode 100644 src/unittest/CMakeLists.txt
create mode 100644 src/unittest/test.cpp
create mode 100644 src/unittest/test.h
create mode 100644 src/unittest/test_activeobject.cpp
create mode 100644 src/unittest/test_address.cpp
create mode 100644 src/unittest/test_areastore.cpp
create mode 100644 src/unittest/test_authdatabase.cpp
create mode 100644 src/unittest/test_ban.cpp
create mode 100644 src/unittest/test_clientactiveobjectmgr.cpp
create mode 100644 src/unittest/test_collision.cpp
create mode 100644 src/unittest/test_compression.cpp
create mode 100644 src/unittest/test_config.h.in
create mode 100644 src/unittest/test_connection.cpp
create mode 100644 src/unittest/test_eventmanager.cpp
create mode 100644 src/unittest/test_filepath.cpp
create mode 100644 src/unittest/test_gameui.cpp
create mode 100644 src/unittest/test_inventory.cpp
create mode 100644 src/unittest/test_keycode.cpp
create mode 100644 src/unittest/test_map_settings_manager.cpp
create mode 100644 src/unittest/test_mapnode.cpp
create mode 100644 src/unittest/test_modchannels.cpp
create mode 100644 src/unittest/test_nodedef.cpp
create mode 100644 src/unittest/test_noderesolver.cpp
create mode 100644 src/unittest/test_noise.cpp
create mode 100644 src/unittest/test_objdef.cpp
create mode 100644 src/unittest/test_player.cpp
create mode 100644 src/unittest/test_profiler.cpp
create mode 100644 src/unittest/test_random.cpp
create mode 100644 src/unittest/test_schematic.cpp
create mode 100644 src/unittest/test_serialization.cpp
create mode 100644 src/unittest/test_server_shutdown_state.cpp
create mode 100644 src/unittest/test_serveractiveobjectmgr.cpp
create mode 100644 src/unittest/test_servermodmanager.cpp
create mode 100644 src/unittest/test_settings.cpp
create mode 100644 src/unittest/test_socket.cpp
create mode 100644 src/unittest/test_threading.cpp
create mode 100644 src/unittest/test_utilities.cpp
create mode 100644 src/unittest/test_voxelalgorithms.cpp
create mode 100644 src/unittest/test_voxelarea.cpp
create mode 100644 src/unittest/test_voxelmanipulator.cpp
create mode 100644 src/util/CMakeLists.txt
create mode 100644 src/util/areastore.cpp
create mode 100644 src/util/areastore.h
create mode 100644 src/util/auth.cpp
create mode 100644 src/util/auth.h
create mode 100644 src/util/base64.cpp
create mode 100644 src/util/base64.h
create mode 100644 src/util/basic_macros.h
create mode 100644 src/util/container.h
create mode 100644 src/util/directiontables.cpp
create mode 100644 src/util/directiontables.h
create mode 100644 src/util/enriched_string.cpp
create mode 100644 src/util/enriched_string.h
create mode 100644 src/util/hex.h
create mode 100644 src/util/ieee_float.cpp
create mode 100644 src/util/ieee_float.h
create mode 100644 src/util/md32_common.h
create mode 100644 src/util/numeric.cpp
create mode 100644 src/util/numeric.h
create mode 100644 src/util/pointedthing.cpp
create mode 100644 src/util/pointedthing.h
create mode 100644 src/util/pointer.h
create mode 100644 src/util/serialize.cpp
create mode 100644 src/util/serialize.h
create mode 100644 src/util/sha1.cpp
create mode 100644 src/util/sha1.h
create mode 100644 src/util/sha2.h
create mode 100644 src/util/sha256.c
create mode 100644 src/util/srp.cpp
create mode 100644 src/util/srp.h
create mode 100644 src/util/strfnd.h
create mode 100644 src/util/string.cpp
create mode 100644 src/util/string.h
create mode 100644 src/util/thread.h
create mode 100644 src/util/timetaker.cpp
create mode 100644 src/util/timetaker.h
create mode 100644 src/version.cpp
create mode 100644 src/version.h
create mode 100644 src/voxel.cpp
create mode 100644 src/voxel.h
create mode 100644 src/voxelalgorithms.cpp
create mode 100644 src/voxelalgorithms.h
create mode 100644 textures/base/pack/air.png
create mode 100644 textures/base/pack/aux_btn.png
create mode 100644 textures/base/pack/blank.png
create mode 100644 textures/base/pack/camera_btn.png
create mode 100644 textures/base/pack/chat_btn.png
create mode 100644 textures/base/pack/chat_hide_btn.png
create mode 100644 textures/base/pack/chat_show_btn.png
create mode 100644 textures/base/pack/checkbox_16.png
create mode 100644 textures/base/pack/checkbox_32.png
create mode 100644 textures/base/pack/checkbox_64.png
create mode 100644 textures/base/pack/debug_btn.png
create mode 100644 textures/base/pack/down.png
create mode 100644 textures/base/pack/drop_btn.png
create mode 100644 textures/base/pack/error_screenshot.png
create mode 100644 textures/base/pack/fast_btn.png
create mode 100644 textures/base/pack/fly_btn.png
create mode 100644 textures/base/pack/gear_icon.png
create mode 100644 textures/base/pack/halo.png
create mode 100644 textures/base/pack/ignore.png
create mode 100644 textures/base/pack/inventory_btn.png
create mode 100644 textures/base/pack/joystick_bg.png
create mode 100644 textures/base/pack/joystick_center.png
create mode 100644 textures/base/pack/joystick_off.png
create mode 100644 textures/base/pack/jump_btn.png
create mode 100644 textures/base/pack/loading_screenshot.png
create mode 100644 textures/base/pack/logo.png
create mode 100644 textures/base/pack/menu_bg.png
create mode 100644 textures/base/pack/menu_header.png
create mode 100644 textures/base/pack/minimap_btn.png
create mode 100644 textures/base/pack/minimap_mask_round.png
create mode 100644 textures/base/pack/minimap_mask_square.png
create mode 100644 textures/base/pack/minimap_overlay_round.png
create mode 100644 textures/base/pack/minimap_overlay_square.png
create mode 100644 textures/base/pack/no_screenshot.png
create mode 100644 textures/base/pack/noclip_btn.png
create mode 100644 textures/base/pack/object_marker_red.png
create mode 100644 textures/base/pack/player_marker.png
create mode 100644 textures/base/pack/progress_bar.png
create mode 100644 textures/base/pack/progress_bar_bg.png
create mode 100644 textures/base/pack/rangeview_btn.png
create mode 100644 textures/base/pack/rare_controls.png
create mode 100644 textures/base/pack/refresh.png
create mode 100644 textures/base/pack/server_flags_creative.png
create mode 100644 textures/base/pack/server_flags_damage.png
create mode 100644 textures/base/pack/server_flags_favorite.png
create mode 100644 textures/base/pack/server_flags_pvp.png
create mode 100644 textures/base/pack/server_ping_1.png
create mode 100644 textures/base/pack/server_ping_2.png
create mode 100644 textures/base/pack/server_ping_3.png
create mode 100644 textures/base/pack/server_ping_4.png
create mode 100644 textures/base/pack/smoke_puff.png
create mode 100644 textures/base/pack/sunrisebg.png
create mode 100644 textures/base/pack/unknown_item.png
create mode 100644 textures/base/pack/unknown_node.png
create mode 100644 textures/base/pack/unknown_object.png
create mode 100644 textures/base/pack/zoom.png
create mode 100755 util/buildbot/buildwin32.sh
create mode 100755 util/buildbot/buildwin64.sh
create mode 100644 util/buildbot/toolchain_mingw.cmake
create mode 100644 util/buildbot/toolchain_mingw64.cmake
create mode 100755 util/bump_version.sh
create mode 100755 util/generate-texture-normals.sh
create mode 100755 util/test_multiplayer.sh
create mode 100755 util/travis/before_install.sh
create mode 100644 util/travis/clang-format-whitelist.txt
create mode 100755 util/travis/clangtidy.sh
create mode 100644 util/travis/common.sh
create mode 100644 util/travis/lint.sh
create mode 100755 util/travis/run-clang-tidy.py
create mode 100755 util/travis/script.sh
create mode 100644 util/travis/toolchain_mingw.cmake.in
create mode 100755 util/updatepo.sh
create mode 100644 util/wireshark/minetest.lua
diff --git a/.DS_Store b/.DS_Store
new file mode 100644
index 0000000000000000000000000000000000000000..2b0cae2e8b9032d40d0f92314541787e36bd7f09
GIT binary patch
literal 6148
zcmeHKJx{|h5PgP76tPrHjM
;HGUh0mcAE?1D~&fhNm?svR|sh)!Z;^;5AZ%VHqNwk}ET5l-=pS2UaX
z@2wZ{f)0I+_@gBU82|p4DN7Rd^p{CUA#EIJLAXR94-lHqcLC%^cmO<)3MzDGyY`;i~PQe
z&5QwK;GZ$zqVz7E@}u-_{q}is*T(FR?9#-p6M>C#?-9U>oFhkG8T7Hpv`ZAbfD%R4
Ry*tq!0-g{XjDbI3-~(f~K9m3e
literal 0
HcmV?d00001
diff --git a/.clang-format b/.clang-format
new file mode 100644
index 0000000..455dc60
--- /dev/null
+++ b/.clang-format
@@ -0,0 +1,30 @@
+BasedOnStyle: LLVM
+IndentWidth: 8
+UseTab: Always
+BreakBeforeBraces: Custom
+Standard: Cpp11
+BraceWrapping:
+ AfterClass: true
+ AfterControlStatement: false
+ AfterEnum: true
+ AfterFunction: true
+ AfterNamespace: true
+ AfterStruct: true
+ AfterUnion: true
+ BeforeCatch: false
+ BeforeElse: false
+AllowShortIfStatementsOnASingleLine: false
+IndentCaseLabels: false
+AccessModifierOffset: -8
+ColumnLimit: 90
+AllowShortFunctionsOnASingleLine: InlineOnly
+SortIncludes: false
+IncludeCategories:
+ - Regex: '^".*'
+ Priority: 2
+ - Regex: '^<.*'
+ Priority: 1
+AlignAfterOpenBracket: DontAlign
+ContinuationIndentWidth: 16
+ConstructorInitializerIndentWidth: 16
+BreakConstructorInitializers: AfterColon
diff --git a/.clang-tidy b/.clang-tidy
new file mode 100644
index 0000000..80c1949
--- /dev/null
+++ b/.clang-tidy
@@ -0,0 +1,4 @@
+Checks: '-*,modernize-use-emplace,modernize-use-default-member-init,modernize-use-equals-delete,modernize-use-equals-default,modernize-return-braced-init-list,modernize-loop-convert,modernize-avoid-bind,misc-throw-by-value-catch-by-reference,misc-string-compare,misc-inefficient-algorithm,misc-inaccurate-erase,misc-incorrect-roundings,misc-unconventional-assign-operator,bugprone-suspicious-memset-usage,performance-*'
+CheckOptions:
+ - key: modernize-use-default-member-init.UseAssignment
+ value: True
diff --git a/.gitattributes b/.gitattributes
new file mode 100644
index 0000000..2e62a4e
--- /dev/null
+++ b/.gitattributes
@@ -0,0 +1,2 @@
+*.cpp diff=cpp
+*.h diff=cpp
diff --git a/.github/ISSUE_TEMPLATE.md b/.github/ISSUE_TEMPLATE.md
new file mode 100644
index 0000000..f6fc9ab
--- /dev/null
+++ b/.github/ISSUE_TEMPLATE.md
@@ -0,0 +1,31 @@
+##### Issue type
+
+ - Bug report
+ - Feature request
+ - Documentation issue
+ - Build issue
+
+##### Minetest version
+
+```
+
+```
+
+##### OS / Hardware
+
+Operating system:
+CPU:
+
+
+GPU model:
+OpenGL version:
+
+##### Summary
+
+
+##### Steps to reproduce
+
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..6591b84
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,113 @@
+## Editors and Development environments
+*~
+*.swp
+*.bak*
+*.orig
+# Vim
+*.vim
+# Kate
+.*.kate-swp
+.swp.*
+# KDevelop4
+.kdev4/
+*.kdev4
+# Eclipse (CDT and LDT)
+.project
+.cproject
+.settings/
+.buildpath
+.metadata
+# GNU Global
+tags
+!tags/
+gtags.files
+.idea/*
+# Codelite
+*.project
+
+## Files related to minetest development cycle
+/*.patch
+*.diff
+# GNU Patch reject file
+*.rej
+
+## Non-static Minetest directories or symlinks to these
+/bin/
+/games/*
+!/games/minimal/
+/cache
+/textures/*
+!/textures/base/
+/screenshots
+/sounds
+/mods/*
+!/mods/minetest/
+/mods/minetest/*
+!/mods/minetest/mods_here.txt
+/worlds
+/world/
+/clientmods/*
+!/clientmods/preview/
+/client/mod_storage/
+
+## Configuration/log files
+minetest.conf
+debug.txt
+
+## Other files generated by minetest
+screenshot_*.png
+testbm.txt
+
+## Doxygen files
+doc/Doxyfile
+doc/html/
+doc/doxygen_*
+
+## Build files
+CMakeFiles
+Makefile
+!build/android/Makefile
+build/android/path.cfg
+build/android/*.apk
+build/android/.externalNativeBuild
+cmake_install.cmake
+CMakeCache.txt
+CPackConfig.cmake
+CPackSourceConfig.cmake
+src/test_config.h
+src/android_version.h
+src/android_version_githash.h
+src/cmake_config.h
+src/cmake_config_githash.h
+src/unittest/test_world/world.mt
+src/lua/build/
+locale/
+.directory
+*.cbp
+*.layout
+*.o
+*.a
+*.ninja
+.ninja*
+*.gch
+*.iml
+test_config.h
+cmake-build-debug/
+cmake-build-release/
+cmake_config.h
+cmake_config_githash.h
+CMakeDoxy*
+compile_commands.json
+
+## Android build files
+build/android/src/main/assets
+build/android/build
+build/android/deps
+build/android/libs
+build/android/jni/lib
+build/android/jni/src
+build/android/src/main/jniLibs
+build/android/obj
+build/android/local.properties
+build/android/.gradle
+timestamp
diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml
new file mode 100644
index 0000000..b957fdb
--- /dev/null
+++ b/.gitlab-ci.yml
@@ -0,0 +1,324 @@
+---
+# Github repository is cloned every day on Gitlab.com
+# https://gitlab.com/minetest/minetest
+# Pipelines URL: https://gitlab.com/minetest/minetest/pipelines
+
+stages:
+ - build
+ - package
+ - deploy
+
+variables:
+ MINETEST_GAME_REPO: "https://github.com/minetest/minetest_game.git"
+ CONTAINER_IMAGE: registry.gitlab.com/$CI_PROJECT_PATH
+
+.build_template: &build_definition
+ stage: build
+ script:
+ - mkdir cmakebuild
+ - mkdir -p artifact/minetest/usr/
+ - cd cmakebuild
+ - cmake -DCMAKE_INSTALL_PREFIX=../artifact/minetest/usr/ -DCMAKE_BUILD_TYPE=Release -DRUN_IN_PLACE=FALSE -DENABLE_GETTEXT=TRUE -DBUILD_SERVER=TRUE ..
+ - make -j2
+ - make install
+ artifacts:
+ when: on_success
+ expire_in: 2h
+ paths:
+ - artifact/*
+
+.debpkg_template: &debpkg_template
+ stage: package
+ before_script:
+ - apt-get update -y
+ - apt-get install -y git
+ - mkdir -p build/deb/minetest/DEBIAN/
+ - cp misc/debpkg-control build/deb/minetest/DEBIAN/control
+ - cp -Rp artifact/minetest/usr build/deb/minetest/
+ script:
+ - git clone $MINETEST_GAME_REPO build/deb/minetest/usr/share/minetest/games/minetest
+ - rm -Rf build/deb/minetest/usr/share/minetest/games/minetest/.git
+ - sed -i 's/DATEPLACEHOLDER/'$(date +%y.%m.%d)'/g' build/deb/minetest/DEBIAN/control
+ - sed -i 's/LEVELDB_PLACEHOLDER/'$LEVELDB_PKG'/g' build/deb/minetest/DEBIAN/control
+ - cd build/deb/ && dpkg-deb -b minetest/ && mv minetest.deb ../../
+ artifacts:
+ when: on_success
+ expire_in: 90 day
+ paths:
+ - ./*.deb
+
+.debpkg_install: &debpkg_install
+ stage: deploy
+ before_script:
+ - apt-get update -y
+ - apt-get install -y libc6 libcurl3-gnutls libfreetype6 libirrlicht1.8 $LEVELDB_PKG liblua5.1-0 libluajit-5.1-2 libopenal1 libstdc++6 libvorbisfile3 libx11-6 zlib1g
+ script:
+ - dpkg -i ./*.deb
+
+##
+## Debian
+##
+
+# Jessie
+
+build:debian-8:
+ <<: *build_definition
+ image: debian:8
+ before_script:
+ - echo "deb http://ppa.launchpad.net/ubuntu-toolchain-r/test/ubuntu trusty main" > /etc/apt/sources.list.d/uptodate-toolchain.list
+ - apt-key adv --keyserver keyserver.ubuntu.com --recv BA9EF27F
+ - apt-get update -y
+ - apt-get -y install build-essential gcc-6 g++-6 libirrlicht-dev cmake libbz2-dev libpng-dev libjpeg-dev libxxf86vm-dev libgl1-mesa-dev libsqlite3-dev libogg-dev libvorbis-dev libopenal-dev libcurl4-gnutls-dev libfreetype6-dev zlib1g-dev libgmp-dev libjsoncpp-dev
+ variables:
+ CC: gcc-6
+ CXX: g++-6
+
+package:debian-8:
+ image: debian:8
+ dependencies:
+ - build:debian-8
+ variables:
+ LEVELDB_PKG: libleveldb1
+ <<: *debpkg_template
+
+deploy:debian-8:
+ image: debian:8
+ dependencies:
+ - package:debian-8
+ variables:
+ LEVELDB_PKG: libleveldb1
+ <<: *debpkg_install
+
+# Stretch
+
+build:debian-9:
+ <<: *build_definition
+ image: debian:9
+ before_script:
+ - apt-get update -y
+ - apt-get -y install build-essential libirrlicht-dev cmake libbz2-dev libpng-dev libjpeg-dev libxxf86vm-dev libgl1-mesa-dev libsqlite3-dev libogg-dev libvorbis-dev libopenal-dev libcurl4-gnutls-dev libfreetype6-dev zlib1g-dev libgmp-dev libjsoncpp-dev
+
+package:debian-9:
+ image: debian:9
+ dependencies:
+ - build:debian-9
+ variables:
+ LEVELDB_PKG: libleveldb1v5
+ <<: *debpkg_template
+
+deploy:debian-9:
+ image: debian:9
+ dependencies:
+ - package:debian-9
+ variables:
+ LEVELDB_PKG: libleveldb1v5
+ <<: *debpkg_install
+
+##
+## Ubuntu
+##
+
+# Trusty
+
+build:ubuntu-14.04:
+ <<: *build_definition
+ image: ubuntu:trusty
+ before_script:
+ - echo "deb http://ppa.launchpad.net/ubuntu-toolchain-r/test/ubuntu trusty main" > /etc/apt/sources.list.d/uptodate-toolchain.list
+ - apt-key adv --keyserver keyserver.ubuntu.com --recv BA9EF27F
+ - apt-get update -y
+ - apt-get -y install build-essential gcc-6 g++-6 libirrlicht-dev cmake libbz2-dev libpng-dev libjpeg-dev libxxf86vm-dev libgl1-mesa-dev libsqlite3-dev libogg-dev libvorbis-dev libopenal-dev libcurl4-gnutls-dev libfreetype6-dev zlib1g-dev libgmp-dev libjsoncpp-dev
+ variables:
+ CC: gcc-6
+ CXX: g++-6
+
+package:ubuntu-14.04:
+ image: ubuntu:trusty
+ dependencies:
+ - build:ubuntu-14.04
+ variables:
+ LEVELDB_PKG: libleveldb1
+ <<: *debpkg_template
+
+deploy:ubuntu-14.04:
+ image: ubuntu:trusty
+ dependencies:
+ - package:ubuntu-14.04
+ variables:
+ LEVELDB_PKG: libleveldb1
+ <<: *debpkg_install
+
+# Xenial
+
+build:ubuntu-16.04:
+ <<: *build_definition
+ image: ubuntu:xenial
+ before_script:
+ - apt-get update -y
+ - apt-get -y install build-essential libirrlicht-dev cmake libbz2-dev libpng-dev libjpeg-dev libxxf86vm-dev libgl1-mesa-dev libsqlite3-dev libogg-dev libvorbis-dev libopenal-dev libcurl4-gnutls-dev libfreetype6-dev zlib1g-dev libgmp-dev libjsoncpp-dev
+
+package:ubuntu-16.04:
+ image: ubuntu:xenial
+ dependencies:
+ - build:ubuntu-16.04
+ variables:
+ LEVELDB_PKG: libleveldb1v5
+ <<: *debpkg_template
+
+deploy:ubuntu-16.04:
+ image: ubuntu:xenial
+ dependencies:
+ - package:ubuntu-16.04
+ variables:
+ LEVELDB_PKG: libleveldb1v5
+ <<: *debpkg_install
+
+# Yakkety
+
+#build:ubuntu-16.10:
+# <<: *build_definition
+# image: ubuntu:yakkety
+# before_script:
+# - apt-get update -y
+# - apt-get -y install build-essential libirrlicht-dev cmake libbz2-dev libpng-dev libjpeg-dev libxxf86vm-dev libgl1-mesa-dev libsqlite3-dev libogg-dev libvorbis-dev libopenal-dev libcurl4-gnutls-dev libfreetype6-dev zlib1g-dev libgmp-dev libjsoncpp-dev
+
+#package:ubuntu-16.10:
+# image: ubuntu:yakkety
+# dependencies:
+# - build:ubuntu-16.10
+# variables:
+# LEVELDB_PKG: libleveldb1v5
+# <<: *debpkg_template
+
+#deploy:ubuntu-16.10:
+# image: ubuntu:yakkety
+# dependencies:
+# - package:ubuntu-16.10
+# variables:
+# LEVELDB_PKG: libleveldb1v5
+# <<: *debpkg_install
+
+# Zesty
+
+#build:ubuntu-17.04:
+# <<: *build_definition
+# image: ubuntu:zesty
+# before_script:
+# - apt-get update -y
+# - apt-get -y install build-essential libirrlicht-dev cmake libbz2-dev libpng-dev libjpeg-dev libxxf86vm-dev libgl1-mesa-dev libsqlite3-dev libogg-dev libvorbis-dev libopenal-dev libcurl4-gnutls-dev libfreetype6-dev zlib1g-dev libgmp-dev libjsoncpp-dev
+
+#package:ubuntu-17.04:
+# image: ubuntu:zesty
+# dependencies:
+# - build:ubuntu-17.04
+# variables:
+# LEVELDB_PKG: libleveldb1v5
+# <<: *debpkg_template
+
+#deploy:ubuntu-17.04:
+# image: ubuntu:zesty
+# dependencies:
+# - package:ubuntu-17.04
+# variables:
+# LEVELDB_PKG: libleveldb1v5
+# <<: *debpkg_install
+
+##
+## Fedora
+##
+
+build:fedora-24:
+ <<: *build_definition
+ image: fedora:24
+ before_script:
+ - dnf -y install make automake gcc gcc-c++ kernel-devel cmake libcurl* openal* libvorbis* libXxf86vm-devel libogg-devel freetype-devel mesa-libGL-devel zlib-devel jsoncpp-devel irrlicht-devel bzip2-libs gmp-devel sqlite-devel luajit-devel leveldb-devel ncurses-devel doxygen spatialindex-devel bzip2-devel
+
+
+##
+## Mingw for Windows
+##
+
+.generic_win_template: &generic_win_template
+ image: ubuntu:xenial
+ before_script:
+ - apt-get update -y
+ - apt-get install -y p7zip-full wget unzip git cmake gettext
+ - wget http://minetest.kitsunemimi.pw/mingw-w64-${WIN_ARCH}_7.1.1_ubuntu14.04.7z -O mingw.7z > /dev/null
+ - sed -e "s|%PREFIX%|${WIN_ARCH}-w64-mingw32|" -e "s|%ROOTPATH%|/usr/${WIN_ARCH}-w64-mingw32|" < util/travis/toolchain_mingw.cmake.in > ${TOOLCHAIN_OUTPUT}
+ - 7z x -y -o/usr mingw.7z > /dev/null
+
+.build_win_template: &build_win_template
+ <<: *generic_win_template
+ stage: build
+ artifacts:
+ when: on_success
+ expire_in: 2h
+ paths:
+ - build/*
+
+.package_win_template: &package_win_template
+ <<: *generic_win_template
+ stage: package
+ script:
+ - cd build/minetest/_build
+ - make package
+ - cd ../../../
+ - mkdir minetest-win-${WIN_ARCH}
+ - unzip build/minetest/_build/minetest-*-win*.zip -d minetest-win-${WIN_ARCH}
+ - cp /usr/${WIN_ARCH}-w64-mingw32/bin/libgcc*.dll minetest-win-${WIN_ARCH}/minetest-*-win*/bin
+ - cp /usr/${WIN_ARCH}-w64-mingw32/bin/libstdc++*.dll minetest-win-${WIN_ARCH}/minetest-*-win*/bin
+ - cp /usr/${WIN_ARCH}-w64-mingw32/bin/libwinpthread*.dll minetest-win-${WIN_ARCH}/minetest-*-win*/bin
+ artifacts:
+ when: on_success
+ expire_in: 90 day
+ paths:
+ - minetest-win-*/*
+
+build:win32:
+ <<: *build_win_template
+ script:
+ - ./util/buildbot/buildwin32.sh build
+ variables:
+ NO_PACKAGE: "1"
+ WIN_ARCH: "i686"
+ TOOLCHAIN_OUTPUT: "util/buildbot/toolchain_mingw.cmake"
+
+package:win32:
+ <<: *package_win_template
+ dependencies:
+ - build:win32
+ variables:
+ NO_PACKAGE: "1"
+ WIN_ARCH: "i686"
+ TOOLCHAIN_OUTPUT: "util/buildbot/toolchain_mingw.cmake"
+
+build:win64:
+ <<: *build_win_template
+ script:
+ - ./util/buildbot/buildwin64.sh build
+ variables:
+ NO_PACKAGE: "1"
+ WIN_ARCH: "x86_64"
+ TOOLCHAIN_OUTPUT: "util/buildbot/toolchain_mingw64.cmake"
+
+package:win64:
+ <<: *package_win_template
+ dependencies:
+ - build:win64
+ variables:
+ NO_PACKAGE: "1"
+ WIN_ARCH: "x86_64"
+ TOOLCHAIN_OUTPUT: "util/buildbot/toolchain_mingw64.cmake"
+
+package:docker:
+ stage: package
+ image: docker:stable
+ services:
+ - docker:dind
+ before_script:
+ - docker login -u gitlab-ci-token -p $CI_JOB_TOKEN registry.gitlab.com
+ script:
+ - docker build . -t ${CONTAINER_IMAGE}/server:$CI_COMMIT_SHA -t ${CONTAINER_IMAGE}/server:$CI_COMMIT_REF_NAME -t ${CONTAINER_IMAGE}/server:latest
+ - docker push ${CONTAINER_IMAGE}/server:$CI_COMMIT_SHA
+ - docker push ${CONTAINER_IMAGE}/server:$CI_COMMIT_REF_NAME
+ - docker push ${CONTAINER_IMAGE}/server:latest
diff --git a/.mailmap b/.mailmap
new file mode 100644
index 0000000..c487460
--- /dev/null
+++ b/.mailmap
@@ -0,0 +1,33 @@
+0gb.us <0gb.us@0gb.us>
+Calinou
+Perttu Ahola celeron55
+Perttu Ahola celeron55
+Craig Robbins
+Diego Martínez
+Ilya Zhuravlev
+kwolekr
+PilzAdam PilzAdam
+PilzAdam Pilz Adam
+PilzAdam PilzAdam
+proller
+proller
+RealBadAngel
+RealBadAngel
+Selat
+ShadowNinja ShadowNinja
+Shen Zheyu arsdragonfly
+Pavel Elagin elagin
+Esteban I. Ruiz Moreno Esteban I. RM
+manuel duarte manuel joaquim
+manuel duarte sweetbomber
+Diego Martínez kaeza
+Diego Martínez Diego Martinez
+Lord James Lord89James
+BlockMen Block Men
+sfan5 Sfan5
+DannyDark dannydark
+Ilya Pavlov Ilya
+Ilya Zhuravlev xyzz
+sapier sapier
+sapier sapier
+
diff --git a/.travis.yml b/.travis.yml
new file mode 100644
index 0000000..2409a51
--- /dev/null
+++ b/.travis.yml
@@ -0,0 +1,109 @@
+language: cpp
+before_install: ./util/travis/before_install.sh
+script: ./util/travis/script.sh
+sudo: required
+dist: trusty
+group: edge
+notifications:
+ email: false
+matrix:
+ fast_finish: true
+ include:
+
+ - env: LINT=1
+ compiler: clang
+ os: linux
+ addons:
+ apt:
+ packages: ['clang-format-5.0']
+ sources: &sources
+ - llvm-toolchain-trusty-5.0
+
+ - env: CLANG_TIDY=1
+ compiler: clang
+ os: linux
+ script: ./util/travis/clangtidy.sh
+ addons:
+ apt:
+ packages: ['clang-tidy-5.0']
+ sources: &sources
+ - llvm-toolchain-trusty-5.0
+
+ - env: PLATFORM=Win32
+ compiler: gcc
+ os: linux
+ addons:
+ apt:
+ packages: ['gcc-mingw-w64-i686', 'g++-mingw-w64-i686', 'binutils-mingw-w64-i686']
+ sources: &sources
+ - ubuntu-toolchain-r-test
+ - sourceline: 'deb http://mirrors.kernel.org/ubuntu xenial main universe'
+
+ - env: PLATFORM=Win64
+ compiler: gcc
+ os: linux
+ addons:
+ apt:
+ packages: ['gcc-mingw-w64-x86-64', 'g++-mingw-w64-x86-64', 'binutils-mingw-w64-x86-64']
+ sources: &sources
+ - ubuntu-toolchain-r-test
+ - sourceline: 'deb http://mirrors.kernel.org/ubuntu xenial main universe'
+
+ - env: PLATFORM=Unix
+ compiler: clang
+ os: osx
+ osx_image: xcode8
+
+ - env: PLATFORM=Unix COMPILER=gcc-6
+ compiler: gcc
+ os: linux
+ addons:
+ apt:
+ packages: ['gcc-6', 'g++-6']
+ sources: &sources
+ - ubuntu-toolchain-r-test
+
+ - env: PLATFORM=Unix COMPILER=gcc-7
+ compiler: gcc
+ os: linux
+ addons:
+ apt:
+ packages: ['gcc-7', 'g++-7']
+ sources: &sources
+ - ubuntu-toolchain-r-test
+
+ - env: PLATFORM=Unix COMPILER=clang-3.6
+ compiler: clang
+ os: linux
+ addons:
+ apt:
+ packages: ['clang-3.6', 'clang++-3.6']
+ sources: &sources
+ - llvm-toolchain-trusty-3.6
+
+ - env: PLATFORM=Unix COMPILER=clang-5.0
+ compiler: clang
+ os: linux
+ addons:
+ apt:
+ packages: ['clang-5.0', 'clang++-5.0']
+ sources: &sources
+ - llvm-toolchain-trusty-5.0
+
+ - env: PLATFORM=Unix COMPILER=clang-5.0 FREETYPE=0
+ compiler: clang
+ os: linux
+ addons:
+ apt:
+ packages: ['clang-5.0', 'clang++-5.0']
+ sources: &sources
+ - llvm-toolchain-trusty-5.0
+
+ - env: PLATFORM=Unix COMPILER=clang-5.0 VALGRIND=1
+ compiler: clang
+ os: linux
+ addons:
+ apt:
+ packages: ['valgrind', 'clang-5.0', 'clang++-5.0']
+ sources: &sources
+ - llvm-toolchain-trusty-5.0
diff --git a/CMakeLists.txt b/CMakeLists.txt
new file mode 100644
index 0000000..e647f62
--- /dev/null
+++ b/CMakeLists.txt
@@ -0,0 +1,328 @@
+cmake_minimum_required(VERSION 2.6)
+
+if(${CMAKE_VERSION} STREQUAL "2.8.2")
+ # Bug http://vtk.org/Bug/view.php?id=11020
+ message(WARNING "CMake/CPack version 2.8.2 will not create working .deb packages!")
+endif()
+
+# This can be read from ${PROJECT_NAME} after project() is called
+project(minetest)
+set(PROJECT_NAME_CAPITALIZED "Minetest")
+
+# Works only for cmake 3.1 and greater
+set(CMAKE_CXX_STANDARD 11)
+set(GCC_MINIMUM_VERSION "4.8")
+set(CLANG_MINIMUM_VERSION "3.4")
+
+# Also remember to set PROTOCOL_VERSION in network/networkprotocol.h when releasing
+set(VERSION_MAJOR 5)
+set(VERSION_MINOR 0)
+set(VERSION_PATCH 1)
+set(VERSION_EXTRA "" CACHE STRING "Stuff to append to version string")
+
+# Change to false for releases
+set(DEVELOPMENT_BUILD FALSE)
+
+set(VERSION_STRING "${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}")
+if(VERSION_EXTRA)
+ set(VERSION_STRING ${VERSION_STRING}-${VERSION_EXTRA})
+elseif(DEVELOPMENT_BUILD)
+ set(VERSION_STRING "${VERSION_STRING}-dev")
+endif()
+
+if (CMAKE_BUILD_TYPE STREQUAL Debug)
+ # Append "-debug" to version string
+ set(VERSION_STRING "${VERSION_STRING}-debug")
+endif()
+
+message(STATUS "*** Will build version ${VERSION_STRING} ***")
+
+
+# Configuration options
+set(DEFAULT_RUN_IN_PLACE FALSE)
+if(WIN32)
+ set(DEFAULT_RUN_IN_PLACE TRUE)
+endif()
+set(RUN_IN_PLACE ${DEFAULT_RUN_IN_PLACE} CACHE BOOL
+ "Run directly in source directory structure")
+
+
+set(BUILD_CLIENT TRUE CACHE BOOL "Build client")
+set(BUILD_SERVER FALSE CACHE BOOL "Build server")
+
+
+set(WARN_ALL TRUE CACHE BOOL "Enable -Wall for Release build")
+
+if(NOT CMAKE_BUILD_TYPE)
+ # Default to release
+ set(CMAKE_BUILD_TYPE Release CACHE STRING "Build type: Debug or Release" FORCE)
+endif()
+
+# Included stuff
+set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${CMAKE_SOURCE_DIR}/cmake/Modules/")
+
+
+# This is done here so that relative search paths are more reasonable
+find_package(Irrlicht)
+
+
+# Installation
+
+if(WIN32)
+ set(SHAREDIR ".")
+ set(BINDIR "bin")
+ set(DOCDIR "doc")
+ set(EXAMPLE_CONF_DIR ".")
+ set(LOCALEDIR "locale")
+elseif(APPLE)
+ set(BUNDLE_NAME ${PROJECT_NAME}.app)
+ set(BUNDLE_PATH "${BUNDLE_NAME}")
+ set(BINDIR ${BUNDLE_NAME}/Contents/MacOS)
+ set(SHAREDIR ${BUNDLE_NAME}/Contents/Resources)
+ set(DOCDIR "${SHAREDIR}/${PROJECT_NAME}")
+ set(EXAMPLE_CONF_DIR ${DOCDIR})
+ set(LOCALEDIR "${SHAREDIR}/locale")
+elseif(UNIX) # Linux, BSD etc
+ if(RUN_IN_PLACE)
+ set(SHAREDIR ".")
+ set(BINDIR "bin")
+ set(DOCDIR "doc")
+ set(EXAMPLE_CONF_DIR ".")
+ set(MANDIR "unix/man")
+ set(XDG_APPS_DIR "unix/applications")
+ set(APPDATADIR "unix/metainfo")
+ set(ICONDIR "unix/icons")
+ set(LOCALEDIR "locale")
+ else()
+ set(SHAREDIR "${CMAKE_INSTALL_PREFIX}/share/${PROJECT_NAME}")
+ set(BINDIR "${CMAKE_INSTALL_PREFIX}/bin")
+ set(DOCDIR "${CMAKE_INSTALL_PREFIX}/share/doc/${PROJECT_NAME}")
+ set(MANDIR "${CMAKE_INSTALL_PREFIX}/share/man")
+ set(EXAMPLE_CONF_DIR ${DOCDIR})
+ set(XDG_APPS_DIR "${CMAKE_INSTALL_PREFIX}/share/applications")
+ set(APPDATADIR "${CMAKE_INSTALL_PREFIX}/share/metainfo")
+ set(ICONDIR "${CMAKE_INSTALL_PREFIX}/share/icons")
+ set(LOCALEDIR "${CMAKE_INSTALL_PREFIX}/share/${PROJECT_NAME}/locale")
+ endif()
+endif()
+
+set(CUSTOM_SHAREDIR "" CACHE STRING "Directory to install data files into")
+if(NOT CUSTOM_SHAREDIR STREQUAL "")
+ set(SHAREDIR "${CUSTOM_SHAREDIR}")
+ message(STATUS "Using SHAREDIR=${SHAREDIR}")
+endif()
+
+set(CUSTOM_BINDIR "" CACHE STRING "Directory to install binaries into")
+if(NOT CUSTOM_BINDIR STREQUAL "")
+ set(BINDIR "${CUSTOM_BINDIR}")
+ message(STATUS "Using BINDIR=${BINDIR}")
+endif()
+
+set(CUSTOM_DOCDIR "" CACHE STRING "Directory to install documentation into")
+if(NOT CUSTOM_DOCDIR STREQUAL "")
+ set(DOCDIR "${CUSTOM_DOCDIR}")
+ if(NOT RUN_IN_PLACE)
+ set(EXAMPLE_CONF_DIR ${DOCDIR})
+ endif()
+ message(STATUS "Using DOCDIR=${DOCDIR}")
+endif()
+
+set(CUSTOM_MANDIR "" CACHE STRING "Directory to install manpages into")
+if(NOT CUSTOM_MANDIR STREQUAL "")
+ set(MANDIR "${CUSTOM_MANDIR}")
+ message(STATUS "Using MANDIR=${MANDIR}")
+endif()
+
+set(CUSTOM_EXAMPLE_CONF_DIR "" CACHE STRING "Directory to install example config file into")
+if(NOT CUSTOM_EXAMPLE_CONF_DIR STREQUAL "")
+ set(EXAMPLE_CONF_DIR "${CUSTOM_EXAMPLE_CONF_DIR}")
+ message(STATUS "Using EXAMPLE_CONF_DIR=${EXAMPLE_CONF_DIR}")
+endif()
+
+set(CUSTOM_XDG_APPS_DIR "" CACHE STRING "Directory to install .desktop files into")
+if(NOT CUSTOM_XDG_APPS_DIR STREQUAL "")
+ set(XDG_APPS_DIR "${CUSTOM_XDG_APPS_DIR}")
+ message(STATUS "Using XDG_APPS_DIR=${XDG_APPS_DIR}")
+endif()
+
+set(CUSTOM_ICONDIR "" CACHE STRING "Directory to install icons into")
+if(NOT CUSTOM_ICONDIR STREQUAL "")
+ set(ICONDIR "${CUSTOM_ICONDIR}")
+ message(STATUS "Using ICONDIR=${ICONDIR}")
+endif()
+
+set(CUSTOM_LOCALEDIR "" CACHE STRING "Directory to install l10n files into")
+if(NOT CUSTOM_LOCALEDIR STREQUAL "")
+ set(LOCALEDIR "${CUSTOM_LOCALEDIR}")
+ message(STATUS "Using LOCALEDIR=${LOCALEDIR}")
+endif()
+
+
+install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/builtin" DESTINATION "${SHAREDIR}")
+if(RUN_IN_PLACE)
+ install(FILES "${CMAKE_CURRENT_SOURCE_DIR}/mods/mods_here.txt" DESTINATION "${SHAREDIR}/mods")
+ install(FILES "${CMAKE_CURRENT_SOURCE_DIR}/textures/texture_packs_here.txt" DESTINATION "${SHAREDIR}/textures")
+endif()
+
+install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/games/minetest_game" DESTINATION "${SHAREDIR}/games/"
+ COMPONENT "SUBGAME_MINETEST_GAME" OPTIONAL PATTERN ".git*" EXCLUDE )
+install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/games/minimal" DESTINATION "${SHAREDIR}/games/"
+ COMPONENT "SUBGAME_MINIMAL" OPTIONAL PATTERN ".git*" EXCLUDE )
+
+if(BUILD_CLIENT)
+ install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/client/shaders" DESTINATION "${SHAREDIR}/client")
+ install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/textures/base/pack" DESTINATION "${SHAREDIR}/textures/base")
+ if(RUN_IN_PLACE)
+ install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/clientmods" DESTINATION "${SHAREDIR}")
+ install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/client/serverlist" DESTINATION "${SHAREDIR}/client")
+ endif()
+endif()
+
+install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/fonts" DESTINATION "${SHAREDIR}")
+
+install(FILES "README.md" DESTINATION "${DOCDIR}" COMPONENT "Docs")
+install(FILES "doc/lua_api.txt" DESTINATION "${DOCDIR}" COMPONENT "Docs")
+install(FILES "doc/menu_lua_api.txt" DESTINATION "${DOCDIR}" COMPONENT "Docs")
+install(FILES "doc/texture_packs.txt" DESTINATION "${DOCDIR}" COMPONENT "Docs")
+install(FILES "doc/world_format.txt" DESTINATION "${DOCDIR}" COMPONENT "Docs")
+install(FILES "minetest.conf.example" DESTINATION "${EXAMPLE_CONF_DIR}")
+
+if(UNIX AND NOT APPLE)
+ install(FILES "doc/minetest.6" "doc/minetestserver.6" DESTINATION "${MANDIR}/man6")
+ install(FILES "misc/net.minetest.minetest.desktop" DESTINATION "${XDG_APPS_DIR}")
+ install(FILES "misc/net.minetest.minetest.appdata.xml" DESTINATION "${APPDATADIR}")
+ install(FILES "misc/minetest.svg" DESTINATION "${ICONDIR}/hicolor/scalable/apps")
+ install(FILES "misc/minetest-xorg-icon-128.png"
+ DESTINATION "${ICONDIR}/hicolor/128x128/apps"
+ RENAME "minetest.png")
+endif()
+
+if(APPLE)
+ install(FILES "misc/minetest-icon.icns" DESTINATION "${SHAREDIR}")
+ install(FILES "misc/Info.plist" DESTINATION "${BUNDLE_PATH}/Contents")
+endif()
+
+# Library pack
+find_package(GMP REQUIRED)
+find_package(Json REQUIRED)
+find_package(Lua REQUIRED)
+
+# JsonCPP doesn't compile well on GCC 4.8
+if(NOT ENABLE_SYSTEM_JSONCPP)
+ set(GCC_MINIMUM_VERSION "4.9")
+endif()
+
+if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
+ if(CMAKE_CXX_COMPILER_VERSION VERSION_LESS "${GCC_MINIMUM_VERSION}")
+ message(FATAL_ERROR "Insufficient gcc version, found ${CMAKE_CXX_COMPILER_VERSION}. "
+ "Version ${GCC_MINIMUM_VERSION} or higher is required.")
+ endif()
+elseif(CMAKE_CXX_COMPILER_ID STREQUAL "Clang")
+ if (CMAKE_CXX_COMPILER_VERSION VERSION_LESS "${CLANG_MINIMUM_VERSION}")
+ message(FATAL_ERROR "Insufficient clang version, found ${CMAKE_CXX_COMPILER_VERSION}. "
+ "Version ${CLANG_MINIMUM_VERSION} or higher is required.")
+ endif()
+endif()
+
+# Subdirectories
+# Be sure to add all relevant definitions above this
+
+add_subdirectory(src)
+
+
+# CPack
+
+set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "An InfiniMiner/Minecraft inspired game")
+set(CPACK_PACKAGE_VERSION_MAJOR ${VERSION_MAJOR})
+set(CPACK_PACKAGE_VERSION_MINOR ${VERSION_MINOR})
+set(CPACK_PACKAGE_VERSION_PATCH ${VERSION_PATCH})
+set(CPACK_PACKAGE_VENDOR "celeron55")
+set(CPACK_PACKAGE_CONTACT "Perttu Ahola ")
+
+include(CPackComponent)
+
+cpack_add_component(Docs
+ DISPLAY_NAME "Documentation"
+ DESCRIPTION "Documentation about Minetest and Minetest modding"
+)
+
+cpack_add_component(SUBGAME_MINETEST_GAME
+ DISPLAY_NAME "Minetest Game"
+ DESCRIPTION "The official subgame for the Minetest engine, that can easily extended by mods."
+ GROUP "Subgames"
+)
+
+cpack_add_component(SUBGAME_MINIMAL
+ DISPLAY_NAME "Minimal development test"
+ DESCRIPTION "A minimal subgame helping to develop the engine."
+ DISABLED #DISABLED does not mean it is disabled, and is just not selected by default.
+ GROUP "Subgames"
+)
+
+cpack_add_component_group(Subgames
+ DESCRIPTION "Games for the Minetest engine."
+)
+
+if(WIN32)
+ # Include all dynamically linked runtime libaries such as MSVCRxxx.dll
+ include(InstallRequiredSystemLibraries)
+
+ if(RUN_IN_PLACE)
+ if(CMAKE_SIZEOF_VOID_P EQUAL 8)
+ set(CPACK_PACKAGE_FILE_NAME "${PROJECT_NAME}-${VERSION_STRING}-win64")
+ else()
+ set(CPACK_PACKAGE_FILE_NAME "${PROJECT_NAME}-${VERSION_STRING}-win32")
+ endif()
+
+ set(CPACK_GENERATOR ZIP)
+
+ else()
+ set(CPACK_GENERATOR WIX ZIP)
+ set(CPACK_PACKAGE_NAME "${PROJECT_NAME_CAPITALIZED}")
+ set(CPACK_PACKAGE_INSTALL_DIRECTORY "${PROJECT_NAME_CAPITALIZED}")
+ set(CPACK_PACKAGE_EXECUTABLES ${PROJECT_NAME} "${PROJECT_NAME_CAPITALIZED}")
+ set(CPACK_CREATE_DESKTOP_LINKS ${PROJECT_NAME})
+
+ set(CPACK_WIX_PRODUCT_ICON "${CMAKE_CURRENT_SOURCE_DIR}/misc/minetest-icon.ico")
+ # Supported languages can be found at
+ # http://wixtoolset.org/documentation/manual/v3/wixui/wixui_localization.html
+ #set(CPACK_WIX_CULTURES "ar-SA,bg-BG,ca-ES,hr-HR,cs-CZ,da-DK,nl-NL,en-US,et-EE,fi-FI,fr-FR,de-DE")
+ set(CPACK_WIX_UI_BANNER "${CMAKE_CURRENT_SOURCE_DIR}/misc/CPACK_WIX_UI_BANNER.BMP")
+ set(CPACK_WIX_UI_DIALOG "${CMAKE_CURRENT_SOURCE_DIR}/misc/CPACK_WIX_UI_DIALOG.BMP")
+
+ set(CPACK_RESOURCE_FILE_LICENSE "${CMAKE_CURRENT_SOURCE_DIR}/doc/lgpl-2.1.txt")
+
+ # The correct way would be to include both x32 and x64 into one installer
+ # and install the appropriate one.
+ # CMake does not support that, so there are two separate GUID's
+ if(CMAKE_SIZEOF_VOID_P EQUAL 8)
+ set(CPACK_WIX_UPGRADE_GUID "745A0FB3-5552-44CA-A587-A91C397CCC56")
+ else()
+ set(CPACK_WIX_UPGRADE_GUID "814A2E2D-2779-4BBD-9ACD-FC3BD51FBBA2")
+ endif()
+ endif()
+elseif(APPLE)
+ set(CPACK_INCLUDE_TOPLEVEL_DIRECTORY 0)
+ set(CPACK_PACKAGE_FILE_NAME "${PROJECT_NAME}-${VERSION_STRING}-osx")
+ set(CPACK_GENERATOR ZIP)
+else()
+ set(CPACK_PACKAGE_FILE_NAME "${PROJECT_NAME}-${VERSION_STRING}-linux")
+ set(CPACK_GENERATOR TGZ)
+ set(CPACK_SOURCE_GENERATOR TGZ)
+endif()
+
+include(CPack)
+
+
+# Add a target to generate API documentation with Doxygen
+find_package(Doxygen)
+if(DOXYGEN_FOUND)
+ configure_file(${CMAKE_CURRENT_SOURCE_DIR}/doc/Doxyfile.in
+ ${CMAKE_CURRENT_BINARY_DIR}/doc/Doxyfile @ONLY)
+ add_custom_target(doc
+ ${DOXYGEN_EXECUTABLE} ${CMAKE_CURRENT_BINARY_DIR}/doc/Doxyfile
+ WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/doc
+ COMMENT "Generating API documentation with Doxygen" VERBATIM
+ )
+endif()
+
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
new file mode 100644
index 0000000..b234fb2
--- /dev/null
+++ b/CONTRIBUTING.md
@@ -0,0 +1,111 @@
+# Contributing
+
+Contributions are welcome! Here's how you can help:
+
+- [Contributing code](#code)
+- [Reporting issues](#issues)
+- [Requesting features](#feature-requests)
+- [Translating](#translations)
+- [Donating](#donations)
+
+## Code
+
+1. [Fork](https://help.github.com/articles/fork-a-repo/) the repository and [clone](https://help.github.com/articles/cloning-a-repository/) your fork.
+
+2. Before you start coding, consider opening an [issue at Github](https://github.com/minetest/minetest/issues) to discuss the suitability and implementation of your intended contribution with the core developers. If you are planning to start some very significant coding, you would benefit from first discussing on our IRC development channel [#minetest-dev](http://www.minetest.net/irc/). Note that a proper IRC client is required to speak on this channel.
+
+3. Start coding!
+ - Refer to the [Lua API](https://github.com/minetest/minetest/blob/master/doc/lua_api.txt), [Developer Wiki](http://dev.minetest.net/Main_Page) and other [documentation](https://github.com/minetest/minetest/tree/master/doc).
+ - Follow the [C/C++](http://dev.minetest.net/Code_style_guidelines) and [Lua](http://dev.minetest.net/Lua_code_style_guidelines) code style guidelines.
+ - Check your code works as expected and document any changes to the Lua API.
+
+4. Commit & [push](https://help.github.com/articles/pushing-to-a-remote/) your changes to a new branch (not `master`, one change per branch)
+ - Commit messages should:
+ - Use the present tense.
+ - Be descriptive. See the commit messages by core developers for examples.
+ - The first line should:
+ - Start with a capital letter.
+ - Be a compact summary of the commit.
+ - Preferably have less than 70 characters.
+ - Have no full stop at the end.
+ - The second line should be empty.
+ - The following lines should describe the commit, starting a new line for each point.
+
+5. Once you are happy with your changes, submit a pull request.
+ - Open the [pull-request form](https://github.com/minetest/minetest/pull/new/master).
+ - Add a description explaining what you've done (or if it's a work-in-progress - what you need to do).
+
+### A pull-request is considered merge-able when:
+
+1. It follows the roadmap in some way and fits the whole picture of the project: [roadmap introduction](http://c55.me/blog/?p=1491), [roadmap continued](https://forum.minetest.net/viewtopic.php?t=9177)
+2. It works.
+3. It follows the code style for [C/C++](http://dev.minetest.net/Code_style_guidelines) or [Lua](http://dev.minetest.net/Lua_code_style_guidelines).
+4. The code's interfaces are well designed, regardless of other aspects that might need more work in the future.
+5. It uses protocols and formats which include the required compatibility.
+
+## Issues
+
+If you experience an issue, we would like to know the details - especially when a stable release is on the way.
+
+1. Do a quick search on GitHub to check if the issue has already been reported.
+2. Is it an issue with the Minetest *engine*? If not, report it [elsewhere](http://www.minetest.net/development/#reporting-issues).
+3. [Open an issue](https://github.com/minetest/minetest/issues/new) and describe the issue you are having - you could include:
+ - Error logs (check the bottom of the `debug.txt` file).
+ - Screenshots.
+ - Ways you have tried to solve the issue, and whether they worked or not.
+ - Your Minetest version and the content (games, mods or texture packs) you have installed.
+ - Your platform (e.g. Windows 10 or Ubuntu 15.04 x64).
+
+After reporting you should aim to answer questions or clarifications as this helps pinpoint the cause of the issue (if you don't do this your issue may be closed after 1 month).
+
+## Feature requests
+
+Feature requests are welcome but take a moment to see if your idea follows the roadmap in some way and fits the whole picture of the project: [roadmap introduction](http://c55.me/blog/?p=1491), [roadmap continued](https://forum.minetest.net/viewtopic.php?t=9177). You should provide a clear explanation with as much detail as possible.
+
+## Translations
+
+Translations of Minetest are performed using Weblate. You can access the project page with a list of current languages [here](https://hosted.weblate.org/projects/minetest/minetest/).
+
+## Donations
+
+If you'd like to monetarily support Minetest development, you can find donation methods on [our website](http://www.minetest.net/development/#donate).
+
+# Maintaining
+
+*This is a concise version of the [Rules & Guidelines](http://dev.minetest.net/Category:Rules_and_Guidelines) on the developer wiki.*
+
+These notes are for those who have push access Minetest (core developers / maintainers).
+
+- See the [project organisation](http://dev.minetest.net/Organisation) for the people involved.
+
+## Reviewing pull requests
+
+Pull requests should be reviewed and, if appropriate, checked if they achieve their intended purpose. You can show that you are in the process of, or will review the pull request by commenting *"Looks good"* or something similar.
+
+**If the pull-request is not [merge-able](#a-pull-request-is-considered-merge-able-when):**
+
+Submit a comment explaining to the author what they need to change to make the pull-request merge-able.
+
+- If the author comments or makes changes to the pull-request, it can be reviewed again.
+- If no response is made from the author within 1 month (when improvements are suggested or a question is asked), it can be closed.
+
+**If the pull-request is [merge-able](#a-pull-request-is-considered-merge-able-when):**
+
+Submit a :+1: (+1) or "Looks good" comment to show you believe the pull-request should be merged. "Looks good" comments often signify that the patch might require (more) testing.
+
+- Two core developers must agree to the merge before it is carried out and both should +1 the pull request.
+- Who intends to merge the pull-request should follow the commit rules:
+ - The title should follow the commit guidelines (title starts with a capital letter, present tense, descriptive).
+ - Don't modify history older than 10 minutes.
+ - Use rebase, not merge to get linear history:
+ - `curl https://github.com/minetest/minetest/pull/1.patch | git am`
+
+## Reviewing issues and feature requests
+
+- If an issue does not get a response from its author within 1 month (when requiring more details), it can be closed.
+- When an issue is a duplicate, refer to the first ones and close the later ones.
+- Tag issues with the appropriate [labels](https://github.com/minetest/minetest/labels) for devices, platforms etc.
+
+## Releasing a new version
+
+*Refer to [dev.minetest.net/Releasing_Minetest](http://dev.minetest.net/Releasing_Minetest)*
diff --git a/Dockerfile b/Dockerfile
new file mode 100644
index 0000000..2773411
--- /dev/null
+++ b/Dockerfile
@@ -0,0 +1,40 @@
+FROM debian:stretch
+
+USER root
+RUN apt-get update -y && \
+ apt-get -y install build-essential libirrlicht-dev cmake libbz2-dev libpng-dev libjpeg-dev \
+ libsqlite3-dev libcurl4-gnutls-dev zlib1g-dev libgmp-dev libjsoncpp-dev git && \
+ apt-get clean && rm -rf /var/cache/apt/archives/* && \
+ rm -rf /var/lib/apt/lists/*
+
+COPY . /usr/src/minetest
+
+RUN mkdir -p /usr/src/minetest/cmakebuild && cd /usr/src/minetest/cmakebuild && \
+ cmake -DCMAKE_INSTALL_PREFIX=/usr/local -DCMAKE_BUILD_TYPE=Release -DRUN_IN_PLACE=FALSE \
+ -DBUILD_SERVER=TRUE \
+ -DBUILD_CLIENT=FALSE \
+ -DENABLE_SYSTEM_JSONCPP=1 \
+ .. && \
+ make -j2 && \
+ rm -Rf ../games/minetest_game && git clone https://github.com/minetest/minetest_game ../games/minetest_game && \
+ make install
+
+FROM debian:stretch
+
+USER root
+RUN groupadd minetest && useradd -m -g minetest -d /var/lib/minetest minetest && \
+ apt-get update -y && \
+ apt-get -y install libcurl3-gnutls libjsoncpp1 liblua5.1-0 libluajit-5.1-2 libpq5 libsqlite3-0 \
+ libstdc++6 zlib1g libc6
+
+WORKDIR /var/lib/minetest
+
+COPY --from=0 /usr/local/share/minetest /usr/local/share/minetest
+COPY --from=0 /usr/local/bin/minetestserver /usr/local/bin/minetestserver
+COPY --from=0 /usr/local/share/doc/minetest/minetest.conf.example /etc/minetest/minetest.conf
+
+USER minetest
+
+EXPOSE 30000/udp
+
+CMD ["/usr/local/bin/minetestserver", "--config", "/etc/minetest/minetest.conf"]
diff --git a/LICENSE.txt b/LICENSE.txt
new file mode 100644
index 0000000..994e024
--- /dev/null
+++ b/LICENSE.txt
@@ -0,0 +1,171 @@
+
+License of Minetest textures and sounds
+---------------------------------------
+
+This applies to textures and sounds contained in the main Minetest
+distribution.
+
+Attribution-ShareAlike 3.0 Unported (CC BY-SA 3.0)
+http://creativecommons.org/licenses/by-sa/3.0/
+
+textures/base/pack/refresh.png is under the Apache 2 license
+https://www.apache.org/licenses/LICENSE-2.0.html
+
+Authors of media files
+-----------------------
+Everything not listed in here:
+Copyright (C) 2010-2012 celeron55, Perttu Ahola
+
+ShadowNinja:
+ textures/base/pack/smoke_puff.png
+
+paramat:
+ textures/base/pack/menu_header.png
+
+erlehmann:
+ misc/minetest-icon-24x24.png
+ misc/minetest-icon.ico
+ misc/minetest.svg
+ textures/base/pack/logo.png
+
+JRottm
+ textures/base/pack/player_marker.png
+
+srifqi
+ textures/base/pack/chat_hide_btn.png
+ textures/base/pack/chat_show_btn.png
+ textures/base/pack/joystick_bg.png
+ textures/base/pack/joystick_center.png
+ textures/base/pack/joystick_off.png
+ textures/base/pack/minimap_btn.png
+
+License of Minetest source code
+-------------------------------
+
+Minetest
+Copyright (C) 2010-2018 celeron55, Perttu Ahola
+
+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 2.1 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.
+
+Irrlicht
+---------------
+
+This program uses the Irrlicht Engine. http://irrlicht.sourceforge.net/
+
+ The Irrlicht Engine License
+
+Copyright © 2002-2005 Nikolaus Gebhardt
+
+This software is provided 'as-is', without any express or implied
+warranty. In no event will the authors be held liable for any damages
+arising from the use of this software.
+
+Permission is granted to anyone to use this software for any purpose,
+including commercial applications, and to alter it and redistribute
+it freely, subject to the following restrictions:
+
+ 1. The origin of this software must not be misrepresented; you
+ must not claim that you wrote the original software. If you use
+ this software in a product, an acknowledgment in the product
+ documentation would be appreciated but is not required.
+ 2. Altered source versions must be plainly marked as such, and must
+ not be misrepresented as being the original software.
+ 3. This notice may not be removed or altered from any source
+ distribution.
+
+
+JThread
+---------------
+
+This program uses the JThread library. License for JThread follows:
+
+Copyright (c) 2000-2006 Jori Liesenborgs (jori.liesenborgs@gmail.com)
+
+Permission is hereby granted, free of charge, to any person obtaining a
+copy of this software and associated documentation files (the "Software"),
+to deal in the Software without restriction, including without limitation
+the rights to use, copy, modify, merge, publish, distribute, sublicense,
+and/or sell copies of the Software, and to permit persons to whom the
+Software is furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included
+in all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
+OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
+IN THE SOFTWARE.
+
+Lua
+---------------
+
+Lua is licensed under the terms of the MIT license reproduced below.
+This means that Lua is free software and can be used for both academic
+and commercial purposes at absolutely no cost.
+
+For details and rationale, see https://www.lua.org/license.html .
+
+Copyright (C) 1994-2008 Lua.org, PUC-Rio.
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in
+all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
+
+Fonts
+---------------
+
+Bitstream Vera Fonts Copyright:
+
+ Copyright (c) 2003 by Bitstream, Inc. All Rights Reserved. Bitstream Vera is
+ a trademark of Bitstream, Inc.
+
+Arimo - Apache License, version 2.0
+ Digitized data copyright (c) 2010-2012 Google Corporation.
+
+Cousine - Apache License, version 2.0
+ Digitized data copyright (c) 2010-2012 Google Corporation.
+
+DroidSansFallBackFull:
+
+ Copyright (C) 2008 The Android Open Source Project
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
diff --git a/build/android/Makefile b/build/android/Makefile
new file mode 100644
index 0000000..c5a21c2
--- /dev/null
+++ b/build/android/Makefile
@@ -0,0 +1,766 @@
+# build options
+
+OS := $(shell uname)
+
+# compile with GPROF
+# GPROF = 1
+
+# build for build platform
+API = 14
+APP_PLATFORM = android-$(API)
+
+ANDR_ROOT = $(shell pwd)
+PROJ_ROOT = $(shell realpath $(ANDR_ROOT)/../..)
+APP_ROOT = $(ANDR_ROOT)/src/main
+
+VERSION_MAJOR := $(shell cat $(PROJ_ROOT)/CMakeLists.txt | \
+ grep ^set\(VERSION_MAJOR\ | sed 's/)/ /' | cut -f2 -d' ')
+VERSION_MINOR := $(shell cat $(PROJ_ROOT)/CMakeLists.txt | \
+ grep ^set\(VERSION_MINOR\ | sed 's/)/ /' | cut -f2 -d' ')
+VERSION_PATCH := $(shell cat $(PROJ_ROOT)/CMakeLists.txt | \
+ grep ^set\(VERSION_PATCH\ | sed 's/)/ /' | cut -f2 -d' ')
+
+################################################################################
+# toolchain config for arm new processors
+################################################################################
+TARGET_HOST = arm-linux
+TARGET_ABI = armeabi-v7a
+TARGET_LIBDIR = armeabi-v7a
+TARGET_TOOLCHAIN = arm-linux-androideabi-
+TARGET_CFLAGS_ADDON = -mfloat-abi=softfp -mfpu=vfpv3 -O3
+TARGET_CXXFLAGS_ADDON = $(TARGET_CFLAGS_ADDON)
+TARGET_ARCH = armv7
+CROSS_CC = clang
+CROSS_CXX = clang++
+COMPILER_VERSION = clang
+HAVE_LEVELDB = 0
+
+################################################################################
+# toolchain config for little endian mips
+################################################################################
+#TARGET_HOST = mipsel-linux
+#TARGET_ABI = mips
+#TARGET_LIBDIR = mips
+#TARGET_TOOLCHAIN = mipsel-linux-android-
+#TARGET_ARCH = mips32
+#CROSS_CC = mipsel-linux-android-gcc
+#CROSS_CXX = mipsel-linux-android-g++
+#COMPILER_VERSION = 4.9
+#HAVE_LEVELDB = 0
+
+################################################################################
+# toolchain config for x86
+################################################################################
+#TARGET_HOST = x86-linux
+#TARGET_ABI = x86
+#TARGET_LIBDIR = x86
+#TARGET_TOOLCHAIN = x86-
+#TARGET_ARCH = x86
+#CROSS_CC = clang
+#CROSS_CXX = clang++
+#COMPILER_VERSION = clang
+#HAVE_LEVELDB = 0
+
+################################################################################
+ASSETS_TIMESTAMP = deps/assets_timestamp
+
+LEVELDB_DIR = $(ANDR_ROOT)/deps/leveldb/
+LEVELDB_LIB = $(LEVELDB_DIR)libleveldb.a
+LEVELDB_TIMESTAMP = $(LEVELDB_DIR)/timestamp
+LEVELDB_TIMESTAMP_INT = $(ANDR_ROOT)/deps/leveldb_timestamp
+LEVELDB_URL_GIT = https://github.com/google/leveldb
+LEVELDB_COMMIT = 2d0320a458d0e6a20fff46d5f80b18bfdcce7018
+
+OPENAL_DIR = $(ANDR_ROOT)/deps/openal-soft/
+OPENAL_LIB = $(OPENAL_DIR)libs/$(TARGET_ABI)/libopenal.so
+OPENAL_TIMESTAMP = $(OPENAL_DIR)/timestamp
+OPENAL_TIMESTAMP_INT = $(ANDR_ROOT)/deps/openal_timestamp
+OPENAL_URL_GIT = https://github.com/apportable/openal-soft
+
+OGG_DIR = $(ANDR_ROOT)/deps/libvorbis-libogg-android/
+OGG_LIB = $(OGG_DIR)libs/$(TARGET_ABI)/libogg.so
+VORBIS_LIB = $(OGG_DIR)libs/$(TARGET_ABI)/libogg.so
+OGG_TIMESTAMP = $(OGG_DIR)timestamp
+OGG_TIMESTAMP_INT = $(ANDR_ROOT)/deps/ogg_timestamp
+OGG_URL_GIT = https://gitlab.com/minetest/libvorbis-libogg-android
+
+IRRLICHT_REVISION = 5150
+IRRLICHT_DIR = $(ANDR_ROOT)/deps/irrlicht/
+IRRLICHT_LIB = $(IRRLICHT_DIR)lib/Android/libIrrlicht.a
+IRRLICHT_TIMESTAMP = $(IRRLICHT_DIR)timestamp
+IRRLICHT_TIMESTAMP_INT = $(ANDR_ROOT)/deps/irrlicht_timestamp
+IRRLICHT_URL_SVN = https://svn.code.sf.net/p/irrlicht/code/branches/ogl-es@$(IRRLICHT_REVISION)
+
+OPENSSL_VERSION = 1.0.2n
+OPENSSL_BASEDIR = openssl-$(OPENSSL_VERSION)
+OPENSSL_DIR = $(ANDR_ROOT)/deps/$(OPENSSL_BASEDIR)/
+OPENSSL_LIB = $(OPENSSL_DIR)/libssl.a
+OPENSSL_TIMESTAMP = $(OPENSSL_DIR)timestamp
+OPENSSL_TIMESTAMP_INT = $(ANDR_ROOT)/deps/openssl_timestamp
+OPENSSL_URL = https://www.openssl.org/source/openssl-$(OPENSSL_VERSION).tar.gz
+
+CURL_VERSION = 7.60.0
+CURL_DIR = $(ANDR_ROOT)/deps/curl-$(CURL_VERSION)
+CURL_LIB = $(CURL_DIR)/lib/.libs/libcurl.a
+CURL_TIMESTAMP = $(CURL_DIR)/timestamp
+CURL_TIMESTAMP_INT = $(ANDR_ROOT)/deps/curl_timestamp
+CURL_URL_HTTP = https://curl.haxx.se/download/curl-${CURL_VERSION}.tar.bz2
+
+FREETYPE_DIR = $(ANDR_ROOT)/deps/freetype2-android/
+FREETYPE_LIB = $(FREETYPE_DIR)/Android/obj/local/$(TARGET_ABI)/libfreetype2-static.a
+FREETYPE_TIMESTAMP = $(FREETYPE_DIR)timestamp
+FREETYPE_TIMESTAMP_INT = $(ANDR_ROOT)/deps/freetype_timestamp
+FREETYPE_URL_GIT = https://github.com/cdave1/freetype2-android
+
+ICONV_VERSION = 1.14
+ICONV_DIR = $(ANDR_ROOT)/deps/libiconv/
+ICONV_LIB = $(ICONV_DIR)/lib/.libs/libiconv.so
+ICONV_TIMESTAMP = $(ICONV_DIR)timestamp
+ICONV_TIMESTAMP_INT = $(ANDR_ROOT)/deps/iconv_timestamp
+ICONV_URL_HTTP = https://ftp.gnu.org/pub/gnu/libiconv/libiconv-$(ICONV_VERSION).tar.gz
+
+SQLITE3_FOLDER = sqlite-amalgamation-3240000
+SQLITE3_URL = https://www.sqlite.org/2018/$(SQLITE3_FOLDER).zip
+
+ANDROID_SDK = $(shell grep '^sdk\.dir' local.properties | sed 's/^.*=[[:space:]]*//')
+ANDROID_NDK = $(shell grep '^ndk\.dir' local.properties | sed 's/^.*=[[:space:]]*//')
+
+#use interim target variable to switch leveldb on or off
+ifeq ($(HAVE_LEVELDB),1)
+ LEVELDB_TARGET = $(LEVELDB_LIB)
+endif
+
+.PHONY : debug release reconfig delconfig \
+ leveldb_download clean_leveldb leveldb\
+ irrlicht_download clean_irrlicht irrlicht \
+ clean_assets assets sqlite3_download \
+ freetype_download clean_freetype freetype \
+ apk clean_apk \
+ clean_all clean prep_srcdir \
+ install_debug install_release envpaths all \
+ $(ASSETS_TIMESTAMP) $(LEVELDB_TIMESTAMP) \
+ $(OPENAL_TIMESTAMP) $(OGG_TIMESTAMP) \
+ $(IRRLICHT_TIMESTAMP) $(CURL_TIMESTAMP) \
+ $(OPENSSL_TIMESTAMP) \
+ $(ANDR_ROOT)/jni/src/android_version.h \
+ $(ANDR_ROOT)/jni/src/android_version_githash.h
+
+debug : local.properties
+ export NDEBUG=; \
+ export BUILD_TYPE=debug; \
+ $(MAKE) apk
+
+all : debug release
+
+release : local.properties
+ @export NDEBUG=1; \
+ export BUILD_TYPE=release; \
+ $(MAKE) apk
+
+reconfig: delconfig
+ @$(MAKE) local.properties
+
+delconfig:
+ $(RM) local.properties
+
+local.properties:
+ @echo "Please specify path of ANDROID NDK"; \
+ echo "e.g. $$HOME/Android/Sdk/ndk-bundle/"; \
+ read ANDROID_NDK ; \
+ if [ ! -d $$ANDROID_NDK ] ; then \
+ echo "$$ANDROID_NDK is not a valid folder"; \
+ exit 1; \
+ fi; \
+ echo "ndk.dir = $$ANDROID_NDK" > local.properties; \
+ echo "Please specify path of ANDROID SDK"; \
+ echo "e.g. $$HOME/Android/Sdk/"; \
+ read SDKFLDR ; \
+ if [ ! -d $$SDKFLDR ] ; then \
+ echo "$$SDKFLDR is not a valid folder"; \
+ exit 1; \
+ fi; \
+ echo "sdk.dir = $$SDKFLDR" >> local.properties;
+
+
+$(OPENAL_TIMESTAMP) : openal_download
+ @LAST_MODIF=$$(find ${OPENAL_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+ if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then \
+ touch ${OPENAL_TIMESTAMP}; \
+ fi
+
+openal_download :
+ @if [ ! -d ${OPENAL_DIR} ] ; then \
+ echo "openal sources missing, downloading..."; \
+ mkdir -p ${ANDR_ROOT}/deps; \
+ cd ${ANDR_ROOT}/deps ; \
+ git clone ${OPENAL_URL_GIT} || exit 1; \
+ fi
+
+openal : $(OPENAL_LIB)
+
+$(OPENAL_LIB): $(OPENAL_TIMESTAMP)
+ + @REFRESH=0; \
+ if [ ! -e ${OPENAL_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ ${OPENAL_TIMESTAMP} -nt ${OPENAL_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ $$REFRESH -ne 0 ] ; then \
+ echo "changed timestamp for openal detected building..."; \
+ cd ${OPENAL_DIR}; \
+ export APP_PLATFORM=${APP_PLATFORM}; \
+ export TARGET_ABI=${TARGET_ABI}; \
+ export TARGET_CFLAGS_ADDON="${TARGET_CFLAGS_ADDON}"; \
+ export TARGET_CXXFLAGS_ADDON="${TARGET_CXXFLAGS_ADDON}"; \
+ export COMPILER_VERSION=${COMPILER_VERSION}; \
+ ${ANDROID_NDK}/ndk-build \
+ NDK_APPLICATION_MK=${ANDR_ROOT}/jni/Deps.mk || exit 1; \
+ touch ${OPENAL_TIMESTAMP}; \
+ touch ${OPENAL_TIMESTAMP_INT}; \
+ else \
+ echo "nothing to be done for openal"; \
+ fi
+
+clean_openal :
+ $(RM) -rf ${OPENAL_DIR}
+
+$(OGG_TIMESTAMP) : ogg_download
+ @LAST_MODIF=$$(find ${OGG_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+ if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then \
+ touch ${OGG_TIMESTAMP}; \
+ fi
+
+ogg_download :
+ @if [ ! -d ${OGG_DIR} ] ; then \
+ echo "ogg sources missing, downloading..."; \
+ mkdir -p ${ANDR_ROOT}/deps; \
+ cd ${ANDR_ROOT}/deps ; \
+ git clone ${OGG_URL_GIT}|| exit 1; \
+ cd libvorbis-libogg-android ; \
+ patch -p1 < ${ANDR_ROOT}/patches/libvorbis-libogg-fpu.patch || exit 1; \
+ fi
+
+ogg : $(OGG_LIB)
+
+$(OGG_LIB): $(OGG_TIMESTAMP)
+ + @REFRESH=0; \
+ if [ ! -e ${OGG_TIMESTAMP_INT} ] ; then \
+ echo "${OGG_TIMESTAMP_INT} doesn't exist"; \
+ REFRESH=1; \
+ fi; \
+ if [ ${OGG_TIMESTAMP} -nt ${OGG_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ $$REFRESH -ne 0 ] ; then \
+ echo "changed timestamp for ogg detected building..."; \
+ cd ${OGG_DIR}; \
+ export APP_PLATFORM=${APP_PLATFORM}; \
+ export TARGET_ABI=${TARGET_ABI}; \
+ ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh \
+ --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION} \
+ --platform=${APP_PLATFORM} \
+ --install-dir=$${TOOLCHAIN}; \
+ touch ${OGG_TIMESTAMP}; \
+ touch ${OGG_TIMESTAMP_INT}; \
+ else \
+ echo "nothing to be done for libogg/libvorbis"; \
+ fi
+
+clean_ogg :
+ $(RM) -rf ${OGG_DIR}
+
+$(OPENSSL_TIMESTAMP) : openssl_download
+ @LAST_MODIF=$$(find ${OPENSSL_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+ if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then \
+ touch ${OPENSSL_TIMESTAMP}; \
+ fi
+
+openssl_download :
+ @if [ ! -d ${OPENSSL_DIR} ] ; then \
+ echo "openssl sources missing, downloading..."; \
+ mkdir -p ${ANDR_ROOT}/deps; \
+ cd ${ANDR_ROOT}/deps ; \
+ wget ${OPENSSL_URL} || exit 1; \
+ tar -xzf ${OPENSSL_BASEDIR}.tar.gz; \
+ cd ${OPENSSL_BASEDIR}; \
+ patch -p1 < ${ANDR_ROOT}/patches/openssl_arch.patch; \
+ sed -i 's/-mandroid //g' Configure; \
+ fi
+
+openssl : $(OPENSSL_LIB)
+
+$(OPENSSL_LIB): $(OPENSSL_TIMESTAMP)
+ @REFRESH=0; \
+ if [ ! -e ${OPENSSL_TIMESTAMP_INT} ] ; then \
+ echo "${OPENSSL_TIMESTAMP_INT} doesn't exist"; \
+ REFRESH=1; \
+ fi; \
+ if [ ${OPENSSL_TIMESTAMP} -nt ${OPENSSL_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ $$REFRESH -ne 0 ] ; then \
+ echo "changed timestamp for openssl detected building..."; \
+ cd ${OPENSSL_DIR}; \
+ ln -s ${OPENSSL_DIR} ../openssl; \
+ export TOOLCHAIN=/tmp/ndk-${TARGET_HOST}-openssl; \
+ ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh \
+ --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION} \
+ --platform=${APP_PLATFORM} \
+ --stl=libc++ \
+ --install-dir=$${TOOLCHAIN}; \
+ export PATH="$${TOOLCHAIN}/bin:$${PATH}"; \
+ export CFLAGS="$${CFLAGS} ${TARGET_CFLAGS_ADDON}"; \
+ export LDFLAGS="$${LDFLAGS} ${TARGET_LDFLAGS_ADDON}"; \
+ CC=${CROSS_CC} ./Configure -DL_ENDIAN no-asm android-${TARGET_ARCH} \
+ -D__ANDROID_API__=$(API); \
+ CC=${CROSS_CC} ANDROID_DEV=/tmp/ndk-${TARGET_HOST} make depend; \
+ CC=${CROSS_CC} ANDROID_DEV=/tmp/ndk-${TARGET_HOST} make build_libs; \
+ touch ${OPENSSL_TIMESTAMP}; \
+ touch ${OPENSSL_TIMESTAMP_INT}; \
+ $(RM) -rf $${TOOLCHAIN}; \
+ else \
+ echo "nothing to be done for openssl"; \
+ fi
+
+clean_openssl :
+ $(RM) -rf ${OPENSSL_DIR}; \
+ $(RM) -rf $(ANDR_ROOT)/deps/${OPENSSL_BASEDIR}.tar.gz; \
+ $(RM) -rf $(ANDR_ROOT)/deps/openssl
+
+$(LEVELDB_TIMESTAMP) : leveldb_download
+ @LAST_MODIF=$$(find ${LEVELDB_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+ if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then \
+ touch ${LEVELDB_TIMESTAMP}; \
+ fi
+
+leveldb_download :
+ @if [ ! -d ${LEVELDB_DIR} ] ; then \
+ echo "leveldb sources missing, downloading..."; \
+ mkdir -p ${ANDR_ROOT}/deps; \
+ cd ${ANDR_ROOT}/deps ; \
+ git clone ${LEVELDB_URL_GIT} || exit 1; \
+ cd ${LEVELDB_DIR} || exit 1; \
+ git checkout ${LEVELDB_COMMIT} || exit 1; \
+ fi
+
+leveldb : $(LEVELDB_LIB)
+ifeq ($(HAVE_LEVELDB),1)
+$(LEVELDB_LIB): $(LEVELDB_TIMESTAMP)
+ @REFRESH=0; \
+ if [ ! -e ${LEVELDB_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ ${LEVELDB_TIMESTAMP} -nt ${LEVELDB_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ $$REFRESH -ne 0 ] ; then \
+ echo "changed timestamp for leveldb detected building..."; \
+ cd deps/leveldb; \
+ export CROSS_PREFIX=${TARGET_TOOLCHAIN}; \
+ export TOOLCHAIN=/tmp/ndk-${TARGET_HOST}-leveldb; \
+ ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh \
+ --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION} \
+ --platform=${APP_PLATFORM} \
+ --stl=libc++ \
+ --install-dir=$${TOOLCHAIN}; \
+ export PATH="$${TOOLCHAIN}/bin:$${PATH}"; \
+ export CC=${CROSS_CC}; \
+ export CXX=${CROSS_CXX}; \
+ export CFLAGS="$${CFLAGS} ${TARGET_CFLAGS_ADDON}"; \
+ export CPPFLAGS="$${CPPFLAGS} ${TARGET_CXXFLAGS_ADDON}"; \
+ export LDFLAGS="$${LDFLAGS} ${TARGET_LDFLAGS_ADDON}"; \
+ export TARGET_OS=OS_ANDROID_CROSSCOMPILE; \
+ $(MAKE) || exit 1; \
+ touch ${LEVELDB_TIMESTAMP}; \
+ touch ${LEVELDB_TIMESTAMP_INT}; \
+ $(RM) -rf $${TOOLCHAIN}; \
+ else \
+ echo "nothing to be done for leveldb"; \
+ fi
+endif
+
+clean_leveldb :
+ ./gradlew cleanLevelDB
+
+$(FREETYPE_TIMESTAMP) : freetype_download
+ @LAST_MODIF=$$(find ${FREETYPE_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+ if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then \
+ touch ${FREETYPE_TIMESTAMP}; \
+ fi
+
+freetype_download :
+ @if [ ! -d ${FREETYPE_DIR} ] ; then \
+ echo "freetype sources missing, downloading..."; \
+ mkdir -p ${ANDR_ROOT}/deps; \
+ cd deps; \
+ git clone ${FREETYPE_URL_GIT} || exit 1; \
+ fi
+
+freetype : $(FREETYPE_LIB)
+
+$(FREETYPE_LIB) : $(FREETYPE_TIMESTAMP)
+ + @REFRESH=0; \
+ if [ ! -e ${FREETYPE_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ ! -e ${FREETYPE_LIB} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ ${FREETYPE_TIMESTAMP} -nt ${FREETYPE_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ $$REFRESH -ne 0 ] ; then \
+ mkdir -p ${FREETYPE_DIR}; \
+ echo "changed timestamp for freetype detected building..."; \
+ cd ${FREETYPE_DIR}/Android/jni; \
+ export APP_PLATFORM=${APP_PLATFORM}; \
+ export TARGET_ABI=${TARGET_ABI}; \
+ export TARGET_CFLAGS_ADDON="${TARGET_CFLAGS_ADDON}"; \
+ export TARGET_CXXFLAGS_ADDON="${TARGET_CXXFLAGS_ADDON}"; \
+ export COMPILER_VERSION=${COMPILER_VERSION}; \
+ ${ANDROID_NDK}/ndk-build \
+ NDK_APPLICATION_MK=${ANDR_ROOT}/jni/Deps.mk || exit 1; \
+ touch ${FREETYPE_TIMESTAMP}; \
+ touch ${FREETYPE_TIMESTAMP_INT}; \
+ else \
+ echo "nothing to be done for freetype"; \
+ fi
+
+clean_freetype :
+ ./gradlew cleanFreetype
+
+$(ICONV_TIMESTAMP) : iconv_download
+ @LAST_MODIF=$$(find ${ICONV_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+ if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then \
+ touch ${ICONV_TIMESTAMP}; \
+ fi
+
+iconv_download :
+ @if [ ! -d ${ICONV_DIR} ] ; then \
+ echo "iconv sources missing, downloading..."; \
+ mkdir -p ${ANDR_ROOT}/deps; \
+ cd ${ANDR_ROOT}/deps; \
+ wget ${ICONV_URL_HTTP} || exit 1; \
+ tar -xzf libiconv-${ICONV_VERSION}.tar.gz || exit 1; \
+ rm libiconv-${ICONV_VERSION}.tar.gz; \
+ ln -s libiconv-${ICONV_VERSION} libiconv; \
+ cd ${ICONV_DIR}; \
+ patch -p1 < ${ANDR_ROOT}/patches/libiconv_android.patch; \
+ patch -p1 < ${ANDR_ROOT}/patches/libiconv_stdio.patch; \
+ fi
+
+iconv : $(ICONV_LIB)
+
+$(ICONV_LIB) : $(ICONV_TIMESTAMP)
+ @REFRESH=0; \
+ if [ ! -e ${ICONV_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ ! -e ${ICONV_LIB} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ ${ICONV_TIMESTAMP} -nt ${ICONV_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ $$REFRESH -ne 0 ] ; then \
+ mkdir -p ${ICONV_DIR}; \
+ echo "changed timestamp for iconv detected building..."; \
+ cd ${ICONV_DIR}; \
+ export TOOLCHAIN=/tmp/ndk-${TARGET_HOST}-iconv; \
+ ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh \
+ --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION} \
+ --platform=${APP_PLATFORM} \
+ --stl=libc++ \
+ --install-dir=$${TOOLCHAIN}; \
+ export PATH="$${TOOLCHAIN}/bin:$${PATH}"; \
+ export CFLAGS="$${CFLAGS} ${TARGET_CFLAGS_ADDON}"; \
+ export LDFLAGS="$${LDFLAGS} ${TARGET_LDFLAGS_ADDON} -lstdc++"; \
+ export CC=${CROSS_CC}; \
+ export CXX=${CROSS_CXX}; \
+ export TARGET_OS=OS_ANDROID_CROSSCOMPILE; \
+ ./configure --host=${TARGET_HOST} || exit 1; \
+ sed -i 's/LIBICONV_VERSION_INFO) /LIBICONV_VERSION_INFO) -avoid-version /g' lib/Makefile; \
+ grep "iconv_LDFLAGS" src/Makefile; \
+ $(MAKE) -s || exit 1; \
+ touch ${ICONV_TIMESTAMP}; \
+ touch ${ICONV_TIMESTAMP_INT}; \
+ rm -rf ${TOOLCHAIN}; \
+ else \
+ echo "nothing to be done for iconv"; \
+ fi
+
+clean_iconv :
+ ./gradlew cleanIconv
+
+#Note: Texturehack patch is required for gpu's not supporting color format
+# correctly. Known bad GPU:
+# -geforce on emulator
+# -Vivante Corporation GC1000 core (e.g. Galaxy Tab 3)
+
+irrlicht_download :
+ @if [ ! -d "deps/irrlicht" ] ; then \
+ echo "irrlicht sources missing, downloading..."; \
+ mkdir -p ${ANDR_ROOT}/deps; \
+ cd deps; \
+ svn co ${IRRLICHT_URL_SVN} irrlicht || exit 1; \
+ cd irrlicht; \
+ patch -p1 < ${ANDR_ROOT}/patches/irrlicht-touchcount.patch || exit 1; \
+ patch -p1 < ${ANDR_ROOT}/patches/irrlicht-back_button.patch || exit 1; \
+ patch -p1 < ${ANDR_ROOT}/patches/irrlicht-texturehack.patch || exit 1; \
+ patch -p1 < ${ANDR_ROOT}/patches/irrlicht-native_activity.patch || exit 1; \
+ fi
+
+$(IRRLICHT_TIMESTAMP) : irrlicht_download
+ @LAST_MODIF=$$(find ${IRRLICHT_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+ if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then \
+ touch ${IRRLICHT_TIMESTAMP}; \
+ fi
+
+irrlicht : $(IRRLICHT_LIB)
+
+$(IRRLICHT_LIB): $(IRRLICHT_TIMESTAMP) $(FREETYPE_LIB)
+ + @REFRESH=0; \
+ if [ ! -e ${IRRLICHT_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ ! -e ${IRRLICHT_LIB} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ ${IRRLICHT_TIMESTAMP} -nt ${IRRLICHT_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ $$REFRESH -ne 0 ] ; then \
+ mkdir -p ${IRRLICHT_DIR}; \
+ echo "changed timestamp for irrlicht detected building..."; \
+ cd deps/irrlicht/source/Irrlicht/Android; \
+ export APP_PLATFORM=${APP_PLATFORM}; \
+ export TARGET_ABI=${TARGET_ABI}; \
+ export TARGET_CFLAGS_ADDON="${TARGET_CFLAGS_ADDON}"; \
+ export TARGET_CXXFLAGS_ADDON="${TARGET_CXXFLAGS_ADDON}"; \
+ export COMPILER_VERSION=${COMPILER_VERSION}; \
+ ${ANDROID_NDK}/ndk-build \
+ NDK_APPLICATION_MK=${ANDR_ROOT}/jni/Deps.mk || exit 1; \
+ touch ${IRRLICHT_TIMESTAMP}; \
+ touch ${IRRLICHT_TIMESTAMP_INT}; \
+ else \
+ echo "nothing to be done for irrlicht"; \
+ fi
+
+clean_irrlicht :
+ ./gradlew cleanIrrlicht
+
+$(CURL_TIMESTAMP) : curl_download
+ @LAST_MODIF=$$(find ${CURL_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+ if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then \
+ touch ${CURL_TIMESTAMP}; \
+ fi
+
+curl_download :
+ @if [ ! -d "deps/curl-${CURL_VERSION}" ] ; then \
+ echo "curl sources missing, downloading..."; \
+ mkdir -p ${ANDR_ROOT}/deps; \
+ cd deps; \
+ wget ${CURL_URL_HTTP} || exit 1; \
+ tar -xjf curl-${CURL_VERSION}.tar.bz2 || exit 1; \
+ rm curl-${CURL_VERSION}.tar.bz2; \
+ ln -s curl-${CURL_VERSION} curl; \
+ fi
+
+curl : $(CURL_LIB)
+
+$(CURL_LIB): $(CURL_TIMESTAMP) $(OPENSSL_LIB)
+ @REFRESH=0; \
+ if [ ! -e ${CURL_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ ! -e ${CURL_LIB} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ ${CURL_TIMESTAMP} -nt ${CURL_TIMESTAMP_INT} ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ $$REFRESH -ne 0 ] ; then \
+ mkdir -p ${CURL_DIR}; \
+ echo "changed timestamp for curl detected building..."; \
+ cd deps/curl-${CURL_VERSION}; \
+ export CROSS_PREFIX=${TARGET_TOOLCHAIN}; \
+ export TOOLCHAIN=/tmp/ndk-${TARGET_HOST}-curl; \
+ ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh \
+ --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION} \
+ --platform=${APP_PLATFORM} \
+ --stl=libc++ \
+ --install-dir=$${TOOLCHAIN}; \
+ export PATH="$${TOOLCHAIN}/bin:$${PATH}"; \
+ export CC=${CROSS_CC}; \
+ export CXX=${CROSS_CXX}; \
+ export TARGET_OS=OS_ANDROID_CROSSCOMPILE; \
+ export CPPFLAGS="$${CPPFLAGS} -I${OPENSSL_DIR}/include ${TARGET_CFLAGS_ADDON}"; \
+ export CFLAGS="$${CFLAGS} ${TARGET_CFLAGS_ADDON}"; \
+ export LDFLAGS="$${LDFLAGS} -L${OPENSSL_DIR} ${TARGET_LDFLAGS_ADDON}"; \
+ ./configure --host=${TARGET_HOST} --disable-shared --enable-static --with-ssl; \
+ $(MAKE) -s || exit 1; \
+ touch ${CURL_TIMESTAMP}; \
+ touch ${CURL_TIMESTAMP_INT}; \
+ $(RM) -rf $${TOOLCHAIN}; \
+ else \
+ echo "nothing to be done for curl"; \
+ fi
+
+clean_curl :
+ ./gradlew cleanCURL
+
+sqlite3_download: deps/${SQLITE3_FOLDER}/sqlite3.c
+
+deps/${SQLITE3_FOLDER}/sqlite3.c :
+ cd deps; \
+ wget ${SQLITE3_URL}; \
+ unzip ${SQLITE3_FOLDER}.zip; \
+ ln -s ${SQLITE3_FOLDER} sqlite; \
+ cd ${SQLITE3_FOLDER};
+
+clean_sqlite3:
+ ./gradlew cleanSQLite3
+
+$(ASSETS_TIMESTAMP) : $(IRRLICHT_LIB)
+ @mkdir -p ${ANDR_ROOT}/deps; \
+ for DIRNAME in {builtin,client,doc,fonts,games,mods,po,textures}; do \
+ LAST_MODIF=$$(find ${PROJ_ROOT}/${DIRNAME} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+ if [ $$(basename $$LAST_MODIF) != "timestamp" ]; then \
+ touch ${PROJ_ROOT}/${DIRNAME}/timestamp; \
+ touch ${ASSETS_TIMESTAMP}; \
+ echo ${DIRNAME} changed $$LAST_MODIF; \
+ fi; \
+ done; \
+ LAST_MODIF=$$(find ${IRRLICHT_DIR}/media -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+ if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then \
+ touch ${IRRLICHT_DIR}/media/timestamp; \
+ touch ${ASSETS_TIMESTAMP}; \
+ fi; \
+ if [ ${PROJ_ROOT}/minetest.conf.example -nt ${ASSETS_TIMESTAMP} ] ; then \
+ echo "conf changed"; \
+ touch ${ASSETS_TIMESTAMP}; \
+ fi; \
+ if [ ${PROJ_ROOT}/README.txt -nt ${ASSETS_TIMESTAMP} ] ; then \
+ touch ${ASSETS_TIMESTAMP}; \
+ fi; \
+ if [ ! -e $(ASSETS_TIMESTAMP) ] ; then \
+ touch $(ASSETS_TIMESTAMP); \
+ fi
+
+assets : $(ASSETS_TIMESTAMP)
+ @REFRESH=0; \
+ if [ ! -e ${ASSETS_TIMESTAMP}.old ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ ${ASSETS_TIMESTAMP} -nt ${ASSETS_TIMESTAMP}.old ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ ! -d ${APP_ROOT}/assets ] ; then \
+ REFRESH=1; \
+ fi; \
+ if [ $$REFRESH -ne 0 ] ; then \
+ echo "assets changed, refreshing..."; \
+ $(MAKE) clean_assets; \
+ ./gradlew copyAssets; \
+ cp -r ${IRRLICHT_DIR}/media/Shaders ${APP_ROOT}/assets/Minetest/media; \
+ cd ${APP_ROOT}/assets || exit 1; \
+ find . -name "timestamp" -exec rm {} \; ; \
+ find . -name "*.blend" -exec rm {} \; ; \
+ find . -name "*~" -exec rm {} \; ; \
+ find . -type d -path "*.git" -exec rm -rf {} \; ; \
+ find . -type d -path "*.svn" -exec rm -rf {} \; ; \
+ find . -type f -path "*.gitignore" -exec rm -rf {} \; ; \
+ ls -R | grep ":$$" | sed -e 's/:$$//' -e 's/\.//' -e 's/^\///' > "index.txt"; \
+ find -L Minetest > filelist.txt; \
+ cp ${ANDR_ROOT}/${ASSETS_TIMESTAMP} ${ANDR_ROOT}/${ASSETS_TIMESTAMP}.old; \
+ else \
+ echo "nothing to be done for assets"; \
+ fi
+
+clean_assets :
+ ./gradlew cleanAssets
+
+apk: local.properties assets $(ICONV_LIB) $(IRRLICHT_LIB) $(CURL_LIB) $(LEVELDB_TARGET) \
+ $(OPENAL_LIB) $(OGG_LIB) prep_srcdir $(ANDR_ROOT)/jni/src/android_version.h \
+ $(ANDR_ROOT)/jni/src/android_version_githash.h sqlite3_download
+ + @export TARGET_LIBDIR=${TARGET_LIBDIR}; \
+ export HAVE_LEVELDB=${HAVE_LEVELDB}; \
+ export APP_PLATFORM=${APP_PLATFORM}; \
+ export TARGET_ABI=${TARGET_ABI}; \
+ export TARGET_CFLAGS_ADDON="${TARGET_CFLAGS_ADDON}"; \
+ export TARGET_CXXFLAGS_ADDON="${TARGET_CXXFLAGS_ADDON}"; \
+ export COMPILER_VERSION=${COMPILER_VERSION}; \
+ export GPROF=${GPROF}; \
+ ${ANDROID_NDK}/ndk-build || exit 1; \
+ if [ ! -e ${APP_ROOT}/jniLibs ]; then \
+ ln -s ${ANDR_ROOT}/libs ${APP_ROOT}/jniLibs || exit 1; \
+ fi; \
+ export VERSION_STR="${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}" && \
+ export BUILD_TYPE_C=$$(echo "$${BUILD_TYPE}" | sed 's/./\U&/') && \
+ ./gradlew assemble$$BUILD_TYPE_C && \
+ echo "APK stored at: build/outputs/apk/$$BUILD_TYPE/Minetest-$$BUILD_TYPE.apk" && \
+ echo "You can install it with \`make install_$$BUILD_TYPE\`"
+
+# These Intentionally doesn't depend on their respective build steps,
+# because it takes a while to verify that everything's up-to-date.
+install_debug:
+ ${ANDROID_SDK}/platform-tools/adb install -r build/outputs/apk/debug/Minetest-debug.apk
+
+install_release:
+ ${ANDROID_SDK}/platform-tools/adb install -r build/outputs/apk/release/Minetest-release.apk
+
+prep_srcdir :
+ @if [ ! -e ${ANDR_ROOT}/jni/src ]; then \
+ ln -s ${PROJ_ROOT}/src ${ANDR_ROOT}/jni/src; \
+ fi; \
+ if [ ! -e ${ANDR_ROOT}/jni/lib ]; then \
+ ln -s ${PROJ_ROOT}/lib ${ANDR_ROOT}/jni/lib; \
+ fi
+
+clean_apk :
+ ./gradlew clean
+
+clean_all :
+ ./gradlew cleanAll
+
+$(ANDR_ROOT)/jni/src/android_version_githash.h : prep_srcdir
+ @export VERSION_FILE=${ANDR_ROOT}/jni/src/android_version_githash.h; \
+ export VERSION_FILE_NEW=$${VERSION_FILE}.new; \
+ { \
+ echo "#ifndef ANDROID_MT_VERSION_GITHASH_H"; \
+ echo "#define ANDROID_MT_VERSION_GITHASH_H"; \
+ export GITHASH=$$(git rev-parse --short=8 HEAD); \
+ export VERSION_STR="${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}"; \
+ echo "#define VERSION_GITHASH \"$$VERSION_STR-$$GITHASH-Android\""; \
+ echo "#endif"; \
+ } > "$${VERSION_FILE_NEW}"; \
+ if ! cmp -s $${VERSION_FILE} $${VERSION_FILE_NEW}; then \
+ echo "android_version_githash.h changed, updating..."; \
+ mv "$${VERSION_FILE_NEW}" "$${VERSION_FILE}"; \
+ else \
+ rm "$${VERSION_FILE_NEW}"; \
+ fi
+
+
+$(ANDR_ROOT)/jni/src/android_version.h : prep_srcdir
+ @export VERSION_FILE=${ANDR_ROOT}/jni/src/android_version.h; \
+ export VERSION_FILE_NEW=$${VERSION_FILE}.new; \
+ { \
+ echo "#ifndef ANDROID_MT_VERSION_H"; \
+ echo "#define ANDROID_MT_VERSION_H"; \
+ echo "#define VERSION_MAJOR ${VERSION_MAJOR}"; \
+ echo "#define VERSION_MINOR ${VERSION_MINOR}"; \
+ echo "#define VERSION_PATCH ${VERSION_PATCH}"; \
+ echo "#define VERSION_STRING STR(VERSION_MAJOR) \".\" STR(VERSION_MINOR) \
+ \".\" STR(VERSION_PATCH)"; \
+ echo "#endif"; \
+ } > $${VERSION_FILE_NEW}; \
+ if ! cmp -s $${VERSION_FILE} $${VERSION_FILE_NEW}; then \
+ echo "android_version.h changed, updating..."; \
+ mv "$${VERSION_FILE_NEW}" "$${VERSION_FILE}"; \
+ else \
+ rm "$${VERSION_FILE_NEW}"; \
+ fi
+
+clean : clean_apk clean_assets
diff --git a/build/android/build.gradle b/build/android/build.gradle
new file mode 100644
index 0000000..11a4a71
--- /dev/null
+++ b/build/android/build.gradle
@@ -0,0 +1,170 @@
+buildscript {
+ repositories {
+ maven { url 'https://maven.google.com' }
+ jcenter()
+ }
+ dependencies {
+ classpath 'com.android.tools.build:gradle:3.1.3'
+ }
+}
+
+allprojects {
+ repositories {
+ maven { url 'https://maven.google.com' }
+ jcenter()
+ }
+}
+
+def curl_version = "7.60.0"
+def irrlicht_revision = "5150"
+def openal_version = "1.18.2"
+def openssl_version = "1.0.2n"
+def sqlite3_version = "3240000"
+
+apply plugin: "com.android.application"
+
+android {
+ compileSdkVersion 28
+ buildToolsVersion "28.0.3"
+
+ defaultConfig {
+ versionCode 24
+ versionName "${System.env.VERSION_STR}.${versionCode}"
+ minSdkVersion 14
+ targetSdkVersion 28
+ applicationId "net.minetest.minetest"
+ manifestPlaceholders = [package: "net.minetest.minetest", project: project.name]
+ ndk {
+ // Specifies the ABI configurations of your native
+ // libraries Gradle should build and package with your APK.
+ // abiFilters 'armeabi-v7a', 'arm64-v8a', 'x86', 'x86_64'
+ abiFilters 'armeabi-v7a', 'x86'
+ }
+ }
+
+ lintOptions {
+ disable "OldTargetApi", "GoogleAppIndexingWarning"
+ }
+
+ Properties props = new Properties()
+ props.load(new FileInputStream(file("local.properties")))
+
+ if (props.getProperty("keystore") != null) {
+ signingConfigs {
+ release {
+ storeFile file(props["keystore"])
+ storePassword props["keystore.password"]
+ keyAlias props["key"]
+ keyPassword props["key.password"]
+ }
+ }
+
+ buildTypes {
+ release {
+ signingConfig signingConfigs.release
+ }
+ }
+ }
+}
+
+task cleanAssets(type: Delete) {
+ delete 'src/main/assets'
+}
+
+task copyAssets {
+ dependsOn 'cleanAssets'
+ mkdir "src/main/assets"
+
+ def mtAssetsFolder = "src/main/assets/Minetest"
+ def projRoot = "../.."
+ def gameToCopy = "minetest_game"
+
+ doLast {
+ mkdir "${mtAssetsFolder}"
+ mkdir "${mtAssetsFolder}/client"
+ mkdir "${mtAssetsFolder}/fonts"
+ mkdir "${mtAssetsFolder}/games"
+ mkdir "${mtAssetsFolder}/media"
+
+ copy {
+ from "${projRoot}/minetest.conf.example", "${projRoot}/README.md" into mtAssetsFolder
+ }
+ copy {
+ from "${projRoot}/doc/lgpl-2.1.txt" into "${mtAssetsFolder}/LICENSE.txt"
+ }
+ copy {
+ from "${projRoot}/builtin" into "${mtAssetsFolder}/builtin"
+ }
+ copy {
+ from "${projRoot}/client/shaders" into "${mtAssetsFolder}/client/shaders"
+ }
+ copy {
+ from "${projRoot}/fonts" include "*.ttf" into "${mtAssetsFolder}/fonts"
+ }
+ copy {
+ from "${projRoot}/games/${gameToCopy}" into "${mtAssetsFolder}/games/${gameToCopy}"
+ }
+ copy {
+ from "${projRoot}/po" into "${mtAssetsFolder}/po"
+ }
+ copy {
+ from "${projRoot}/textures" into "${mtAssetsFolder}/textures"
+ }
+ }
+}
+
+task cleanIconv(type: Delete) {
+ delete 'deps/libiconv'
+}
+
+task cleanIrrlicht(type: Delete) {
+ delete 'deps/irrlicht'
+}
+
+task cleanLevelDB(type: Delete) {
+ delete 'deps/leveldb'
+}
+
+task cleanCURL(type: Delete) {
+ delete 'deps/curl'
+ delete 'deps/curl-' + curl_version
+}
+
+task cleanOpenSSL(type: Delete) {
+ delete 'deps/openssl'
+ delete 'deps/openssl-' + openssl_version
+ delete 'deps/openssl-' + openssl_version + '.tar.gz'
+}
+
+task cleanOpenAL(type: Delete) {
+ delete 'deps/openal-soft'
+}
+
+task cleanFreetype(type: Delete) {
+ delete 'deps/freetype2-android'
+}
+
+task cleanOgg(type: Delete) {
+ delete 'deps/libvorbis-libogg-android'
+}
+
+task cleanSQLite3(type: Delete) {
+ delete 'deps/sqlite-amalgamation-' + sqlite3_version
+ delete 'deps/sqlite-amalgamation-' + sqlite3_version + '.zip'
+}
+
+task cleanAll(type: Delete, dependsOn: [clean, cleanAssets, cleanIconv,
+ cleanFreetype, cleanIrrlicht, cleanLevelDB, cleanSQLite3, cleanCURL,
+ cleanOpenSSL, cleanOpenAL, cleanOgg]) {
+ delete 'deps'
+ delete 'gen'
+ delete 'libs'
+ delete 'obj'
+ delete 'bin'
+ delete 'Debug'
+ delete 'and_env'
+}
+
+dependencies {
+ implementation 'com.android.support:support-v4:28.0.0'
+}
diff --git a/build/android/gradle/wrapper/gradle-wrapper.jar b/build/android/gradle/wrapper/gradle-wrapper.jar
new file mode 100644
index 0000000000000000000000000000000000000000..6b6ea3ab4ff4f69d55c5fd9c0a6ac70f47d41008
GIT binary patch
literal 54731
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