Toggle menu
Toggle preferences menu
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

Module:HeaderIncrementer: Difference between revisions

From Teriock
Content deleted Content added
No edit summary
No edit summary
Line 1: Line 1:
local p = {}
local p = {}


-- Function to adjust headings with recursion control
function p.incrementHeadings(frame)
function p.incrementHeadings(frame)
-- Get the content and recursion depth
-- Get the content and recursion depth
Line 23: Line 24:
end)
end)


-- Return processed content directly
-- Add a marker to indicate processing is complete
return "{{H|content=" .. incrementedContent .. "|processed=yes}}"
return incrementedContent
end
end



Revision as of 02:57, 26 December 2024

Documentation for this module may be created at Module:HeaderIncrementer/doc

local p = {}

-- Function to adjust headings with recursion control
function p.incrementHeadings(frame)
    -- Get the content and recursion depth
    local content = frame.args.content or "No content provided."
    local depth = tonumber(frame.args.depth) or 1
    local maxDepth = 3 -- Set a reasonable recursion limit

    -- Check if recursion limit is reached
    if depth > maxDepth then
        return "Recursion limit reached."
    end

    -- Increment heading levels
    local incrementedContent = content:gsub("(=%s*)(.-)(%s*=)", function(leadingEquals, text, trailingEquals)
        local headingLevel = #leadingEquals -- Count the number of `=` signs
        if headingLevel < 6 then
            local newEquals = string.rep("=", headingLevel + 1)
            return newEquals .. text .. newEquals
        else
            return leadingEquals .. text .. trailingEquals
        end
    end)

    -- Return processed content directly
    return incrementedContent
end

return p