Wikipedii
olowiki
https://olo.wikipedia.org/wiki/Pi%C3%A4sivu
MediaWiki 1.47.0-wmf.3
first-letter
Medii
Erikoine
Pagin
Käyttäi
Käyttäi pagin
Wikipedii
Wikipedien paginat
Failu
Failu pagin
MediiWiki
MediiWiki pagin
Šablonu
Šablonu pagin
Abu
Abu pagin
Kategourii
Kategourii pagin
TimedText
TimedText talk
Moduuli
Keskustelu moduulista
Event
Event talk
Moduuli:Infobox
828
303
50326
46839
2026-05-22T17:55:23Z
Olksolo
356
inappropriate namespace for categories
50326
Scribunto
text/plain
local p = {}
local args = {}
local origArgs = {}
local root
local empty_row_categories = {}
local category_in_empty_row_pattern = '%[%[%s*[Cc][Aa][Tt][Ee][Gg][Oo][Rr][Yy]%s*:[^]]*]]'
local has_rows = false
local function fixChildBoxes(sval, tt)
local function notempty( s ) return s and s:match( '%S' ) end
if notempty(sval) then
local marker = '<span class=special_infobox_marker>'
local s = sval
-- start moving templatestyles and categories inside of table rows
local slast = ''
while slast ~= s do
slast = s
s = mw.ustring.gsub(s, '(</[Tt][Rr]%s*>%s*)(%[%[%s*[Cc][Aa][Tt][Ee][Gg][Oo][Rr][Yy]%s*:[^]]*%]%])', '%2%1')
s = mw.ustring.gsub(s, '(</[Tt][Rr]%s*>%s*)(\127[^\127]*UNIQ%-%-templatestyles%-%x+%-QINU[^\127]*\127)', '%2%1')
end
-- end moving templatestyles and categories inside of table rows
s = mw.ustring.gsub(s, '(<%s*[Tt][Rr])', marker .. '%1')
s = mw.ustring.gsub(s, '(</[Tt][Rr]%s*>)', '%1' .. marker)
if s:match(marker) then
s = mw.ustring.gsub(s, marker .. '%s*' .. marker, '')
s = mw.ustring.gsub(s, '([\r\n]|-[^\r\n]*[\r\n])%s*' .. marker, '%1')
s = mw.ustring.gsub(s, marker .. '%s*([\r\n]|-)', '%1')
s = mw.ustring.gsub(s, '(</[Cc][Aa][Pp][Tt][Ii][Oo][Nn]%s*>%s*)' .. marker, '%1')
s = mw.ustring.gsub(s, '(<%s*[Tt][Aa][Bb][Ll][Ee][^<>]*>%s*)' .. marker, '%1')
s = mw.ustring.gsub(s, '^(%{|[^\r\n]*[\r\n]%s*)' .. marker, '%1')
s = mw.ustring.gsub(s, '([\r\n]%{|[^\r\n]*[\r\n]%s*)' .. marker, '%1')
s = mw.ustring.gsub(s, marker .. '(%s*</[Tt][Aa][Bb][Ll][Ee]%s*>)', '%1')
s = mw.ustring.gsub(s, marker .. '(%s*\n|%})', '%1')
end
if s:match(marker) then
local subcells = mw.text.split(s, marker)
s = ''
for k = 1, #subcells do
if k == 1 then
s = s .. subcells[k] .. '</' .. tt .. '></tr>'
elseif k == #subcells then
local rowstyle = ' style="display:none"'
if notempty(subcells[k]) then rowstyle = '' end
s = s .. '<tr' .. rowstyle ..'><' .. tt .. ' colspan=2>\n' ..
subcells[k]
elseif notempty(subcells[k]) then
if (k % 2) == 0 then
s = s .. subcells[k]
else
s = s .. '<tr><' .. tt .. ' colspan=2>\n' ..
subcells[k] .. '</' .. tt .. '></tr>'
end
end
end
end
-- the next two lines add a newline at the end of lists for the PHP parser
-- [[Special:Diff/849054481]]
-- remove when [[:phab:T191516]] is fixed or OBE
s = mw.ustring.gsub(s, '([\r\n][%*#;:][^\r\n]*)$', '%1\n')
s = mw.ustring.gsub(s, '^([%*#;:][^\r\n]*)$', '%1\n')
s = mw.ustring.gsub(s, '^([%*#;:])', '\n%1')
s = mw.ustring.gsub(s, '^(%{%|)', '\n%1')
return s
else
return sval
end
end
-- Cleans empty tables
local function cleanInfobox()
root = tostring(root)
if has_rows == false then
root = mw.ustring.gsub(root, '<table[^<>]*>%s*</table>', '')
end
end
-- Returns the union of the values of two tables, as a sequence.
local function union(t1, t2)
local vals = {}
for k, v in pairs(t1) do
vals[v] = true
end
for k, v in pairs(t2) do
vals[v] = true
end
local ret = {}
for k, v in pairs(vals) do
table.insert(ret, k)
end
return ret
end
-- Returns a table containing the numbers of the arguments that exist
-- for the specified prefix. For example, if the prefix was 'data', and
-- 'data1', 'data2', and 'data5' exist, it would return {1, 2, 5}.
local function getArgNums(prefix)
local nums = {}
for k, v in pairs(args) do
local num = tostring(k):match('^' .. prefix .. '([1-9]%d*)$')
if num then table.insert(nums, tonumber(num)) end
end
table.sort(nums)
return nums
end
-- Adds a row to the infobox, with either a header cell
-- or a label/data cell combination.
local function addRow(rowArgs)
if rowArgs.header and rowArgs.header ~= '_BLANK_' then
has_rows = true
root
:tag('tr')
:addClass(rowArgs.rowclass)
:cssText(rowArgs.rowstyle)
:tag('th')
:attr('colspan', '2')
:addClass('infobox-header')
:addClass(rowArgs.class)
:addClass(args.headerclass)
-- @deprecated next; target .infobox-<name> .infobox-header
:cssText(args.headerstyle)
:cssText(rowArgs.rowcellstyle)
:wikitext(fixChildBoxes(rowArgs.header, 'th'))
if rowArgs.data then
root:wikitext(
'[[Kategourii:Halaman dengan sel data kotak info yang dihiraukan]]'
)
end
elseif rowArgs.data and rowArgs.data:gsub(
category_in_empty_row_pattern, ''
):match('^%S') then
has_rows = true
local row = root:tag('tr')
row:addClass(rowArgs.rowclass)
row:cssText(rowArgs.rowstyle)
if rowArgs.label then
row
:tag('th')
:attr('scope', 'row')
:addClass('infobox-label')
-- @deprecated next; target .infobox-<name> .infobox-label
:cssText(args.labelstyle)
:cssText(rowArgs.rowcellstyle)
:wikitext(rowArgs.label)
:done()
end
local dataCell = row:tag('td')
dataCell
:attr('colspan', not rowArgs.label and '2' or nil)
:addClass(not rowArgs.label and 'infobox-full-data' or 'infobox-data')
:addClass(rowArgs.class)
-- @deprecated next; target .infobox-<name> .infobox(-full)-data
:cssText(rowArgs.datastyle)
:cssText(rowArgs.rowcellstyle)
:wikitext(fixChildBoxes(rowArgs.data, 'td'))
else
table.insert(empty_row_categories, rowArgs.data or '')
end
end
local function renderTitle()
if not args.title then return end
has_rows = true
root
:tag('caption')
:addClass('infobox-title')
:addClass(args.titleclass)
-- @deprecated next; target .infobox-<name> .infobox-title
:cssText(args.titlestyle)
:wikitext(args.title)
end
local function renderAboveRow()
if not args.above then return end
has_rows = true
root
:tag('tr')
:tag('th')
:attr('colspan', '2')
:addClass('infobox-above')
:addClass(args.aboveclass)
-- @deprecated next; target .infobox-<name> .infobox-above
:cssText(args.abovestyle)
:wikitext(fixChildBoxes(args.above,'th'))
end
local function renderBelowRow()
if not args.below then return end
has_rows = true
root
:tag('tr')
:tag('td')
:attr('colspan', '2')
:addClass('infobox-below')
:addClass(args.belowclass)
-- @deprecated next; target .infobox-<name> .infobox-below
:cssText(args.belowstyle)
:wikitext(fixChildBoxes(args.below,'td'))
end
local function addSubheaderRow(subheaderArgs)
if subheaderArgs.data and
subheaderArgs.data:gsub(category_in_empty_row_pattern, ''):match('^%S') then
has_rows = true
local row = root:tag('tr')
row:addClass(subheaderArgs.rowclass)
local dataCell = row:tag('td')
dataCell
:attr('colspan', '2')
:addClass('infobox-subheader')
:addClass(subheaderArgs.class)
:cssText(subheaderArgs.datastyle)
:cssText(subheaderArgs.rowcellstyle)
:wikitext(fixChildBoxes(subheaderArgs.data, 'td'))
else
table.insert(empty_row_categories, subheaderArgs.data or '')
end
end
local function renderSubheaders()
if args.subheader then
args.subheader1 = args.subheader
end
if args.subheaderrowclass then
args.subheaderrowclass1 = args.subheaderrowclass
end
local subheadernums = getArgNums('subheader')
for k, num in ipairs(subheadernums) do
addSubheaderRow({
data = args['subheader' .. tostring(num)],
-- @deprecated next; target .infobox-<name> .infobox-subheader
datastyle = args.subheaderstyle,
rowcellstyle = args['subheaderstyle' .. tostring(num)],
class = args.subheaderclass,
rowclass = args['subheaderrowclass' .. tostring(num)]
})
end
end
local function addImageRow(imageArgs)
if imageArgs.data and
imageArgs.data:gsub(category_in_empty_row_pattern, ''):match('^%S') then
has_rows = true
local row = root:tag('tr')
row:addClass(imageArgs.rowclass)
local dataCell = row:tag('td')
dataCell
:attr('colspan', '2')
:addClass('infobox-image')
:addClass(imageArgs.class)
:cssText(imageArgs.datastyle)
:wikitext(fixChildBoxes(imageArgs.data, 'td'))
else
table.insert(empty_row_categories, imageArgs.data or '')
end
end
local function renderImages()
if args.image then
args.image1 = args.image
end
if args.caption then
args.caption1 = args.caption
end
local imagenums = getArgNums('image')
for k, num in ipairs(imagenums) do
local caption = args['caption' .. tostring(num)]
local data = mw.html.create():wikitext(args['image' .. tostring(num)])
if caption then
data
:tag('div')
:addClass('infobox-caption')
-- @deprecated next; target .infobox-<name> .infobox-caption
:cssText(args.captionstyle)
:wikitext(caption)
end
addImageRow({
data = tostring(data),
-- @deprecated next; target .infobox-<name> .infobox-image
datastyle = args.imagestyle,
class = args.imageclass,
rowclass = args['imagerowclass' .. tostring(num)]
})
end
end
-- When autoheaders are turned on, preprocesses the rows
local function preprocessRows()
if not args.autoheaders then return end
local rownums = union(getArgNums('header'), getArgNums('data'))
table.sort(rownums)
local lastheader
for k, num in ipairs(rownums) do
if args['header' .. tostring(num)] then
if lastheader then
args['header' .. tostring(lastheader)] = nil
end
lastheader = num
elseif args['data' .. tostring(num)] and
args['data' .. tostring(num)]:gsub(
category_in_empty_row_pattern, ''
):match('^%S') then
local data = args['data' .. tostring(num)]
if data:gsub(category_in_empty_row_pattern, ''):match('%S') then
lastheader = nil
end
end
end
if lastheader then
args['header' .. tostring(lastheader)] = nil
end
end
-- Gets the union of the header and data argument numbers,
-- and renders them all in order
local function renderRows()
local rownums = union(getArgNums('header'), getArgNums('data'))
table.sort(rownums)
for k, num in ipairs(rownums) do
addRow({
header = args['header' .. tostring(num)],
label = args['label' .. tostring(num)],
data = args['data' .. tostring(num)],
datastyle = args.datastyle,
class = args['class' .. tostring(num)],
rowclass = args['rowclass' .. tostring(num)],
-- @deprecated next; target .infobox-<name> rowclass
rowstyle = args['rowstyle' .. tostring(num)],
rowcellstyle = args['rowcellstyle' .. tostring(num)]
})
end
end
local function renderNavBar()
if not args.name then return end
has_rows = true
root
:tag('tr')
:tag('td')
:attr('colspan', '2')
:addClass('infobox-navbar')
:wikitext(require('Modul:Navbar')._navbar{
args.name,
mini = 1,
})
end
local function renderItalicTitle()
local italicTitle = args['italic title'] and mw.ustring.lower(args['italic title'])
if italicTitle == '' or italicTitle == 'force' or italicTitle == 'yes' then
root:wikitext(mw.getCurrentFrame():expandTemplate({title = 'italic title'}))
end
end
-- Categories in otherwise empty rows are collected in empty_row_categories.
-- This function adds them to the module output. It is not affected by
-- args.decat because this module should not prevent module-external categories
-- from rendering.
local function renderEmptyRowCategories()
for _, s in ipairs(empty_row_categories) do
root:wikitext(s)
end
end
-- Render tracking categories. args.decat == turns off tracking categories.
local function renderTrackingCategories()
if args.decat == 'yes' then return end
if args.child == 'yes' then
if args.title then
root:wikitext(
'[[Kategourii:Halaman dengan parameter judul awal kotak info]]'
)
end
elseif #(getArgNums('data')) == 0 and mw.title.getCurrentTitle().namespace == 0 then
root:wikitext('[[Kategourii:Artikel yang menggunakan kotak info yang tidak memiliki kolom data]]')
end
end
--[=[
Loads the templatestyles for the infobox.
TODO: FINISH loading base templatestyles here rather than in
MediaWiki:Common.css. There are 4-5000 pages with 'raw' infobox tables.
See [[Mediawiki_talk:Common.css/to_do#Infobox]] and/or come help :).
When we do this we should clean up the inline CSS below too.
Will have to do some bizarre conversion category like with sidebar.
]=]
local function loadTemplateStyles()
local frame = mw.getCurrentFrame()
-- See function description
local base_templatestyles = frame:extensionTag{
name = 'templatestyles', args = { src = 'Modul:Infobox/styles.css' }
}
local templatestyles = ''
if args['templatestyles'] then templatestyles = frame:extensionTag{
name = 'templatestyles', args = { src = args['templatestyles'] }
}
end
local child_templatestyles = ''
if args['child templatestyles'] then child_templatestyles = frame:extensionTag{
name = 'templatestyles', args = { src = args['child templatestyles'] }
}
end
local grandchild_templatestyles = ''
if args['grandchild templatestyles'] then grandchild_templatestyles = frame:extensionTag{
name = 'templatestyles', args = { src = args['grandchild templatestyles'] }
}
end
return table.concat({
base_templatestyles, -- see function description
templatestyles,
child_templatestyles,
grandchild_templatestyles
})
end
-- common functions between the child and non child cases
local function structure_infobox_common()
renderSubheaders()
renderImages()
preprocessRows()
renderRows()
renderBelowRow()
renderNavBar()
renderItalicTitle()
renderEmptyRowCategories()
renderTrackingCategories()
cleanInfobox()
end
-- Specify the overall layout of the infobox, with special settings if the
-- infobox is used as a 'child' inside another infobox.
local function _infobox()
if args.child ~= 'yes' then
root = mw.html.create('table')
root
:addClass(args.subbox == 'yes' and 'infobox-subbox' or 'infobox')
:addClass(args.bodyclass)
-- @deprecated next; target .infobox-<name>
:cssText(args.bodystyle)
renderTitle()
renderAboveRow()
else
root = mw.html.create()
root
:wikitext(args.title)
end
structure_infobox_common()
return loadTemplateStyles() .. root
end
-- If the argument exists and isn't blank, add it to the argument table.
-- Blank arguments are treated as nil to match the behaviour of ParserFunctions.
local function preprocessSingleArg(argName)
if origArgs[argName] and origArgs[argName] ~= '' then
args[argName] = origArgs[argName]
end
end
-- Assign the parameters with the given prefixes to the args table, in order, in
-- batches of the step size specified. This is to prevent references etc. from
-- appearing in the wrong order. The prefixTable should be an array containing
-- tables, each of which has two possible fields, a "prefix" string and a
-- "depend" table. The function always parses parameters containing the "prefix"
-- string, but only parses parameters in the "depend" table if the prefix
-- parameter is present and non-blank.
local function preprocessArgs(prefixTable, step)
if type(prefixTable) ~= 'table' then
error("Non-table value detected for the prefix table", 2)
end
if type(step) ~= 'number' then
error("Invalid step value detected", 2)
end
-- Get arguments without a number suffix, and check for bad input.
for i,v in ipairs(prefixTable) do
if type(v) ~= 'table' or type(v.prefix) ~= "string" or
(v.depend and type(v.depend) ~= 'table') then
error('Invalid input detected to preprocessArgs prefix table', 2)
end
preprocessSingleArg(v.prefix)
-- Only parse the depend parameter if the prefix parameter is present
-- and not blank.
if args[v.prefix] and v.depend then
for j, dependValue in ipairs(v.depend) do
if type(dependValue) ~= 'string' then
error('Invalid "depend" parameter value detected in preprocessArgs')
end
preprocessSingleArg(dependValue)
end
end
end
-- Get arguments with number suffixes.
local a = 1 -- Counter variable.
local moreArgumentsExist = true
while moreArgumentsExist == true do
moreArgumentsExist = false
for i = a, a + step - 1 do
for j,v in ipairs(prefixTable) do
local prefixArgName = v.prefix .. tostring(i)
if origArgs[prefixArgName] then
-- Do another loop if any arguments are found, even blank ones.
moreArgumentsExist = true
preprocessSingleArg(prefixArgName)
end
-- Process the depend table if the prefix argument is present
-- and not blank, or we are processing "prefix1" and "prefix" is
-- present and not blank, and if the depend table is present.
if v.depend and (args[prefixArgName] or (i == 1 and args[v.prefix])) then
for j,dependValue in ipairs(v.depend) do
local dependArgName = dependValue .. tostring(i)
preprocessSingleArg(dependArgName)
end
end
end
end
a = a + step
end
end
-- Parse the data parameters in the same order that the old {{infobox}} did, so
-- that references etc. will display in the expected places. Parameters that
-- depend on another parameter are only processed if that parameter is present,
-- to avoid phantom references appearing in article reference lists.
local function parseDataParameters()
preprocessSingleArg('autoheaders')
preprocessSingleArg('child')
preprocessSingleArg('bodyclass')
preprocessSingleArg('subbox')
preprocessSingleArg('bodystyle')
preprocessSingleArg('title')
preprocessSingleArg('titleclass')
preprocessSingleArg('titlestyle')
preprocessSingleArg('above')
preprocessSingleArg('aboveclass')
preprocessSingleArg('abovestyle')
preprocessArgs({
{prefix = 'subheader', depend = {'subheaderstyle', 'subheaderrowclass'}}
}, 10)
preprocessSingleArg('subheaderstyle')
preprocessSingleArg('subheaderclass')
preprocessArgs({
{prefix = 'image', depend = {'caption', 'imagerowclass'}}
}, 10)
preprocessSingleArg('captionstyle')
preprocessSingleArg('imagestyle')
preprocessSingleArg('imageclass')
preprocessArgs({
{prefix = 'header'},
{prefix = 'data', depend = {'label'}},
{prefix = 'rowclass'},
{prefix = 'rowstyle'},
{prefix = 'rowcellstyle'},
{prefix = 'class'}
}, 50)
preprocessSingleArg('headerclass')
preprocessSingleArg('headerstyle')
preprocessSingleArg('labelstyle')
preprocessSingleArg('datastyle')
preprocessSingleArg('below')
preprocessSingleArg('belowclass')
preprocessSingleArg('belowstyle')
preprocessSingleArg('name')
-- different behaviour for italics if blank or absent
args['italic title'] = origArgs['italic title']
preprocessSingleArg('decat')
preprocessSingleArg('templatestyles')
preprocessSingleArg('child templatestyles')
preprocessSingleArg('grandchild templatestyles')
end
-- If called via #invoke, use the args passed into the invoking template.
-- Otherwise, for testing purposes, assume args are being passed directly in.
function p.infobox(frame)
if frame == mw.getCurrentFrame() then
origArgs = frame:getParent().args
else
origArgs = frame
end
parseDataParameters()
return _infobox()
end
-- For calling via #invoke within a template
function p.infoboxTemplate(frame)
origArgs = {}
for k,v in pairs(frame.args) do origArgs[k] = mw.text.trim(v) end
parseDataParameters()
return _infobox()
end
return p
dyuc4gubolp0fhkghywfery09b1eg62
50327
50326
2026-05-22T18:04:01Z
Olksolo
356
tracking category translation
50327
Scribunto
text/plain
local p = {}
local args = {}
local origArgs = {}
local root
local empty_row_categories = {}
local category_in_empty_row_pattern = '%[%[%s*[Cc][Aa][Tt][Ee][Gg][Oo][Rr][Yy]%s*:[^]]*]]'
local has_rows = false
local function fixChildBoxes(sval, tt)
local function notempty( s ) return s and s:match( '%S' ) end
if notempty(sval) then
local marker = '<span class=special_infobox_marker>'
local s = sval
-- start moving templatestyles and categories inside of table rows
local slast = ''
while slast ~= s do
slast = s
s = mw.ustring.gsub(s, '(</[Tt][Rr]%s*>%s*)(%[%[%s*[Cc][Aa][Tt][Ee][Gg][Oo][Rr][Yy]%s*:[^]]*%]%])', '%2%1')
s = mw.ustring.gsub(s, '(</[Tt][Rr]%s*>%s*)(\127[^\127]*UNIQ%-%-templatestyles%-%x+%-QINU[^\127]*\127)', '%2%1')
end
-- end moving templatestyles and categories inside of table rows
s = mw.ustring.gsub(s, '(<%s*[Tt][Rr])', marker .. '%1')
s = mw.ustring.gsub(s, '(</[Tt][Rr]%s*>)', '%1' .. marker)
if s:match(marker) then
s = mw.ustring.gsub(s, marker .. '%s*' .. marker, '')
s = mw.ustring.gsub(s, '([\r\n]|-[^\r\n]*[\r\n])%s*' .. marker, '%1')
s = mw.ustring.gsub(s, marker .. '%s*([\r\n]|-)', '%1')
s = mw.ustring.gsub(s, '(</[Cc][Aa][Pp][Tt][Ii][Oo][Nn]%s*>%s*)' .. marker, '%1')
s = mw.ustring.gsub(s, '(<%s*[Tt][Aa][Bb][Ll][Ee][^<>]*>%s*)' .. marker, '%1')
s = mw.ustring.gsub(s, '^(%{|[^\r\n]*[\r\n]%s*)' .. marker, '%1')
s = mw.ustring.gsub(s, '([\r\n]%{|[^\r\n]*[\r\n]%s*)' .. marker, '%1')
s = mw.ustring.gsub(s, marker .. '(%s*</[Tt][Aa][Bb][Ll][Ee]%s*>)', '%1')
s = mw.ustring.gsub(s, marker .. '(%s*\n|%})', '%1')
end
if s:match(marker) then
local subcells = mw.text.split(s, marker)
s = ''
for k = 1, #subcells do
if k == 1 then
s = s .. subcells[k] .. '</' .. tt .. '></tr>'
elseif k == #subcells then
local rowstyle = ' style="display:none"'
if notempty(subcells[k]) then rowstyle = '' end
s = s .. '<tr' .. rowstyle ..'><' .. tt .. ' colspan=2>\n' ..
subcells[k]
elseif notempty(subcells[k]) then
if (k % 2) == 0 then
s = s .. subcells[k]
else
s = s .. '<tr><' .. tt .. ' colspan=2>\n' ..
subcells[k] .. '</' .. tt .. '></tr>'
end
end
end
end
-- the next two lines add a newline at the end of lists for the PHP parser
-- [[Special:Diff/849054481]]
-- remove when [[:phab:T191516]] is fixed or OBE
s = mw.ustring.gsub(s, '([\r\n][%*#;:][^\r\n]*)$', '%1\n')
s = mw.ustring.gsub(s, '^([%*#;:][^\r\n]*)$', '%1\n')
s = mw.ustring.gsub(s, '^([%*#;:])', '\n%1')
s = mw.ustring.gsub(s, '^(%{%|)', '\n%1')
return s
else
return sval
end
end
-- Cleans empty tables
local function cleanInfobox()
root = tostring(root)
if has_rows == false then
root = mw.ustring.gsub(root, '<table[^<>]*>%s*</table>', '')
end
end
-- Returns the union of the values of two tables, as a sequence.
local function union(t1, t2)
local vals = {}
for k, v in pairs(t1) do
vals[v] = true
end
for k, v in pairs(t2) do
vals[v] = true
end
local ret = {}
for k, v in pairs(vals) do
table.insert(ret, k)
end
return ret
end
-- Returns a table containing the numbers of the arguments that exist
-- for the specified prefix. For example, if the prefix was 'data', and
-- 'data1', 'data2', and 'data5' exist, it would return {1, 2, 5}.
local function getArgNums(prefix)
local nums = {}
for k, v in pairs(args) do
local num = tostring(k):match('^' .. prefix .. '([1-9]%d*)$')
if num then table.insert(nums, tonumber(num)) end
end
table.sort(nums)
return nums
end
-- Adds a row to the infobox, with either a header cell
-- or a label/data cell combination.
local function addRow(rowArgs)
if rowArgs.header and rowArgs.header ~= '_BLANK_' then
has_rows = true
root
:tag('tr')
:addClass(rowArgs.rowclass)
:cssText(rowArgs.rowstyle)
:tag('th')
:attr('colspan', '2')
:addClass('infobox-header')
:addClass(rowArgs.class)
:addClass(args.headerclass)
-- @deprecated next; target .infobox-<name> .infobox-header
:cssText(args.headerstyle)
:cssText(rowArgs.rowcellstyle)
:wikitext(fixChildBoxes(rowArgs.header, 'th'))
if rowArgs.data then
root:wikitext(
'[[Kategourii:Pages using infobox templates with ignored data cells]]'
)
end
elseif rowArgs.data and rowArgs.data:gsub(
category_in_empty_row_pattern, ''
):match('^%S') then
has_rows = true
local row = root:tag('tr')
row:addClass(rowArgs.rowclass)
row:cssText(rowArgs.rowstyle)
if rowArgs.label then
row
:tag('th')
:attr('scope', 'row')
:addClass('infobox-label')
-- @deprecated next; target .infobox-<name> .infobox-label
:cssText(args.labelstyle)
:cssText(rowArgs.rowcellstyle)
:wikitext(rowArgs.label)
:done()
end
local dataCell = row:tag('td')
dataCell
:attr('colspan', not rowArgs.label and '2' or nil)
:addClass(not rowArgs.label and 'infobox-full-data' or 'infobox-data')
:addClass(rowArgs.class)
-- @deprecated next; target .infobox-<name> .infobox(-full)-data
:cssText(rowArgs.datastyle)
:cssText(rowArgs.rowcellstyle)
:wikitext(fixChildBoxes(rowArgs.data, 'td'))
else
table.insert(empty_row_categories, rowArgs.data or '')
end
end
local function renderTitle()
if not args.title then return end
has_rows = true
root
:tag('caption')
:addClass('infobox-title')
:addClass(args.titleclass)
-- @deprecated next; target .infobox-<name> .infobox-title
:cssText(args.titlestyle)
:wikitext(args.title)
end
local function renderAboveRow()
if not args.above then return end
has_rows = true
root
:tag('tr')
:tag('th')
:attr('colspan', '2')
:addClass('infobox-above')
:addClass(args.aboveclass)
-- @deprecated next; target .infobox-<name> .infobox-above
:cssText(args.abovestyle)
:wikitext(fixChildBoxes(args.above,'th'))
end
local function renderBelowRow()
if not args.below then return end
has_rows = true
root
:tag('tr')
:tag('td')
:attr('colspan', '2')
:addClass('infobox-below')
:addClass(args.belowclass)
-- @deprecated next; target .infobox-<name> .infobox-below
:cssText(args.belowstyle)
:wikitext(fixChildBoxes(args.below,'td'))
end
local function addSubheaderRow(subheaderArgs)
if subheaderArgs.data and
subheaderArgs.data:gsub(category_in_empty_row_pattern, ''):match('^%S') then
has_rows = true
local row = root:tag('tr')
row:addClass(subheaderArgs.rowclass)
local dataCell = row:tag('td')
dataCell
:attr('colspan', '2')
:addClass('infobox-subheader')
:addClass(subheaderArgs.class)
:cssText(subheaderArgs.datastyle)
:cssText(subheaderArgs.rowcellstyle)
:wikitext(fixChildBoxes(subheaderArgs.data, 'td'))
else
table.insert(empty_row_categories, subheaderArgs.data or '')
end
end
local function renderSubheaders()
if args.subheader then
args.subheader1 = args.subheader
end
if args.subheaderrowclass then
args.subheaderrowclass1 = args.subheaderrowclass
end
local subheadernums = getArgNums('subheader')
for k, num in ipairs(subheadernums) do
addSubheaderRow({
data = args['subheader' .. tostring(num)],
-- @deprecated next; target .infobox-<name> .infobox-subheader
datastyle = args.subheaderstyle,
rowcellstyle = args['subheaderstyle' .. tostring(num)],
class = args.subheaderclass,
rowclass = args['subheaderrowclass' .. tostring(num)]
})
end
end
local function addImageRow(imageArgs)
if imageArgs.data and
imageArgs.data:gsub(category_in_empty_row_pattern, ''):match('^%S') then
has_rows = true
local row = root:tag('tr')
row:addClass(imageArgs.rowclass)
local dataCell = row:tag('td')
dataCell
:attr('colspan', '2')
:addClass('infobox-image')
:addClass(imageArgs.class)
:cssText(imageArgs.datastyle)
:wikitext(fixChildBoxes(imageArgs.data, 'td'))
else
table.insert(empty_row_categories, imageArgs.data or '')
end
end
local function renderImages()
if args.image then
args.image1 = args.image
end
if args.caption then
args.caption1 = args.caption
end
local imagenums = getArgNums('image')
for k, num in ipairs(imagenums) do
local caption = args['caption' .. tostring(num)]
local data = mw.html.create():wikitext(args['image' .. tostring(num)])
if caption then
data
:tag('div')
:addClass('infobox-caption')
-- @deprecated next; target .infobox-<name> .infobox-caption
:cssText(args.captionstyle)
:wikitext(caption)
end
addImageRow({
data = tostring(data),
-- @deprecated next; target .infobox-<name> .infobox-image
datastyle = args.imagestyle,
class = args.imageclass,
rowclass = args['imagerowclass' .. tostring(num)]
})
end
end
-- When autoheaders are turned on, preprocesses the rows
local function preprocessRows()
if not args.autoheaders then return end
local rownums = union(getArgNums('header'), getArgNums('data'))
table.sort(rownums)
local lastheader
for k, num in ipairs(rownums) do
if args['header' .. tostring(num)] then
if lastheader then
args['header' .. tostring(lastheader)] = nil
end
lastheader = num
elseif args['data' .. tostring(num)] and
args['data' .. tostring(num)]:gsub(
category_in_empty_row_pattern, ''
):match('^%S') then
local data = args['data' .. tostring(num)]
if data:gsub(category_in_empty_row_pattern, ''):match('%S') then
lastheader = nil
end
end
end
if lastheader then
args['header' .. tostring(lastheader)] = nil
end
end
-- Gets the union of the header and data argument numbers,
-- and renders them all in order
local function renderRows()
local rownums = union(getArgNums('header'), getArgNums('data'))
table.sort(rownums)
for k, num in ipairs(rownums) do
addRow({
header = args['header' .. tostring(num)],
label = args['label' .. tostring(num)],
data = args['data' .. tostring(num)],
datastyle = args.datastyle,
class = args['class' .. tostring(num)],
rowclass = args['rowclass' .. tostring(num)],
-- @deprecated next; target .infobox-<name> rowclass
rowstyle = args['rowstyle' .. tostring(num)],
rowcellstyle = args['rowcellstyle' .. tostring(num)]
})
end
end
local function renderNavBar()
if not args.name then return end
has_rows = true
root
:tag('tr')
:tag('td')
:attr('colspan', '2')
:addClass('infobox-navbar')
:wikitext(require('Modul:Navbar')._navbar{
args.name,
mini = 1,
})
end
local function renderItalicTitle()
local italicTitle = args['italic title'] and mw.ustring.lower(args['italic title'])
if italicTitle == '' or italicTitle == 'force' or italicTitle == 'yes' then
root:wikitext(mw.getCurrentFrame():expandTemplate({title = 'italic title'}))
end
end
-- Categories in otherwise empty rows are collected in empty_row_categories.
-- This function adds them to the module output. It is not affected by
-- args.decat because this module should not prevent module-external categories
-- from rendering.
local function renderEmptyRowCategories()
for _, s in ipairs(empty_row_categories) do
root:wikitext(s)
end
end
-- Render tracking categories. args.decat == turns off tracking categories.
local function renderTrackingCategories()
if args.decat == 'yes' then return end
if args.child == 'yes' then
if args.title then
root:wikitext(
'[[Kategourii:Pages using embedded infobox templates with the title parameter]]'
)
end
elseif #(getArgNums('data')) == 0 and mw.title.getCurrentTitle().namespace == 0 then
root:wikitext('[[Kategourii:Articles using infobox templates with no data rows]]')
end
end
--[=[
Loads the templatestyles for the infobox.
TODO: FINISH loading base templatestyles here rather than in
MediaWiki:Common.css. There are 4-5000 pages with 'raw' infobox tables.
See [[Mediawiki_talk:Common.css/to_do#Infobox]] and/or come help :).
When we do this we should clean up the inline CSS below too.
Will have to do some bizarre conversion category like with sidebar.
]=]
local function loadTemplateStyles()
local frame = mw.getCurrentFrame()
-- See function description
local base_templatestyles = frame:extensionTag{
name = 'templatestyles', args = { src = 'Modul:Infobox/styles.css' }
}
local templatestyles = ''
if args['templatestyles'] then templatestyles = frame:extensionTag{
name = 'templatestyles', args = { src = args['templatestyles'] }
}
end
local child_templatestyles = ''
if args['child templatestyles'] then child_templatestyles = frame:extensionTag{
name = 'templatestyles', args = { src = args['child templatestyles'] }
}
end
local grandchild_templatestyles = ''
if args['grandchild templatestyles'] then grandchild_templatestyles = frame:extensionTag{
name = 'templatestyles', args = { src = args['grandchild templatestyles'] }
}
end
return table.concat({
base_templatestyles, -- see function description
templatestyles,
child_templatestyles,
grandchild_templatestyles
})
end
-- common functions between the child and non child cases
local function structure_infobox_common()
renderSubheaders()
renderImages()
preprocessRows()
renderRows()
renderBelowRow()
renderNavBar()
renderItalicTitle()
renderEmptyRowCategories()
renderTrackingCategories()
cleanInfobox()
end
-- Specify the overall layout of the infobox, with special settings if the
-- infobox is used as a 'child' inside another infobox.
local function _infobox()
if args.child ~= 'yes' then
root = mw.html.create('table')
root
:addClass(args.subbox == 'yes' and 'infobox-subbox' or 'infobox')
:addClass(args.bodyclass)
-- @deprecated next; target .infobox-<name>
:cssText(args.bodystyle)
renderTitle()
renderAboveRow()
else
root = mw.html.create()
root
:wikitext(args.title)
end
structure_infobox_common()
return loadTemplateStyles() .. root
end
-- If the argument exists and isn't blank, add it to the argument table.
-- Blank arguments are treated as nil to match the behaviour of ParserFunctions.
local function preprocessSingleArg(argName)
if origArgs[argName] and origArgs[argName] ~= '' then
args[argName] = origArgs[argName]
end
end
-- Assign the parameters with the given prefixes to the args table, in order, in
-- batches of the step size specified. This is to prevent references etc. from
-- appearing in the wrong order. The prefixTable should be an array containing
-- tables, each of which has two possible fields, a "prefix" string and a
-- "depend" table. The function always parses parameters containing the "prefix"
-- string, but only parses parameters in the "depend" table if the prefix
-- parameter is present and non-blank.
local function preprocessArgs(prefixTable, step)
if type(prefixTable) ~= 'table' then
error("Non-table value detected for the prefix table", 2)
end
if type(step) ~= 'number' then
error("Invalid step value detected", 2)
end
-- Get arguments without a number suffix, and check for bad input.
for i,v in ipairs(prefixTable) do
if type(v) ~= 'table' or type(v.prefix) ~= "string" or
(v.depend and type(v.depend) ~= 'table') then
error('Invalid input detected to preprocessArgs prefix table', 2)
end
preprocessSingleArg(v.prefix)
-- Only parse the depend parameter if the prefix parameter is present
-- and not blank.
if args[v.prefix] and v.depend then
for j, dependValue in ipairs(v.depend) do
if type(dependValue) ~= 'string' then
error('Invalid "depend" parameter value detected in preprocessArgs')
end
preprocessSingleArg(dependValue)
end
end
end
-- Get arguments with number suffixes.
local a = 1 -- Counter variable.
local moreArgumentsExist = true
while moreArgumentsExist == true do
moreArgumentsExist = false
for i = a, a + step - 1 do
for j,v in ipairs(prefixTable) do
local prefixArgName = v.prefix .. tostring(i)
if origArgs[prefixArgName] then
-- Do another loop if any arguments are found, even blank ones.
moreArgumentsExist = true
preprocessSingleArg(prefixArgName)
end
-- Process the depend table if the prefix argument is present
-- and not blank, or we are processing "prefix1" and "prefix" is
-- present and not blank, and if the depend table is present.
if v.depend and (args[prefixArgName] or (i == 1 and args[v.prefix])) then
for j,dependValue in ipairs(v.depend) do
local dependArgName = dependValue .. tostring(i)
preprocessSingleArg(dependArgName)
end
end
end
end
a = a + step
end
end
-- Parse the data parameters in the same order that the old {{infobox}} did, so
-- that references etc. will display in the expected places. Parameters that
-- depend on another parameter are only processed if that parameter is present,
-- to avoid phantom references appearing in article reference lists.
local function parseDataParameters()
preprocessSingleArg('autoheaders')
preprocessSingleArg('child')
preprocessSingleArg('bodyclass')
preprocessSingleArg('subbox')
preprocessSingleArg('bodystyle')
preprocessSingleArg('title')
preprocessSingleArg('titleclass')
preprocessSingleArg('titlestyle')
preprocessSingleArg('above')
preprocessSingleArg('aboveclass')
preprocessSingleArg('abovestyle')
preprocessArgs({
{prefix = 'subheader', depend = {'subheaderstyle', 'subheaderrowclass'}}
}, 10)
preprocessSingleArg('subheaderstyle')
preprocessSingleArg('subheaderclass')
preprocessArgs({
{prefix = 'image', depend = {'caption', 'imagerowclass'}}
}, 10)
preprocessSingleArg('captionstyle')
preprocessSingleArg('imagestyle')
preprocessSingleArg('imageclass')
preprocessArgs({
{prefix = 'header'},
{prefix = 'data', depend = {'label'}},
{prefix = 'rowclass'},
{prefix = 'rowstyle'},
{prefix = 'rowcellstyle'},
{prefix = 'class'}
}, 50)
preprocessSingleArg('headerclass')
preprocessSingleArg('headerstyle')
preprocessSingleArg('labelstyle')
preprocessSingleArg('datastyle')
preprocessSingleArg('below')
preprocessSingleArg('belowclass')
preprocessSingleArg('belowstyle')
preprocessSingleArg('name')
-- different behaviour for italics if blank or absent
args['italic title'] = origArgs['italic title']
preprocessSingleArg('decat')
preprocessSingleArg('templatestyles')
preprocessSingleArg('child templatestyles')
preprocessSingleArg('grandchild templatestyles')
end
-- If called via #invoke, use the args passed into the invoking template.
-- Otherwise, for testing purposes, assume args are being passed directly in.
function p.infobox(frame)
if frame == mw.getCurrentFrame() then
origArgs = frame:getParent().args
else
origArgs = frame
end
parseDataParameters()
return _infobox()
end
-- For calling via #invoke within a template
function p.infoboxTemplate(frame)
origArgs = {}
for k,v in pairs(frame.args) do origArgs[k] = mw.text.trim(v) end
parseDataParameters()
return _infobox()
end
return p
8xyd1vbfgxwic8om3jnp7hx6a4p3ilb
Python
0
16647
50323
50319
2026-05-22T12:58:56Z
Onegaborg
144
50323
wikitext
text/x-wiki
[[Failu:Python_logo_and_wordmark.svg|pienoiskuva|Python Logotiippu ]]
<div style="font-size: 90%;">'''Python''' on korgei tazavaldivon programmuindukieldy, kudamas on dynamiekkutipisoičendu da muistien automaattine ohjuaju. Kieli on šuunnattu kehittäjän suoritukšen ta koodin luvettomuon parantamiseh. Pythonan ytimen syntaksi on minimalistine, ga vakiokirjasto kuului äijy hyövyllisty funktsieloi.
Python on monisparadigmaline programmuindukieldy, kudai kannattau imperatiivistu, proseduurualizuttu, strukturualizuttu, funkcionualizuttu, asinkronu, objektuorientualizuttu programmuindua da metaprogramuindua. Aspect-oriented programmingua osittain kannatetah dekoraattorien kauti, tävvembi kannatus annetah ližärahoin vuoh. Šemmosie metodiekkoja kuin šopimuš- ta logiikkoprogramointi voipi toteuttua kirjastolojen tahi laajennukšien avulla. Piäarhitektuuran ominazis ollah dynaamine typingi, automaattine muistieloin halličendu, täyzi introspektii, poikkeuksien käsittelymekanismu, monivirrallizen laskendustoimindan kannatus, kudamas on globalii tulkin lukkuandua, korgeitasozet datarakentehet. Kannatetah ohjelmien juondua moduuliloikse, kuduat puolespäi voijah yhtistyä paketoikse.
Pythonan vertailumielizennu toteutuksennu on [[CPython]]-tulkuttaju, kudai kannattau enimyöllizesti käytettylöi alovehtu, kudai on kielen de facto standardannu. Se on levitetty pyhtonan piälizen Python Software Foundation License -litsenssien mugah, kudai andau käyttiä sidä rajoittamattah kaikkie sovelluksii myöte proprietaries. CPython tiivistäy alovehellizet tekstat korgiel baitanalovehellizekse kodikse, kudai ruadau stack-virtualizes mašinas. Vienan kielen toizet kolme piäliästy rakendustu ollah Jython (JVM:ä varoin), IronPython (CLR/.NET:ä varoin) da PyPy. PyPy on kirjutettu Python-kieleh (RPython) alovehel da kehitettih CPython:an vaihtoehdokse, kuduan tarkoituksennu on ližätä programmoin suorittamizen kiirehuttu, sidä kesken JIT-kompil'atsien käytändäl. Python 2 -versien kannatus loppihes vuvvennu 2020. Nykyjäh aktiivisešti kehitelläh Python 3:n versijuo. Kielen kehittämisty ruvetah '''PEP'''-kielen ([[Anglien kieli|angl]]. ''Python Enhancement Proposal''), kudualois kuvatah uvvistuksii, luajitah kohenduksii kogukunnalpäi tulluon palautuksen mugah da dokumentoitah loppupäätökset
Standardu-kirjastoh kuuluu suuri joukko hyödyllisty moduuliloi, niilöin joukos on eri alovehpiirilöi, kudamis on toiminnoi tekstanke ruadamizespäi verkkoh sovelluksien kirjutamizen työkaluh suate. Lisävoimat, kui matemaattine simuloindu, laittehienke ruado, veb-sovelluksien kirjutamine libo pelien kehittämine, voijah toteuttua ylen äijäl kolmanden luvetteloin vuoh, sego C- libo [[C++]]-kielen kirjutettuloin luvetteloin integroindas, da iče Python-interpretattoru voibi integroidu niilöin kielien kirjutettuloih projektoih. On olemas pyyton kielel kirjutettuloin ohjelmistojen erikoistu varasto - PyPI. Tämä repozitorii andau keinoi pakettien helpoh asendamizeh operatsiesistiemah da rodih de facto standardakse Pythonale. Vuvvennu 2019 šiinä oli yli 175 tuhatta pakettia
Python on roinnuhes yhtenny kaikis suosituimmilois kielilöis, sidä käytetäh tiedoloin analysoindas, mašinoin opastundas, web-kehittämizes, pelien kehittämizes, skriptoin kirjutamizes da DevOpsas. Lugijattomuon, kebjen syntaksan, luonnonkielen lähäl olendan da psevdokodin mugah olendan vuoh kieli on hyvä opastumah programmoičendua, avvuttau kehittämäh sellittäjiä duumaičendua (kudai kuului algoritmillizeh duumaičendua). Ongelmallistu da kokeilendua vie äijäl helpotetah se, ku kieli on tulkittavannu. Hyvä koodin luvendettavuš helpottau niise vianšuštua, vaikka kielen käytös opasusprosessis voipi olla vaikeukšie virhehien ymmärtämisel (serveriyhteykšen puuttumisella, tiedoston lukemisen virhehes) kolmansien toimintojen kučuloissa, kumpaset täytetäh monimutkaisie tehtävie. Kieldy käytetäh äijät suuret kompaniet, kui [[Google]] da [[NASA]].</div>
[[Kategourii:Ohjelmoičuksen kielet|P]]
156zqbnf866l38i24p78lgh01y321a9
50325
50323
2026-05-22T15:41:03Z
Miro Tuomi
8600
50325
wikitext
text/x-wiki
[[Failu:Python_logo_and_wordmark.svg|pienoiskuva|Python Logotiippu ]]
<div style="font-size: 90%;">'''Python''' on korgei tazavaldivon programmuindukieldy, kudamas on dynamiekkutipisoičendu da muistien automaattine ohjuaju. Kieli on šuunnattu kehittäjän suoritukšen da koodin luvettomuon parantamiseh. Pythonan ytimen syntaksi on minimalistine, ga vakiokirjasto kuului äijy hyövyllisty funktsieloi.
Python on monisparadigmaline programmuindukieldy, kudai kannattau imperatiivistu, proseduurualizuttu, strukturualizuttu, funkcionualizuttu, asinkronu, objektuorientualizuttu programmuindua da metaprogramuindua. Aspect-oriented programmingua osittain kannatetah dekoraattorien kauti, tävvembi kannatus annetah ližärahoin vuoh. Šemmosie metodiekkoja kuin šopimuš- ta logiikkoprogramointi voipi toteuttua kirjastolojen tahi laajennukšien avulla. Piäarhitektuuran ominazis ollah dynaamine typingi, automaattine muistieloin halličendu, täyzi introspektii, poikkeuksien käsittelymekanismu, monivirrallizen laskendustoimindan kannatus, kudamas on globalii tulkin lukkuandua, korgeitasozet datarakentehet. Kannatetah ohjelmien juondua moduuliloikse, kuduat puolespäi voijah yhtistyä paketoikse.
Pythonan vertailumielizennu toteutuksennu on [[CPython]]-tulkuttaju, kudai kannattau enimyöllizesti käytettylöi alovehtu, kudai on kielen de facto standardannu. Se on levitetty pyhtonan piälizen Python Software Foundation License -litsenssien mugah, kudai andau käyttiä sidä rajoittamattah kaikkie sovelluksii myöte proprietaries. CPython tiivistäy alovehellizet tekstat korgiel baitanalovehellizekse kodikse, kudai ruadau stack-virtualizes mašinas. Vienan kielen toizet kolme piäliästy rakendustu ollah Jython (JVM:ä varoin), IronPython (CLR/.NET:ä varoin) da PyPy. PyPy on kirjutettu Python-kieleh (RPython) alovehel da kehitettih CPython:an vaihtoehdokse, kuduan tarkoituksennu on ližätä programmoin suorittamizen kiirehuttu, sidä kesken JIT-kompil'atsien käytändäl. Python 2 -versien kannatus loppihes vuvvennu 2020. Nykyjäh aktiivisešti kehitelläh Python 3:n versijuo. Kielen kehittämisty ruvetah '''PEP'''-kielen ([[Anglien kieli|angl]]. ''Python Enhancement Proposal''), kudualois kuvatah uvvistuksii, luajitah kohenduksii kogukunnalpäi tulluon palautuksen mugah da dokumentoitah loppupäätökset
Standardu-kirjastoh kuuluu suuri joukko hyödyllisty moduuliloi, niilöin joukos on eri alovehpiirilöi, kudamis on toiminnoi tekstanke ruadamizespäi verkkoh sovelluksien kirjutamizen työkaluh suate. Lisävoimat, kui matemaattine simuloindu, laittehienke ruado, veb-sovelluksien kirjutamine libo pelien kehittämine, voijah toteuttua ylen äijäl kolmanden luvetteloin vuoh, sego C- libo [[C++]]-kielen kirjutettuloin luvetteloin integroindas, da iče Python-interpretattoru voibi integroidu niilöin kielien kirjutettuloih projektoih. On olemas pyyton kielel kirjutettuloin ohjelmistojen erikoistu varasto - PyPI. Tämä repozitorii andau keinoi pakettien helpoh asendamizeh operatsiesistiemah da rodih de facto standardakse Pythonale. Vuvvennu 2019 šiinä oli yli 175 tuhatta pakettia
Python on roinnuhes yhtenny kaikis suosituimmilois kielilöis, sidä käytetäh tiedoloin analysoindas, mašinoin opastundas, web-kehittämizes, pelien kehittämizes, skriptoin kirjutamizes da DevOpsas. Lugijattomuon, kebjen syntaksan, luonnonkielen lähäl olendan da psevdokodin mugah olendan vuoh kieli on hyvä opastumah programmoičendua, avvuttau kehittämäh sellittäjiä duumaičendua (kudai kuului algoritmillizeh duumaičendua). Ongelmallistu da kokeilendua vie äijäl helpotetah se, ku kieli on tulkittavannu. Hyvä koodin luvendettavuš helpottau niise vianšuštua, vaikka kielen käytös opasusprosessis voipi olla vaikeukšie virhehien ymmärtämisel (serveriyhteykšen puuttumisella, tiedoston lukemisen virhehes) kolmansien toimintojen kučuloissa, kumpaset täytetäh monimutkaisie tehtävie. Kieldy käytetäh äijät suuret kompaniet, kui [[Google]] da [[NASA]].</div>
[[Kategourii:Ohjelmoičuksen kielet|P]]
f4isbq8l4cxm4kr565yurd9dxqged2z
Illi Savčuk
0
16648
50321
2026-05-22T12:16:32Z
Onegaborg
144
Uuzi sivu: {{Ristikanzu}} [[File:Illi_Savcuk.jpg|thumb|200.px|alt=Illi Savčuk |Illi Savčuk ]] Illi Savčuk (tozinimi on Ilja Savčenko) on muzikantu. Häi on rodinuhes 11. ligakuudu vuvvennu 1962 Petroskoil. Muaman puoles on vepsäläine. Illi Savčuk on ven'alas-suomelazen Cyanide sego ispuanien- da anglienkielizen Das Kuhn -rockjoukkoloin alguhpanijoin keskes. Cyanide-joukos häi soitti lyöndysoittimil. Das Kuhn-joukko Karjalaspäi on hyvin kuulužu rockmuuzikan suvaiččijoin keskes....
50321
wikitext
text/x-wiki
{{Ristikanzu}}
[[File:Illi_Savcuk.jpg|thumb|200.px|alt=Illi Savčuk |Illi Savčuk ]]
Illi Savčuk (tozinimi on Ilja Savčenko) on muzikantu. Häi on rodinuhes 11. ligakuudu vuvvennu 1962 Petroskoil. Muaman puoles on vepsäläine. Illi Savčuk on ven'alas-suomelazen Cyanide sego ispuanien- da anglienkielizen Das Kuhn -rockjoukkoloin alguhpanijoin keskes. Cyanide-joukos häi soitti lyöndysoittimil. Das Kuhn-joukko Karjalaspäi on hyvin kuulužu rockmuuzikan suvaiččijoin keskes.
[[Kategourii:Karjalaine kul'tuuru|S]]
[[Kategourii:Karjalan muuzikku|S]]
[[Kategourii:Karjalazet|S]]
8mtphyfx6p8v8bme9gaqzleym3q8eo3
50322
50321
2026-05-22T12:20:32Z
Onegaborg
144
50322
wikitext
text/x-wiki
{{Ristikanzu}}
[[File:Illi_Savcuk.jpg|thumb|200.px|alt=Illi Savčuk |Illi Savčuk ]]
'''Illi Savčuk''' (tozinimi on '''Ilja Savčenko''', rodinuhes [[11. ligakuudu]] vuvvennu [[1962]], [[Petroskoi]], [[Karjalan tazavaldu]]) on muzikantu.
Muaman puoles on vepsäläine. Illi Savčuk on ven'alas-suomelazen Cyanide sego ispuanien- da anglienkielizen [[Das Kuhn]] -rockjoukkoloin alguhpanijoin keskes. Cyanide-joukos häi soitti lyöndysoittimil. Das Kuhn-joukko Karjalaspäi on hyvin kuulužu [[Rok (muuzikku)|rockmuuzikan]] suvaiččijoin keskes.
[[Kategourii:Karjalaine kul'tuuru|S]]
[[Kategourii:Karjalan muuzikku|S]]
[[Kategourii:Karjalazet|S]]
lu5b1a5l3adm5engc5atmy993dp5hsf
Kategourii:Ohjelmoičuksen kielet
14
16649
50324
2026-05-22T13:01:10Z
Onegaborg
144
Uuzi sivu: [[Kategourii:Informuatiekku|O]]
50324
wikitext
text/x-wiki
[[Kategourii:Informuatiekku|O]]
2y75n4p3sbk7aeoprjyyqwqd7q44fq9
Šablonu:Potd/2026-05-23
10
16650
50328
2026-05-22T19:07:34Z
Frhdkazan
283
Uuzi sivu: 1 Mercado do Bolhão.jpg
50328
wikitext
text/x-wiki
1 Mercado do Bolhão.jpg
oed558l6gvoyg6s9lemc3uqf0m9m5qs
Šablonu:Motd/2026-05-23
10
16651
50329
2026-05-22T19:13:07Z
Frhdkazan
283
Uuzi sivu: Laysan albatross nests on Midway Atoll NWR (55226395261).webm
50329
wikitext
text/x-wiki
Laysan albatross nests on Midway Atoll NWR (55226395261).webm
2tztztqt3tsyiwpg9vsiybbqday5f4d
Kategourii:Tiähtijoukot
14
16652
50330
2026-05-23T06:03:12Z
Fembriha
8650
Uuzi sivu: [[Kategourii:Tiähtijoukot]]
50330
wikitext
text/x-wiki
[[Kategourii:Tiähtijoukot]]
0c1axrklycm2ljulb3c0l8fmhq27nbw
50333
50330
2026-05-23T06:05:35Z
Fembriha
8650
50333
wikitext
text/x-wiki
[[Kategourii:Tiähtitiedo]]
aozawrscq9y89k60zmysn8jimf0czz3
Kategourii:Asterizmat
14
16653
50331
2026-05-23T06:03:57Z
Fembriha
8650
Uuzi sivu: [[Kategourii:Asterizmat]]
50331
wikitext
text/x-wiki
[[Kategourii:Asterizmat]]
cnujftjkoopts3z5hv9xjpt35s1y7fo
50332
50331
2026-05-23T06:05:17Z
Fembriha
8650
50332
wikitext
text/x-wiki
[[Kategourii:Tiähtitiedo]]
aozawrscq9y89k60zmysn8jimf0czz3
Otava (asterizmu)
0
16654
50334
2026-05-23T06:29:08Z
Fembriha
8650
Uuzi sivu: [[File:Ursa Major constellation detail map.PNG|thumb|Otavan tähtii]] '''Otava''' libo '''Adamantiähtet''' on [[Suuri Kondii|Suuren Kondien]] asterizmu. Kaikkil Otavan tiähtil on omii arabien nimiloi: {| class="wikitable" style="text-align: center;" ! | Nimi || [[Bayeran designatsii|Bayeran<br/>designatsii]] || [[Magnituudu (tiähtitiedo)|Magnituudu]] || Väli<br/>([[Valgovuozi|valgovuottu]]) |- | [[Dubhe]] || α UMa (''alfa Ursae Majoris'') || 1.8 || 124 |- | [[Merak]] ||...
50334
wikitext
text/x-wiki
[[File:Ursa Major constellation detail map.PNG|thumb|Otavan tähtii]]
'''Otava''' libo '''Adamantiähtet''' on [[Suuri Kondii|Suuren Kondien]] asterizmu.
Kaikkil Otavan tiähtil on omii arabien nimiloi:
{| class="wikitable" style="text-align: center;"
! | Nimi || [[Bayeran designatsii|Bayeran<br/>designatsii]] || [[Magnituudu (tiähtitiedo)|Magnituudu]] || Väli<br/>([[Valgovuozi|valgovuottu]])
|-
| [[Dubhe]] || α UMa (''alfa Ursae Majoris'') || 1.8 || 124
|-
| [[Merak]] || β UMa (''beta Ursae Majoris'') || 2.4 || 79
|-
| [[Phecda]] || γ UMa (''gamma Ursae Majoris'') || 2.4 || 84
|-
| [[Megrez]] || δ UMa (''delta Ursae Majoris'') || 3.3 || 81
|-
| [[Alioth]] || ε UMa (''epsilon Ursae Majoris'') || 1.8 || 81
|-
| [[Mizar]] || ζ UMa (''zeta Ursae Majoris'') || 2.2 || 78
|-
| [[Alkaid]] || η UMa (''eta Ursae Majoris'') || 1.9 || 101
|}
[[Kategourii:Asterizmat]]
6uo3d30qj39tr9m5g8lza3w1fkuwriz
50335
50334
2026-05-23T07:53:49Z
Fembriha
8650
/* */
50335
wikitext
text/x-wiki
[[File:Ursa Major constellation detail map.PNG|thumb|Otavan tähtii]]
'''Otava''' libo '''Adamantiähtet''' on [[Suuri Kondii|Suuren Kondien]] asterizmu.
Kaikkil Otavan tiähtil on omii arabien nimiloi:
{| class="wikitable" style="text-align: center;"
! | Nimi || [[Bayeran designatsii|Bayeran<br/>designatsii]] || [[Magnituudu (tiähtitiedo)|Magnituudu]] || Väli<br/>([[Valgovuozi|valgovuottu]])
|-
| [[Dubhe]] || α UMa <br>(''alfa Ursae Majoris'') || 1.8 || 124
|-
| [[Merak]] || β UMa <br>(''beta Ursae Majoris'') || 2.4 || 79
|-
| [[Phecda]] || γ UMa <br>(''gamma Ursae Majoris'') || 2.4 || 84
|-
| [[Megrez]] || δ UMa <br>(''delta Ursae Majoris'') || 3.3 || 81
|-
| [[Alioth]] || ε UMa <br>(''epsilon Ursae Majoris'') || 1.8 || 81
|-
| [[Mizar]] || ζ UMa <br>(''zeta Ursae Majoris'') || 2.2 || 78
|-
| [[Alkaid]] || η UMa <br>(''eta Ursae Majoris'') || 1.9 || 101
|}
[[Kategourii:Asterizmat]]
4ukxxc95p6e4p6xfxa1j4ydpxnghkzs