コンテンツにスキップ

英文维基 | 中文维基 | 日文维基 | 草榴社区

モジュール:Error

半永久的に保護されているモジュール

2021年5月5日 (水) 05:39; ネイ (会話 | 投稿記録) による版 (+TemplateStyles、phab:T280766による)(日時は個人設定で未設定ならUTC

(差分) ← 古い版 | 最新版 (差分) | 新しい版 → (差分)
モジュールの解説[表示] [編集] [履歴] [キャッシュを破棄]

このモジュールは"error"クラスのHTMLメッセージを作成します。{{error}}の置換として作成されたモジュールであり、詳しい使い方についてはそちらをご参照ください。

-- This module implements {{error}}.

local p = {}

local function _error(frame, args)
    local tag = mw.ustring.lower(tostring(args.tag))

    -- Work out what html tag we should use.
    if not (tag == 'p' or tag == 'span' or tag == 'div') then
        tag = 'strong'
    end
    
    -- Generate the html.
    local retval = frame:extensionTag{name = 'templatestyles', args = {src = 'Module:Error/styles.css'}}
    local errortag = mw.html.create(tag)
        :addClass('error')
        :wikitext(tostring(args.message or args[1] or error('エラーメッセージが指定されていません', 2)))
    retval = retval .. tostring(errortag)

    return retval
end

function p.error(frame)
    local args
    if type(frame.args) == 'table' then
        -- We're being called via #invoke. The args are passed through to the module
        -- from the template page, so use the args that were passed into the template.
        args = frame.args
    else
        -- We're being called from another module or from the debug console, so assume
        -- the args are passed in directly.
        args = frame
    end
    -- if the message parameter is present but blank, change it to nil so that Lua will
    -- consider it false.
    if args.message == "" then
        args.message = nil
    end
    return _error(frame, args)
end

return p