Модуль:Сущность/поля: различия между версиями

Материал из Space Station 14 Вики
Новая страница: «local p = {} local getArgs = require('Module:Arguments').getArgs local function trim(s) if not s then return s end return (s:gsub('^%s*(.-)%s*$', '%1')) end 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) d...»
 
Нет описания правки
 
(не показано 17 промежуточных версий этого же участника)
Строка 12: Строка 12:


local function split_first_underscore(k)
local function split_first_underscore(k)
     local a, b = k:match('^([^_]+)_(.+)$')
     local pos = k:find('_', 1, true)
     return a, b
    if not pos or pos == 1 or pos == #k then
        return nil, nil
    end
     return k:sub(1, pos - 1), k:sub(pos + 1)
end
end


local function collect_labels_from_args(args)
local function each_compound_arg(args, fn)
    local meta = {}
    local seen = {}
     for k, v in pairs(args) do
     for k, v in pairs(args) do
         if type(k) == 'string' and k:find('_', 1, true) then
         if type(k) == 'string' and k:find('_', 1, true) then
             local base, rem = split_first_underscore(k)
             local base, rem = split_first_underscore(k)
             if base and rem then
             if base and rem then
                 local label = strip_trailing_digits(rem)
                 fn(base, rem, v)
                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
         end
     end
     end
    return meta
end
end


local function render_from_args(args)
local function collect_labels_from_args(args)
     local field = args[1] or args.field or args["field"]
     local meta = {}
    local label = args[2] or args.label or args["label"]
    local seen = {}
    field = field and trim(field) or ''
 
    label = label and trim(label) or ''
    each_compound_arg(args, function(base, rem)
        local label = trim(strip_trailing_digits(rem))
        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)


    -- map base -> label -> value
    local map = {}
     for k, v in pairs(args) do
     for k, v in pairs(args) do
         if type(k) == 'string' and k:find('_', 1, true) then
         if type(k) == 'string' and not k:find('_', 1, true) then
             local base, rem = split_first_underscore(k)
             meta[k] = tostring(v)
            if base and rem then
        end
                local lab = strip_trailing_digits(rem)
    end
                lab = trim(lab)
 
                map[base] = map[base] or {}
    return meta
                local cur = map[base][lab]
end
                if cur then
 
                    map[base][lab] = cur .. '\n' .. tostring(v)
local function get_raw_arg(sources, key)
                else
    for _, source in ipairs(sources) do
                    map[base][lab] = tostring(v)
        if source and source[key] ~= nil then
                end
            return source[key]
            end
         end
         end
     end
     end
    return nil
end
local function render_from_frame(frame)
    local parent = frame:getParent()
    local sources = { frame.args, parent and parent.args }
    local field = get_raw_arg(sources, 1)
    local label = get_raw_arg(sources, 2)
    field = field and trim(field) or ''
    label = label and trim(label) or ''


     if field ~= '' and label ~= '' then
     if field ~= '' and label ~= '' then
         local base = map[field]
         local value = get_raw_arg(sources, field .. '_' .. label)
         if base then return base[label] or '' end
         if value ~= nil then
         return ''
            return tostring(value)
         end
     end
     end


     if args[1] and args[2] then
     if field ~= '' then
         local f = trim(args[1]); local l = trim(args[2])
         local value = get_raw_arg(sources, field)
         local base = map[f]
        if value ~= nil then
        if base then return base[l] or '' end
            return trim(tostring(value))
         end
     end
     end


Строка 80: Строка 90:


function p.main(frame)
function p.main(frame)
     local args = getArgs(frame, {removeBlanks = false})
     local parent = frame:getParent()
     local field = args[1]
     local field = get_raw_arg({ frame.args, parent and parent.args }, 1)


     if field == "json" then
     if field == "json" then
        local args = getArgs(frame, { removeBlanks = false })
         local json = collect_labels_from_args(args)
         local json = collect_labels_from_args(args)
         return mw.text.jsonEncode(json)
         return mw.text.jsonEncode(json)
     end
     end


     return render_from_args(args)
     return render_from_frame(frame)
end
end


return p
return p

Текущая версия от 18:38, 17 июня 2026

Для документации этого модуля может быть создана страница Модуль:Сущность/поля/doc

local p = {}
local getArgs = require('Module:Arguments').getArgs

local function trim(s)
    if not s then return s end
    return (s:gsub('^%s*(.-)%s*$', '%1'))
end

local function strip_trailing_digits(s)
    return s:gsub('%d+$', '')
end

local function split_first_underscore(k)
    local pos = k:find('_', 1, true)
    if not pos or pos == 1 or pos == #k then
        return nil, nil
    end
    return k:sub(1, pos - 1), k:sub(pos + 1)
end

local function each_compound_arg(args, fn)
    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
                fn(base, rem, v)
            end
        end
    end
end

local function collect_labels_from_args(args)
    local meta = {}
    local seen = {}

    each_compound_arg(args, function(base, rem)
        local label = trim(strip_trailing_digits(rem))
        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)

    for k, v in pairs(args) do
        if type(k) == 'string' and not k:find('_', 1, true) then
            meta[k] = tostring(v)
        end
    end

    return meta
end

local function get_raw_arg(sources, key)
    for _, source in ipairs(sources) do
        if source and source[key] ~= nil then
            return source[key]
        end
    end
    return nil
end

local function render_from_frame(frame)
    local parent = frame:getParent()
    local sources = { frame.args, parent and parent.args }
    local field = get_raw_arg(sources, 1)
    local label = get_raw_arg(sources, 2)
    field = field and trim(field) or ''
    label = label and trim(label) or ''

    if field ~= '' and label ~= '' then
        local value = get_raw_arg(sources, field .. '_' .. label)
        if value ~= nil then
            return tostring(value)
        end
    end

    if field ~= '' then
        local value = get_raw_arg(sources, field)
        if value ~= nil then
            return trim(tostring(value))
        end
    end

    return ''
end

function p.main(frame)
    local parent = frame:getParent()
    local field = get_raw_arg({ frame.args, parent and parent.args }, 1)

    if field == "json" then
        local args = getArgs(frame, { removeBlanks = false })
        local json = collect_labels_from_args(args)
        return mw.text.jsonEncode(json)
    end

    return render_from_frame(frame)
end

return p