Модуль:Hani-sortkey
Бул модуль текстти Хан скриптинде сорттоо үчүн колдонулат. Ал Ай-Чам, Түштүк Амами Ошима, Борбордук Бай, Пани Бай, Түштүк Бай, Бяо-Цзяо Миен, Био, Чыгыш Мин, Жин, Мандарин, Түндүк Пинхуа, Кытай. Пиджин Англисче, Пуксиан Мин, Макао Пиджин португалча, Түштүк Пинхуа, Хуйчжоу, Борбордук Мин, Дунган, Даур, Е, Ган, Хакка, Йемаек, Сян, Жапон, Хачижо, Кикай, Лама Бай, Орто Кытай, Адабий кытай, Цзе, Роуран , Туйухун, Туоба, Вухуань, Сианбей, Орто Вьетнам, Каолань, Түндүк Мин, Транслингвал, Мияко, Мин Нан, Датиан Мин, Хоккиен, Хайлуфэн Мин, Хайнанец, Лонгян Мин, Лейчжоу Мин, Теочев, Женан Мин, Саньшян Мин, Нюн, Эски кытай, эски япон, окиноерабу, эски уйгур, буэй, баекдже, түндүк Амами ошима, йэйама, окинаван, суи, байланг, токуношима, алчука, бала, кьякала, тай, вьетнам, ву, ваксианг, классикалык тибет, орто монгол, буйео. Аны шаблондон колдонуу үчүн, {{sortkey}} модулун колдонуңуз, Module:languages#Language:makeSortKey.
Сыноо иштери үчүн Module:Hani-sortkey/testcases караңыз.
Төмөндө көрсөтүлгөн мазмунду түзгөн демонстрация функциялары Module:Hani-sortkey/templates ичинде жайгашкан. Модулга өзгөртүүлөр Module:Hani-sortkey/sandbox ичинде сыналышы мүмкүн. Жеке символдор үчүн сорттоо баскычтары 178 маалымат модулунун биринен алынган. Module:Hani-sortkey/data бул модулдар үчүн документтерди түзөт.
Сорт баскычтарын көрсөтүү
түзөтүү- {{PS/2接口}} (
PS2手08口00
) - {{gas爐/gas炉}} (
gas火16
) - {{γ粒子}} (
γ米05子00
) - {{命裡有時終須有,命裡無時莫強求/命里有时终须有,命里无时莫强求}} (
口05衣07月02日06糸05頁03月02口05衣07火08日06艸07弓08水02
) - {{得個……字/得个……字}} (
彳08人08子03
) - {{濕𣲷𣲷/湿𣲷𣲷}} (
水14水05水05
) - {{赛车}} (
貝10車00
) - {{鿪}} (
火13
) - {{九}} (
乙01
) - {{𡆔}} (
口23
) - {{𡎇}} (
土09
) - {{阿坝}} (
阜05土04
)
Идеографиялык сүрөттөө тизмеги
түзөтүү- {{⿰亻革}} (
⿰人00革00
) - {{⿰亻革家語/⿰亻革家语}} (
⿰人00革00宀07言07
) - {{⿺辶⿳穴⿲月⿱⿲幺言幺⿲長馬長刂心⿺辶⿳穴⿲月⿱⿲幺言幺⿲長馬長刂心麵/⿺辶⿳穴⿲月⿱⿲幺言幺⿲长马长刂心⿺辶⿳穴⿲月⿱⿲幺言幺⿲长马长刂心面}} (
⿺辵00⿳穴00⿲月00⿱⿲幺00言00幺00⿲長00馬00長00刀00心00⿺辵00⿳穴00⿲月00⿱⿲幺00言00幺00⿲長00馬00長00刀00心00麥09
)
local export = {}
local m_str_utils = require("Module:string utilities")
local byte = string.byte
local codepoint = m_str_utils.codepoint
local concat = table.concat
local convert_iteration_marks = require("Module:Hani").convert_iteration_marks
local explode = m_str_utils.explode_utf8
local format = string.format
local gmatch = string.gmatch
local gsub = string.gsub
local insert = table.insert
local sub = string.sub
local u = m_str_utils.char
local ugsub = mw.ustring.gsub
local umatch = mw.ustring.match
local upper = m_str_utils.upper
local m_data = require("Module:Hani-sortkey/data/serialized")
local m_data_core = mw.loadData("Module:Hani-sortkey/data/core")
local cache = {}
--[[
Returns the index in the string where the ideographic description sequence
(IDS) ends, or the index of the end of the string. Iterates whenever
another ideographic description character (IDC) is found.
]]
local function findEndOfIDS(text, IDchar, i)
if not (text and IDchar and i) then
return nil
end
local j = i
local component = 1
-- Number of components expected after current IDC.
local components = m_data_core.ids[IDchar]
while component <= components do
j = j + 1
local char = text[j]
if not char then
break
elseif m_data_core.ids[char] then
j = findEndOfIDS(text, char, j)
end
component = component + 1
end
--[[
If the expected number of components has been found,
return the current index in the text.
]]
if component - components == 1 then
return j
else
return nil
end
end
local function unserialize(a, b)
return m_data_core.radicals[byte(a)] .. format("%02d", byte(b) - 10)
end
-- The data is stored in [[Module:Hani-sortkey/data]]. This data is not accessed directly (due to the large amount of memory this would consume), but is instead stored in a serialized form as [[Module:Hani-sortkey/data/serialized]]. If the data is changed, the new serialized data can be generated with [[Module:Hani-sortkey/data/serializer]].
function export.getData(char)
if type(char) == "string" then
char = codepoint(char)
elseif type(char) ~= "number" then
error("getData must operate on a single character or codepoint.")
end
local offset, s, f, lookup = 0
for i = 2, m_data_core.ranges.n, 2 do
s, f = m_data_core.ranges[i - 1], m_data_core.ranges[i]
if char > f then
offset = offset + f - s + 1
elseif char >= s and char <= f then
lookup = 2 * (offset + char - s + 1)
return (gsub(sub(m_data, lookup - 1, lookup), "(.)(.)", unserialize))
end
end
return u(char)
end
function export.makeSortKey(text, lang, sc)
local scripts = {
Hani = true,
Hans = true,
Hant = true,
Jpan = true,
Kore = true
}
if sc and not scripts[sc] then
return upper(text)
end
-- Convert any iteration marks into full characters, and remove any spaces. Also remove punctuation if the term contains non-punctuation (so that entries for punctuation characters can still be sorted properly).
text = ugsub(convert_iteration_marks(text), "%s+", "")
if not umatch(text, "^%p+$") then
text = ugsub(text, "%p+", "")
end
text = explode(text)
local sort, text_len, i = {}, #text, 0
while i < text_len do
i = i + 1
local char = text[i]
if m_data_core.preconvert[char] then
local j = 0
for c in gmatch(m_data_core.preconvert[char], ".[\128-\191]*") do
if j == 0 then
text[i] = c
else
insert(text, i + j, c)
end
j = j + 1
end
char = text[i]
text_len = #text
end
--[=[
If we encounter an ideographic description character (IDC),
find out if it begins a valid ideographic description sequence (IDS).
If the IDS is valid and a sortkey for it is listed in
[[Module:Hani-sortkey/data/unsupported]], then return
the sortkey, and move to the next character after the
IDS.
Otherwise, insert the IDC into the sortkey and move to the next
character after the IDC.
If the IDS is valid and no sortkey for it is found, track it.
]=]
if m_data_core.ids[char] then
local j = findEndOfIDS(text, char, i)
local IDS, data
if j then
IDS = concat(text, nil, i, j)
data = m_data_core.unsupported[IDS]
end
if not data then
if IDS then
require("Module:debug").track("Hani-sortkey/IDS-without-sortkey")
mw.log("ideographic description sequence without sortkey: '"
.. IDS .. "'")
else
require("Module:debug").track("Hani-sortkey/invalid-IDS")
mw.log("invalid ideographic description sequence at the beginning of '"
.. text[i] .. "'")
end
end
if IDS and data then
insert(sort, data)
i = j
else
insert(sort, char)
end
else
if not cache[char] then
cache[char] = export.getData(char)
end
insert(sort, cache[char])
end
end
return concat(sort)
end
return export