From 60fec2cb4fe398f974e5e3026ce3c37dac95eecb Mon Sep 17 00:00:00 2001 From: Kacper Kostka Date: Sun, 12 Feb 2023 16:07:35 +0100 Subject: [PATCH] nice --- mods/amogus_blocks/textures/Bricks_purple.png | Bin 0 -> 314 bytes mods/amogus_craftings/init.lua | 30 +- .../entities/sussy_imposter_entity.lua | 2 +- .../entities/villager_amogus.lua | 178 ++ mods/amogus_entities/init.lua | 3 +- mods/amogus_entities/textures/imposta_egg.png | Bin 0 -> 182 bytes mods/amogus_general/init.lua | 9 +- mods/amogus_generator/init.lua | 4 +- mods/amogus_items/init.lua | 41 +- mods/amogus_items/textures/amogus_food.png | Bin 0 -> 154 bytes mods/amogus_items/textures/golden_pick.png | Bin 231 -> 273 bytes mods/amogus_items/textures/obsusian_pick.png | Bin 0 -> 289 bytes .../amogus_items/textures/obsusian_shovel.png | Bin 0 -> 272 bytes mods/amogus_items/textures/obsusian_sword.png | Bin 0 -> 273 bytes mods/amogus_items/textures/stone_pick.png | Bin 226 -> 273 bytes .../amogus_items/textures/sussium_pickaxe.png | Bin 227 -> 273 bytes mods/player_api/init.lua | 2 +- mods/schemedit/.mailmap | 2 - mods/schemedit/LICENSE | 16 - mods/schemedit/README.md | 39 - mods/schemedit/USAGE.md | 44 - mods/schemedit/init.lua | 1548 ----------------- mods/schemedit/locale/schemedit.de.tr | 85 - mods/schemedit/locale/template.txt | 85 - mods/schemedit/make_readme.lua | 69 - mods/schemedit/mod.conf | 5 - mods/schemedit/screenshot.png | Bin 49064 -> 0 bytes mods/schemedit/settingtypes.txt | 8 - mods/schemedit/textures/schemedit_border.png | Bin 102 -> 0 bytes .../textures/schemedit_border_checkers.png | Bin 90 -> 0 bytes mods/schemedit/textures/schemedit_creator.png | Bin 97 -> 0 bytes .../textures/schemedit_creator_bottom.png | Bin 123 -> 0 bytes .../textures/schemedit_creator_sides.png | Bin 89 -> 0 bytes .../textures/schemedit_creator_top.png | Bin 128 -> 0 bytes .../schemedit/textures/schemedit_probtool.png | Bin 159 -> 0 bytes mods/schemedit/textures/schemedit_void.png | Bin 116 -> 0 bytes 36 files changed, 252 insertions(+), 1918 deletions(-) create mode 100644 mods/amogus_blocks/textures/Bricks_purple.png create mode 100644 mods/amogus_entities/entities/villager_amogus.lua create mode 100644 mods/amogus_entities/textures/imposta_egg.png create mode 100644 mods/amogus_items/textures/amogus_food.png create mode 100644 mods/amogus_items/textures/obsusian_pick.png create mode 100644 mods/amogus_items/textures/obsusian_shovel.png create mode 100644 mods/amogus_items/textures/obsusian_sword.png delete mode 100644 mods/schemedit/.mailmap delete mode 100644 mods/schemedit/LICENSE delete mode 100644 mods/schemedit/README.md delete mode 100644 mods/schemedit/USAGE.md delete mode 100644 mods/schemedit/init.lua delete mode 100644 mods/schemedit/locale/schemedit.de.tr delete mode 100644 mods/schemedit/locale/template.txt delete mode 100644 mods/schemedit/make_readme.lua delete mode 100644 mods/schemedit/mod.conf delete mode 100644 mods/schemedit/screenshot.png delete mode 100644 mods/schemedit/settingtypes.txt delete mode 100644 mods/schemedit/textures/schemedit_border.png delete mode 100644 mods/schemedit/textures/schemedit_border_checkers.png delete mode 100644 mods/schemedit/textures/schemedit_creator.png delete mode 100644 mods/schemedit/textures/schemedit_creator_bottom.png delete mode 100644 mods/schemedit/textures/schemedit_creator_sides.png delete mode 100644 mods/schemedit/textures/schemedit_creator_top.png delete mode 100644 mods/schemedit/textures/schemedit_probtool.png delete mode 100644 mods/schemedit/textures/schemedit_void.png diff --git a/mods/amogus_blocks/textures/Bricks_purple.png b/mods/amogus_blocks/textures/Bricks_purple.png new file mode 100644 index 0000000000000000000000000000000000000000..66e924539a01d86794e2e05aefed671658bc7571 GIT binary patch literal 314 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbKJV{wqX6T`Z5GB1G~mUKs7M+SzC z{oH>NS%G}l0G|+76NbnPhE4A7?)LWfR#sNFwzkgB&X$&z*4EZGHZ~3p4xXN#CMG7P zrl#KB-ezWI9v&Wcc6J5^1{M|;=H}*3PEKxaZYQ3W-vb)RS>O>_%)r2R7=#&*=dVZs z3Z{6vIEH8h$DTXL*P_7VdT|y1?-h%A7XSD^|J9*GDtl*7n!Lp^rE2zH!-UQTj?9Mb zzotaaWIP@1=kUn=+rG!0ZV}1{@_YG=#Xdz(&RqHH^?!@sY3)*t^%chRm98(!+4C+; uig6CVL>JRzsn45N0PW*TjqptK^<~fkvN?bl1TFr#5I dx&#%gGpH;S6^t=A`Utd}!PC{xWt~$(697taJNp0t literal 0 HcmV?d00001 diff --git a/mods/amogus_general/init.lua b/mods/amogus_general/init.lua index 4093928..78259ba 100644 --- a/mods/amogus_general/init.lua +++ b/mods/amogus_general/init.lua @@ -3,7 +3,7 @@ minetest.register_on_joinplayer(function(player) --player:set_sky({r=0, g=0, b=0}, "plain", {}) -- play music in loop without position - if false then + if true then minetest.sound_play("amogus_incomming", { to_player = player:get_player_name(), loop = true, @@ -11,7 +11,14 @@ minetest.register_on_joinplayer(function(player) }) end end) +minetest.register_on_joinplayer(function(player) + + player:set_lighting({ + shadows = {intensity = 0.5} + }) + +end) amogus_general = { } ---- SOUNDS CONFIGURATION ---- diff --git a/mods/amogus_generator/init.lua b/mods/amogus_generator/init.lua index 9906444..4c741cd 100644 --- a/mods/amogus_generator/init.lua +++ b/mods/amogus_generator/init.lua @@ -480,7 +480,7 @@ minetest.register_on_generated(function(minp, maxp, seed) -- break --end --if is_new_chunk then - for i = 1, math.random(10, 15) do + for i = 1, math.random(10, 25) do minetest.add_entity({x = minp.x + math.random(16), y = minp.y + 1, z = minp.z + math.random(16)}, "amogus_entities:amogus") --minetest.sound_play("amogus_sound", { pos = pos,gain = 1.0,max_hear_distance = 5}) end @@ -541,7 +541,7 @@ minetest.register_abm({ nodenames = {"air"}, neighbors = {"group:stone"}, interval = 30, - chance = 100, + chance = 60, action = function(pos) -- avoid spawning inside liquids if minetest.registered_nodes[minetest.get_node(pos).name].liquidtype == "none" then diff --git a/mods/amogus_items/init.lua b/mods/amogus_items/init.lua index 6029760..6d69635 100644 --- a/mods/amogus_items/init.lua +++ b/mods/amogus_items/init.lua @@ -1,6 +1,6 @@ minetest.register_item(":", { -- Hand type = "none", - wield_image = "coke.png", + wield_image = "CRT.png", wield_scale = {x=.3,y=2,z=2.5}, range = 5, tool_capabilities = { @@ -153,12 +153,6 @@ minetest.register_tool("amogus_items:lightsaber_green", { }, sound = {breaks = "amogus_sound"}, }) - --- add theese items : goldenpickaxe, wooden plank, gold_ingot, sussium_ingot ---minetest.register_craftitem("amogus_items:wooden_plank", { - --description = "Wooden Plank", - -- inventory_image = "wooden_plank.png", ---}) minetest.register_craftitem("amogus_items:gold_ingot", { description = "Gold Ingot", inventory_image = "gold_ingot.png", @@ -186,7 +180,7 @@ minetest.register_tool("amogus_items:goldenplumba", { crumbly = {times={[1] = 0, [2] = 0, [3] = 0}, uses = 10, maxlevel=3}, cracky = {times={[1] = 0, [2] = 0, [3] = 0}, uses = 10, maxlevel=3}, }, - damage_groups = {fleshy = 10}, + damage_groups = {fleshy = 2}, }, on_use = function(itemstack, user, pointed_thing) if pointed_thing.type == "node" then @@ -213,7 +207,7 @@ minetest.register_tool("amogus_items:susplumba", { crumbly = {times={[1] = 0, [2] = 0, [3] = 0}, uses = 10, maxlevel=3}, cracky = {times={[1] = 0, [2] = 0, [3] = 0}, uses = 10, maxlevel=3}, }, - damage_groups = {fleshy = 10}, + damage_groups = {fleshy = 2}, }, on_use = function(itemstack, user, pointed_thing) if pointed_thing.type == "node" then @@ -677,4 +671,31 @@ bucket.register_liquid( {tool = 1, water_bucket = 1} ) --- end of modifed code from bucket mod from minetest_game \ No newline at end of file +minetest.register_tool("amogus_items:obsusian_shovel", { + description = "Obsidian Shovel", + inventory_image = "obsusian_shovel.png", + tool_capabilities = { + full_punch_interval = 1.0, + max_drop_level = 1, + groupcaps = { + crumbly = {times = {[1] = 0.80, [2] = 0.40, [3] = 0.20}, uses = 30, maxlevel = 3}, + }, + damage_groups = {fleshy = 1.6}, + }, + sound = {breaks = "default_tool_breaks"}, +}) + + +minetest.register_tool("amogus_items:obsusian_sword", { + description = "Obsidian Sword", + inventory_image = "obsusian_sword.png", + tool_capabilities = { + full_punch_interval = 1.0, + max_drop_level = 1, + groupcaps = { + snappy = {times = {[2] = 0.70, [3] = 0.30}, uses = 30, maxlevel = 3}, + }, + damage_groups = {fleshy = 3.8}, + }, + sound = {breaks = "default_tool_breaks"}, +}) diff --git a/mods/amogus_items/textures/amogus_food.png b/mods/amogus_items/textures/amogus_food.png new file mode 100644 index 0000000000000000000000000000000000000000..2a6c4ffffb32d35ff25b17fea90cc50186fce0b5 GIT binary patch literal 154 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`jKx9jP7LeL$-D$|LOfj@LoEE0 zQx*sqJi7EB1Wpw7^z=krePqJ0L^6#-@2rC9;R_5?8V(CP7OY>~e(?WlmPMh`O8)B1 y3$__5?Cw$#?+IbPkR&J;`{E^Yy2+$DI~fI-wFJeM{q+T!&*16m=d#Wzp$PzlgfzVX literal 0 HcmV?d00001 diff --git a/mods/amogus_items/textures/golden_pick.png b/mods/amogus_items/textures/golden_pick.png index 3d883e79f21ece9648013d68ffbfba02c6016690..1b44b1d7470e64c7ab61951d5679b131aec25f52 100644 GIT binary patch delta 256 zcmaFPIFV_BWIZzj1A~Sxe=v|@EDmyaVpw-h<|UBBlJ4m1$iT3%pZiZDE08Y{;1lBd z{~-JSD?$IyvTtf<4Y4+=4E0EGwgO7_#u#S+DUOmLzu^B6z;Lg5ZzNERv%n*=n1O-s zFbFdq&tH)O6b$inaSYK2jy)Gx$#+13gE@dL_+9bJlRSrkOS95L0+%sYa8J=xtc+@zpNz5V7~fU lO)9$zw16))!ZXd+mq82UDj)`dOTm*tl&7no%Q~loCII`KS6=`C delta 214 zcmV;{04e{G0_Opc8Gi-<001BJ|6u?C00DDSM?wIu&K&6g005y$L_t(IPh(`D5HM1x zp8>;w{|DLs!wnVohA`i5W!QY|ADHP^`5Q$K3J0VarVyLU&^3e9zzu-e99pFf*1P8D zIikFWVL;UsM~2(aUJ-2wiUAhYggL$DeEvYuE&a8DXQtRZ*}AjS~50h`)c z!SRnRs_=OS#QNS%G}T0G|+7Nl8g#V`DWnHK0H*!?`&OPd73APjI#hu{Np<^#BU;Ueufnq_|6h z{DS|(0fU!6<0qgnXMsm#F#`kNVGw3Kp1&dmC>Y`C;uxY49DCMV=zszTb3n^2{_pk$ z&YW9JxsUG&6o?N}@QC{~WnosBz|~Dc+fKGIq@1y>cVoKp#NsBS(T9Ioj2S!`ni-4* z%&gAYsi$`Le`NS%G}H0G|+7Nl8g#V`Ct14#U$;4F7u>&V^VTRfc*bI9mY)m7Ufo11YYOAiv=M zFu<_sjLvzWC})93WHAE+-(e7DJf6QI1t{q4>Ealo5uAHEQs{sJ2lIsmcZ>dWPw&#P zdfNVkx8e35rho`#7ZulFXZs+wIj;NGDoqb%p8C6RNS%G|s0G|+7AT22=xryQb9EPX84CmC;)a2ykfP&xMBr1UvM@f)h@P7zkxYxWl z5-7%5;1OBOz`%D1gc(IOyc&RlA)YRdAsWH4=L7i~3^^+P8&i w|2^ghY+E!~rCm1eOaPkCmm1-j=IhI#1!QvoF$i1=o(!TqUHx3vIVCg!0JAz#yZ`_I literal 0 HcmV?d00001 diff --git a/mods/amogus_items/textures/stone_pick.png b/mods/amogus_items/textures/stone_pick.png index f3d004de4f85709451beb9999ac9233a9f6cc591..7e7910036d8dc6e6da372d3bda3e1e3eb05b5c6e 100644 GIT binary patch delta 256 zcmaFFIFV_BWIZzj1A~Sxe=v|@EDmyaVpw-h<|UBBlJ4m1$iT3%pZiZDE08Y{;1lBN z9G+M*ZD~Snx1No2h_z8=s7Hdc6;M)FWl;x^;wTC73;quQ4ELJ%Mgqk+3p^r=85sBu zgD~Uq{1quc!4OXu#}JL+*mHrEdIG6cl{m}Z#91=i*nzy{!QI!ZByzzx9VZ$gF;Gyvp6 ze1@PHfG^Z>8A7xHxLiUop3zeh$R!{#Pz-^hm}CQxT|%}2$gTna=5}cjOae3200000 LNkvXXu0mjfOfXTs diff --git a/mods/amogus_items/textures/sussium_pickaxe.png b/mods/amogus_items/textures/sussium_pickaxe.png index aa62e581fe0c07dc8089fa59ad8c2514e6e38be6..0739461ea9a8586fa92e5f0d1da6216a92ea03ee 100644 GIT binary patch delta 256 zcmaFNIFV_BWIZzj1A~Sxe=v|@EDmyaVpw-h<|UBBlJ4m1$iT3%pZiZDE08Y{;1lAy zRMg|CZ1NeYh%#>E1=|z9qV2IDUOmLzu^B6z;Lg5ZzNERv%n*=n1O-s zFbFdq&tH)O6b$inaSYK2jy)Gx$#+13gE@dL_+9bJlRSrkOS95L0+%sYa8J=xtc+@zpNz5V7~fU lO)9$zw16))!ZXd+mq82UDj)`dOTm*tl&7no%Q~loCIIXtRx1Di delta 210 zcmV;@04@KK0^Oj-JD72#Nv7Hdlsv{J;I|6+uJ52E3F@{txmOy3>g<1WRlHvh&gXO~??q0r&zA zpCKp);0twJh7fH4$g9{4AsEl-DG6iX0RGZw5sl&7TL1t6 M07*qoM6N<$g84~Q9{>OV diff --git a/mods/player_api/init.lua b/mods/player_api/init.lua index a32ca1f..94b058a 100644 --- a/mods/player_api/init.lua +++ b/mods/player_api/init.lua @@ -22,7 +22,7 @@ player_api.register_model("amogus_entity.obj", { collisionbox = {-0.3, 0.0, -0.3, 0.3, 1.7, 0.3}, visual = "mesh", - visual_size = {x=15, y=15, z=15}, + visual_size = {x=8, y=8, z=8}, }) diff --git a/mods/schemedit/.mailmap b/mods/schemedit/.mailmap deleted file mode 100644 index 3d78b58..0000000 --- a/mods/schemedit/.mailmap +++ /dev/null @@ -1,2 +0,0 @@ -Wuzzy -Wuzzy diff --git a/mods/schemedit/LICENSE b/mods/schemedit/LICENSE deleted file mode 100644 index 9593721..0000000 --- a/mods/schemedit/LICENSE +++ /dev/null @@ -1,16 +0,0 @@ -MIT License -Copyright (c) 2017-2020 Elijah Duffy and Wuzzy -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. diff --git a/mods/schemedit/README.md b/mods/schemedit/README.md deleted file mode 100644 index 1f50ffc..0000000 --- a/mods/schemedit/README.md +++ /dev/null @@ -1,39 +0,0 @@ -# Schematic Editor [`schemedit`] - -## Version -1.7.1 - -## Description -This is a mod which allows you to edit and export schematics (`.mts` files). - -This mod works in Minetest 5.0.0 or later, but recommended is version 5.1.0 -or later. - -It supports node probabilities, forced node placement and slice probabilities. - -It adds 3 items: - -* Schematic Creator: Used to mark a region and export or import it as schematic -* Schematic Void: Marks a position in a schematic which should not replace anything when placed as a schematic -* Schematic Node Probability Tool: Set per-node probabilities and forced node placement - -Note: The import feature requires Minetest 5.1.0 or later. - -It also adds these server commands: - -* `placeschem` to place a schematic -* `mts2lua` to convert .mts files to .lua files (Lua code) - -There's also a setting `schemedit_export_lua` to enable automatic export to .lua files. - -## Usage help -This mod assumes you already have a basic understanding about how schematics in Minetest work. -If not, refer to the Minetest Lua API documentation to understand more about schematics. - -To learn how to use all the items in this mod, read `USAGE.md`. - -You can also find the same help texts in-game if you if you use the optional Help modpack -(mods `doc` and `doc_items`). - -## License of everything -MIT License diff --git a/mods/schemedit/USAGE.md b/mods/schemedit/USAGE.md deleted file mode 100644 index 3e37ce0..0000000 --- a/mods/schemedit/USAGE.md +++ /dev/null @@ -1,44 +0,0 @@ -## Usage help -In this section you'll learn how to use the items of this mod. -Note: If you have the `doc` and `doc_items` mods installed, you can also access the same help texts in-game (possibly translated). - -### Schematic Creator -The schematic creator is used to save a region of the world into a schematic file (.mts). - -#### Usage -To get started, place the block facing directly in front of any bottom left corner of the structure you want to save. This block can only be accessed by the placer or by anyone with the “`schematic_override`” privilege. -To save a region, use the block, enter the size and a schematic name and hit “Export schematic”. The file will always be saved in the world directory. Note you can use this name in the /placeschem command to place the schematic again. - -Importing a schematic will load a schematic from the world directory, place it in front of the schematic creator and sets probability and force-place data accordingly. -The other features of the schematic creator are optional and are used to allow to add randomness and fine-tuning. - -Y slices are used to remove entire slices based on chance. For each slice of the schematic region along the Y axis, you can specify that it occurs only with a certain chance. In the Y slice tab, you have to specify the Y slice height (0 = bottom) and a probability from 0 to 255 (255 is for 100%). By default, all Y slices occur always. - -With a schematic node probability tool, you can set a probability for each node and enable them to overwrite all nodes when placed as schematic. This tool must be used prior to the file export. - - -### Schematic Node Probability Tool -This is an advanced tool which only makes sense when used together with a schematic creator. It is used to finetune the way how nodes from a schematic are placed. -It allows you to set two things: -1) Set probability: Chance for any particular node to be actually placed (default: always placed) -2) Enable force placement: These nodes replace node other than air and ignore when placed in a schematic (default: off) - -#### Usage - -BASIC USAGE: -Punch to configure the tool. Select a probability (0-255; 255 is for 100%) and enable or disable force placement. Now place the tool on any node to apply these values to the node. This information is preserved in the node until it is destroyed or changed by the tool again. This tool has no effect on schematic voids. -Now you can use a schematic creator to save a region as usual, the nodes will now be saved with the special node settings applied. - -NODE HUD: -To help you remember the node values, the nodes with special values are labelled in the HUD. The first line shows probability and force placement (with “[F]”). The second line is the current distance to the node. Nodes with default settings and schematic voids are not labelled. -To disable the node HUD, unselect the tool or hit “place” while not pointing anything. - -UPDATING THE NODE HUD: -The node HUD is not updated automatically and may be outdated. The node HUD only updates the HUD for nodes close to you whenever you place the tool or press the punch and sneak keys simultaneously. If you sneak-punch a schematic creator, then the node HUD is updated for all nodes within the schematic creator's region, even if this region is very big. - - -### Schematic Void -This is an utility block used in the creation of schematic files. It should be used together with a schematic creator. When saving a schematic, all nodes with a schematic void will be left unchanged when the schematic is placed again. Technically, this is equivalent to a block with the node probability set to 0. - -#### Usage -Just place the schematic void like any other block and use the schematic creator to save a portion of the world. \ No newline at end of file diff --git a/mods/schemedit/init.lua b/mods/schemedit/init.lua deleted file mode 100644 index ceb2dc5..0000000 --- a/mods/schemedit/init.lua +++ /dev/null @@ -1,1548 +0,0 @@ -local S -if minetest.get_translator then - S = minetest.get_translator("schemedit") -else - S = function(s) return s end -end -local F = minetest.formspec_escape - -local schemedit = {} - --- Directory separator -local DIR_DELIM = "/" --- Set to true to enable `make_schemedit_readme` command -local MAKE_README = false - -local export_path_full = table.concat({minetest.get_worldpath(), "schems"}, DIR_DELIM) - --- truncated export path so the server directory structure is not exposed publicly -local export_path_trunc = table.concat({S(""), "schems"}, DIR_DELIM) - --- Text colors -local TEXT_COLOR_GUI = "#D79E9E" -local TEXT_COLOR_GUI_NUMBER = 0xD79E9E -local TEXT_COLOR_ERROR = "#FF0000" -local TEXT_COLOR_SUCCESS = "#00FF00" - --- Text symbol for force placement -local FORCE_SYMBOL = "[F]" - - - -local can_import = minetest.read_schematic ~= nil - -schemedit.markers = {} - --- [local function] Renumber table -local function renumber(t) - local res = {} - for _, i in pairs(t) do - res[#res + 1] = i - end - return res -end - -local get_border_texture = function() - local val = minetest.settings:get("schemedit_border_style") - if val == "checkers" then - -- checkers style - return "schemedit_border_checkers.png" - else - -- edges style - return "schemedit_border.png" - end -end - -local NEEDED_PRIV = "server" -local function check_priv(player_name, quit) - local privs = minetest.get_player_privs(player_name) - if privs[NEEDED_PRIV] then - return true - else - if not quit then - minetest.chat_send_player(player_name, minetest.colorize(TEXT_COLOR_ERROR, - S("Insufficient privileges! You need the “@1” privilege to use this.", NEEDED_PRIV))) - end - return false - end -end - --- Lua export -local export_schematic_to_lua -if can_import then - export_schematic_to_lua = function(schematic, filepath, options) - if not options then options = {} end - local str = minetest.serialize_schematic(schematic, "lua", options) - local file = io.open(filepath, "w") - if file and str then - file:write(str) - file:flush() - file:close() - return true - else - return false - end - end -end - --- Export nodes between pos1 and pos2 into filepath. --- The area MUST be emerged and loaded before calling this function. --- * path: path name (without file name) --- * schem_name: raw schematic name (without ".mts" suffix) --- * pos1, pos2: Area bounds (vectors) --- * player_name: Player name for chat messages --- * slice_list: y_slice list for minetest.create_schematic --- --- returns true on success -local export_schematic_to_mts = function(pos1, pos2, path, schem_name, player_name, slice_list) - local plist = schemedit.scan_metadata(pos1, pos2) - local probability_list = {} - for hash, i in pairs(plist) do - local prob = schemedit.lua_prob_to_schematic_prob(i.prob) - if i.force_place == true then - prob = prob + 128 - end - - table.insert(probability_list, { - pos = minetest.get_position_from_hash(hash), - prob = prob, - }) - end - - local filepath = path..schem_name..".mts" - local res = minetest.create_schematic(pos1, pos2, probability_list, filepath, slice_list) - - if res then - minetest.chat_send_player(player_name, minetest.colorize(TEXT_COLOR_SUCCESS, - S("Exported schematic to @1", filepath))) - -- Additional export to Lua file if MTS export was successful - local schematic = minetest.read_schematic(filepath, {}) - if schematic and minetest.settings:get_bool("schemedit_export_lua") and export_schematic_to_lua then - local filepath_lua = path..schem_name..".lua" - res = export_schematic_to_lua(schematic, filepath_lua) - if res then - minetest.chat_send_player(player_name, minetest.colorize(TEXT_COLOR_SUCCESS, - S("Exported schematic to @1", filepath_lua))) - end - end - return true - else - minetest.chat_send_player(player_name, minetest.colorize(TEXT_COLOR_ERROR, - S("Failed to export schematic to @1", filepath))) - return false - end -end - ---- ---- Formspec API ---- - -local contexts = {} -local form_data = {} -local tabs = {} -local forms = {} -local displayed_waypoints = {} - --- Sadly, the probabilities presented in Lua (0-255) are not identical to the REAL probabilities in the --- schematic file (0-127). There are two converter functions to convert from one probability type to another. --- This mod tries to retain the “Lua probability” as long as possible and only switches to “schematic probability” --- on an actual export to a schematic. - -function schemedit.lua_prob_to_schematic_prob(lua_prob) - return math.floor(lua_prob / 2) -end - -function schemedit.schematic_prob_to_lua_prob(schematic_prob) - return schematic_prob * 2 - -end - --- [function] Add form -function schemedit.add_form(name, def) - def.name = name - forms[name] = def - - if def.tab then - tabs[#tabs + 1] = name - end -end - --- [function] Generate tabs -function schemedit.generate_tabs(current) - local retval = "tabheader[0,0;tabs;" - for _, t in pairs(tabs) do - local f = forms[t] - if f.tab ~= false and f.caption then - retval = retval..f.caption.."," - - if type(current) ~= "number" and current == f.name then - current = _ - end - end - end - retval = retval:sub(1, -2) -- Strip last comma - retval = retval..";"..current.."]" -- Close tabheader - return retval -end - --- [function] Handle tabs -function schemedit.handle_tabs(pos, name, fields) - local tab = tonumber(fields.tabs) - if tab and tabs[tab] and forms[tabs[tab]] then - schemedit.show_formspec(pos, name, forms[tabs[tab]].name) - return true - end -end - --- [function] Show formspec -function schemedit.show_formspec(pos, player, tab, show, ...) - if forms[tab] then - if type(player) == "string" then - player = minetest.get_player_by_name(player) - end - local name = player:get_player_name() - - if show ~= false then - if not form_data[name] then - form_data[name] = {} - end - - local form = forms[tab].get(form_data[name], pos, name, ...) - if forms[tab].tab then - form = form..schemedit.generate_tabs(tab) - end - - minetest.show_formspec(name, "schemedit:"..tab, form) - contexts[name] = pos - - -- Update player attribute - if forms[tab].cache_name ~= false then - local pmeta = player:get_meta() - pmeta:set_string("schemedit:tab", tab) - end - else - minetest.close_formspec(pname, "schemedit:"..tab) - end - end -end - --- [event] On receive fields -minetest.register_on_player_receive_fields(function(player, formname, fields) - local formname = formname:split(":") - - if formname[1] == "schemedit" and forms[formname[2]] then - local handle = forms[formname[2]].handle - local name = player:get_player_name() - if contexts[name] then - if not form_data[name] then - form_data[name] = {} - end - - if not schemedit.handle_tabs(contexts[name], name, fields) and handle then - handle(form_data[name], contexts[name], name, fields) - end - end - end -end) - --- Helper function. Scans probabilities of all nodes in the given area and returns a prob_list -schemedit.scan_metadata = function(pos1, pos2) - local prob_list = {} - - for x=pos1.x, pos2.x do - for y=pos1.y, pos2.y do - for z=pos1.z, pos2.z do - local scanpos = {x=x, y=y, z=z} - local node = minetest.get_node_or_nil(scanpos) - - local prob, force_place - if node == nil or node.name == "schemedit:void" then - prob = 0 - force_place = false - else - local meta = minetest.get_meta(scanpos) - - prob = tonumber(meta:get_string("schemedit_prob")) or 255 - local fp = meta:get_string("schemedit_force_place") - if fp == "true" then - force_place = true - else - force_place = false - end - end - - local hashpos = minetest.hash_node_position(scanpos) - prob_list[hashpos] = { - pos = scanpos, - prob = prob, - force_place = force_place, - } - end - end - end - - return prob_list -end - --- alignment for probtool item count -local PROBTOOL_COUNT_ALIGN = 5 -- top left - --- Sets probability and force_place metadata of an item. --- Also updates item description. --- The itemstack is updated in-place. -local function set_item_metadata(itemstack, prob, force_place) - local smeta = itemstack:get_meta() - local prob_desc = "\n"..S("Probability: @1", prob or - smeta:get_string("schemedit_prob") or S("Not Set")) - -- Update probability - if prob and prob >= 0 and prob < 255 then - smeta:set_string("schemedit_prob", tostring(prob)) - local print_count = tostring(prob) - if force_place then - print_count = print_count .. FORCE_SYMBOL - end - -- Display a number in the item icon - smeta:set_string("count_meta", print_count) - smeta:set_int("count_alignment", PROBTOOL_COUNT_ALIGN) - elseif prob and prob == 255 then - -- Clear prob metadata for default probability - prob_desc = "" - smeta:set_string("schemedit_prob", nil) - if force_place == true then - smeta:set_string("count_meta", FORCE_SYMBOL) - smeta:set_string("count_alignment", PROBTOOL_COUNT_ALIGN) - else - smeta:set_string("count_meta", nil) - smeta:set_string("count_alignment", nil) - end - else - prob_desc = "\n"..S("Probability: @1", smeta:get_string("schemedit_prob") or - S("Not Set")) - end - - -- Update force place - if force_place == true then - smeta:set_string("schemedit_force_place", "true") - elseif force_place == false then - smeta:set_string("schemedit_force_place", nil) - end - - -- Update description - local desc = minetest.registered_items[itemstack:get_name()].description - local meta_desc = smeta:get_string("description") - if meta_desc and meta_desc ~= "" then - desc = meta_desc - end - - local original_desc = smeta:get_string("original_description") - if original_desc and original_desc ~= "" then - desc = original_desc - else - smeta:set_string("original_description", desc) - end - - local force_desc = "" - if smeta:get_string("schemedit_force_place") == "true" then - force_desc = "\n"..S("Force placement") - end - - desc = desc..minetest.colorize(TEXT_COLOR_GUI, prob_desc..force_desc) - - smeta:set_string("description", desc) - - return itemstack -end - ---- ---- Formspec Tabs ---- -local import_btn = "" -if can_import then - import_btn = "button[0.5,2.5;6,1;import;"..F(S("Import schematic")).."]" -end -schemedit.add_form("main", { - tab = true, - caption = S("Main"), - get = function(self, pos, name) - local meta = minetest.get_meta(pos):to_table().fields - local strpos = minetest.pos_to_string(pos) - local hashpos = minetest.hash_node_position(pos) - - local border_button - if meta.schem_border == "true" and schemedit.markers[hashpos] then - border_button = "button[3.5,7.5;3,1;border;"..F(S("Hide border")).."]" - else - border_button = "button[3.5,7.5;3,1;border;"..F(S("Show border")).."]" - end - - local xs, ys, zs = meta.x_size or 1, meta.y_size or 1, meta.z_size or 1 - local size = {x=xs, y=ys, z=zs} - local schem_name = meta.schem_name or "" - - local form = [[ - size[7,8] - label[0.5,-0.1;]]..F(S("Position: @1", strpos))..[[] - label[3,-0.1;]]..F(S("Owner: @1", name))..[[] - label[0.5,0.4;]]..F(S("Schematic name: @1", F(schem_name)))..[[] - label[0.5,0.9;]]..F(S("Size: @1", minetest.pos_to_string(size)))..[[] - - field[0.8,2;5,1;name;]]..F(S("Schematic name:"))..[[;]]..F(schem_name or "")..[[] - button[5.3,1.69;1.2,1;save_name;]]..F(S("OK"))..[[] - tooltip[save_name;]]..F(S("Save schematic name"))..[[] - field_close_on_enter[name;false] - - button[0.5,3.5;6,1;export;]]..F(S("Export schematic")).."]".. - import_btn..[[ - textarea[0.8,4.5;6.2,1;;]]..F(S("Export/import path:\n@1", - export_path_trunc .. DIR_DELIM .. F(S(""))..".mts"))..[[;] - button[0.5,5.5;3,1;air2void;]]..F(S("Air to voids"))..[[] - button[3.5,5.5;3,1;void2air;]]..F(S("Voids to air"))..[[] - tooltip[air2void;]]..F(S("Turn all air nodes into schematic void nodes"))..[[] - tooltip[void2air;]]..F(S("Turn all schematic void nodes into air nodes"))..[[] - field[0.8,7;2,1;x;]]..F(S("X size:"))..[[;]]..xs..[[] - field[2.8,7;2,1;y;]]..F(S("Y size:"))..[[;]]..ys..[[] - field[4.8,7;2,1;z;]]..F(S("Z size:"))..[[;]]..zs..[[] - field_close_on_enter[x;false] - field_close_on_enter[y;false] - field_close_on_enter[z;false] - button[0.5,7.5;3,1;save;]]..F(S("Save size"))..[[] - ]].. - border_button - if minetest.get_modpath("doc") then - form = form .. "image_button[6.4,-0.2;0.8,0.8;doc_button_icon_lores.png;doc;]" .. - "tooltip[doc;"..F(S("Help")).."]" - end - return form - end, - handle = function(self, pos, name, fields) - if fields.doc then - doc.show_entry(name, "nodes", "schemedit:creator", true) - return - end - - if not check_priv(name, fields.quit) then - return - end - - local realmeta = minetest.get_meta(pos) - local meta = realmeta:to_table().fields - local hashpos = minetest.hash_node_position(pos) - - -- Save size vector values - if (fields.x and fields.x ~= "") then - local x = tonumber(fields.x) - if x then - meta.x_size = math.max(x, 1) - end - end - if (fields.y and fields.y ~= "") then - local y = tonumber(fields.y) - if y then - meta.y_size = math.max(y, 1) - end - end - if (fields.z and fields.z ~= "") then - local z = tonumber(fields.z) - if z then - meta.z_size = math.max(z, 1) - end - end - - -- Save schematic name - if fields.name then - meta.schem_name = fields.name - end - - -- Node conversion - if (fields.air2void) then - local pos1, pos2 = schemedit.size(pos) - pos1, pos2 = schemedit.sort_pos(pos1, pos2) - local nodes = minetest.find_nodes_in_area(pos1, pos2, {"air"}) - minetest.bulk_set_node(nodes, {name="schemedit:void"}) - return - elseif (fields.void2air) then - local pos1, pos2 = schemedit.size(pos) - pos1, pos2 = schemedit.sort_pos(pos1, pos2) - local nodes = minetest.find_nodes_in_area(pos1, pos2, {"schemedit:void"}) - minetest.bulk_set_node(nodes, {name="air"}) - return - end - - -- Toggle border - if fields.border then - if meta.schem_border == "true" and schemedit.markers[hashpos] then - schemedit.unmark(pos) - meta.schem_border = "false" - else - schemedit.mark(pos) - meta.schem_border = "true" - end - end - - -- Export schematic - if fields.export and meta.schem_name and meta.schem_name ~= "" then - local pos1, pos2 = schemedit.size(pos) - pos1, pos2 = schemedit.sort_pos(pos1, pos2) - local path = export_path_full .. DIR_DELIM - minetest.mkdir(path) - - local slist = minetest.deserialize(meta.slices) - local slice_list = {} - for _, i in pairs(slist) do - slice_list[#slice_list + 1] = { - ypos = i.ypos, - prob = schemedit.lua_prob_to_schematic_prob(i.prob), - } - end - - -- We emerge the entire area before exporting first. - -- This is required to so make sure we don't export - -- unloaded areas (=ignore nodes). - - -- callback for minetest.emerge_area - local after_emerged = function(blockpos, action, calls_remaining, param) - if action == minetest.EMERGE_CANCELLED then - minetest.chat_send_player(param.player_name, minetest.colorize(TEXT_COLOR_ERROR, - S("Could not emerge area from @1 to @2: Emerging was cancelled. Nothing was exported."))) - elseif action == minetest.EMERGE_ERRORED then - minetest.chat_send_player(param.player_name, minetest.colorize(TEXT_COLOR_ERROR, - S("Could not emerge area from @1 to @2: Error while emerging. Nothing was exported."))) - elseif action == minetest.EMERGE_GENERATED or action == minetest.EMERGE_FROM_MEMORY or action == minetest.EMERGE_FROM_DISK then - if calls_remaining > 0 then - return - end - - -- Start the export! - export_schematic_to_mts(param.pos1, param.pos2, param.path, param.schem_name, param.player_name, param.slice_list) - - -- Note: Player chat message is handled in the export function - else - minetest.chat_send_player(param.player_name, minetest.colorize(TEXT_COLOR_ERROR, - S("Could not emerge area from @1 to @2: Unknown action in emerge callback. Nothing was exported."))) - - end - end - local emerge_param = { - pos1 = pos1, - pos2 = pos2, - path = path, - schem_name = meta.schem_name, - player_name = name, - slice_list = slice_list - } - minetest.emerge_area(pos1, pos2, after_emerged, emerge_param) - end - - -- Import schematic - if fields.import and meta.schem_name and meta.schem_name ~= "" then - if not can_import then - return - end - local pos1 - local node = minetest.get_node(pos) - local path = export_path_full .. DIR_DELIM - - local filepath = path..meta.schem_name..".mts" - local schematic = minetest.read_schematic(filepath, {write_yslice_prob="low"}) - local success = false - - if schematic then - meta.x_size = schematic.size.x - meta.y_size = schematic.size.y - meta.z_size = schematic.size.z - meta.slices = minetest.serialize(renumber(schematic.yslice_prob)) - local special_x_size = meta.x_size - local special_y_size = meta.y_size - local special_z_size = meta.z_size - - if node.param2 == 1 then - pos1 = vector.add(pos, {x=1,y=0,z=-meta.z_size+1}) - meta.x_size, meta.z_size = meta.z_size, meta.x_size - elseif node.param2 == 2 then - pos1 = vector.add(pos, {x=-meta.x_size+1,y=0,z=-meta.z_size}) - elseif node.param2 == 3 then - pos1 = vector.add(pos, {x=-meta.x_size,y=0,z=0}) - meta.x_size, meta.z_size = meta.z_size, meta.x_size - else - pos1 = vector.add(pos, {x=0,y=0,z=1}) - end - - local schematic_for_meta = table.copy(schematic) - -- Strip probability data for placement - schematic.yslice_prob = {} - for d=1, #schematic.data do - schematic.data[d].prob = nil - end - - -- Place schematic - success = minetest.place_schematic(pos1, schematic, "0", nil, true) - - -- Add special schematic data to nodes - if success then - local d = 1 - for z=0, special_z_size-1 do - for y=0, special_y_size-1 do - for x=0, special_x_size-1 do - local data = schematic_for_meta.data[d] - local pp = {x=pos1.x+x, y=pos1.y+y, z=pos1.z+z} - if data.prob == 0 then - minetest.set_node(pp, {name="schemedit:void"}) - else - local meta = minetest.get_meta(pp) - if data.prob and data.prob ~= 255 and data.prob ~= 254 then - meta:set_string("schemedit_prob", tostring(data.prob)) - else - meta:set_string("schemedit_prob", "") - end - if data.force_place then - meta:set_string("schemedit_force_place", "true") - else - meta:set_string("schemedit_force_place", "") - end - end - d = d + 1 - end - end - end - end - end - if success then - minetest.chat_send_player(name, minetest.colorize(TEXT_COLOR_SUCCESS, - S("Imported schematic from @1", filepath))) - else - minetest.chat_send_player(name, minetest.colorize(TEXT_COLOR_ERROR, - S("Failed to import schematic from @1", filepath))) - end - end - - - - -- Save meta before updating visuals - local inv = realmeta:get_inventory():get_lists() - realmeta:from_table({fields = meta, inventory = inv}) - - -- Update border - if not fields.border and meta.schem_border == "true" then - schemedit.mark(pos) - end - - -- Update formspec - if not fields.quit then - schemedit.show_formspec(pos, minetest.get_player_by_name(name), "main") - end - end, -}) - -schemedit.add_form("slice", { - caption = S("Y Slices"), - tab = true, - get = function(self, pos, name, visible_panel) - local meta = minetest.get_meta(pos):to_table().fields - - self.selected = self.selected or 1 - local selected = tostring(self.selected) - local slice_list = minetest.deserialize(meta.slices) - local slices = "" - for _, i in pairs(slice_list) do - local insert = F(S("Y = @1; Probability = @2", tostring(i.ypos), tostring(i.prob))) - slices = slices..insert.."," - end - slices = slices:sub(1, -2) -- Remove final comma - - local form = [[ - size[7,8] - table[0,0;6.8,6;slices;]]..slices..[[;]]..selected..[[] - ]] - - -- Close edit panel if no slices - if self.panel_edit and slices == "" then - self.panel_edit = nil - end - - if self.panel_add or self.panel_edit then - local ypos_default, prob_default = "", "" - local done_button = "button[5,7.18;2,1;done_add;"..F(S("Add")).."]" - if self.panel_edit then - done_button = "button[5,7.18;2,1;done_edit;"..F(S("Apply")).."]" - if slice_list[self.selected] then - ypos_default = slice_list[self.selected].ypos - prob_default = slice_list[self.selected].prob - end - end - - local field_ypos = "" - if self.panel_add then - field_ypos = "field[0.3,7.5;2.5,1;ypos;"..F(S("Y position (max. @1):", (meta.y_size - 1)))..";"..ypos_default.."]" - end - - form = form..[[ - ]]..field_ypos..[[ - field[2.8,7.5;2.5,1;prob;]]..F(S("Probability (0-255):"))..[[;]]..prob_default..[[] - field_close_on_enter[ypos;false] - field_close_on_enter[prob;false] - ]]..done_button - end - - if not self.panel_edit then - if self.panel_add then - form = form.."button[0,6;2.4,1;add;"..F(S("Cancel")).."]" - else - form = form.."button[0,6;2.4,1;add;"..F(S("Add slice")).."]" - end - end - - if slices ~= "" and self.selected and not self.panel_add then - if not self.panel_edit then - form = form..[[ - button[2.4,6;2.4,1;remove;]]..F(S("Remove slice"))..[[] - button[4.8,6;2.4,1;edit;]]..F(S("Edit slice"))..[[] - ]] - else - form = form..[[ - button[4.8,6;2.4,1;edit;]]..F(S("Back"))..[[] - ]] - end - end - - return form - end, - handle = function(self, pos, name, fields) - if not check_priv(name, fields.quit) then - return - end - - local meta = minetest.get_meta(pos) - local player = minetest.get_player_by_name(name) - - if fields.slices then - local slices = fields.slices:split(":") - self.selected = tonumber(slices[2]) - end - - if fields.add then - if not self.panel_add then - self.panel_add = true - schemedit.show_formspec(pos, player, "slice") - else - self.panel_add = nil - schemedit.show_formspec(pos, player, "slice") - end - end - - local ypos, prob = tonumber(fields.ypos), tonumber(fields.prob) - if fields.done_edit then - ypos = 0 - end - if (fields.done_add or fields.done_edit) and ypos and prob and - ypos <= (meta:get_int("y_size") - 1) and prob >= 0 and prob <= 255 then - local slice_list = minetest.deserialize(meta:get_string("slices")) - local index = #slice_list + 1 - if fields.done_edit then - index = self.selected - end - - local dupe = false - if fields.done_add then - for k,v in pairs(slice_list) do - if v.ypos == ypos then - v.prob = prob - dupe = true - end - end - end - if fields.done_edit and slice_list[index] then - ypos = slice_list[index].ypos - end - if not dupe then - slice_list[index] = {ypos = ypos, prob = prob} - end - - meta:set_string("slices", minetest.serialize(slice_list)) - - -- Update and show formspec - self.panel_add = nil - schemedit.show_formspec(pos, player, "slice") - end - - if fields.remove and self.selected then - local slice_list = minetest.deserialize(meta:get_string("slices")) - slice_list[self.selected] = nil - meta:set_string("slices", minetest.serialize(renumber(slice_list))) - - -- Update formspec - self.selected = math.max(1, self.selected-1) - self.panel_edit = nil - schemedit.show_formspec(pos, player, "slice") - end - - if fields.edit then - if not self.panel_edit then - self.panel_edit = true - schemedit.show_formspec(pos, player, "slice") - else - self.panel_edit = nil - schemedit.show_formspec(pos, player, "slice") - end - end - end, -}) - -schemedit.add_form("probtool", { - cache_name = false, - caption = S("Schematic Node Probability Tool"), - get = function(self, pos, name) - local player = minetest.get_player_by_name(name) - if not player then - return - end - local probtool = player:get_wielded_item() - if probtool:get_name() ~= "schemedit:probtool" then - return - end - - local meta = probtool:get_meta() - local prob = tonumber(meta:get_string("schemedit_prob")) - local force_place = meta:get_string("schemedit_force_place") - - if not prob then - prob = 255 - end - if force_place == nil or force_place == "" then - force_place = "false" - end - if force_place == "true" then - self.force_place = true - else - self.force_place = false - end - local form = "size[5,4]".. - "label[0,0;"..F(S("Schematic Node Probability Tool")).."]".. - "field[0.75,1;4,1;prob;"..F(S("Probability (0-255)"))..";"..prob.."]".. - "checkbox[0.60,1.5;force_place;"..F(S("Force placement"))..";" .. force_place .. "]" .. - "button_exit[0.25,3;2,1;cancel;"..F(S("Cancel")).."]".. - "button_exit[2.75,3;2,1;submit;"..F(S("Apply")).."]".. - "tooltip[prob;"..F(S("Probability that the node will be placed")).."]".. - "tooltip[force_place;"..F(S("If enabled, the node will replace nodes other than air and ignore")).."]".. - "field_close_on_enter[prob;false]" - return form - end, - handle = function(self, pos, name, fields) - if not check_priv(name, fields.quit) then - return - end - - if fields.submit then - local prob = tonumber(fields.prob) - if prob then - local player = minetest.get_player_by_name(name) - if not player then - return - end - local probtool = player:get_wielded_item() - if probtool:get_name() ~= "schemedit:probtool" then - return - end - - local force_place = self.force_place == true - - set_item_metadata(probtool, prob, force_place) - - -- Repurpose the tool's wear bar to display the set probability - probtool:set_wear(math.floor(((255-prob)/255)*65535)) - - player:set_wielded_item(probtool) - end - end - if fields.force_place == "true" then - self.force_place = true - elseif fields.force_place == "false" then - self.force_place = false - end - end, -}) - ---- ---- API ---- - ---- Copies and modifies positions `pos1` and `pos2` so that each component of --- `pos1` is less than or equal to the corresponding component of `pos2`. --- Returns the new positions. -function schemedit.sort_pos(pos1, pos2) - if not pos1 or not pos2 then - return - end - - pos1, pos2 = table.copy(pos1), table.copy(pos2) - if pos1.x > pos2.x then - pos2.x, pos1.x = pos1.x, pos2.x - end - if pos1.y > pos2.y then - pos2.y, pos1.y = pos1.y, pos2.y - end - if pos1.z > pos2.z then - pos2.z, pos1.z = pos1.z, pos2.z - end - return pos1, pos2 -end - --- [function] Prepare size -function schemedit.size(pos) - local pos1 = vector.new(pos) - local meta = minetest.get_meta(pos) - local node = minetest.get_node(pos) - local param2 = node.param2 - local size = { - x = meta:get_int("x_size"), - y = math.max(meta:get_int("y_size") - 1, 0), - z = meta:get_int("z_size"), - } - - if param2 == 1 then - local new_pos = vector.add({x = size.z, y = size.y, z = -size.x}, pos) - pos1.x = pos1.x + 1 - new_pos.z = new_pos.z + 1 - return pos1, new_pos - elseif param2 == 2 then - local new_pos = vector.add({x = -size.x, y = size.y, z = -size.z}, pos) - pos1.z = pos1.z - 1 - new_pos.x = new_pos.x + 1 - return pos1, new_pos - elseif param2 == 3 then - local new_pos = vector.add({x = -size.z, y = size.y, z = size.x}, pos) - pos1.x = pos1.x - 1 - new_pos.z = new_pos.z - 1 - return pos1, new_pos - else - local new_pos = vector.add(size, pos) - pos1.z = pos1.z + 1 - new_pos.x = new_pos.x - 1 - return pos1, new_pos - end -end - --- [function] Mark region -function schemedit.mark(pos) - schemedit.unmark(pos) - - local id = minetest.hash_node_position(pos) - local owner = minetest.get_meta(pos):get_string("owner") - local pos1, pos2 = schemedit.size(pos) - pos1, pos2 = schemedit.sort_pos(pos1, pos2) - - local thickness = 0.2 - local sizex, sizey, sizez = (1 + pos2.x - pos1.x) / 2, (1 + pos2.y - pos1.y) / 2, (1 + pos2.z - pos1.z) / 2 - local m = {} - local low = true - local offset - - -- XY plane markers - for _, z in ipairs({pos1.z - 0.5, pos2.z + 0.5}) do - if low then - offset = -0.01 - else - offset = 0.01 - end - local marker = minetest.add_entity({x = pos1.x + sizex - 0.5, y = pos1.y + sizey - 0.5, z = z + offset}, "schemedit:display") - if marker ~= nil then - marker:set_properties({ - visual_size={x=(sizex+0.01) * 2, y=(sizey+0.01) * 2}, - }) - marker:get_luaentity().id = id - marker:get_luaentity().owner = owner - table.insert(m, marker) - end - low = false - end - - low = true - -- YZ plane markers - for _, x in ipairs({pos1.x - 0.5, pos2.x + 0.5}) do - if low then - offset = -0.01 - else - offset = 0.01 - end - - local marker = minetest.add_entity({x = x + offset, y = pos1.y + sizey - 0.5, z = pos1.z + sizez - 0.5}, "schemedit:display") - if marker ~= nil then - marker:set_properties({ - visual_size={x=(sizez+0.01) * 2, y=(sizey+0.01) * 2}, - }) - marker:set_rotation({x=0, y=math.pi / 2, z=0}) - marker:get_luaentity().id = id - marker:get_luaentity().owner = owner - table.insert(m, marker) - end - low = false - end - - low = true - -- XZ plane markers - for _, y in ipairs({pos1.y - 0.5, pos2.y + 0.5}) do - if low then - offset = -0.01 - else - offset = 0.01 - end - - local marker = minetest.add_entity({x = pos1.x + sizex - 0.5, y = y + offset, z = pos1.z + sizez - 0.5}, "schemedit:display") - if marker ~= nil then - marker:set_properties({ - visual_size={x=(sizex+0.01) * 2, y=(sizez+0.01) * 2}, - }) - marker:set_rotation({x=math.pi/2, y=0, z=0}) - marker:get_luaentity().id = id - marker:get_luaentity().owner = owner - table.insert(m, marker) - end - low = false - end - - - - schemedit.markers[id] = m - return true -end - --- [function] Unmark region -function schemedit.unmark(pos) - local id = minetest.hash_node_position(pos) - if schemedit.markers[id] then - local retval - for _, entity in ipairs(schemedit.markers[id]) do - entity:remove() - retval = true - end - return retval - end -end - ---- ---- Mark node probability values near player ---- - --- Show probability and force_place status of a particular position for player in HUD. --- Probability is shown as a number followed by the FORCE_SYMBOL if the node is force-placed. -function schemedit.display_node_prob(player, pos, prob, force_place) - local wpstring - if prob and force_place == true then - wpstring = string.format("%s "..FORCE_SYMBOL, prob) - elseif prob and type(tonumber(prob)) == "number" then - wpstring = prob - elseif force_place == true then - wpstring = FORCE_SYMBOL - end - if wpstring then - return player:hud_add({ - hud_elem_type = "waypoint", - name = wpstring, - precision = 0, - text = "m", -- For the distance artifact [legacy] - number = TEXT_COLOR_GUI_NUMBER, - world_pos = pos, - z_index = -300, - }) - end -end - --- Display the node probabilities and force_place status of the nodes in a region. --- By default, this is done for nodes near the player (distance: 5). --- But the boundaries can optionally be set explicitly with pos1 and pos2. -function schemedit.display_node_probs_region(player, pos1, pos2) - local playername = player:get_player_name() - local pos = vector.round(player:get_pos()) - - local dist = 5 - -- Default: 5 nodes away from player in any direction - if not pos1 then - pos1 = vector.subtract(pos, dist) - end - if not pos2 then - pos2 = vector.add(pos, dist) - end - for x=pos1.x, pos2.x do - for y=pos1.y, pos2.y do - for z=pos1.z, pos2.z do - local checkpos = {x=x, y=y, z=z} - local nodehash = minetest.hash_node_position(checkpos) - - -- If node is already displayed, remove it so it can re replaced later - if displayed_waypoints[playername][nodehash] then - player:hud_remove(displayed_waypoints[playername][nodehash]) - displayed_waypoints[playername][nodehash] = nil - end - - local prob, force_place - local meta = minetest.get_meta(checkpos) - prob = meta:get_string("schemedit_prob") - force_place = meta:get_string("schemedit_force_place") == "true" - local hud_id = schemedit.display_node_prob(player, checkpos, prob, force_place) - if hud_id then - displayed_waypoints[playername][nodehash] = hud_id - displayed_waypoints[playername].display_active = true - end - end - end - end -end - --- Remove all active displayed node statuses. -function schemedit.clear_displayed_node_probs(player) - local playername = player:get_player_name() - for nodehash, hud_id in pairs(displayed_waypoints[playername]) do - if nodehash ~= "display_active" then - player:hud_remove(hud_id) - displayed_waypoints[playername][nodehash] = nil - displayed_waypoints[playername].display_active = false - end - end -end - -minetest.register_on_joinplayer(function(player) - displayed_waypoints[player:get_player_name()] = { - display_active = false -- If true, there *might* be at least one active node prob HUD display - -- If false, no node probabilities are displayed for sure. - } -end) - -minetest.register_on_leaveplayer(function(player) - displayed_waypoints[player:get_player_name()] = nil -end) - --- Regularily clear the displayed node probabilities and force_place --- for all players who do not wield the probtool. --- This makes sure the screen is not spammed with information when it --- isn't needed. -local cleartimer = 0 -minetest.register_globalstep(function(dtime) - cleartimer = cleartimer + dtime - if cleartimer > 2 then - local players = minetest.get_connected_players() - for p = 1, #players do - local player = players[p] - local pname = player:get_player_name() - if displayed_waypoints[pname].display_active then - local item = player:get_wielded_item() - if item:get_name() ~= "schemedit:probtool" then - schemedit.clear_displayed_node_probs(player) - end - end - end - cleartimer = 0 - end -end) - ---- ---- Registrations ---- - --- [priv] schematic_override -minetest.register_privilege("schematic_override", { - description = S("Allows you to access schemedit nodes not owned by you"), - give_to_singleplayer = false, -}) - -local help_import = "" -if can_import then - help_import = S("Importing a schematic will load a schematic from the world directory, place it in front of the schematic creator and sets probability and force-place data accordingly.").."\n" -end - --- [node] Schematic creator -minetest.register_node("schemedit:creator", { - description = S("Schematic Creator"), - _doc_items_longdesc = S("The schematic creator is used to save a region of the world into a schematic file (.mts)."), - _doc_items_usagehelp = S("To get started, place the block facing directly in front of any bottom left corner of the structure you want to save. This block can only be accessed by the placer or by anyone with the “schematic_override” privilege.").."\n".. -S("To save a region, use the block, enter the size and a schematic name and hit “Export schematic”. The file will always be saved in the world directory. Note you can use this name in the /placeschem command to place the schematic again.").."\n\n".. -help_import.. -S("The other features of the schematic creator are optional and are used to allow to add randomness and fine-tuning.").."\n\n".. -S("Y slices are used to remove entire slices based on chance. For each slice of the schematic region along the Y axis, you can specify that it occurs only with a certain chance. In the Y slice tab, you have to specify the Y slice height (0 = bottom) and a probability from 0 to 255 (255 is for 100%). By default, all Y slices occur always.").."\n\n".. -S("With a schematic node probability tool, you can set a probability for each node and enable them to overwrite all nodes when placed as schematic. This tool must be used prior to the file export."), - tiles = {"schemedit_creator_top.png", "schemedit_creator_bottom.png", - "schemedit_creator_sides.png"}, - groups = { dig_immediate = 2}, - paramtype2 = "facedir", - is_ground_content = false, - - after_place_node = function(pos, player) - local name = player:get_player_name() - local meta = minetest.get_meta(pos) - - meta:set_string("owner", name) - meta:set_string("infotext", S("Schematic Creator").."\n"..S("(owned by @1)", name)) - meta:set_string("prob_list", minetest.serialize({})) - meta:set_string("slices", minetest.serialize({})) - - local node = minetest.get_node(pos) - local dir = minetest.facedir_to_dir(node.param2) - - meta:set_int("x_size", 1) - meta:set_int("y_size", 1) - meta:set_int("z_size", 1) - - -- Don't take item from itemstack - return true - end, - can_dig = function(pos, player) - local name = player:get_player_name() - local meta = minetest.get_meta(pos) - if meta:get_string("owner") == name or - minetest.check_player_privs(player, "schematic_override") == true then - return true - end - - return false - end, - on_rightclick = function(pos, node, player) - local meta = minetest.get_meta(pos) - local name = player:get_player_name() - if meta:get_string("owner") == name or - minetest.check_player_privs(player, "schematic_override") == true then - -- Get player attribute - local pmeta = player:get_meta() - local tab = pmeta:get_string("schemedit:tab") - if not forms[tab] or not tab then - tab = "main" - end - - schemedit.show_formspec(pos, player, tab, true) - end - end, - after_destruct = function(pos) - schemedit.unmark(pos) - end, - - -- No support for Minetest Game's screwdriver - on_rotate = false, -}) - -minetest.register_tool("schemedit:probtool", { - description = S("Schematic Node Probability Tool"), - _doc_items_longdesc = -S("This is an advanced tool which only makes sense when used together with a schematic creator. It is used to finetune the way how nodes from a schematic are placed.").."\n".. -S("It allows you to set two things:").."\n".. -S("1) Set probability: Chance for any particular node to be actually placed (default: always placed)").."\n".. -S("2) Enable force placement: These nodes replace node other than air and ignore when placed in a schematic (default: off)"), - _doc_items_usagehelp = "\n".. -S("BASIC USAGE:").."\n".. -S("Punch to configure the tool. Select a probability (0-255; 255 is for 100%) and enable or disable force placement. Now place the tool on any node to apply these values to the node. This information is preserved in the node until it is destroyed or changed by the tool again. This tool has no effect on schematic voids.").."\n".. -S("Now you can use a schematic creator to save a region as usual, the nodes will now be saved with the special node settings applied.").."\n\n".. -S("NODE HUD:").."\n".. -S("To help you remember the node values, the nodes with special values are labelled in the HUD. The first line shows probability and force placement (with “[F]”). The second line is the current distance to the node. Nodes with default settings and schematic voids are not labelled.").."\n".. -S("To disable the node HUD, unselect the tool or hit “place” while not pointing anything.").."\n\n".. -S("UPDATING THE NODE HUD:").."\n".. -S("The node HUD is not updated automatically and may be outdated. The node HUD only updates the HUD for nodes close to you whenever you place the tool or press the punch and sneak keys simultaneously. If you sneak-punch a schematic creator, then the node HUD is updated for all nodes within the schematic creator's region, even if this region is very big."), - wield_image = "schemedit_probtool.png", - inventory_image = "schemedit_probtool.png", - liquids_pointable = true, - groups = { disable_repair = 1 }, - on_use = function(itemstack, user, pointed_thing) - local uname = user:get_player_name() - if uname and not check_priv(uname) then - return - end - - local ctrl = user:get_player_control() - -- Simple use - if not ctrl.sneak then - -- Open dialog to change the probability to apply to nodes - schemedit.show_formspec(user:get_pos(), user, "probtool", true) - - -- Use + sneak - else - -- Display the probability and force_place values for nodes. - - -- If a schematic creator was punched, only enable display for all nodes - -- within the creator's region. - local use_creator_region = false - if pointed_thing and pointed_thing.type == "node" and pointed_thing.under then - local punchpos = pointed_thing.under - local node = minetest.get_node(punchpos) - if node.name == "schemedit:creator" then - local pos1, pos2 = schemedit.size(punchpos) - pos1, pos2 = schemedit.sort_pos(pos1, pos2) - schemedit.display_node_probs_region(user, pos1, pos2) - return - end - end - - -- Otherwise, just display the region close to the player - schemedit.display_node_probs_region(user) - end - end, - on_secondary_use = function(itemstack, user, pointed_thing) - local uname = user:get_player_name() - if uname and not check_priv(uname) then - return - end - - schemedit.clear_displayed_node_probs(user) - end, - -- Set note probability and force_place and enable node probability display - on_place = function(itemstack, placer, pointed_thing) - local pname = placer:get_player_name() - if pname and not check_priv(pname) then - return - end - - -- Use pointed node's on_rightclick function first, if present - local node = minetest.get_node(pointed_thing.under) - if placer and not placer:get_player_control().sneak then - if minetest.registered_nodes[node.name] and minetest.registered_nodes[node.name].on_rightclick then - return minetest.registered_nodes[node.name].on_rightclick(pointed_thing.under, node, placer, itemstack) or itemstack - end - end - - -- This sets the node probability of pointed node to the - -- currently used probability stored in the tool. - local pos = pointed_thing.under - local node = minetest.get_node(pos) - -- Schematic void are ignored, they always have probability 0 - if node.name == "schemedit:void" then - return itemstack - end - local nmeta = minetest.get_meta(pos) - local imeta = itemstack:get_meta() - local prob = tonumber(imeta:get_string("schemedit_prob")) - local force_place = imeta:get_string("schemedit_force_place") - - if not prob or prob == 255 then - nmeta:set_string("schemedit_prob", nil) - else - nmeta:set_string("schemedit_prob", prob) - end - if force_place == "true" then - nmeta:set_string("schemedit_force_place", "true") - else - nmeta:set_string("schemedit_force_place", nil) - end - - -- Enable node probablity display - schemedit.display_node_probs_region(placer) - - return itemstack - end, -}) - -local use_texture_alpha_void -if minetest.features.use_texture_alpha_string_modes then - use_texture_alpha_void = "clip" -else - use_texture_alpha_void = true -end - -minetest.register_node("schemedit:void", { - description = S("Schematic Void"), - _doc_items_longdesc = S("This is an utility block used in the creation of schematic files. It should be used together with a schematic creator. When saving a schematic, all nodes with a schematic void will be left unchanged when the schematic is placed again. Technically, this is equivalent to a block with the node probability set to 0."), - _doc_items_usagehelp = S("Just place the schematic void like any other block and use the schematic creator to save a portion of the world."), - tiles = { "schemedit_void.png" }, - use_texture_alpha = use_texture_alpha_void, - drawtype = "nodebox", - is_ground_content = false, - paramtype = "light", - walkable = false, - sunlight_propagates = true, - node_box = { - type = "fixed", - fixed = { - { -4/16, -4/16, -4/16, 4/16, 4/16, 4/16 }, - }, - }, - groups = { dig_immediate = 3}, -}) - --- [entity] Visible schematic border -minetest.register_entity("schemedit:display", { - visual = "upright_sprite", - textures = {get_border_texture()}, - visual_size = {x=10, y=10}, - pointable = false, - physical = false, - static_save = false, - glow = minetest.LIGHT_MAX, - - on_step = function(self, dtime) - if not self.id then - self.object:remove() - elseif not schemedit.markers[self.id] then - self.object:remove() - end - end, - on_activate = function(self) - self.object:set_armor_groups({immortal = 1}) - end, -}) - -minetest.register_lbm({ - label = "Reset schematic creator border entities", - name = "schemedit:reset_border", - nodenames = "schemedit:creator", - run_at_every_load = true, - action = function(pos, node) - local meta = minetest.get_meta(pos) - meta:set_string("schem_border", "false") - end, -}) - -local function add_suffix(schem) - -- Automatically add file name suffix if omitted - local schem_full, schem_lua - if string.sub(schem, string.len(schem)-3, string.len(schem)) == ".mts" then - schem_full = schem - schem_lua = string.sub(schem, 1, -5) .. ".lua" - else - schem_full = schem .. ".mts" - schem_lua = schem .. ".lua" - end - return schem_full, schem_lua -end - --- [chatcommand] Place schematic -minetest.register_chatcommand("placeschem", { - description = S("Place schematic at the position specified or the current player position (loaded from @1). “-c” will clear the area first", export_path_trunc), - privs = {server = true}, - params = S("[.mts] [-c] [ ]"), - func = function(name, param) - local schem, clear, p = string.match(param, "^([^ ]+) +(%-c) *(.*)$") - if not schem then - schem, p = string.match(param, "^([^ ]+) *(.*)$") - end - clear = clear == "-c" - - local ppos = minetest.get_player_by_name(name):get_pos() - - local pos - if p and p ~= "" then - local pp = string.split(p, " ") - local nums = {} - local axes = { "x", "y", "z" } - for a=1, #axes do - local axis = axes[a] - local parsed - if minetest.parse_relative_number then - parsed = minetest.parse_relative_number(pp[a], ppos[axis]) - else - parsed = tonumber(ppos[axis]) - end - if not parsed then - return false - end - table.insert(nums, parsed) - end - pos = vector.new(nums[1], nums[2], nums[3]) - else - pos = ppos - end - - pos = vector.round(pos) - - if not schem then - return false, S("No schematic file specified.") - end - - local schem_full, schem_lua = add_suffix(schem) - local success = false - local schem_path = export_path_full .. DIR_DELIM .. schem_full - if minetest.read_schematic then - -- We don't call minetest.place_schematic with the path name directly because - -- this would trigger the caching and we wouldn't get any updates to the schematic - -- files when we reload. minetest.read_schematic circumvents that. - local schematic = minetest.read_schematic(schem_path, {}) - if schematic then - if clear then - -- Clear same size for X and Z because - -- because schematic is randomly rotated - local max_xz = math.max(schematic.size.x, schematic.size.z) - local posses = {} - for z=pos.z, pos.z+max_xz-1 do - for y=pos.y, pos.y+schematic.size.y-1 do - for x=pos.x, pos.x+max_xz-1 do - table.insert(posses, {x=x,y=y,z=z}) - end - end - end - minetest.bulk_set_node(posses, {name="air"}) - end - minetest.log("action", "[schemedit] Placing schematic '"..schem.."' at: "..minetest.pos_to_string(pos)) - success = minetest.place_schematic(pos, schematic, "random", nil, false) - end - else - -- Legacy support for Minetest versions that do not have minetest.read_schematic. - -- Note: "-c" is ignored here. - minetest.log("action", "[schemedit] Placing schematic '"..schem.."' at: "..minetest.pos_to_string(pos)) - success = minetest.place_schematic(schem_path, schematic, "random", nil, false) - end - - if success == nil then - return false, S("Schematic file could not be loaded!") - else - return true - end - end, -}) - -minetest.register_chatcommand("listschems", { - description = S("List schematic files in world path"), - privs = {server = true}, - params = "", - func = function(name, param) - local files = minetest.get_dir_list(export_path_full, false) - if not files then - return false - end - local out_files = {} - -- Only show files with “.mts” suffix - for f=#files, 1, -1 do - if string.sub(string.lower(files[f]), -4, -1) == ".mts" then - table.insert(out_files, files[f]) - end - end - table.sort(out_files) - local str = table.concat(out_files, ", ") - if str == "" then - return true, S("No schematic files.") - end - return true, str - end, -}) - -if can_import then --- [chatcommand] Convert MTS schematic file to .lua file -minetest.register_chatcommand("mts2lua", { - description = S("Convert .mts schematic file to .lua file (loaded from @1)", export_path_trunc), - privs = {server = true}, - params = S("[.mts] [comments]"), - func = function(name, param) - local schem, comments_str = string.match(param, "^([^ ]+) *(.*)$") - - if not schem then - return false, S("No schematic file specified.") - end - - local comments = comments_str == "comments" - - -- Automatically add file name suffix if omitted - local schem_full, schem_lua = add_suffix(schem) - local schem_path = export_path_full .. DIR_DELIM .. schem_full - local schematic = minetest.read_schematic(schem_path, {}) - - if schematic then - local str = minetest.serialize_schematic(schematic, "lua", {lua_use_comments=comments}) - local lua_path = export_path_full .. DIR_DELIM .. schem_lua - local file = io.open(lua_path, "w") - if file and str then - file:write(str) - file:flush() - file:close() - return true, S("Exported schematic to @1", lua_path) - else - return false, S("Failed!") - end - end - end, -}) -end - -if MAKE_README then - dofile(minetest.get_modpath("schemedit")..DIR_DELIM.."make_readme.lua") -end diff --git a/mods/schemedit/locale/schemedit.de.tr b/mods/schemedit/locale/schemedit.de.tr deleted file mode 100644 index 86cab9a..0000000 --- a/mods/schemedit/locale/schemedit.de.tr +++ /dev/null @@ -1,85 +0,0 @@ -# textdomain: schemedit -= -Insufficient privileges! You need the “@1” privilege to use this.=Unzureichende Privilegien! Sie benötigen das „@1“-Privileg, um dies benutzen zu können. -Exported schematic to @1=Schematic nach @1 exportiert -Failed to export schematic to @1=Schematic konnte nicht nach @1 exportiert werden -Probability: @1=Wahrscheinlichkeit: @1 -Not Set=Nicht gesetzt -Force placement=Platzierung erzwingen -Import schematic=Schematic importieren -Main=Grundeinstellungen -Hide border=Rand verbergen -Show border=Rand anzeigen -Position: @1=Position: @1 -Owner: @1=Eigentümer: @1 -Schematic name: @1=Schematic-Name: @1 -Size: @1=Größe: @1 -Schematic name:=Schematic-Name: -OK=OK -Save schematic name=Schematic-Name speichern -Export schematic=Schematic exportieren -Export/import path:@n@1=Export-/Importpfad:@n@1 -= -Air to voids=Luft zu Lücken -Voids to air=Lücken zu Luft -Turn all air nodes into schematic void nodes=Alle Luft-Nodes zu Schematic-Lücken umwandeln -Turn all schematic void nodes into air nodes=Alle Schematic-Lücken zu Luft-Nodes umwandeln -X size:=X-Größe: -Y size:=Y-Größe: -Z size:=Z-Größe: -Save size=Größe speichern -Help=Hilfe -Could not emerge area from @1 to @2: Emerging was cancelled. Nothing was exported.=Gebiet von @1 zu @2 konnte nicht emergt werden: Emergen wurde abgebrochen. Nichts wurde exportiert. -Could not emerge area from @1 to @2: Error while emerging. Nothing was exported.=Gebiet von @1 zu @2 konnte nicht emergt werden: Fehler beim Emergen. Nichts wurde exportiert. -Could not emerge area from @1 to @2: Unknown action in emerge callback. Nothing was exported.=Gebiet von @1 zu @2 konnte nicht emergt werden: Unbekannte Aktion im Emerge-Callback. Nichts wurde exportiert. -Imported schematic from @1=Schematic von @1 importiert -Failed to import schematic from @1=Schematic konnte nicht von @1 importiert werden -Y Slices=Y-Scheiben -Y @= @1; Probability @= @2=Y @= @1; Wahrscheinlichkeit @= @2 -Add=Hinzufügen -Apply=Anwenden -Y position (max. @1):=Y-Position (max. @1): -Probability (0-255):=Wahrscheinlichkeit (0-255): -Cancel=Abbrechen -Add slice=Neue Scheibe -Remove slice=Scheibe entfernen -Edit slice=Scheibe anpassen -Back=Zurück -Schematic Node Probability Tool=Schematic-Node-Wahrscheinlichkeitswerkzeug -Probability (0-255)=Wahrscheinlichkeit (0-255) -Probability that the node will be placed=Wahrscheinlichkeit, dass der Node platizert wird -If enabled, the node will replace nodes other than air and ignore=Wenn aktiviert, wird der Node alle Nodes außer Luft und Ignorieren ersetzen -Allows you to access schemedit nodes not owned by you=Damit können Sie auf Schemedit-Nodes, die ihnen nicht gehören, zugreifen -Importing a schematic will load a schematic from the world directory, place it in front of the schematic creator and sets probability and force-place data accordingly.=Das Importieren eines Schematics wird eine Schematicdatei aus dem Weltverzeichnis laden, sie vor dem Schematic-Macher platzieren und die Wahrscheinlichkeits- und Zwangsplatzierungsdaten entsprechend setzen. -Schematic Creator=Schematic-Macher -The schematic creator is used to save a region of the world into a schematic file (.mts).=Der Schematic-Macher wird benutzt, um eine Region der Welt in eine Schematic-Datei (.mts) zu speichern. -To get started, place the block facing directly in front of any bottom left corner of the structure you want to save. This block can only be accessed by the placer or by anyone with the “schematic_override” privilege.=Um anzufangen, platzieren Sie den Block direkt vor einer beliebigen unteren linken Ecke des Gebäudes, das Sie speichern möchten. Dieser Block kann nur vom Platzierer oder von Spielern mit dem „schematic_override“-Privileg benutzt werden. -To save a region, use the block, enter the size and a schematic name and hit “Export schematic”. The file will always be saved in the world directory. Note you can use this name in the /placeschem command to place the schematic again.=Um eine Region zu speichern, benutzen Sie den Block, geben Sie die Größe und einen Schematic-Namen ein und klicken Sie auf „Schematic exportieren“. Die Datei wird immer im Weltverzeichnis gespeichert. Beachten Sie, dass Sie diesen Namen im „/placeschem“-Befehl benutzen können, um das Schematic erneut zu platzieren. -The other features of the schematic creator are optional and are used to allow to add randomness and fine-tuning.=Die anderen Funktionen des Schematic-Machers sind optional und werden für Zufälligkeit und Feinjustierungen benutzt. -Y slices are used to remove entire slices based on chance. For each slice of the schematic region along the Y axis, you can specify that it occurs only with a certain chance. In the Y slice tab, you have to specify the Y slice height (0 @= bottom) and a probability from 0 to 255 (255 is for 100%). By default, all Y slices occur always.=Y-Scheiben werden benutzt, um ganze Scheiben mit einer gewissen Wahrscheinlichkeit auszulassen. Für jede Scheibe der Schematic-Region entlang der Y-Achse können Sie festlegen, dass sie nur mit einer gewissen Wahrscheinlichkeit auftritt. In der Registerkarte „Y-Scheiben“ müssen Sie die Höhe der Y-Scheibe festlegen (0 @= Boden) sowie eine Wahrscheinlichkeit zwischen 0 und 255 (255 steht für 100%). Standardmäßig treten alle Y-Scheiben immer auf. -With a schematic node probability tool, you can set a probability for each node and enable them to overwrite all nodes when placed as schematic. This tool must be used prior to the file export.=Mit einem Schematic-Node-Wahrscheinlichkeitswerkzeug können Sie die Wahrscheinlichkeit für jeden Node setzen und sie dazu aktivieren, alle Nodes zu ersetzen, wenn sie als Schematic platziert werden. Dieses Werkzeug muss vor dem Dateiexport benutzt werden. -(owned by @1)=(Eigentümer: @1) -This is an advanced tool which only makes sense when used together with a schematic creator. It is used to finetune the way how nodes from a schematic are placed.=Dies ist ein fortgeschrittenes Werkzeug, der nur sinnvoll in Verwendung mit einem Schematic-Macher benutzt werden kann. Er wird benutzt, um die Art und Weise, wie Nodes aus einem Schematic platziert werden, feinzujustieren. -It allows you to set two things:=Damit können Sie zwei Dinge setzen: -1) Set probability: Chance for any particular node to be actually placed (default: always placed)=1) Wahrscheinlichkeit setzen: Wahrscheinlichkeit für einen bestimmten Node, dass er tatsächlich platziert wird (Standard: immer platziert) -2) Enable force placement: These nodes replace node other than air and ignore when placed in a schematic (default: off)=2) Zwangsplatzierung aktivieren: Diese Nodes ersetzen alle Nodes außer Luft und Ignorieren, wenn Sie in einem Schematic platziert werden (Standard: aus) -BASIC USAGE:=GRUNDLEGENDE BENUTZUNG: -Punch to configure the tool. Select a probability (0-255; 255 is for 100%) and enable or disable force placement. Now place the tool on any node to apply these values to the node. This information is preserved in the node until it is destroyed or changed by the tool again. This tool has no effect on schematic voids.=Schlagen Sie zu, um das Werkzeug zu konfigurieren. Wählen Sie eine Wahrscheinlichkeit (0-255; 255 steht für 100%) und aktivieren oder deaktivieren Sie die erzwungene Platzierung. Platzieren Sie nun das Werkzeug auf einen beliebigen Node, um diese Werte auf dem Node anzuwenden. Diese Information bleibt im Node erhalten, bis er zerstört oder erneut vom Werkzeug geändert wird. Dieses Werkzeug hat keine Auswirkung auf Schematic-Lücken. -Now you can use a schematic creator to save a region as usual, the nodes will now be saved with the special node settings applied.=Anschließend können Sie einen Schematic-Macher benutzen, um eine Region wie gewöhnlich zu speichern, die Nodes werden nun mit den besonderen Node-Einstellungen gespeichert. -NODE HUD:=NODE-HUD: -To help you remember the node values, the nodes with special values are labelled in the HUD. The first line shows probability and force placement (with “[F]”). The second line is the current distance to the node. Nodes with default settings and schematic voids are not labelled.=Um Ihnen dabei zu helfen, sich die Node-Werte zu merken, werden die Nodes mit besonderen Werten in der Benutzeroberfläche gekennzeichnet. Die erste Zeile zeigt die Wahrscheinlichkeit und die Zwangsplatzierung (mit „[F]“) an. Die zweite Zeile zeigt die momentane Entfernung zum Node an. Nodes mit den Standardeinstellungen und Schematic-Lücken werden nicht gekennzeichnet. -To disable the node HUD, unselect the tool or hit “place” while not pointing anything.=Um die Node-HUD zu deaktivieren, wählen Sie das Werkzeug ab oder drücken Sie die Platzierentaste, während Sie auf nichts zeigen. -UPDATING THE NODE HUD:=NODE-HUD AKTUALISIEREN: -The node HUD is not updated automatically and may be outdated. The node HUD only updates the HUD for nodes close to you whenever you place the tool or press the punch and sneak keys simultaneously. If you sneak-punch a schematic creator, then the node HUD is updated for all nodes within the schematic creator's region, even if this region is very big.=Die Node-HUD wird nicht automatisch aktualisiert und kann veraltet sein. Die Node-HUD wird nur die HUD für Nodes in Ihrer Nähe aktualisieren oder wenn Sie das Werkzeug benutzen oder gleichzeitig die Schlag- und Schleichtaste drücken. Wenn Sie auf einen Schematic-Macher schleichschlagen, wird die Node-HUD für alle Nodes innerhalb der Region des Schematic-Machers aktualisiert, selbst, wenn diese Region sehr groß ist. -Schematic Void=Schematic-Lücke -This is an utility block used in the creation of schematic files. It should be used together with a schematic creator. When saving a schematic, all nodes with a schematic void will be left unchanged when the schematic is placed again. Technically, this is equivalent to a block with the node probability set to 0.=Dies ist ein Hilfsblock, der bei der Erstellung von Schematic-Dateien benutzt wird. Er sollte zusammen mit einem Schematic-Macher benutzt werden. Wenn ein Schematic gespeichert wird, werden alle Nodes mit einer Schematic-Lücke unverändert gelassen, wenn das Schematic erneut platziert wird. Technisch gesehen ist dieses Verhalten identisch mit einem Block, der eine Node-Wahrscheinlichkeit von 0 hat. -Just place the schematic void like any other block and use the schematic creator to save a portion of the world.=Platzieren Sie einfach die Schematic-Lücke wie jeden anderen Block und benutzen Sie den Schematic-Macher, um einen Teil der Welt zu speichern. -Place schematic at the position specified or the current player position (loaded from @1). “-c” will clear the area first=Schematic an der angegebenen Position oder der aktuellen Spielerposition platzieren (geladen von @1). Mit „-c“ wird das Gebiet zuerst geleert -[.mts] [-c] [ ]=[.mts] [-c] [ ] -No schematic file specified.=Keinen Schematic-Namen angegeben. -Schematic file could not be loaded!=Schematic-Datei konnte nicht geladen werden! -List schematic files in world path=Schematic-Dateien im Weltpfad auflisten -No schematic files.=Keine Schematic-Dateien. -Convert .mts schematic file to .lua file (loaded from @1)=„.mts“-Schematicdatei zu „.lua“-Datei konvertieren (geladen von @1) -[.mts] [comments]=[.mts] [comments] -Failed!=Fehlgeschlagen! diff --git a/mods/schemedit/locale/template.txt b/mods/schemedit/locale/template.txt deleted file mode 100644 index 6f7da28..0000000 --- a/mods/schemedit/locale/template.txt +++ /dev/null @@ -1,85 +0,0 @@ -# textdomain: schemedit -= -Insufficient privileges! You need the “@1” privilege to use this.= -Exported schematic to @1= -Failed to export schematic to @1= -Probability: @1= -Not Set= -Force placement= -Import schematic= -Main= -Hide border= -Show border= -Position: @1= -Owner: @1= -Schematic name: @1= -Size: @1= -Schematic name:= -OK= -Save schematic name= -Export schematic= -Export/import path:@n@1= -= -Air to voids= -Voids to air= -Turn all air nodes into schematic void nodes= -Turn all schematic void nodes into air nodes= -X size:= -Y size:= -Z size:= -Save size= -Help= -Could not emerge area from @1 to @2: Emerging was cancelled. Nothing was exported.= -Could not emerge area from @1 to @2: Error while emerging. Nothing was exported.= -Could not emerge area from @1 to @2: Unknown action in emerge callback. Nothing was exported.= -Imported schematic from @1= -Failed to import schematic from @1= -Y Slices= -Y @= @1; Probability @= @2= -Add= -Apply= -Y position (max. @1):= -Probability (0-255):= -Cancel= -Add slice= -Remove slice= -Edit slice= -Back= -Schematic Node Probability Tool= -Probability (0-255)= -Probability that the node will be placed= -If enabled, the node will replace nodes other than air and ignore= -Allows you to access schemedit nodes not owned by you= -Importing a schematic will load a schematic from the world directory, place it in front of the schematic creator and sets probability and force-place data accordingly.= -Schematic Creator= -The schematic creator is used to save a region of the world into a schematic file (.mts).= -To get started, place the block facing directly in front of any bottom left corner of the structure you want to save. This block can only be accessed by the placer or by anyone with the “schematic_override” privilege.= -To save a region, use the block, enter the size and a schematic name and hit “Export schematic”. The file will always be saved in the world directory. Note you can use this name in the /placeschem command to place the schematic again.= -The other features of the schematic creator are optional and are used to allow to add randomness and fine-tuning.= -Y slices are used to remove entire slices based on chance. For each slice of the schematic region along the Y axis, you can specify that it occurs only with a certain chance. In the Y slice tab, you have to specify the Y slice height (0 @= bottom) and a probability from 0 to 255 (255 is for 100%). By default, all Y slices occur always.= -With a schematic node probability tool, you can set a probability for each node and enable them to overwrite all nodes when placed as schematic. This tool must be used prior to the file export.= -(owned by @1)= -This is an advanced tool which only makes sense when used together with a schematic creator. It is used to finetune the way how nodes from a schematic are placed.= -It allows you to set two things:= -1) Set probability: Chance for any particular node to be actually placed (default: always placed)= -2) Enable force placement: These nodes replace node other than air and ignore when placed in a schematic (default: off)= -BASIC USAGE:= -Punch to configure the tool. Select a probability (0-255; 255 is for 100%) and enable or disable force placement. Now place the tool on any node to apply these values to the node. This information is preserved in the node until it is destroyed or changed by the tool again. This tool has no effect on schematic voids.= -Now you can use a schematic creator to save a region as usual, the nodes will now be saved with the special node settings applied.= -NODE HUD:= -To help you remember the node values, the nodes with special values are labelled in the HUD. The first line shows probability and force placement (with “[F]”). The second line is the current distance to the node. Nodes with default settings and schematic voids are not labelled.= -To disable the node HUD, unselect the tool or hit “place” while not pointing anything.= -UPDATING THE NODE HUD:= -The node HUD is not updated automatically and may be outdated. The node HUD only updates the HUD for nodes close to you whenever you place the tool or press the punch and sneak keys simultaneously. If you sneak-punch a schematic creator, then the node HUD is updated for all nodes within the schematic creator's region, even if this region is very big.= -Schematic Void= -This is an utility block used in the creation of schematic files. It should be used together with a schematic creator. When saving a schematic, all nodes with a schematic void will be left unchanged when the schematic is placed again. Technically, this is equivalent to a block with the node probability set to 0.= -Just place the schematic void like any other block and use the schematic creator to save a portion of the world.= -Place schematic at the position specified or the current player position (loaded from @1). “-c” will clear the area first= -[.mts] [-c] [ ]= -No schematic file specified.= -Schematic file could not be loaded!= -List schematic files in world path= -No schematic files.= -Convert .mts schematic file to .lua file (loaded from @1)= -[.mts] [comments]= -Failed!= diff --git a/mods/schemedit/make_readme.lua b/mods/schemedit/make_readme.lua deleted file mode 100644 index 4137bcf..0000000 --- a/mods/schemedit/make_readme.lua +++ /dev/null @@ -1,69 +0,0 @@ --- This file adds a command for generating the schemedit usage help readme --- file, in Markdown format. The text is extracted from the metadata of --- the items. This is only used for development purposes, after the --- help text of any of the items was changed. - --- How to use: Temporarily set MAKE_README to true in init.lua, then --- start the game as admin and run “/make_schemedit_readme”. Copy the --- generated file back to the mod directory (USAGE.md). - --- Everything here is intentionally NOT translated because it is for text --- files only. - - --- Extract text from item definition -local get_text = function(item, field) - local text = minetest.registered_items[item][field] - - -- Remove translation escapes - text = string.gsub(text, "\x1BE", "") - text = string.gsub(text, "\x1B%(T@schemedit%)", "") - - -- Fix Markdown syntax error - text = string.gsub(text, "schematic_override", "`schematic_override`") - return text -end - - --- Schemedit items to generate the readme from -local items = { "creator", "probtool", "void" } - -minetest.register_chatcommand("make_schemedit_readme", { - description = "Generate the schemedit usage help readme file", - privs = {server=true}, - func = function(name, param) - - local readme = "## Usage help".."\n" - readme = readme .. "In this section you'll learn how to use the items of this mod.".."\n" - readme = readme .. "Note: If you have the `doc` and `doc_items` mods installed, you can also access the same help texts in-game (possibly translated).".."\n\n" - - local entries = {} - for i=1, #items do - local item = items[i] - local desc = get_text("schemedit:"..item, "description") - local longdesc = get_text("schemedit:"..item, "_doc_items_longdesc") - local usagehelp = get_text("schemedit:"..item, "_doc_items_usagehelp") - - readme = readme .. "### "..desc.."\n" - readme = readme .. longdesc .."\n\n" - readme = readme .. "#### Usage\n" - readme = readme .. usagehelp - if i < #items then - readme = readme .. "\n\n\n" - end - end - - local path = minetest.get_worldpath().."/schemedit_readme.md" - local file = io.open(path, "w") - if not file then - return false, "Failed to open file!" - end - local ok = file:write(readme) - file:close() - if ok then - return true, "File written to: "..path - else - return false, "Failed to write file!" - end - end -}) diff --git a/mods/schemedit/mod.conf b/mods/schemedit/mod.conf deleted file mode 100644 index 44eeba9..0000000 --- a/mods/schemedit/mod.conf +++ /dev/null @@ -1,5 +0,0 @@ -name = schemedit -title = Schematic Editor -optional_depends = doc -description = Advanced tool for modders and advanced users to create and edit schematics. -min_minetest_version = 5.0 diff --git a/mods/schemedit/screenshot.png b/mods/schemedit/screenshot.png deleted file mode 100644 index 86433d1f0a00419fd7b654a607cced2d10b32b8e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 49064 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 wDx}HZgPtr3n>N2a!*%3mvv4FO#sk47eD|2 diff --git a/mods/schemedit/textures/schemedit_border_checkers.png b/mods/schemedit/textures/schemedit_border_checkers.png deleted file mode 100644 index a1818178fc20ca0977cca343df944138c1bda42c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 90 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`ik>cxAr_~T6M&#%{+vJab7m=> mH86P96e!-aD?wlf1H(t7D1q7gRlWihGkCiCxvXz-I{8A@f^dzC+RHNMM={Ra!W&SZ(;)%W!{F)a=d#Wzp$Py3BN;OQ diff --git a/mods/schemedit/textures/schemedit_creator_bottom.png b/mods/schemedit/textures/schemedit_creator_bottom.png deleted file mode 100644 index f0dc0a681f755a25a5a9f386a283be3e42743b33..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 123 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61SBU+%rFB|PM$7~Ar*|t7nqyBpFHWnlKwzY zC6;-DtB_JG^QO0q77SwQf>#*aBTOEMI$CsYVC(RjWIExE$|4)zq79eKmu1e6Vzexb V5GcMD#|$)$!PC{xWt~$(697;UBQF2| diff --git a/mods/schemedit/textures/schemedit_creator_sides.png b/mods/schemedit/textures/schemedit_creator_sides.png deleted file mode 100644 index 6d3c6e4b9b940450a1039130e04f6c054e055645..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 89 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61SBU+%rFB|3Z5>GAr*|t7nB7jtbSNqWaQ|= l%Ui&wZRgQu&X%Q~loCIAm06a)YO diff --git a/mods/schemedit/textures/schemedit_creator_top.png b/mods/schemedit/textures/schemedit_creator_top.png deleted file mode 100644 index 5c26991a5d9f885170dd902613dee23fbd391175..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 128 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61SBU+%rFB|?w&4=Ar*|t7nB7PE`G4HlbkGbeX!mT!)ZvBXjRplYfH#_?c a7#RM_pG_`Za`P9^NCr<=KbLh*2~7Z)Y$&Aw diff --git a/mods/schemedit/textures/schemedit_probtool.png b/mods/schemedit/textures/schemedit_probtool.png deleted file mode 100644 index cdd6b2a426c6aa7846d6cfc14716d80fa28e7ed8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 159 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!93?!50ihlx9oB=)|u0Z;Ia&kaGfS!!`cOZwc zB*-tA!Qt7BG$6;t)5S5Qf>HN)BkKVNp09)qW=pUXO@geCyc C6ff2Q diff --git a/mods/schemedit/textures/schemedit_void.png b/mods/schemedit/textures/schemedit_void.png deleted file mode 100644 index 9ae57f9cbbe1b566fd9ff3b66c661f0b3c127f66..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 116 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61SBU+%rFB|Y$ZW{!9W@a@|Lkr1X7xwE{-7; zjL8yt3JmNAmN#xtSa#?4lN1Z3FymB*>;QFw9-4xA!)0cNs{tr>mdK II;Vst0D?UpC;$Ke