8,756
edits
mNo edit summary |
mNo edit summary |
||
(93 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
local p = {} | local p = {} | ||
local cargo = mw.ext.cargo | |||
local | |||
local | function p.a(seed) | ||
math.randomseed(tonumber(seed)) | |||
local count = cargo.query('Characters=C, GeneralData=GD', 'TRIM(COUNT(C._pageName))=Number', {join='C.ObjectID=GD.ObjectID', where='C._pageNamespace="0" AND (NOT GD.ParentObject WITHIN "Wall" AND NOT GD.PlainName LIKE "* door")'})[1]['Number'] | |||
local offsetin = math.random(0 , tonumber(count)-2) | |||
local tables = 'Characters=C, GeneralData=GD' | |||
local fields = 'GD.PlainName=Name, GD._pageName=Page' | |||
local args ={join='C._pageName=GD._pageName', where='GD._pageNamespace="0" AND (NOT GD.ParentObject WITHIN "Wall" AND NOT GD.PlainName LIKE "* door")', offset=offsetin,limit = 1} | |||
local result = cargo.query(tables, fields, args) | |||
if not next(result) then | |||
error('?????') | |||
end | |||
return '[[' .. result[1]['Page'] .. '|'.. result[1]['Name'] .. ']]' | |||
end | |||
return p. | function p.getRandomChara(frame) | ||
return p.a(frame.args.seed) | |||
end | end | ||
function p.test( | function p.test(seed) | ||
return p.a(tostring(seed)) | |||
end | end | ||
return p | return p |