mirror of
https://github.com/sbrl/Minetest-WorldEditAdditions.git
synced 2024-11-21 23:13:00 +00:00
Merge branch 'main' into vortechnix
This commit is contained in:
commit
90b456a687
8 changed files with 250 additions and 5 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -1,4 +1,5 @@
|
||||||
_site/
|
_site/
|
||||||
|
.luarocks/
|
||||||
|
|
||||||
# Created by https://www.toptal.com/developers/gitignore/api/git
|
# Created by https://www.toptal.com/developers/gitignore/api/git
|
||||||
# Edit at https://www.toptal.com/developers/gitignore?templates=git
|
# Edit at https://www.toptal.com/developers/gitignore?templates=git
|
||||||
|
|
40
.tests/strings/str_padend.test.lua
Normal file
40
.tests/strings/str_padend.test.lua
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
local polyfill = require("worldeditadditions.utils.strings.polyfill")
|
||||||
|
|
||||||
|
describe("str_padend", function()
|
||||||
|
it("should pad a string", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_padend("test", 5, " "),
|
||||||
|
"test "
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should pad a different string", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_padend("yay", 4, " "),
|
||||||
|
"yay "
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should pad a string with multiple characters", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_padend("test", 10, " "),
|
||||||
|
"test "
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should not pad a long string", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_padend("testtest", 5, " "),
|
||||||
|
"testtest"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should pad with other characters", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_padend("1", 2, "0"),
|
||||||
|
"10"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should pad with multiple other characters", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_padend("1", 5, "0"),
|
||||||
|
"10000"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
end)
|
40
.tests/strings/str_padstart.test.lua
Normal file
40
.tests/strings/str_padstart.test.lua
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
local polyfill = require("worldeditadditions.utils.strings.polyfill")
|
||||||
|
|
||||||
|
describe("str_padstart", function()
|
||||||
|
it("should pad a string", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_padstart("test", 5, " "),
|
||||||
|
" test"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should pad a different string", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_padstart("yay", 4, " "),
|
||||||
|
" yay"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should pad a string with multiple characters", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_padstart("test", 10, " "),
|
||||||
|
" test"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should not pad a long string", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_padstart("testtest", 5, " "),
|
||||||
|
"testtest"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should pad with other characters", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_padstart("1", 2, "0"),
|
||||||
|
"01"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should pad with multiple other characters", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_padstart("1", 5, "0"),
|
||||||
|
"00001"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
end)
|
40
.tests/strings/str_starts.test.lua
Normal file
40
.tests/strings/str_starts.test.lua
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
local polyfill = require("worldeditadditions.utils.strings.polyfill")
|
||||||
|
|
||||||
|
describe("str_starts", function()
|
||||||
|
it("should return true for a single character", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_starts("test", "t"),
|
||||||
|
true
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should return true for a multiple characters", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_starts("test", "te"),
|
||||||
|
true
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should return true for identical strings", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_starts("test", "test"),
|
||||||
|
true
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should return false for a single character ", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_starts("test", "y"),
|
||||||
|
false
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should return false for a character present elsewherer", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_starts("test", "e"),
|
||||||
|
false
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("should return false for another substring", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.str_starts("test", "est"),
|
||||||
|
false
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
end)
|
46
.tests/strings/trim.test.lua
Normal file
46
.tests/strings/trim.test.lua
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
local polyfill = require("worldeditadditions.utils.strings.polyfill")
|
||||||
|
|
||||||
|
describe("trim", function()
|
||||||
|
it("work for a string that's already trimmed", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.trim("test"),
|
||||||
|
"test"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("trim from the start", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.trim(" test"),
|
||||||
|
"test"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("trim from the end", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.trim("test "),
|
||||||
|
"test"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("trim from both ends", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.trim(" test "),
|
||||||
|
"test"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("trim another string", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.trim("yay "),
|
||||||
|
"yay"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("trim tabs", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.trim("//forest "),
|
||||||
|
"//forest"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
it("avoid trimming spaces in the middle", function()
|
||||||
|
assert.are.equal(
|
||||||
|
polyfill.trim("te st "),
|
||||||
|
"te st"
|
||||||
|
)
|
||||||
|
end)
|
||||||
|
end)
|
|
@ -14,7 +14,7 @@ Note to self: See the bottom of this file for the release template text.
|
||||||
- Any `<chance>` can now either be a 1-in-N number (e.g. `4`, `10`), or a percentage chance (e.g. `50%`, `10%`).
|
- Any `<chance>` can now either be a 1-in-N number (e.g. `4`, `10`), or a percentage chance (e.g. `50%`, `10%`).
|
||||||
- Caveat: Percentages are converted to a 1-in-N chance, but additionally that number is rounded down in some places
|
- Caveat: Percentages are converted to a 1-in-N chance, but additionally that number is rounded down in some places
|
||||||
- `//torus`, `//hollowtorus`: Add optional new axes
|
- `//torus`, `//hollowtorus`: Add optional new axes
|
||||||
- `//torus`, `//ellipsoid`: Add optional hollow keyword
|
- `//torus`, `//ellipsoid`: Add optional hollow keyword - @VorTechnix
|
||||||
- `//multi`: Add curly brace syntax for nesting command calls ([more information](https://github.com/sbrl/Minetest-WorldEditAdditions/blob/main/Chat-Command-Reference.md#multi-command_a-command_b-command_c-))
|
- `//multi`: Add curly brace syntax for nesting command calls ([more information](https://github.com/sbrl/Minetest-WorldEditAdditions/blob/main/Chat-Command-Reference.md#multi-command_a-command_b-command_c-))
|
||||||
- `//erode`: Add new `river` erosion algorithm for filling in potholes and removing pillars
|
- `//erode`: Add new `river` erosion algorithm for filling in potholes and removing pillars
|
||||||
|
|
||||||
|
|
63
tests.sh
Executable file
63
tests.sh
Executable file
|
@ -0,0 +1,63 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
# Make sure the current directory is the location of this script to simplify matters
|
||||||
|
cd "$(dirname "$(readlink -f "$0")")" || { echo "Error: Failed to cd to script directory" >&2; exit 1; };
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
log_msg() {
|
||||||
|
echo "[ $SECONDS ] >>> $*" >&2;
|
||||||
|
}
|
||||||
|
|
||||||
|
# $1 - Command name to check for
|
||||||
|
check_command() {
|
||||||
|
set +e;
|
||||||
|
which $1 >/dev/null 2>&1; exit_code=$?
|
||||||
|
if [[ "${exit_code}" -ne 0 ]]; then
|
||||||
|
log_msg "Error: Couldn't locate $1. Make sure it's installed and in your path.";
|
||||||
|
fi
|
||||||
|
set -e;
|
||||||
|
}
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
check_command luarocks;
|
||||||
|
|
||||||
|
luarocks_root="${PWD}/.luarocks";
|
||||||
|
|
||||||
|
# Setup the lua module path
|
||||||
|
eval "$(luarocks --tree "${luarocks_root}" path)";
|
||||||
|
|
||||||
|
mode="${1}"; shift;
|
||||||
|
|
||||||
|
run_setup() {
|
||||||
|
log_msg "Installing busted";
|
||||||
|
|
||||||
|
luarocks --tree "${luarocks_root}" install busted;
|
||||||
|
}
|
||||||
|
|
||||||
|
run_test() {
|
||||||
|
.luarocks/bin/busted --no-auto-insulate --pattern ".test.lua" .tests;
|
||||||
|
}
|
||||||
|
|
||||||
|
case "${mode}" in
|
||||||
|
setup )
|
||||||
|
run_setup;
|
||||||
|
;;
|
||||||
|
|
||||||
|
run )
|
||||||
|
if [[ ! -d "${luarocks_root}" ]]; then
|
||||||
|
run_setup;
|
||||||
|
fi
|
||||||
|
run_test;
|
||||||
|
;;
|
||||||
|
|
||||||
|
busted )
|
||||||
|
.luarocks/bin/busted "${@}";
|
||||||
|
;;
|
||||||
|
|
||||||
|
* )
|
||||||
|
echo -e "Usage:
|
||||||
|
path/to/run.sh setup # Setup to run the tests
|
||||||
|
path/to/run.sh run # Run the tests" >&2;
|
||||||
|
;;
|
||||||
|
esac
|
|
@ -7,13 +7,13 @@ this?". If yes, then your implementation probably belongs here.
|
||||||
|
|
||||||
--- Pads str to length len with char from right
|
--- Pads str to length len with char from right
|
||||||
-- @source https://snipplr.com/view/13092/strlpad--pad-string-to-the-left
|
-- @source https://snipplr.com/view/13092/strlpad--pad-string-to-the-left
|
||||||
function worldeditadditions.str_padend(str, len, char)
|
local function str_padend(str, len, char)
|
||||||
if char == nil then char = ' ' end
|
if char == nil then char = ' ' end
|
||||||
return str .. string.rep(char, len - #str)
|
return str .. string.rep(char, len - #str)
|
||||||
end
|
end
|
||||||
--- Pads str to length len with char from left
|
--- Pads str to length len with char from left
|
||||||
-- Adapted from the above
|
-- Adapted from the above
|
||||||
function worldeditadditions.str_padstart(str, len, char)
|
local function str_padstart(str, len, char)
|
||||||
if char == nil then char = ' ' end
|
if char == nil then char = ' ' end
|
||||||
return string.rep(char, len - #str) .. str
|
return string.rep(char, len - #str) .. str
|
||||||
end
|
end
|
||||||
|
@ -22,7 +22,7 @@ end
|
||||||
-- @param str string The string to operate on
|
-- @param str string The string to operate on
|
||||||
-- @param start number The start string to look for
|
-- @param start number The start string to look for
|
||||||
-- @returns bool Whether start is present at the beginning of str
|
-- @returns bool Whether start is present at the beginning of str
|
||||||
function worldeditadditions.str_starts(str, start)
|
local function str_starts(str, start)
|
||||||
return string.sub(str, 1, string.len(start)) == start
|
return string.sub(str, 1, string.len(start)) == start
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -30,6 +30,21 @@ end
|
||||||
-- From http://lua-users.org/wiki/StringTrim
|
-- From http://lua-users.org/wiki/StringTrim
|
||||||
-- @param str string The string to trim the whitespace from.
|
-- @param str string The string to trim the whitespace from.
|
||||||
-- @returns string A copy of the original string with the whitespace trimmed.
|
-- @returns string A copy of the original string with the whitespace trimmed.
|
||||||
function worldeditadditions.trim(str)
|
local function trim(str)
|
||||||
return (str:gsub("^%s*(.-)%s*$", "%1"))
|
return (str:gsub("^%s*(.-)%s*$", "%1"))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
if worldeditadditions then
|
||||||
|
worldeditadditions.str_padend = str_padend
|
||||||
|
worldeditadditions.str_padstart = str_padstart
|
||||||
|
worldeditadditions.str_starts = str_starts
|
||||||
|
worldeditadditions.trim = trim
|
||||||
|
else
|
||||||
|
return {
|
||||||
|
str_padend = str_padend,
|
||||||
|
str_padstart = str_padstart,
|
||||||
|
str_starts = str_starts,
|
||||||
|
trim = trim
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
Loading…
Reference in a new issue