Razlika između verzija stranice "Modul:Coordinates"

[pregledana izmjena][pregledana izmjena]
Uklonjeni sadržaj Dodani sadržaj
No edit summary
No edit summary
Red 3:
templates. It provides several methods, including
 
{{#Invokeinvoke:Coordinates | coord }} : General function formatting and displaying
coordinate values.
 
{{#Invokeinvoke:Coordinates | dec2dms }} : Simple function for converting decimal
degree values to DMS format.
 
{{#Invokeinvoke:Coordinates | dms2dec }} : Simple function for converting DMS format
to decimal degree format.
 
{{#Invokeinvoke:Coordinates | link }} : Export the link used to reach the tools
 
]]
 
require('Module:No globals')
 
local math_mod = require("Module:Math")
Line 41 ⟶ 43:
end
local s = (first .. second):upper()
return s:find('^[NS][EW]$') or s:find('^[EW][NS]$') or s:find('^[SJ][IZ]$') or s:find('^[IZ][SJ]$')
end
 
Line 51 ⟶ 53:
wrappers = 'Template:Coord'
})
return coordinates[funcName](args, frame)
end
end
Line 107 ⟶ 109:
end
local geodmshtml = '<span class="geo-dms" title="Karte, Maps, zračne fotografije, i ostali podacijepodaci za oveovu lokacijelokaciju">'
.. '<span class="latitude">' .. coordinateSpec["dms-lat"] .. '</span> '
.. '<span class="longitude">' ..coordinateSpec["dms-long"] .. '</span>'
Line 116 ⟶ 118:
if lat < 0 then
-- FIXME this breaks the pre-existing precision
geodeclat = tostring(coordinateSpec["dec-lat"]):sub(2) .. "°SJ"
else
geodeclat = (coordinateSpec["dec-lat"] or 0) .. "°NS"
end
 
Line 125 ⟶ 127:
if long < 0 then
-- FIXME does not handle unicode minus
geodeclong = tostring(coordinateSpec["dec-long"]):sub(2) .. "°WZ"
else
geodeclong = (coordinateSpec["dec-long"] or 0) .. "°EI"
end
local geodechtml = '<span class="geo-dec" title="Karte, Maps, zračne fotografije, i ostali podacijepodaci za oveovu lokacijelokaciju">'
.. geodeclat .. ' '
.. geodeclong
Line 218 ⟶ 220:
local factor = 1
if direction == "S" or direction == "J" or direction == "W" or direction == "Z" then
factor = -1
end
Line 249 ⟶ 251:
if strong then
if lat_d < 0 then
table.insert(errors, {source, "stepeniStepeni geografske širine < 0 sa zastavicom za hemisferu"})
end
if long_d < 0 then
table.insert(errors, {source, "stepeniStepeni geografske dužine < 0 asa zastavicom za hemisferu"})
end
--[[
Line 261 ⟶ 263:
if long_d > 180 then
table.insert(errors, {source, "longitudeStepeni degreesgeografske dužine > 180 withsa zastavicom hemisphereza flaghemisferu"})
end
]]
Line 267 ⟶ 269:
if lat_d > 90 then
table.insert(errors, {source, "stepeniStepeni geografske širine > 90"})
end
if lat_d < -90 then
table.insert(errors, {source, "stepeniStepeni geografske širine < -90−90"})
end
if lat_m >= 60 then
table.insert(errors, {source, "minuteMinute geografske širine >= 60"})
end
if lat_m < 0 then
table.insert(errors, {source, "minuteMinute geografske širine < 0"})
end
if lat_s >= 60 then
table.insert(errors, {source, "sekundeSekunde geografske širine >= 60"})
end
if lat_s < 0 then
table.insert(errors, {source, "sekundeSekunde geografske širine < 0"})
end
if long_d >= 360 then
table.insert(errors, {source, "stepeniStepeni geografske dužine >= 360"})
end
if long_d <= -360 then
table.insert(errors, {source, "stepeniStepeni geografske dužine <= -360−360"})
end
if long_m >= 60 then
table.insert(errors, {source, "minuteMinute geografske dužine >= 60"})
end
if long_m < 0 then
table.insert(errors, {source, "minuteMinute geografske dužine < 0"})
end
if long_s >= 60 then
table.insert(errors, {source, "sekundeSekunde geografske dužine >= 60"})
end
if long_s < 0 then
table.insert(errors, {source, "sekundeSekunde geografske dužine < 0"})
end
Line 309 ⟶ 311:
parseDec
 
Transforms decimal format latitude and longitude into the a
structure to be used in displaying coordinates
]]
Line 319 ⟶ 321:
return nil, {{"parseDec", "Nedostaje geografska dužina"}}
elseif not tonumber(long) then
return nil, {{"parseDec", "NijeGeografsku dužinu nije bilo moguće učitati geografsku dužinu kao broj: " .. long}}
end
Line 327 ⟶ 329:
 
local mode = coordinates.determineMode( lat, long );
coordinateSpec["dms-lat"] = convert_dec2dms( lat, "NS", "SJ", mode) -- {{coord/dec2dms|{{{1}}}|N|S|{{coord/prec dec|{{{1}}}|{{{2}}}}}}}
coordinateSpec["dms-long"] = convert_dec2dms( long, "EI", "WZ", mode) -- {{coord/dec2dms|{{{2}}}|E|W|{{coord/prec dec|{{{1}}}|{{{2}}}}}}}
if format then
Line 346 ⟶ 348:
]]
local function parseDMS( lat_d, lat_m, lat_s, lat_f, long_d, long_m, long_s, long_f, format )
local coordinateSpec, errors, backward = {}, {}
local errors = {}
lat_f = lat_f:upper();
Line 353 ⟶ 354:
-- Check if specified backward
if lat_f == 'E' or lat_f == 'I' or lat_f == 'W' or lat_f == 'Z' then
lat_d, long_d, lat_m, long_m, lat_s, long_s, lat_f, long_f, backward = long_d, lat_d, long_m, lat_m, long_s, lat_s, long_f, lat_f, true;
local t_d, t_m, t_s, t_f;
t_d = lat_d;
t_m = lat_m;
t_s = lat_s;
t_f = lat_f;
lat_d = long_d;
lat_m = long_m;
lat_s = long_s;
lat_f = long_f;
long_d = t_d;
long_m = t_m;
long_s = t_s;
long_f = t_f;
end
Line 373 ⟶ 362:
return nil, {{"parseDMS", "Nedostaje geografska dužina" }}
elseif not tonumber(long_d) then
return nil, {{"parseDMS", "NijeGeografsku dužinu nije bilo moguće učitati geografsku dužinu kao broj: " .. long_d }}
end
if not lat_m and not lat_s and not long_m and not long_s and #errors == 0 then
if math_mod._precision( lat_d ) > 0 or math_mod._precision( long_d ) > 0 then
if lat_f:upper() == 'S' or lat_f:upper() == 'J' then
lat_d = '-' .. lat_d;
end
if long_f:upper() == 'W' or long_f:upper() == 'Z' then
long_d = '-' .. long_d;
end
Line 400 ⟶ 389:
end
 
