モジュール:サンドボックス/MysteryPedia/test
モジュールの解説[作成]
-- Settings
local HOUR_INTERVALS = 1 -- 3
local NUMBER_OF_WANTEDPAGES_SEGMENTS = 2 -- NOTE: excepting the 'basic' page
--
local function requireAny(...)
for i, fullName in ipairs({...}) do
local succeeded, instance = pcall(require, fullName)
if succeeded then
return instance
end
end
error(table.concat({...}, ", ") .. " not found.")
end
local export = {}
local util = requireAny("Module:Utility", "Module:サンドボックス/MysteryPedia/Utility")
function export.order(frame)
local orderNumber = frame.args[1] or error("Arguments need at least one.")
local hours = math.floor(os.time() / 3600)
local timeslot = math.floor(hours / HOUR_INTERVALS)
local index = timeslot % NUMBER_OF_WANTEDPAGES_SEGMENTS + 1
local restricted = (timeslot % 2 == 0)
local moduleName = util.getModuleName()
local basic = mw.loadData(moduleName .. "/data/wanted pages/basic")
local array = mw.loadData(moduleName .. "/data/wanted pages/" .. index)
-- NOTE: objects generated by mw.loadData do not support the # operator.
local max1 = util.size(basic)
local max2 = util.size(array)
mw.logObject({ hours = hours, timeslot = timeslot, index = index, ["max basic"] = max1, ["max page" .. index] = max2 })
-- This function must return a random word, which is the same value until the time-slot has changed.
for i = 1, math.huge, 1 do
local n = math.floor(timeslot * i * math.exp(orderNumber) % (max1 * 2 + max2 + 1))
local word = basic[n] or basic[n - max1] or array[n - (max1 * 2)]
if not word then
break
end
-- PENDING:
-- In this time-slot, hiragana and kanji are highly recommended.
--[[
if restricted then
-- I know this is a rude way. I don't want exactness this time.
if not mw.ustring.match(word, "^[一-龠ぁ-ゞ]+$") then
word = nil
end
end
--]]
if word then
local succeeded, t = pcall(mw.title.new, word)
if succeeded and not t.exists then
return "[[:" .. word .. "]]"
end
end
end
return '<span style="color: gray;">(nothing)</span>'
end
function export.show_codepoint(frame)
local d = mw.ustring.codepoint(frame.args[1])
return frame:expandTemplate({
title = "unicode code",
args = {
["16進"] = mw.ustring.format("%X", d),
["10進"] = d,
}})
end
local function xxchar(lang, frame)
local parameters = frame.args
local sequence
-- NOTE: frame.args does not support the # operator.
if parameters[1] then
if not parameters[2] and mw.ustring.len(parameters[1]) > 1 then -- maybe {{PAGENAME}} passed
sequence = mw.text.split(parameters[1], '')
else -- conventional use
sequence = parameters
end
else
error("Arguments need at least one.")
return ''
end
local validator = requireAny("Module:User:CodeCat/isValidPageName", "Module:IsValidPageName")
local buffer = {"{{lang|" .. lang .. "|" .. "'''"}
for i, c in ipairs(sequence) do
if i > 1 then
table.insert(buffer, ' ')
end
if validator.isValidPageName(frame:newChild({ args = {c} })) ~= '' then
table.insert(buffer, "[[:" .. c .. "#{{" .. lang .. "}}|")
local label = parameters['l' .. i]
if label then
table.insert(buffer, label)
else
table.insert(buffer, c)
end
table.insert(buffer, "]]")
else
table.insert(buffer, c)
end
end
table.insert(buffer, "'''" .. "}}")
return frame:preprocess(table.concat(buffer))
end
-- If you called {{#invoke:}} - the Frame object has arguments passed.
-- You can pass arguments via a template. In this case the parent Frame object has arguments passed. See [[wikt:en:Template:categorize]].
local function getInvoker(frame)
if frame.args[1] and not frame.args['auto'] then
return frame
else
return frame:getParent()
end
end
function export.xxchars(frame)
local lang = frame.args[1] or error("Arguments need at least one.")
local title = frame.args[2] or mw.title.getCurrentTitle().text
return xxchar(lang, frame:newChild({ args = {title} }))
end
-- @deprecated
function export.jachar(frame)
return xxchar("ja", getInvoker(frame))
end
function export.auto_categorize(frame)
local sortKey = frame.args[1]
local title = mw.title.getCurrentTitle().fullText
local data = mw.loadData(util.getModuleName() .. "/data/categories")
return util.categorizeFromData(data, title, sortKey)
end
function export.kanji_variants(frame)
local a = frame.args
local buffer = {"* [[異体字]] : "}
for k, v in pairs(frame:getParent().args) do
if #buffer > 1 then
table.insert(buffer, a["delimiter"])
end
if type(k) == "number" then
table.insert(buffer, mw.ustring.format(a["glyph"], "[[" .. v .. "]]"))
else
table.insert(buffer, mw.ustring.format(a["glyph"], "[[" .. k .. "]]"))
local s = v
if v ~= "異体字" then
s = "[[" .. v .. "]]"
end
table.insert(buffer, mw.ustring.format(a["classification"], s))
end
end
return frame:preprocess(table.concat(buffer))
end
function export.defaultsort(frame) -- {{defsort}} or something
error("Not Implemented")
end
local console = util.import(util.getModuleName("Console"))
do
if console then
console.attach(export)
console.define({
['data'] =
function(index)
return mw.loadData(util.getModuleName() .. "/data/wanted pages/" .. (index or "basic"))
end,
})
end
end
return export