Modul:String2: Forskjell mellom sideversjoner
Hopp til navigering
Hopp til søk
(Prune code duplication in title function) |
(function posnq) |
||
Linje 1: | Linje 1: | ||
local p = {} |
local p = {} |
||
p.upper = function(frame) |
p.upper = function(frame) |
||
Linje 10: | Linje 11: | ||
return string.lower(s) |
return string.lower(s) |
||
end |
end |
||
p.sentence = function (frame ) |
p.sentence = function (frame ) |
||
Linje 15: | Linje 17: | ||
return p.ucfirst(frame) |
return p.ucfirst(frame) |
||
end |
end |
||
p.ucfirst = function (frame ) |
p.ucfirst = function (frame ) |
||
Linje 42: | Linje 45: | ||
end |
end |
||
end |
end |
||
p.title = function (frame ) |
p.title = function (frame ) |
||
Linje 66: | Linje 70: | ||
return table.concat(words, " ") |
return table.concat(words, " ") |
||
end |
end |
||
⚫ | |||
⚫ | |||
-- Wikidata English labels generally begin with a lowercase letter. [[:d:Help:Label#Capitalization]] |
-- Wikidata English labels generally begin with a lowercase letter. [[:d:Help:Label#Capitalization]] |
||
p.label = p.ucfirst |
p.label = p.ucfirst |
||
-- stripZeros finds the first number and strips leading zeros (apart from units) |
-- stripZeros finds the first number and strips leading zeros (apart from units) |
||
-- e.g "0940" -> "940"; "Year: 0023" -> "Year: 23"; "00.12" -> "0.12" |
-- e.g "0940" -> "940"; "Year: 0023" -> "Year: 23"; "00.12" -> "0.12" |
||
Linje 77: | Linje 85: | ||
return s |
return s |
||
end |
end |
||
-- nowiki ensures that a string of text is treated by the MediaWiki software as just a string |
-- nowiki ensures that a string of text is treated by the MediaWiki software as just a string |
||
Linje 84: | Linje 93: | ||
return mw.text.nowiki(str) |
return mw.text.nowiki(str) |
||
end |
end |
||
-- posnq (position, no quotes) returns the numerical start position of the first occurrence |
|||
-- of one piece of text ("match") inside another ("str"). |
|||
-- It return nil if no match is found. |
|||
-- It takes the text to be searched as the first unnamed parameter, which is trimmed. |
|||
-- It takes the text to search for as the second unnamed parameter, which is trimmed and |
|||
-- any doubel quotes " are stripped out. |
|||
p.posnq = function(frame) |
|||
local str = mw.text.trim(frame.args[1] or "") |
|||
--if str == "" then return nil end |
|||
local match = mw.text.trim(frame.args[2] or ""):gsub('"', '') |
|||
-- just take the start position |
|||
local pos = str:find(match, 1, true) |
|||
return pos |
|||
end |
|||
return p |
return p |
Sideversjonen fra 13. nov. 2018 kl. 15:40
Dokumentasjon for denne modulen kan opprettes på Modul:String2/dok
local p = {} p.upper = function(frame) local s = mw.text.trim(frame.args[1] or "") return string.upper(s) end p.lower = function(frame) local s = mw.text.trim(frame.args[1] or "") return string.lower(s) end p.sentence = function (frame ) frame.args[1] = string.lower(frame.args[1]) return p.ucfirst(frame) end p.ucfirst = function (frame ) local s = mw.text.trim( frame.args[1] or "" ) local s1 = "" -- if it's a list chop off and (store as s1) everything up to the first <li> local lipos = string.find(s, "<li>" ) if lipos then s1 = string.sub(s, 1, lipos + 3) s = string.sub(s, lipos + 4) end -- s1 is either "" or the first part of the list markup, so we can continue -- and prepend s1 to the returned string if string.find(s, "^%[%[[^|]+|[^%]]+%]%]") then -- this is a piped wikilink, so we capitalise the text, not the pipe local b, c = string.find(s, "|%A*%a") -- find the first letter after the pipe return s1 .. string.sub(s, 1, c-1) .. string.upper(string.sub(s, c, c)) .. string.sub(s, c+1) end local letterpos = string.find(s, '%a') if letterpos then local first = string.sub(s, 1, letterpos - 1) local letter = string.sub(s, letterpos, letterpos) local rest = string.sub(s, letterpos + 1) return s1 .. first .. string.upper(letter) .. rest else return s1 .. s end end p.title = function (frame ) -- http://grammar.yourdictionary.com/capitalization/rules-for-capitalization-in-titles.html -- recommended by The U.S. Government Printing Office Style Manual: -- "Capitalize all words in titles of publications and documents, -- except a, an, the, at, by, for, in, of, on, to, up, and, as, but, or, and nor." local alwayslower = {['a'] = 1, ['an'] = 1, ['the'] = 1, ['and'] = 1, ['but'] = 1, ['or'] = 1, ['for'] = 1, ['nor'] = 1, ['on'] = 1, ['in'] = 1, ['at'] = 1, ['to'] = 1, ['from'] = 1, ['by'] = 1, ['of'] = 1, ['up'] = 1 } local res = '' local s = mw.text.trim( frame.args[1] or "" ) local words = mw.text.split( s, " ") for i, s in ipairs(words) do s = string.lower( s ) if( i > 1 and alwayslower[s] == 1) then -- leave in lowercase else s = mw.getContentLanguage():ucfirst(s) end words[i] = s end return table.concat(words, " ") end -- Capitalizing only first letter for fetched Wikidata labels. Alias for back-compatibility -- Wikidata English labels generally begin with a lowercase letter. [[:d:Help:Label#Capitalization]] p.label = p.ucfirst -- stripZeros finds the first number and strips leading zeros (apart from units) -- e.g "0940" -> "940"; "Year: 0023" -> "Year: 23"; "00.12" -> "0.12" p.stripZeros = function(frame) local s = mw.text.trim(frame.args[1] or "") n = tonumber( string.match( s, "%d+" ) ) or "" s = string.gsub( s, "%d+", n, 1 ) return s end -- nowiki ensures that a string of text is treated by the MediaWiki software as just a string -- it takes an unnamed parameter and trims whitespace, then removes any wikicode p.nowiki = function(frame) local str = mw.text.trim(frame.args[1] or "") return mw.text.nowiki(str) end -- posnq (position, no quotes) returns the numerical start position of the first occurrence -- of one piece of text ("match") inside another ("str"). -- It return nil if no match is found. -- It takes the text to be searched as the first unnamed parameter, which is trimmed. -- It takes the text to search for as the second unnamed parameter, which is trimmed and -- any doubel quotes " are stripped out. p.posnq = function(frame) local str = mw.text.trim(frame.args[1] or "") --if str == "" then return nil end local match = mw.text.trim(frame.args[2] or ""):gsub('"', '') -- just take the start position local pos = str:find(match, 1, true) return pos end return p