return coordinateSpec, errors, backward
end
 
Line 409 ⟶ 398:
local function formatTest(args)
local result, errors
local backward, primary = false, false
 
local function getParam(args, lim)
Line 424 ⟶ 413:
elseif not tonumber(args[1]) then
-- bad lat logic
return errorPrinter( {{"formatTest", "NijeGeografsku širinu nije bilo moguće učitati geografsku širinu kao broj:" .. args[1]}} )
elseif not args[4] and not args[5] and not args[6] then
-- dec logic
Line 431 ⟶ 420:
return errorPrinter(errors);
end
-- formatting for geohack: geohack expects D_N_D_E notation or D;D notation
result.param = table.concat({args[1], 'N', args[2] or '', 'E', args[3] or ''}, '_')
-- wikiminiatlas doesn't support D;D notation
-- #coordinates parserfunction doesn't support negative decimals with NSWE
result.param = table.concat({
math.abs(tonumber(args[1])),
((tonumber(args[1]) or 0) < 0) and 'S' or 'N',
math.abs(tonumber(args[2])),
((tonumber(args[2]) or 0) < 0) and 'W' or 'E',
args[3] or ''}, '_')
elseif dmsTest(args[4], args[8]) then
-- dms logic
result, errors, backward = parseDMS(args[1], args[2], args[3], args[4],
args[5], args[6], args[7], args[8], args.format)
if args[10] then
table.insert(errors, {'formatTest', 'DodatniPronađeni dodatni neočekivani parametri'})
end
if not result then
Line 445 ⟶ 442:
elseif dmsTest(args[3], args[6]) then
-- dm logic
result, errors, backward = parseDMS(args[1], args[2], nil, args[3],
args[4], args[5], nil, args[6], args['format'])
if args[8] then
table.insert(errors, {'formatTest', 'DodatniPronađeni dodatni neočekivani parametri'})
end
if not result then
Line 456 ⟶ 453:
elseif dmsTest(args[2], args[4]) then
-- d logic
result, errors, backward = parseDMS(args[1], nil, nil, args[2],
args[3], nil, nil, args[4], args.format)
if args[6] then
table.insert(errors, {'formatTest', 'DodatniPronađeni dodatni neočekivani parametri'})
end
if not result then
Line 474 ⟶ 471:
for _, v in ipairs(extra_param) do
if args[v] then
table.insert(errors, {'formatTest', 'Parametar: "' .. v .. '=" trebabi bititrebalo da bude "' .. v .. ':"' })
end
end
Line 482 ⟶ 479:
ret = ret .. ' ' .. errorPrinter(errors) .. '[[Kategorija:Stranice sa neispravnim koordinatama]]'
end
return ret, backward
end
 
