"ମଡ୍ୟୁଲ:Citation/CS1" ପୃଷ୍ଠାର ସଂସ୍କରଣଗୁଡ଼ିକ ମଧ୍ୟରେ ତଫାତ
Content deleted Content added
sync from sandbox; |
Undid revision 913814858 by Trappist the monk (talk) This edit has introduced citation errors all over the project. Please troubleshoot before implementing this change. See [https://en.wikipedia.org/wiki/Wikipedia:Administrators%27_noticeboard#Is_there_a_semi-automated_tool_that_could_fix_these_annoying_%22Cite_Web%22_errors?] |
||
୭ କ ଧାଡ଼ି:
local is_set, in_array, substitute, error_comment, set_error, select_one, -- functions in Module:Citation/CS1/Utilities
add_maint_cat, wrap_style, safe_for_italics, is_wikilink, make_wikilink
local z ={}; -- tables in Module:Citation/CS1/Utilities
Line ୭୧ ⟶ ୭୦:
added_prop_cats [key] = true; -- note that we've added this category
key = key:gsub ('(foreign_lang_source_?2?)%a%a%a?', '%1'); -- strip lang code from keyname
table.insert( z.properties_cats, substitute (cfg.prop_cats [key], arguments)); -- make name then add to table
end
end
Line ୧୫୧ ⟶ ୧୫୦:
domain = domain:gsub ('^//', ''); -- strip '//' from domain name if present; done here so we only have to do it once
if not domain:match ('^[%
return false;
end
Line ୧୫୮ ⟶ ୧୫୭:
return false;
end
-- Do most common case first
if domain:match ('%f[%a%d][%a%d][%a%d%-]+[%a%d]%.%a%a+$') then -- three or more character hostname.hostname or hostname.tld
return true;
return true;
return true;
return true;
elseif domain:match ('%f[%a%d][%a%d]%.org$') then -- one character/digit .org hostname
return true;
elseif domain:match ('%f[%a][qxz]%.com$') then -- assigned one character .com hostname (x.com times out 2015-12-10)
return true;
elseif domain:match ('%f[%a][iq]%.net$') then -- assigned one character .net hostname (q.net registered but not active 2015-12-10)
return true;
elseif domain:match ('%f[%a%d][%a%d]%.%a%a$') then -- one character hostname and cctld (2 chars)
return true;
elseif domain:match ('%f[%a%d][%a%d][%a%d]%.%a%a+$') then -- two character hostname and tld
return true;
elseif domain:match ('^%d%d?%d?%.%d%d?%d?%.%d%d?%d?%.%d%d?%d?') then -- IPv4 address
return true;
else
return false;
end
end
୪୪୫ କ ଧାଡ଼ି:
if not added_deprecated_cat then
added_deprecated_cat = true; -- note that we've added this category
table.insert( z.message_tail, { set_error( 'deprecated_params', {name}, true ) } ); -- add error message
end
end
୫୨୭ କ ଧାଡ଼ି:
is not added. At this time there is no error message for this condition.
Supports |script-title=
TODO: error messages when prefix is invalid ISO639-1 code; when script_value has prefix but no script;
]]
local function format_script_value (script_value
local lang=''; -- initialize to empty string
local name;
Line ୫୩୭ ⟶ ୫୩୮:
lang = script_value:match('^(%l%l)%s*:%s*%S.*'); -- get the language prefix or nil if there is no script
if not is_set (lang) then
return ''; -- script_value was just the prefix so return empty string
end
୫୪୮ କ ଧାଡ଼ି:
add_prop_cat ('script_with_name', {name, lang})
else
add_prop_cat ('script')
end
lang = ' lang="' .. lang .. '" '; -- convert prefix into a lang attribute
else
lang = ''; -- invalid so set lang to empty string
end
end
script_value = substitute (cfg.presentation['bdi'], {lang, script_value}); -- isolate in case script is rtl
Line ୫୭୦ ⟶ ୫୬୭:
]]
local function script_concatenate (title, script
if is_set (script) then
script = format_script_value (script
if is_set (script) then
title = title .. ' ' .. script; -- concatenate title and script title
Line ୫୯୬ ⟶ ୫୯୩:
local msg;
msg = cfg.messages[key]:lower(); -- set the message to lower case before
return substitute( msg, str );
else
return substitute( cfg.messages[key], str );
Line ୬୫୧ ⟶ ୬୪୮:
end
return ws_url, ws_label, L or D; -- return proper url or nil and a label or nil
end
Line ୬୯୪ ⟶ ୬୫୯:
]]
local function format_chapter_title (scriptchapter
local chapter_error = '';
local ws_url, ws_label, L = wikisource_url_make (chapter); -- make a wikisource url and label from a wikisource interwiki link
if ws_url then
ws_label = ws_label:gsub ('_', ''); -- replace underscore separaters with space characters
Line ୭୧୨ ⟶ ୬୭୭:
end
chapter = script_concatenate (chapter, scriptchapter
if is_set (chapterurl) then
chapter = external_link (chapterurl, chapter, chapter_url_source, access); -- adds bare_url_missing_title error if appropriate
elseif ws_url then
chapter = external_link (ws_url, chapter .. ' ', 'ws link in chapter'); -- adds bare_url_missing_title error if appropriate; space char to move icon away from chap text; TODO: better way to do this?
chapter = substitute (cfg.presentation['interwiki-icon'], {cfg.presentation['class-wikisource'], L, chapter});
end
Line ୭୨୬ ⟶ ୬୯୧:
chapter = chapter .. ' ' .. transchapter;
else -- here when transchapter without chapter or script-chapter
chapter = transchapter; --
chapter_error = ' ' .. set_error ('trans_missing_title', {'chapter'});
end
Line ୭୩୨ ⟶ ୬୯୭:
-- if is_set (chapterurl) then
-- chapter = external_link (chapterurl, chapter, chapter_url_source, access); -- adds bare_url_missing_title error if appropriate
-- end
Line ୮୩୫ ⟶ ୮୦୦:
-- maybe let through instead of raising an error?
-- v, origin[k] = args[k], k;
error( cfg.messages['unknown_argument_map']
end
Line ୧,୦୭୪ ⟶ ୧,୦୩୯:
local function is_good_vanc_name (last, first)
local first, suffix = first:match ('(.-),?%s*([%dJS][%drndth]+)%.?$') or first; -- if first has something that looks like a generational suffix, get it
if is_set (suffix) then
Line ୧,୨୭୨ ⟶ ୧,୨୩୭:
etal = true; -- set flag (may have been set previously here or by |display-<names>=etal)
if not nocat then -- no categorization for |vauthors=
table.insert( z.message_tail, {set_error ('etal', {param})}); -- and set an error if not added
end
end
Line ୧,୯୧୬ ⟶ ୧,୮୮୧:
if not is_set (value) then
return true; -- an empty parameter is ok
elseif in_array
return true;
else
Line ୨,୦୨୬ ⟶ ୧,୯୯୧:
if is_journal then
return substitute (cfg.messages['j-page(s)'], pages), '', '', '';
elseif tonumber(pages) ~= nil and not nopp then -- if pages is only digits, assume a single page number
return '', substitute (cfg.messages['p-prefix'], {sepc, pages}), '', '';
elseif not nopp then
Line ୨,୧୪୩ ⟶ ୨,୧୦୮:
err_msg = 'liveweb';
else
path, timestamp, flag = url:match('//web%.archive%.org/([^%d]*)(%d+)([^/]*)/'); -- split out some of the url parts for evaluation
if not is_set(timestamp) or 14 ~= timestamp:len() then -- path and flag optional, must have 14-digit timestamp here
Line ୨,୨୭୦ ⟶ ୨,୨୩୫:
end
if not is_valid_parameter_value (NameListFormat, 'name-list-format', cfg.keywords['name-list-format']) then -- only accepted value for this parameter is 'vanc'
NameListFormat = ''; -- anything else, set to empty string
end
end
end
local Year = A['Year'];
Line ୨,୨୯୭ ⟶ ୨,୨୬୨:
local Chapter = A['Chapter'];
local ScriptChapter = A['ScriptChapter'];
local ChapterLink -- = A['ChapterLink']; -- deprecated as a parameter but still used internally by cite episode
local TransChapter = A['TransChapter'];
Line ୨,୩୧୦ ⟶ ୨,୨୭୪:
ArchiveURL, ArchiveDate = archive_url_check (A['ArchiveURL'], A['ArchiveDate'])
local
if not is_valid_parameter_value (DeadURL, 'dead-url', cfg.keywords ['deadurl']) then -- set in config.defaults to 'yes'
DeadURL = ''; -- anything else, set to empty string
end
local URL = A['URL']
local URLorigin = A:ORIGIN('URL'); -- get name of parameter that holds URL
Line ୨,୩୩୫ ⟶ ୨,୨୮୭:
local ConferenceURLorigin = A:ORIGIN('ConferenceURL'); -- get name of parameter that holds ConferenceURL
local Periodical = A['Periodical'];
local Periodical_origin = A:ORIGIN('Periodical'); -- get the name of the periodical parameter
local Series = A['Series'];
Line ୨,୩୬୫ ⟶ ୨,୨୯୭:
local At;
if
Volume = A['Volume'];
end
-- conference & map books do not support issue
if in_array (config.CitationClass, cfg.templates_using_issue) and not (in_array (config.CitationClass, {'conference', 'map'}) and not is_set (Periodical))then
Issue = hyphen_to_dash (A['Issue']);
end
local Position = '';
if not in_array (config.CitationClass, cfg.templates_not_using_page) then
Line ୨,୪୦୪ ⟶ ୨,୩୧୬:
local PublisherName = A['PublisherName'];
local RegistrationRequired = A['RegistrationRequired'];
if not is_valid_parameter_value (RegistrationRequired, 'registration', cfg.keywords ['yes_true_y']) then
Line ୨,୪୩୨ ⟶ ୨,୩୩୪:
table.insert( z.message_tail, { set_error( 'param_access_requires_param', {'url'}, true ) } );
end
if is_set (UrlAccess) and is_set (SubscriptionRequired) then -- while not aliases, these are much the same so if both are set
table.insert( z.message_tail, { set_error( 'redundant_parameters', {wrap_style ('parameter', 'url-access') .. ' and ' .. wrap_style ('parameter', 'subscription')}, true ) } ); -- add error message
Line ୨,୪୪୩ ⟶ ୨,୩୪୫:
local ChapterUrlAccess = A['ChapterUrlAccess'];
if not is_valid_parameter_value (ChapterUrlAccess,
ChapterUrlAccess = nil;
end
if not is_set(ChapterURL) and is_set(ChapterUrlAccess) then
ChapterUrlAccess = nil;
table.insert( z.message_tail, { set_error( 'param_access_requires_param', {
end
Line ୨,୪୭୮ ⟶ ୨,୩୭୧:
local ID_list = extract_ids( args );
local ID_access_levels = extract_id_access_levels( args, ID_list );
Line ୨,୫୧୭ ⟶ ୨,୪୦୭:
end
local sepc;
local PostScript;
local Ref;
sepc, PostScript, Ref = set_style (Mode:lower(), A['PostScript'], A['Ref'], config.CitationClass);
use_lowercase = ( sepc == ',' );
--check this page to see if it is in one of the namespaces that cs1 is not supposed to add to the error categories
Line ୨,୫୩୭ ⟶ ୨,୪୨୭:
-- check for extra |page=, |pages= or |at= parameters. (also sheet and sheets while we're at it)
select_one( args, {'page', 'p', 'pp', 'pages', 'at', 'sheet', 'sheets'}, 'redundant_parameters' ); -- this is a dummy call simply to get the error message and category
local coins_pages;
Line ୨,୫୫୦ ⟶ ୨,୪୪୦:
end
if not is_set(PublicationPlace) and is_set(Place) then
PublicationPlace = Place; -- promote |place= (|location=) to |publication-place
end
if PublicationPlace == Place then Place = ''; end
--[[
Line ୨,୫୬୧ ⟶ ୨,୪୫୨:
|encyclopedia and |title then map |title to |article and |encyclopedia to |title
|encyclopedia and |article then map |encyclopedia to |title
|encyclopedia then map |encyclopedia to |title
|trans-title maps to |trans-chapter when |title is re-mapped
|url maps to |chapterurl when |title is remapped
Line ୨,୫୭୨ ⟶ ୨,୪୬୪:
if ( config.CitationClass == "encyclopaedia" ) or ( config.CitationClass == "citation" and is_set (Encyclopedia)) then -- test code for citation
if is_set
if is_set(Title) or is_set (ScriptTitle) then
if not is_set(Chapter) then
Chapter = Title; -- |encyclopedia and |title are set so map |title to |article and |encyclopedia to |title
ScriptChapter = ScriptTitle;
TransChapter = TransTitle;
ChapterURL = URL;
Line ୨,୫୯୪ ⟶ ୨,୪୮୫:
ScriptTitle = '';
end
Title = Periodical; -- |encyclopedia set and |article set or not set so map |encyclopedia to |title
Periodical = ''; -- redundant so unset
end
Line ୨,୬୧୫ ⟶ ୨,୫୦୬:
if (config.CitationClass == "mailinglist") then
Periodical = A ['MailingList'];
elseif 'mailinglist' ==
Periodical = ''; -- unset because mailing list is only used for cite mailing list
end
Line ୨,୬୪୮ ⟶ ୨,୫୩୯:
Chapter = A['Map'];
ChapterURL = A['MapURL'];
ChapterUrlAccess =
TransChapter = A['TransMap'];
ChapterURLorigin = A:ORIGIN('MapURL');
Line ୨,୬୯୨ ⟶ ୨,୫୮୩:
-- assemble a table of parts concatenated later into Series
if is_set(Season) then table.insert(s, wrap_msg ('season', Season, use_lowercase)); end
if is_set(SeriesNumber) then table.insert(s, wrap_msg ('
if is_set(Issue) then table.insert(s, wrap_msg ('episode', Issue, use_lowercase)); end
Issue = ''; -- unset because this is not a unique parameter
Line ୨,୬୯୮ ⟶ ୨,୫୮୯:
Chapter = Title; -- promote title parameters to chapter
ScriptChapter = ScriptTitle;
ChapterLink = TitleLink; -- alias episodelink
TransChapter = TransTitle;
Line ୨,୭୨୯ ⟶ ୨,୬୧୯:
-- end of {{cite episode}} stuff
-- Account for the oddities that are {{cite arxiv}}, {{cite biorxiv}}, {{cite citeseerx
do
if in_array (config.CitationClass, {'arxiv', 'biorxiv', 'citeseerx
if not is_set (ID_list[config.CitationClass:upper()]) then -- |arxiv= or |eprint= required for cite arxiv; |biorxiv= & |citeseerx= required for their templates
table.insert( z.message_tail, { set_error( config.CitationClass .. '_missing', {}, true ) } ); -- add error message
end
if 'arxiv' == config.CitationClass then
Periodical = 'arXiv'; -- set to arXiv for COinS; after that, must be set to empty string
end
Periodical = 'bioRxiv'; -- set to bioRxiv for COinS; after that, must be set to empty string
end
if 'citeseerx' == config.CitationClass then
Periodical = 'CiteSeerX'; -- set to CiteSeerX for COinS; after that, must be set to empty string
end
end
end
Line ୨,୮୭୦ ⟶ ୨,୭୭୦:
end
end
if 'none' == Title and in_array (config.CitationClass, {'journal', 'citation'}) and is_set (Periodical) and 'journal' == A:ORIGIN('Periodical') then -- special case for journal cites
Title = ''; -- set title to empty string
add_maint_cat ('untitled');
end
check_for_url ({ -- add error message when any of these parameters
['title']=Title,
[A:ORIGIN('Chapter')]=Chapter,
[
[
});
Line ୨,୯୦୬ ⟶ ୨,୮୦୩:
-- this is the function call to COinS()
local OCinSoutput = COinS({
['Periodical'] =
['Encyclopedia'] =
['Chapter'] = make_coins_title (coins_chapter, ScriptChapter), -- Chapter and ScriptChapter stripped of bold / italic wikimarkup
['Degree'] = Degree; -- cite thesis only
Line ୨,୯୧୮ ⟶ ୨,୮୧୫:
['Volume'] = Volume,
['Issue'] = Issue,
['Pages'] = coins_pages or get_coins_pages (first_set ({Sheet, Sheets, Page, Pages, At}, 5)), -- pages stripped of external links
['Edition'] = Edition,
['PublisherName'] = PublisherName,
['URL'] = first_set ({ChapterURL, URL}, 2),
['Authors'] = coins_author,
Line ୨,୯୨୭ ⟶ ୨,୮୨୪:
}, config.CitationClass);
-- Account for the oddities that are {{cite arxiv}}, {{cite biorxiv
if in_array (config.CitationClass, {'arxiv', 'biorxiv', 'citeseerx
Periodical = ''; -- periodical not allowed in these templates; if article has been published, use cite journal
end
Line ୨,୯୩୫ ⟶ ୨,୮୩୨:
if 'newsgroup' == config.CitationClass then
if is_set (PublisherName) then
PublisherName = substitute (cfg.messages['newsgroup'], external_link( 'news:' .. PublisherName, PublisherName,
end
end
-- Now perform various field substitutions.
Line ୨,୯୮୪ ⟶ ୨,୮୮୩:
control.maximum , contributor_etal = get_display_names (A['DisplayContributors'], #c, 'contributors', contributor_etal);
Contributors = list_people (control, c, contributor_etal);
-- control.maximum = #c; -- number of contributors
-- Contributors = list_people(control, c, false); -- et al not currently supported
end
do -- now do authors
Line ୩,୦୧୫ ⟶ ୨,୯୧୬:
-- special case for chapter format so no error message or cat when chapter not supported
if not (in_array(config.CitationClass, {'web', 'news', 'journal', 'magazine', 'pressrelease', 'podcast', 'newsgroup', 'arxiv', 'biorxiv', 'citeseerx
('citation' == config.CitationClass and
ChapterFormat = style_format (ChapterFormat, ChapterURL, 'chapter-format', 'chapter-url');
end
if not is_set(URL) then
if in_array(config.CitationClass, {"web","podcast", "mailinglist"})
table.insert( z.message_tail, { set_error( 'cite_web_url', {}, true ) } );
end
Line ୩,୦୩୪ ⟶ ୨,୯୩୪:
local OriginalURL, OriginalURLorigin, OriginalFormat, OriginalAccess;
if is_set( ArchiveURL ) then
if is_set (ChapterURL) then -- if chapter-url is set apply archive url to it
Line ୩,୦୪୧ ⟶ ୨,୯୪୦:
OriginalURLorigin = ChapterURLorigin; -- name of chapter-url parameter for error messages
OriginalFormat = ChapterFormat; -- and original |chapter-format=
ChapterURL = ArchiveURL -- swap-in the archive's url
ChapterURLorigin = A:ORIGIN('ArchiveURL') -- name of archive-url parameter for error messages
Line ୩,୦୫୩ ⟶ ୨,୯୫୧:
OriginalFormat = Format; -- and original |format=
OriginalAccess = UrlAccess;
URL = ArchiveURL -- swap-in the archive's url
URLorigin = A:ORIGIN('ArchiveURL') -- name of archive url parameter for error messages
Line ୩,୦୬୩ ⟶ ୨,୯୬୦:
end
if in_array(config.CitationClass, {'web','news','journal', 'magazine', 'pressrelease', 'podcast', 'newsgroup', 'arxiv', 'biorxiv', 'citeseerx
('citation' == config.CitationClass and
local chap_param;
if is_set (Chapter) then -- get a parameter name from one of these chapter related meta-parameters
Line ୩,୦୭୩ ⟶ ୨,୯୭୦:
chap_param = A:ORIGIN ('ChapterURL')
elseif is_set (ScriptChapter) then
chap_param =
else is_set (ChapterFormat)
chap_param = A:ORIGIN ('ChapterFormat')
Line ୩,୦୯୪ ⟶ ୨,୯୯୧:
end
Chapter = format_chapter_title (ScriptChapter
if is_set (Chapter) then
Chapter = Chapter .. ChapterFormat ;
Line ୩,୧୨୨ ⟶ ୩,୦୧୯:
end
if in_array(config.CitationClass, {'web', 'news', 'journal', 'magazine', 'pressrelease', 'podcast', 'newsgroup', 'mailinglist', 'interview', 'arxiv', 'biorxiv', 'citeseerx
('citation' == config.CitationClass and
('map' == config.CitationClass and
Title = kern_quotes (Title); -- if necessary, separate title's leading and trailing quote marks from Module provided quote marks
Title = wrap_style ('quoted-title', Title);
Title = script_concatenate (Title, ScriptTitle
TransTitle= wrap_style ('trans-quoted-title', TransTitle );
elseif 'report' == config.CitationClass then -- no styling for cite report
Title = script_concatenate (Title, ScriptTitle
TransTitle= wrap_style ('trans-quoted-title', TransTitle ); -- for cite report, use this form for trans-title
else
Title = wrap_style ('italic-title', Title);
Title = script_concatenate (Title, ScriptTitle
TransTitle = wrap_style ('trans-italic-title', TransTitle);
end
Line ୩,୨୬୬ ⟶ ୩,୧୬୩:
end
Series = is_set
Agency = is_set(Agency) and (sepc .. " " .. Agency) or "";
Volume = format_volume_issue (Volume, Issue, config.CitationClass, Periodical_origin, sepc, use_lowercase);
------------------------------------ totally unrelated data
Via = " " .. wrap_msg ('via', Via);
end
--[[
Line ୩,୩୨୪ ⟶ ୩,୨୨୫:
ArchiveDate = set_error('archive_missing_date');
end
if "
local arch_text = cfg.messages['archived'];
if sepc ~= "." then arch_text = arch_text:lower() end
Archived = sepc .. " " .. substitute( cfg.messages['archived-
{ external_link( ArchiveURL, arch_text, A:ORIGIN('ArchiveURL'), nil ) .. ArchiveFormat, ArchiveDate } );
if not is_set(OriginalURL) then
Archived = Archived .. " " .. set_error('archive_missing_url');
end
elseif is_set(OriginalURL) then --
local arch_text = cfg.messages['archived-dead'];
if sepc ~= "." then arch_text = arch_text:lower() end
if in_array (
Archived = sepc .. " " .. 'Archived from the original on ' .. ArchiveDate; -- format already styled
if 'bot: unknown' ==
add_maint_cat ('bot:_unknown'); -- and add a category if not already added
else
add_maint_cat ('unfit'); -- and add a category if not already added
end
else --
Archived = sepc .. " " .. substitute( arch_text,
{ external_link( OriginalURL, cfg.messages['original'], OriginalURLorigin, OriginalAccess ) .. OriginalFormat, ArchiveDate } ); -- format already styled
Line ୩,୪୦୧ ⟶ ୩,୩୦୨:
-- Several of the above rely upon detecting this as nil, so do it last.
if
if is_set(Title) or is_set(TitleNote) then
Periodical = sepc .. " " ..
else
Periodical =
end
end
Line ୩,୪୧୩ ⟶ ୩,୩୧୪:
the annotation directly follows the |title= parameter value in the citation rather than the |event= parameter value (if provided).
]]
if "speech" == config.CitationClass then
TitleNote = " (Speech)";
if is_set (Periodical) then
if is_set (Conference) then
Conference = Conference .. sepc .. " ";
end
end
Line ୩,୫୪୨ ⟶ ୩,୪୪୩:
if is_set(PostScript) and PostScript ~= sepc then
text = safe_join( {text, sepc}, sepc );
text = text:sub(1,-sepc:len()-1);
end
Line ୩,୫୯୪ ⟶ ୩,୪୯୫:
end
table.insert (render, substitute (cfg.presentation['ocins'], {OCinSoutput})); -- append metadata to the citation
if 0 ~= #z.message_tail then
Line ୩,୬୫୪ ⟶ ୩,୫୫୫:
local state;
if in_array (cite_class, {'arxiv', 'biorxiv', 'citeseerx
state = whitelist.limited_basic_arguments[name];
if true == state then return true; end -- valid actively supported parameter
Line ୩,୭୨୦ ⟶ ୩,୬୨୧:
value = value:gsub ('%b<>', ''); -- remove xml/html tags because attributes: class=, title=, etc
capture = value:match ('%s+(%a[%
if capture and validate (capture) then -- if the capture is a valid parameter name
table.insert( z.message_tail, {set_error ('missing_pipe',parameter)});
Line ୩,୭୨୭ ⟶ ୩,୬୨୮:
--[[--------------------------<
This is used by templates such as {{cite book}} to create the actual citation text.
Line ୩,୭୯୭ ⟶ ୩,୬୮୧:
is_wikilink = utilities.is_wikilink;
make_wikilink = utilities.make_wikilink;
z = utilities.z; -- table of error and category tables in Module:Citation/CS1/Utilities
Line ୩,୮୭୮ ⟶ ୩,୭୬୧:
if 'string' == type (k) then -- don't evaluate positional parameters
has_invisible_chars (k, v);
end
end
|