跳到内容
折叠侧栏
搜索
创建账号
个人工具
创建账号
登录
导航
首页
最近更改
随机页面
编者用页面
方针
指引
讨论版
格式手册
挂起清单
维护清单
玩法条目
游戏玩法
界面
机制
搭档
潜力值
Link Play
世界模式
故事模式
段位挑战
解歌系统
成就系统
版本更新日志
列表条目
定数表
曲目列表
曲包列表
曲师列表
谱师列表
画师列表
背景列表
友情链接
Rotaeno中文维基
工具
链入页面
相关更改
特殊页面
页面信息
查看“Module:DesignerSong”的源代码
模块
讨论
English
阅读
查看源代码
查看历史
更多
阅读
查看源代码
查看历史
←
Module:DesignerSong
因为以下原因,您没有权限编辑本页:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
p={} local DL = mw.loadJsonData 'User:Economy666/DesignersList.json' local multiId = mw.loadJsonData 'Template:Transition.json'.multiId local trans = mw.loadJsonData 'Template:Transition.json' local mad = require 'Module:AnotherData' local data = require "Module:Arcaea Data" local CL = require 'Module:ConvertLink' local CDL = DL.complex local SDL = DL.simple local specialSong = DL.special local queryMO = data.allSongInformation("id", "mobile") local queryNS = data.allSongInformation("id", "ns") local function readList() local pickList = {} local specialDesigner ={} local mobileList = {} local diffList = {'PST', 'PRS', 'FTR', 'BYD', 'ETR'} for _, song in ipairs(mad.listOf('songs', 'mobile')) do for _,level in ipairs(song.difficulties) do local designer = level.chartDesigner local diff = level.ratingClass if not pickList[designer] then pickList[designer] = {} end if not pickList[designer][song.id] then pickList[designer][song.id] = {} end pickList[designer][song.id][diffList[diff+1]]=true mobileList[song.id]=true if specialSong[song.id] then specialDesigner[designer]=true end end end for _, song in ipairs(mad.listOf('songs', 'ns')) do if not mobileList[song.id] and not multiId[song.id] then for _,level in ipairs(song.difficulties) do local designer = level.chartDesigner local diff = level.ratingClass if not pickList[designer] then pickList[designer] = {} end if not pickList[designer][song.id] then pickList[designer][song.id] = {} end pickList[designer][song.id][diffList[diff+1]]=true if specialSong[song.id] then specialDesigner[designer]=true end end end end return pickList ,specialDesigner end local function genList(pickList ,specialDesigner) local function cate(singleList, cArtist, artist) local artist = artist or cArtist if not singleList[artist] then singleList[artist] = {} end for id,diff in pairs(pickList[cArtist]) do singleList[artist][id] = diff end return singleList end local function otherDesigner(count) if 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 singleList = {} for cDesigner,songids in pairs(pickList) do local designerList={} if CDL[cDesigner] then if CDL[cDesigner].__FullData__ then for _,text in pairs(CDL[cDesigner].__FullData__) do if text.link then local designer = text['link'] if not designerList[designer] then singleList = cate(singleList, cDesigner, designer) designerList[designer]=true end end end else for link in pairs(CDL[cDesigner]) do local designer = link if not designerList[designer] then singleList = cate(singleList, cDesigner, designer) designerList[designer]=true end end end else local temp_text = cDesigner local count = 0 for _,data in ipairs(SDL) do local designer = data.link local dis = data.display if string.find(temp_text, dis) then singleList = cate(singleList, cDesigner, designer) designerList[designer]=true temp_text = string.gsub(temp_text, dis, '') count = count + 1 end end if count == 0 then if specialDesigner[cDesigner] then singleList = cate(singleList, cDesigner, '与主线剧情相关的特殊名义') else singleList = cate(singleList, cDesigner, '其他未确认谱师名义') end end end end return singleList end -- Helper function to remove circular references local function removeCircularReferences(tbl, seen) seen = seen or {} if seen[tbl] then return end seen[tbl] = true for k, v in pairs(tbl) do if type(v) == "table" then if seen[v] then tbl[k] = nil -- Remove the circular reference else removeCircularReferences(v, seen) end end end end -- Your main function -- function p.main() -- readList() -- local singleList = genList() -- -- Remove circular references before encoding to JSON -- removeCircularReferences(singleList) -- return mw.text.jsonEncode(singleList) -- end function p.main() pickList ,specialDesigner = readList() singleList = genList(pickList ,specialDesigner) return unpack(singleList) end return p
本页使用的模板:
Module:DesignerSong/doc
(
查看源代码
)
返回
Module:DesignerSong
。