Line 520 ⟶ 517:
 
Usage:
{{ Invoke#invoke:Coordinates | link }}
]]
Line 533 ⟶ 530:
 
Usage:
{{ Invoke#invoke:Coordinates | dec2dms | decimal_coordinate | positive_suffix |
negative_suffix | precision }}
Line 572 ⟶ 569:
 
Usage:
{{ Invoke#invoke:Coordinates | dms2dec | direction_flag | degrees |
minutes | seconds }}
Line 595 ⟶ 592:
 
Usage:
{{ Invoke#invoke:Coordinates | coord }}
{{ Invoke#invoke:Coordinates | coord | lat | long }}
{{ Invoke#invoke:Coordinates | coord | lat | lat_flag | long | long_flag }}
...
Line 610 ⟶ 607:
coordinates.coord = makeInvokeFunc('_coord')
function coordinates._coord(args)
if (not args[1] or not tonumber(args[1])) and not args[2] and mw.wikibase.getEntityObject() then
args[3] = args[1]; args[1] = nil
local entity = mw.wikibase.getEntityObject()
if entity
Line 628 ⟶ 626:
end
local contents, backward = formatTest(args)
local Notes = args.notes or ''
local Display = args.display and args.display:lower() or 'inline'
Line 639 ⟶ 637:
-- Finds whether coordinates are displayed in the title.
return s:find('title') ~= nil or s == 't' or s == 'it' or s == 'ti'
end
local function coord_wrapper(in_args)
-- Calls the parser function {{#coordinates:}}.
return mw.getCurrentFrame():callParserFunction('#coordinates', in_args) or ''
end
Line 649 ⟶ 652:
.. displaytitle(contents, Notes)
.. makeWikidataCategories()
end
if not args.nosave then
local page_title, count = mw.title.getCurrentTitle(), 1
if backward then
local errorstmp = {}
while not string.find((args[count-1] or ''), '[EW]') do tmp[count] = (args[count] or ''); count = count+1 end
tmp.count = count; count = 2*(count-1)
while count >= tmp.count do table.insert(tmp, 1, (args[count] or '')); count = count-1 end
for i, v in ipairs(tmp) do args[i] = v end
else
while count <= 9 do args[count] = (args[count] or ''); count = count+1 end
end
if isInTitle(Display) and not page_title.isTalkPage and (page_title.subpageText ~= 'doc' and page_title.subpageText ~= 'dok') and page_title.subpageText ~= 'testcases' then args[10] = 'primary' end
args.notes, args.format, args.display = nil
text = text .. coord_wrapper(args)
end
return text
Line 700 ⟶ 718:
for i, v in ipairs(frame.args) do
if i ~= 1 then
if not mw.ustring.find(frame.args[1], (mw.ustring.match(frame.args[i], '^(.-:)') or '')) then
frame.args[1] = mw.ustring.gsub(frame.args[1], '(params=.-)_? ', '%1_'..frame.args[i]..' ') end
end
end
end
if frame.args.name then
if not mw.ustring.find(frame.args[1], '<span class="vcard">') then
local namestr = frame.args.name
frame.args[1] = mw.ustring.gsub(frame.args[1],
'(<span class="geo%-default">)(<span[^<>]*>[^<>]*</span><span[^<>]*>[^<>]*<span[^<>]*>[^<>]*</span></span>)(</span>)',
'%1<span class="vcard">%2<span style="display:none">&#xfeff; (<span class="fn org">' .. namestr .. '</span>)</span></span>%3')
frame.args[1] = mw.ustring.gsub(frame.args[1], '(&params=[^&"<>%[%] ]*) ', '%1&title=' .. mw.uri.encode(namestr) .. ' ')
end
end