mirror of
https://github.com/sbrl/Minetest-WorldEditAdditions.git
synced 2024-12-22 03:35:01 +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/
|
||||
.luarocks/
|
||||
|
||||
# Created by https://www.toptal.com/developers/gitignore/api/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%`).
|
||||
- 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`, `//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-))
|
||||
- `//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
|
||||
-- @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
|
||||
return str .. string.rep(char, len - #str)
|
||||
end
|
||||
--- Pads str to length len with char from left
|
||||
-- Adapted from the above
|
||||
function worldeditadditions.str_padstart(str, len, char)
|
||||
local function str_padstart(str, len, char)
|
||||
if char == nil then char = ' ' end
|
||||
return string.rep(char, len - #str) .. str
|
||||
end
|
||||
|
@ -22,7 +22,7 @@ end
|
|||
-- @param str string The string to operate on
|
||||
-- @param start number The start string to look for
|
||||
-- @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
|
||||
end
|
||||
|
||||
|
@ -30,6 +30,21 @@ end
|
|||
-- From http://lua-users.org/wiki/StringTrim
|
||||
-- @param str string The string to trim the whitespace from.
|
||||
-- @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"))
|
||||
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