Module:ArrayList: Difference between revisions
Appearance
Content deleted Content added
add main function |
delimiter fixes |
||
Line 4: | Line 4: | ||
local function trim(s) |
local function trim(s) |
||
return s:match("^%s*(.-)%s*$") |
return s:match("^%s*(.-)%s*$") |
||
end |
|||
-- Escape special characters in the delimiter for pattern matching |
|||
local function escapePattern(str) |
|||
return str:gsub("([%^%$%(%)%%%.%[%]%*%+%?%-])", "%%%1") |
|||
end |
end |
||
Line 20: | Line 25: | ||
local str = frame.args[2] or "" |
local str = frame.args[2] or "" |
||
local delimiter = frame.args[3] or "," |
local delimiter = frame.args[3] or "," |
||
delimiter = escapePattern(delimiter) |
|||
str = str:gsub("^%s*" .. delimiter .. "%s*(.-)%s*" .. delimiter .. "$", "%1") |
str = str:gsub("^%s*" .. delimiter .. "%s*(.-)%s*" .. delimiter .. "$", "%1") |
||
Line 31: | Line 37: | ||
local delimiter = frame.args[3] or "," |
local delimiter = frame.args[3] or "," |
||
local index = frame.args[4] |
local index = frame.args[4] |
||
delimiter = escapePattern(delimiter) |
|||
-- Remove leading and trailing delimiters and whitespace |
-- Remove leading and trailing delimiters and whitespace |
||
Line 60: | Line 67: | ||
local item = frame.args[4] or "" |
local item = frame.args[4] or "" |
||
local occurrence = tonumber(frame.args[5]) |
local occurrence = tonumber(frame.args[5]) |
||
delimiter = escapePattern(delimiter) |
|||
-- Remove leading and trailing delimiters and whitespace |
-- Remove leading and trailing delimiters and whitespace |
||
Line 69: | Line 77: | ||
-- Iterate over items split by the delimiter |
-- Iterate over items split by the delimiter |
||
for subitem in string.gmatch(str, "([^" .. delimiter .. "]+)") do |
for subitem in string.gmatch(str, "([^" .. delimiter .. "]+)") do |
||
subitem = trim(subitem) |
subitem = trim(subitem) |
||
if subitem == item then |
if subitem == item then |
||
table.insert(positions, index) |
table.insert(positions, index) |
||
Line 90: | Line 98: | ||
local delimiter = frame.args[3] or "," |
local delimiter = frame.args[3] or "," |
||
local operation = frame.args[4] |
local operation = frame.args[4] |
||
delimiter = escapePattern(delimiter) |
|||
-- Remove leading and trailing delimiters and whitespace |
-- Remove leading and trailing delimiters and whitespace |
Revision as of 13:52, 26 July 2024
local p = {}
-- Helper function to trim whitespace
local function trim(s)
return s:match("^%s*(.-)%s*$")
end
-- Escape special characters in the delimiter for pattern matching
local function escapePattern(str)
return str:gsub("([%^%$%(%)%%%.%[%]%*%+%?%-])", "%%%1")
end
-- Main function to call other functions dynamically
function p.main(frame)
local func = frame.args[1]
if p[func] then
return p[func](frame)
else
return "void:nofunction: " .. tostring(func)
end
end
-- Count occurrences of delimiter in a string
function p.count(frame)
local str = frame.args[2] or ""
local delimiter = frame.args[3] or ","
delimiter = escapePattern(delimiter)
str = str:gsub("^%s*" .. delimiter .. "%s*(.-)%s*" .. delimiter .. "$", "%1")
local count = select(2, str:gsub(delimiter, ""))
return count + 1
end
-- Get the Nth item in a delimited string, supporting negative indices
function p.get(frame)
local str = frame.args[2] or ""
local delimiter = frame.args[3] or ","
local index = frame.args[4]
delimiter = escapePattern(delimiter)
-- Remove leading and trailing delimiters and whitespace
str = str:gsub("^%s*" .. delimiter .. "%s*(.-)%s*" .. delimiter .. "$", "%1")
local items = {}
for item in string.gmatch(str, "([^" .. delimiter .. "]+)") do
table.insert(items, trim(item))
end
if index == "last" then
index = #items
elseif index and tonumber(index) then
index = tonumber(index)
if index < 0 then
index = #items + index + 1
end
else
return "void:invalid"
end
return items[index] or "void:outofrange"
end
-- Find the position of the Nth occurrence of a matching item in a delimited string
function p.pos(frame)
local str = frame.args[2] or ""
local delimiter = frame.args[3] or ","
local item = frame.args[4] or ""
local occurrence = tonumber(frame.args[5])
delimiter = escapePattern(delimiter)
-- Remove leading and trailing delimiters and whitespace
str = str:gsub("^%s*" .. delimiter .. "%s*(.-)%s*" .. delimiter .. "$", "%1")
local positions = {}
local index = 1
-- Iterate over items split by the delimiter
for subitem in string.gmatch(str, "([^" .. delimiter .. "]+)") do
subitem = trim(subitem)
if subitem == item then
table.insert(positions, index)
end
index = index + 1
end
if not occurrence then
-- Return positions joined by the delimiter, if positions are found
return #positions > 0 and table.concat(positions, delimiter) or "void:nomatch"
else
-- Return the specified occurrence or -1 if not found
return positions[occurrence] or -1
end
end
-- Perform mathematical operations on numeric array items
function p.math(frame)
local str = frame.args[2] or ""
local delimiter = frame.args[3] or ","
local operation = frame.args[4]
delimiter = escapePattern(delimiter)
-- Remove leading and trailing delimiters and whitespace
str = str:gsub("^%s*" .. delimiter .. "%s*(.-)%s*" .. delimiter .. "$", "%1")
local items = {}
for item in string.gmatch(str, "([^" .. delimiter .. "]+)") do
local number = tonumber(trim(item))
if number then
table.insert(items, number)
else
return "void:isalpha"
end
end
if #items == 0 then
return null
end
if operation == "sum" then
local total = 0
for _, num in ipairs(items) do
total = total + num
end
return total
elseif operation == "min" then
local min = items[1]
for _, num in ipairs(items) do
if num < min then
min = num
end
end
return min
elseif operation == "max" then
local max = items[1]
for _, num in ipairs(items) do
if num > max then
max = num
end
end
return max
else
return "void:unsupported"
end
end
return p