跳到内容
折叠侧栏
搜索
创建账号
个人工具
创建账号
登录
导航
首页
最近更改
随机页面
编者用页面
方针
指引
讨论版
格式手册
挂起清单
维护清单
玩法条目
游戏玩法
界面
机制
搭档
潜力值
Link Play
世界模式
故事模式
段位挑战
解歌系统
成就系统
版本更新日志
列表条目
定数表
曲目列表
曲包列表
曲师列表
谱师列表
画师列表
背景列表
友情链接
Rotaeno中文维基
工具
链入页面
相关更改
特殊页面
页面信息
查看“Module:ConvertLink”的源代码
模块
讨论
English
阅读
查看源代码
查看历史
更多
阅读
查看源代码
查看历史
←
Module:ConvertLink
因为以下原因,您没有权限编辑本页:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
local p = {} -- local mad = require 'Module:AnotherData' local memory = {} local function getMemory(enType, name) if memory[enType] then if memory[enType][name] then return memory[enType][name] end else memory[enType] = {} end end local function link(l, d) if d then return '[[' .. l .. '|' .. d .. ']]' else return '[[' .. l .. ']]' end end local function formatLangText(text) if not text then return text end return mw.ustring.gsub( text, '[一-龠ぁ-ゔァ-ヴー々〆〤ヶ]+', function(v) return ('<span lang="ja">-{%s}-</span>'):format(v) end ) end local function langLink(theType, __link, display, noForm) local dis = display or __link local disForm = noForm and dis or formatLangText(dis) return link(theType..'列表#' .. __link, disForm) end local function fullCL(theType, __FullData__) local artist = '' for _, data in ipairs(__FullData__) do local display_lang = data.zh and data.display or formatLangText(data.display) if data.link then artist = artist .. langLink(theType, data.link, display_lang, true) else artist = artist .. (display_lang or '') end end return artist end local function defaultCL(theType, text, artist_list) local temp_text = text local link_placeholders = {} local placeholder_count = 0 for theLink, display in pairs(artist_list) do if type(display) == 'string' then local link_text = langLink(theType, theLink, display) local placeholder = "__LINK_PLACEHOLDER_" .. placeholder_count .. "__" link_placeholders[placeholder] = link_text temp_text = string.gsub(temp_text, display, placeholder) placeholder_count = placeholder_count + 1 elseif type(display)=='table' then for _,dis in pairs(display) do local link_text = langLink(theType, theLink, dis) local placeholder = "__LINK_PLACEHOLDER_" .. placeholder_count .. "__" link_placeholders[placeholder] = link_text temp_text = string.gsub(temp_text, dis, placeholder) placeholder_count = placeholder_count + 1 end end end if placeholder_count == 0 then return text end local formatted_text = formatLangText(temp_text) for placeholder, link_text in pairs(link_placeholders) do formatted_text = string.gsub(formatted_text, placeholder, link_text) end return formatted_text end local CALv2 local function findArtist(artistName) CALv2 = CALv2 or mw.loadJsonData 'Template:ComplexArtistsList.json' local artist_list = CALv2[artistName] local theType = '曲师' if artist_list then if artist_list.__FullData__ then artist = fullCL(theType, artist_list.__FullData__) else artist = defaultCL(theType, artistName, artist_list) end else artist = langLink(theType, artistName) end return artist end function p.artistLink(artistName) -- 将songlist中纯文本形式的曲师名称转换为带一个或多个链接的曲师名称,同时进行日文转换 -- 输入:曲师名称(需要与songlist内完全一致,或仅存在空格差异)(不要手打!!) -- 返回:带链接的曲师名称 -- 若预期返回多个链接,实际返回一个链接;或曲师使用了马甲未能正确识别,请在 Template:ComplexArtistsList.json 添加新规则 -- 注意事项:json转义符,如曲师名称有 " 需要写成 \"(点名Gram(DJ Genki)); -- lua匹配转义符,CALv2使用匹配简化结构,注意默认格式下value即显示部分(冒号右侧) . * 等符号需要在之前添加%转义 if artistName then artistName=tostring(artistName) else return end local artist = getMemory('artist', artistName) if artist then return artist end artist = findArtist(artistName) memory.artist[artistName] = artist return artist end local DL local function findDesigner(designerName, songid) DL = DL or mw.loadJsonData 'Template:DesignersList.json' local CDL = DL.complex local SDL = DL.simple local theType = '谱师' local function defaultSDL(text) local temp_text = text local link_placeholders = {} local placeholder_count = 0 for _,data in ipairs(SDL) do local dis = data.display local name = data.link if string.find(temp_text, dis) then local link_text = langLink(theType, name, dis) local placeholder = "__LINK_PLACEHOLDER_" .. placeholder_count .. "__" link_placeholders[placeholder] = link_text temp_text = string.gsub(temp_text, dis, placeholder) placeholder_count = placeholder_count + 1 end end if placeholder_count == 0 then return text end local formatted_text = formatLangText(temp_text) for placeholder, link_text in pairs(link_placeholders) do formatted_text = string.gsub(formatted_text, placeholder, link_text) end return formatted_text end local designer local theType = '谱师' local designer_list = CDL[designerName] if designer_list then if designer_list.__FullData__ then designer = fullCL(theType, designer_list.__FullData__) else designer = defaultCL(theType, designerName, designer_list) end else designer = defaultSDL(designerName) end if designer ~= designerName then return designer end designerName = designerName==''and ' ' or designerName if songid then if DL.special[songid] then return langLink(theType,'与主线剧情相关的特殊名义', designerName) end end return langLink(theType, '其他未确认谱师名义', designerName) end function p.designerLink(designerName, songid) -- songid参数可选,用于最终区分"其他未确认谱师名义"与"与主线剧情相关的特殊名义" -- 不填默认归为"其他未确认谱师名义" if designerName then designerName=tostring(designerName) else return end local designer = getMemory('designer', designerName) if designer then return designer end local designer = findDesigner(designerName, songid) memory.designer[designerName] = designer return designer end function p.packLink(packName, short, ns) -- 曲包名称转换成链接 -- short -- true 简短(x Collaboration y) -- false 完整(x Collaboration - Collaboration y) -- ns 适用于Arcaea和Memory Archive曲包 -- true NS版曲包 -- false 移动版曲包 if packName then packName=tostring(packName) else return end local class = 'pack_'..(ns and 'ns' or 'mobile')..(short and '_short' or '') local pack = getMemory(class, packName) if pack then return pack end local discrete_pack = {['Arcaea']='曲包', ['Memory Archive']=''} -- 分离双平台页的曲包,value为后缀附加内容: '曲包'->' (xx版曲包)' ; ''->' (xx版)' local cc = 'Collaboration %- Collaboration' local ccl = 'Collaboration#Collaboration' local linkFlag = '' if discrete_pack[packName] then if ns then linkFlag = (' (NS版%s)'):format(discrete_pack[packName]) else linkFlag = (' (移动版%s)'):format(discrete_pack[packName]) end end local packLink = string.gsub(packName, cc, ccl) .. linkFlag local packDisplay if short then local ccd = 'Collaboration' packDisplay = string.gsub(packName, cc, ccd) else packDisplay = packName end local pack = link(packLink, packDisplay) memory[class][packName] = pack return pack end local lang, VT local function findVer(ver, date) lang = lang or mw.language.getContentLanguage() -- VT = VT or mw.loadJsonData 'Template:VersionTime.json' VT = VT or mw.text.jsonDecode(mw.title.new('Template:VersionTime.json'):getContent()) local ymd = tonumber(lang:formatDate('ymd', '@' .. date)) - 1 local vt if VT[ver] then vt=VT[ver] else return ver, ymd end local dates = vt.time local version = vt.ver if #dates ~= #version then return ver,ymd end local l, r = 1, #dates while l < r do local m = math.floor((l + r) / 2) if dates[m] < ymd then l = m + 1 else r = m end end return ver.. '.' ..version[l], dates[l] end local function dateConvert(date) if not date then return nil end local dateStr = tostring(date) local yy = string.sub(dateStr,1,2) local mm = string.sub(dateStr,3,4) local dd = string.sub(dateStr,5,6) return '20'..string.format("%02d/%02d/%02d", yy, mm, dd % 100) end function p.fullVersionNum(ver, date) local verClass = math.floor(date/100) local verData = getMemory('ver', verClass) if verData then return verData[1], verData[2], 'Memory' end verData={} verData[1], verData[2] = findVer(ver, date) verData[2] = dateConvert(verData[2]) memory.ver[verClass] = verData return verData[1], verData[2] end return p
本页使用的模板:
Module:ConvertLink/doc
(
查看源代码
)
返回
Module:ConvertLink
。