Модуль:Песочница/Pok: различия между версиями

Нет описания правки
мНет описания правки
Метка: отменено
(не показано 336 промежуточных версий этого же участника)
Строка 1: Строка 1:
local p = {}
local p = {}


function p.increment(frame)
local function trim(s)
     local content = mw.title.getCurrentTitle():getContent()
     if not s then return s end
     local currentCount = tonumber(content:match('<!--callCount:(%d+)-->')) or 0
    return (s:gsub('^%s*(.-)%s*$', '%1'))
     local newCount = currentCount + 1
end
     mw.title.getCurrentTitle():edit(content .. '\n<!--callCount:' .. newCount .. '-->')
 
     return "Количество вызовов: " .. newCount
local function strip_trailing_digits(s)
    return s:gsub('%d+$', '')
end
 
local function split_first_underscore(k)
     local a, b = k:match('^([^_]+)_(.+)$')
    return a, b
end
 
local function collect_labels_from_args(args)
    local meta = {}
    local seen = {}
    for k, v in pairs(args) do
        if type(k) == 'string' and k:find('_', 1, true) then
            local base, rem = split_first_underscore(k)
            if base and rem then
                local label = strip_trailing_digits(rem)
                label = trim(label)
                if label ~= '' then
                    meta[base] = meta[base] or {}
                    if not seen[base] then seen[base] = {} end
                    if not seen[base][label] then
                        table.insert(meta[base], label)
                        seen[base][label] = true
                    end
                end
            end
        end
     end
    return meta
end
 
local function render_from_args(args)
    local field = args[1] or args.field or args["field"]
     local label = args[2] or args.label or args["label"]
    field = field and trim(field) or ''
    label = label and trim(label) or ''
 
    -- map base -> label -> value
    local map = {}
    for k, v in pairs(args) do
        if type(k) == 'string' and k:find('_', 1, true) then
            local base, rem = split_first_underscore(k)
            if base and rem then
                local lab = strip_trailing_digits(rem)
                lab = trim(lab)
                map[base] = map[base] or {}
                local cur = map[base][lab]
                if cur then
                    map[base][lab] = cur .. '\n' .. tostring(v)
                else
                    map[base][lab] = tostring(v)
                end
            end
        end
    end
 
    if field ~= '' and label ~= '' then
        local base = map[field]
        if base then return base[label] or '' end
        return ''
    end
 
    if args[1] and args[2] then
        local f = trim(args[1]); local l = trim(args[2])
        local base = map[f]
        if base then return base[l] or '' end
    end
 
     return ''
end
 
function p.main(frame)
    local args = frame.args or {}
    local field = args[1]
 
    if field == "meta" then
        local meta = collect_labels_from_args(args)
        return mw.text.jsonEncode(meta)
    end
 
    return render_from_args(args)
end
end


return p
return p