Module:Citation/CS1/sandbox: Difference between revisions
| m use comma from Configuartions Module to support other languages | imported>Trappist the monk No edit summary | ||
| (One intermediate revision by one other user not shown) | |||
| Line 1: | Line 1: | ||
| --[[ | --[[ | ||
| History of changes since last sync:  | History of changes since last sync: 2023-01-14 | ||
| 2023-02-21: detect |archive-date= / |archive-url= timestamp mismatch; see Help_talk:Citation_Style_1#Error_or_Maint_message_if_archive_date_doesn't_match_url | |||
| 2023-03-14: cleanup archive error messaging; see Help_talk:Citation_Style_1#Possible_invalid_edits_to_live_CS1_module | |||
| ]] | ]] | ||
| Line 22: | Line 18: | ||
| local utilities;																-- functions in Module:Citation/CS1/Utilities | local utilities;																-- functions in Module:Citation/CS1/Utilities | ||
| local z ={};																	-- table of tables in Module:Citation/CS1/Utilities | local z = {};																	-- table of tables in Module:Citation/CS1/Utilities | ||
| local identifiers;																-- functions and tables in Module:Citation/CS1/Identifiers | local identifiers;																-- functions and tables in Module:Citation/CS1/Identifiers | ||
| Line 277: | Line 273: | ||
| local function link_title_ok (link, lorig, title, torig) | local function link_title_ok (link, lorig, title, torig) | ||
| local orig; | 	local orig; | ||
| 	if utilities.is_set (link) then 											-- don't bother if <param>-link doesn't have a value | 	if utilities.is_set (link) then 											-- don't bother if <param>-link doesn't have a value | ||
| 		if not link_param_ok (link) then										-- check |<param>-link= markup | 		if not link_param_ok (link) then										-- check |<param>-link= markup | ||
| Line 413: | Line 409: | ||
| 			utilities.set_message ('err_bare_url_missing_title', {utilities.wrap_style ('parameter', source)}); | 			utilities.set_message ('err_bare_url_missing_title', {utilities.wrap_style ('parameter', source)}); | ||
| 		else | 		else | ||
| 			error (cfg.messages["bare_url_no_origin"]); | 			error (cfg.messages["bare_url_no_origin"]);							-- programmer error; valid parameter name does not have matching meta-parameter | ||
| 		end			 | 		end			 | ||
| 	end | 	end | ||
| Line 1,277: | Line 1,273: | ||
| 					end | 					end | ||
| 				end | 				end | ||
| 				table.insert (name_list, one);									-- add it to the list of names | 				table.insert (name_list, one);									-- add it to the list of names | ||
| Line 1,608: | Line 1,599: | ||
| 				last = utilities.remove_wiki_link (last);						-- remove wikilink markup; show display value only | 				last = utilities.remove_wiki_link (last);						-- remove wikilink markup; show display value only | ||
| 			end | 			end | ||
| 		end | 		end | ||
| 		if link then															-- error check |linkn= alias for unknown interwiki link prefix | 		if link then															-- error check |linkn= alias for unknown interwiki link prefix | ||
| 			local project, language = interwiki_prefixen_get (link, false);		-- false because  | 			local project, language = interwiki_prefixen_get (link, false);		-- false because wiki links in |author-linkn= is an error | ||
| 			if nil == project and nil == language then							-- when both are nil | 			if nil == project and nil == language then							-- when both are nil | ||
| 				utilities.set_message ('err_bad_paramlink', link_alias);		-- not known, emit an error message	-- TODO: err_bad_interwiki? | 				utilities.set_message ('err_bad_paramlink', link_alias);		-- not known, emit an error message	-- TODO: err_bad_interwiki? | ||
| Line 1,622: | Line 1,608: | ||
| 				link_alias = nil; | 				link_alias = nil; | ||
| 			end | 			end | ||
| 		end | 		end | ||
| Line 1,768: | Line 1,748: | ||
| 			if cfg.this_wiki_code ~= lang_subtag then							-- when the language is not the same as this wiki's language | 			if cfg.this_wiki_code ~= lang_subtag then							-- when the language is not the same as this wiki's language | ||
| 				if 2 == lang_subtag:len() then									-- and is a two-character tag | 				if 2 == lang_subtag:len() then									-- and is a two-character tag | ||
| 					utilities.add_prop_cat ('foreign-lang-source', {name, tag}, lang_subtag);		-- categorize it; tag appended to allow for multiple language categorization | 					utilities.add_prop_cat ('foreign-lang-source', {name, tag}, lang_subtag);		-- categorize it; tag appended to allow for multiple language categorization | ||
| 				else															-- or is a recognized language (but has a three-character tag) | 				else															-- or is a recognized language (but has a three-character tag) | ||
| Line 1,817: | Line 1,796: | ||
| 	return cfg.presentation['sep_' .. mode], postscript; | 	return cfg.presentation['sep_' .. mode], postscript; | ||
| end | end | ||
| --[[--------------------------< S E T _ S T Y L E >----------------------------- | --[[--------------------------< S E T _ S T Y L E >----------------------------- | ||
| Line 1,907: | Line 1,887: | ||
| inputs: | inputs: | ||
| 	max: A['DisplayAuthors'] or A['DisplayEditors']; a number or some flavor of etal | 	max: A['DisplayAuthors'] or A['DisplayEditors'], etc; a number or some flavor of etal | ||
| 	count: #a or #e | 	count: #a or #e | ||
| 	list_name: 'authors' or 'editors' | 	list_name: 'authors' or 'editors' | ||
| 	etal: author_etal or editor_etal | 	etal: author_etal or editor_etal | ||
| This function sets an error message when |display-xxxxors= value greater than or equal to number of names but | |||
| not when <max> comes from {{cs1 config}} global settings.  When using global settings, <param> is set to the | |||
| keyword 'cs1 config' which is used to supress the normal error.  Error is suppressed because it is to be expected | |||
| that some citations in an article will have the same or fewer names that the limit specified in {{cs1 config}}. | |||
| ]] | ]] | ||
| Line 1,921: | Line 1,906: | ||
| 		elseif max:match ('^%d+$') then											-- if is a string of numbers | 		elseif max:match ('^%d+$') then											-- if is a string of numbers | ||
| 			max = tonumber (max);												-- make it a number | 			max = tonumber (max);												-- make it a number | ||
| 			if max >= count then	 | 			if (max >= count) and ('cs1 config' ~= param) then					-- error when local |display-xxxxors= value greater than or equal to number of names; not an error when using global setting | ||
| 				utilities.set_message ('err_disp_name', {param, max});			-- add error message | 				utilities.set_message ('err_disp_name', {param, max});			-- add error message | ||
| 				max = nil; | 				max = nil; | ||
| 			end | 			end | ||
| 		else																	-- not a valid keyword or number | 		else																	-- not a valid keyword or number | ||
| 			utilities.set_message ('err_disp_name', {param, max});	 | 			utilities.set_message ('err_disp_name', {param, max});				-- add error message | ||
| 			max = nil;															-- unset; as if |display-xxxxors= had not been set | 			max = nil;															-- unset; as if |display-xxxxors= had not been set | ||
| 		end | 		end | ||
| Line 2,442: | Line 2,427: | ||
| 	for timestamp errors when the timestamp has a wildcard, return the URL unmodified | 	for timestamp errors when the timestamp has a wildcard, return the URL unmodified | ||
| 	for timestamp errors when the timestamp does not have a wildcard, return with timestamp limited to six digits plus wildcard (/yyyymm*/) | 	for timestamp errors when the timestamp does not have a wildcard, return with timestamp limited to six digits plus wildcard (/yyyymm*/) | ||
| A secondary function is to return an archive-url timestamp from those urls that have them (archive.org and | |||
| archive.today).  The timestamp is used by validation.archive_date_check() to see if the value in |archive-date= | |||
| matches the timestamp in the archive url. | |||
| ]=] | ]=] | ||
| Line 2,449: | Line 2,438: | ||
| 	local path, timestamp, flag;												-- portions of the archive.org URL | 	local path, timestamp, flag;												-- portions of the archive.org URL | ||
| 	timestamp = url:match ('//archive.today/(%d%d%d%d%d%d%d%d%d%d%d%d%d%d)/');	-- get timestamp from archive.today urls | |||
| 	if timestamp then															-- if this was an archive.today url ... | |||
| 		return url, date, timestamp;											-- return ArchiveURL, ArchiveDate, and timestamp from |archive-url=, and done | |||
| 	end | |||
| 																				-- here for archive.org urls | |||
| 	if (not url:match('//web%.archive%.org/')) and (not url:match('//liveweb%.archive%.org/')) then		-- also deprecated liveweb Wayback machine URL | 	if (not url:match('//web%.archive%.org/')) and (not url:match('//liveweb%.archive%.org/')) then		-- also deprecated liveweb Wayback machine URL | ||
| 		return url, date;														-- not an archive.org archive, return ArchiveURL and ArchiveDate | 		return url, date;														-- not an archive.org archive, return ArchiveURL and ArchiveDate | ||
| Line 2,478: | Line 2,472: | ||
| 			err_msg = cfg.err_msg_supl.flag; | 			err_msg = cfg.err_msg_supl.flag; | ||
| 		else | 		else | ||
| 			return url, date;	 | 			return url, date, timestamp;										-- return ArchiveURL, ArchiveDate, and timestamp from |archive-url= | ||
| 		end | 		end | ||
| 	end | 	end | ||
| Line 2,485: | Line 2,479: | ||
| 	if is_preview_mode then | 	if is_preview_mode then | ||
| 		return url, date;	 | 		return url, date, timestamp;											-- preview mode so return ArchiveURL, ArchiveDate, and timestamp from |archive-url= | ||
| 	else | 	else | ||
| 		return '', '';															-- return empty strings for ArchiveURL and ArchiveDate | 		return '', '';															-- return empty strings for ArchiveURL and ArchiveDate | ||
| Line 2,552: | Line 2,546: | ||
| 	local a	= {};																-- authors list from |lastn= / |firstn= pairs or |vauthors= | 	local a	= {};																-- authors list from |lastn= / |firstn= pairs or |vauthors= | ||
| 	local Authors; | 	local Authors; | ||
| 	local NameListStyle = is_valid_parameter_value (A['NameListStyle'], A:ORIGIN('NameListStyle'), cfg.keywords_lists['name-list-style'], ''); | 	local NameListStyle; | ||
| 		if cfg.global_cs1_config_t['NameListStyle'] then						-- global setting in {{cs1 config}} overrides local |name-list-style= parameter value; nil when empty or assigned value invalid | |||
| 			NameListStyle = is_valid_parameter_value (cfg.global_cs1_config_t['NameListStyle'], 'cs1 config: name-list-style', cfg.keywords_lists['name-list-style'], '');	-- error messaging 'param' here is a hoax | |||
| 		else | |||
| 			NameListStyle = is_valid_parameter_value (A['NameListStyle'], A:ORIGIN('NameListStyle'), cfg.keywords_lists['name-list-style'], ''); | |||
| 		end | |||
| 		if cfg.global_cs1_config_t['NameListStyle'] and utilities.is_set (A['NameListStyle']) then	-- when template has |name-list-style=<something> which global setting has overridden | |||
| 			utilities.set_message ('maint_overridden_setting');					-- set a maint message | |||
| 		end | |||
| 	local Collaboration = A['Collaboration']; | 	local Collaboration = A['Collaboration']; | ||
| Line 2,561: | Line 2,565: | ||
| 		elseif 2 == selected then | 		elseif 2 == selected then | ||
| 			NameListStyle = 'vanc';												-- override whatever |name-list-style= might be | 			NameListStyle = 'vanc';												-- override whatever |name-list-style= might be | ||
| 			a, author_etal = parse_vauthors_veditors (args,  | 			a, author_etal = parse_vauthors_veditors (args, A['Vauthors'], 'AuthorList');	-- fetch author list from |vauthors=, |author-linkn=, and |author-maskn= | ||
| 		elseif 3 == selected then | 		elseif 3 == selected then | ||
| 			Authors = A['Authors'];												-- use content of |authors= | 			Authors = A['Authors'];												-- use content of |authors= | ||
| Line 2,646: | Line 2,650: | ||
| 	if 'mailinglist' == config.CitationClass then								-- special case for {{cite mailing list}} | 	if 'mailinglist' == config.CitationClass then								-- special case for {{cite mailing list}} | ||
| 		if utilities.is_set (Periodical) and utilities.is_set (A ['MailingList']) then	-- both set emit an error TODO: make a function for this and similar? | 		if utilities.is_set (Periodical) and utilities.is_set (A ['MailingList']) then	-- both set emit an error TODO: make a function for this and similar? | ||
| 			utilities.set_message ('err_redundant_parameters', {utilities.wrap_style ('parameter', Periodical_origin) .. '  | 			utilities.set_message ('err_redundant_parameters', {utilities.wrap_style ('parameter', Periodical_origin) .. cfg.presentation['sep_list_pair'] .. utilities.wrap_style ('parameter', 'mailinglist')}); | ||
| 		end | 		end | ||
| Line 2,767: | Line 2,771: | ||
| 	-- check this page to see if it is in one of the namespaces that cs1 is not supposed to add to the error categories | 	-- check this page to see if it is in one of the namespaces that cs1 is not supposed to add to the error categories | ||
| 	if not utilities.is_set (no_tracking_cats) then								-- ignore if we are already not going to categorize this page | 	if not utilities.is_set (no_tracking_cats) then								-- ignore if we are already not going to categorize this page | ||
| 		if cfg.uncategorized_namespaces[this_page.namespace] then				-- is this page's namespace id one of the uncategorized namespace ids? | |||
| 		if cfg.uncategorized_namespaces[this_page.namespace] then				-- is this  | |||
| 			no_tracking_cats = "true";											-- set no_tracking_cats | 			no_tracking_cats = "true";											-- set no_tracking_cats | ||
| 		end | 		end | ||
| Line 2,833: | Line 2,836: | ||
| 	if ('encyclopaedia' == config.CitationClass) or ('citation' == config.CitationClass and utilities.is_set (Encyclopedia)) then | 	if ('encyclopaedia' == config.CitationClass) or ('citation' == config.CitationClass and utilities.is_set (Encyclopedia)) then | ||
| 		if utilities.is_set (Periodical) and utilities.is_set (Encyclopedia) then	-- when both set emit an error TODO: make a function for this and similar? | 		if utilities.is_set (Periodical) and utilities.is_set (Encyclopedia) then	-- when both set emit an error TODO: make a function for this and similar? | ||
| 			utilities.set_message ('err_redundant_parameters', {utilities.wrap_style ('parameter', A:ORIGIN ('Encyclopedia')) .. '  | 			utilities.set_message ('err_redundant_parameters', {utilities.wrap_style ('parameter', A:ORIGIN ('Encyclopedia')) .. cfg.presentation['sep_list_pair'] .. utilities.wrap_style ('parameter', Periodical_origin)}); | ||
| 		end | 		end | ||
| Line 2,879: | Line 2,882: | ||
| 				ID = A['Number'];												-- yes, use it | 				ID = A['Number'];												-- yes, use it | ||
| 			else																-- ID has a value so emit error message | 			else																-- ID has a value so emit error message | ||
| 				utilities.set_message ('err_redundant_parameters', {utilities.wrap_style ('parameter', 'id') .. '  | 				utilities.set_message ('err_redundant_parameters', {utilities.wrap_style ('parameter', 'id') .. cfg.presentation['sep_list_pair'] .. utilities.wrap_style ('parameter', 'number')}); | ||
| 			end | 			end | ||
| 		end	 | 		end	 | ||
| Line 2,912: | Line 2,915: | ||
| 	-- CS1/2 mode | 	-- CS1/2 mode | ||
| 	local Mode = is_valid_parameter_value (A['Mode'], A:ORIGIN('Mode'), cfg.keywords_lists['mode'], ''); | 	local Mode; | ||
| 		if cfg.global_cs1_config_t['Mode'] then									-- global setting in {{cs1 config}} overrides local |mode= parameter value; nil when empty or assigned value invalid | |||
| 			Mode = is_valid_parameter_value (cfg.global_cs1_config_t['Mode'], 'cs1 config: mode', cfg.keywords_lists['mode'], '');	-- error messaging 'param' here is a hoax | |||
| 		else | |||
| 			Mode = is_valid_parameter_value (A['Mode'], A:ORIGIN('Mode'), cfg.keywords_lists['mode'], ''); | |||
| 		end | |||
| 		if cfg.global_cs1_config_t['Mode'] and utilities.is_set (A['Mode']) then	-- when template has |mode=<something> which global setting has overridden | |||
| 			utilities.set_message ('maint_overridden_setting');					-- set a maint message | |||
| 		end | |||
| 	-- separator character and postscript | 	-- separator character and postscript | ||
| 	local sepc, PostScript = set_style (Mode:lower(), A['PostScript'], config.CitationClass); | 	local sepc, PostScript = set_style (Mode:lower(), A['PostScript'], config.CitationClass); | ||
| Line 2,925: | Line 2,938: | ||
| 	if config.CitationClass == "map" then | 	if config.CitationClass == "map" then | ||
| 		if utilities.is_set (Chapter) then										--TODO: make a function for this and similar? | 		if utilities.is_set (Chapter) then										--TODO: make a function for this and similar? | ||
| 			utilities.set_message ('err_redundant_parameters', {utilities.wrap_style ('parameter', 'map') .. '  | 			utilities.set_message ('err_redundant_parameters', {utilities.wrap_style ('parameter', 'map') .. cfg.presentation['sep_list_pair'] .. utilities.wrap_style ('parameter', Chapter_origin)});	-- add error message | ||
| 		end | 		end | ||
| 		Chapter = A['Map']; | 		Chapter = A['Map']; | ||
| Line 2,968: | Line 2,981: | ||
| 			if utilities.is_set (Season) and utilities.is_set (SeriesNumber) then	-- these are mutually exclusive so if both are set TODO: make a function for this and similar? | 			if utilities.is_set (Season) and utilities.is_set (SeriesNumber) then	-- these are mutually exclusive so if both are set TODO: make a function for this and similar? | ||
| 				utilities.set_message ('err_redundant_parameters', {utilities.wrap_style ('parameter', 'season') .. '  | 				utilities.set_message ('err_redundant_parameters', {utilities.wrap_style ('parameter', 'season') .. cfg.presentation['sep_list_pair'] .. utilities.wrap_style ('parameter', 'seriesno')});		-- add error message | ||
| 				SeriesNumber = '';												-- unset; prefer |season= over |seriesno= | 				SeriesNumber = '';												-- unset; prefer |season= over |seriesno= | ||
| 			end | 			end | ||
| Line 3,064: | Line 3,077: | ||
| 	local ArchiveDate; | 	local ArchiveDate; | ||
| 	local ArchiveFormat = A['ArchiveFormat']; | 	local ArchiveFormat = A['ArchiveFormat']; | ||
| 	local archive_url_timestamp;												-- timestamp from wayback machine url | |||
| 	ArchiveURL, ArchiveDate = archive_url_check (A['ArchiveURL'], A['ArchiveDate']) | |||
| 	ArchiveURL, ArchiveDate, archive_url_timestamp = archive_url_check (A['ArchiveURL'], A['ArchiveDate']) | |||
| 	ArchiveFormat = style_format (ArchiveFormat, ArchiveURL, 'archive-format', 'archive-url'); | 	ArchiveFormat = style_format (ArchiveFormat, ArchiveURL, 'archive-format', 'archive-url'); | ||
| 	ArchiveURL, ArchiveDate = is_unique_archive_url (ArchiveURL, URL, ChapterURL, A:ORIGIN('ArchiveURL'), ArchiveDate);		-- add error message when URL or ChapterURL == ArchiveURL | 	ArchiveURL, ArchiveDate = is_unique_archive_url (ArchiveURL, URL, ChapterURL, A:ORIGIN('ArchiveURL'), ArchiveDate);		-- add error message when URL or ChapterURL == ArchiveURL | ||
| 	local AccessDate = A['AccessDate']; | 	local AccessDate = A['AccessDate']; | ||
| 	local LayDate = A['LayDate']; | 	local LayDate = A['LayDate']; | ||
| Line 3,129: | Line 3,142: | ||
| 				LayDate = date_parameters_list['lay-date'].val; | 				LayDate = date_parameters_list['lay-date'].val; | ||
| 				PublicationDate = date_parameters_list['publication-date'].val; | 				PublicationDate = date_parameters_list['publication-date'].val; | ||
| 			end | |||
| 			if archive_url_timestamp and utilities.is_set (ArchiveDate) then | |||
| 				validation.archive_date_check (ArchiveDate, archive_url_timestamp);	-- does YYYYMMDD in archive_url_timestamp match date in ArchiveDate | |||
| 			end | 			end | ||
| 		else | 		else | ||
| Line 3,272: | Line 3,289: | ||
| 		local last_first_list; | 		local last_first_list; | ||
| 		local control = {   | 		local control = {   | ||
| 			format = NameListStyle,												-- empty string or 'vanc' | 			format = NameListStyle,												-- empty string, '&', 'amp', 'and', or 'vanc' | ||
| 			maximum = nil,														-- as if display-authors or display-editors not set | 			maximum = nil,														-- as if display-authors or display-editors not set | ||
| 			mode = Mode | 			mode = Mode | ||
| Line 3,278: | Line 3,295: | ||
| 		do																		-- do editor name list first because the now unsupported coauthors used to modify control table | 		do																		-- do editor name list first because the now unsupported coauthors used to modify control table | ||
| 			control.maximum , editor_etal = get_display_names (A['DisplayEditors'], #e, 'editors', editor_etal, A:ORIGIN ('DisplayEditors')); | 			if cfg.global_cs1_config_t['DisplayEditors'] then					-- global setting from {{cs1 config}} overrides local setting | ||
| 				control.maximum , editor_etal = get_display_names (cfg.global_cs1_config_t['DisplayEditors'], #e, 'editors', editor_etal, 'cs1 config'); | |||
| 			else | |||
| 				control.maximum , editor_etal = get_display_names (A['DisplayEditors'], #e, 'editors', editor_etal, A:ORIGIN ('DisplayEditors')); | |||
| 			end | |||
| 			if cfg.global_cs1_config_t['DisplayEditors'] and utilities.is_set (A['DisplayEditors']) then	-- when template has |display-editors=<something> which global setting has overridden | |||
| 				utilities.set_message ('maint_overridden_setting');				-- set a maint message | |||
| 			end | |||
| 			Editors, EditorCount = list_people (control, e, editor_etal); | 			Editors, EditorCount = list_people (control, e, editor_etal); | ||
| Line 3,286: | Line 3,312: | ||
| 		end | 		end | ||
| 		do																		-- now do interviewers | 		do																		-- now do interviewers | ||
| 			control.maximum, interviewer_etal = get_display_names (A['DisplayInterviewers'], #interviewers_list, 'interviewers', interviewer_etal, A:ORIGIN ('DisplayInterviewers')); | 			if cfg.global_cs1_config_t['DisplayInterviewers'] then				-- global setting from {{cs1 config}} overrides local setting | ||
| 				control.maximum, interviewer_etal = get_display_names (cfg.global_cs1_config_t['DisplayInterviewers'], #interviewers_list, 'interviewers', interviewer_etal, 'cs1 config'); | |||
| 			else | |||
| 				control.maximum, interviewer_etal = get_display_names (A['DisplayInterviewers'], #interviewers_list, 'interviewers', interviewer_etal, A:ORIGIN ('DisplayInterviewers')); | |||
| 			end | |||
| 			if cfg.global_cs1_config_t['DisplayInterviewers'] and utilities.is_set (A['DisplayInterviewers']) then	-- when template has |display-interviewers=<something> which global setting has overridden | |||
| 				utilities.set_message ('maint_overridden_setting');				-- set a maint message | |||
| 			end | |||
| 			Interviewers = list_people (control, interviewers_list, interviewer_etal); | 			Interviewers = list_people (control, interviewers_list, interviewer_etal); | ||
| 		end | 		end | ||
| 		do																		-- now do translators | 		do																		-- now do translators | ||
| 			control.maximum, translator_etal = get_display_names (A['DisplayTranslators'], #t, 'translators', translator_etal, A:ORIGIN ('DisplayTranslators')); | 			if cfg.global_cs1_config_t['DisplayTranslators'] then				-- global setting from {{cs1 config}} overrides local setting | ||
| 				control.maximum, translator_etal = get_display_names (cfg.global_cs1_config_t['DisplayTranslators'], #t, 'translators', 'cs1 config'); | |||
| 			else | |||
| 				control.maximum, translator_etal = get_display_names (A['DisplayTranslators'], #t, 'translators', translator_etal, A:ORIGIN ('DisplayTranslators')); | |||
| 			end | |||
| 			if cfg.global_cs1_config_t['DisplayTranslators'] and utilities.is_set (A['DisplayTranslators']) then	-- when template has |display-translators=<something> which global setting has overridden | |||
| 				utilities.set_message ('maint_overridden_setting');				-- set a maint message | |||
| 			end | |||
| 			Translators = list_people (control, t, translator_etal); | 			Translators = list_people (control, t, translator_etal); | ||
| 		end | 		end | ||
| 		do																		-- now do contributors | 		do																		-- now do contributors | ||
| 			control.maximum, contributor_etal = get_display_names (A['DisplayContributors'], #c, 'contributors', contributor_etal, A:ORIGIN ('DisplayContributors')); | 			if cfg.global_cs1_config_t['DisplayContributors'] then				-- global setting from {{cs1 config}} overrides local setting | ||
| 				control.maximum, contributor_etal = get_display_names (cfg.global_cs1_config_t['DisplayContributors'], #c, 'contributors', contributor_etal, 'cs1 config'); | |||
| 			else | |||
| 				control.maximum, contributor_etal = get_display_names (A['DisplayContributors'], #c, 'contributors', contributor_etal, A:ORIGIN ('DisplayContributors')); | |||
| 			end | |||
| 			if cfg.global_cs1_config_t['DisplayContributors'] and utilities.is_set (A['DisplayContributors']) then	-- when template has |display-contributors=<something> which global setting has overridden | |||
| 				utilities.set_message ('maint_overridden_setting');				-- set a maint message | |||
| 			end | |||
| 			Contributors = list_people (control, c, contributor_etal); | 			Contributors = list_people (control, c, contributor_etal); | ||
| 		end | 		end | ||
| 		do																		-- now do authors | 		do																		-- now do authors | ||
| 			control.maximum, author_etal = get_display_names (A['DisplayAuthors'], #a, 'authors', author_etal, A:ORIGIN ('DisplayAuthors')); | 			if cfg.global_cs1_config_t['DisplayAuthors'] then					-- global setting from {{cs1 config}} overrides local setting | ||
| 				control.maximum, author_etal = get_display_names (cfg.global_cs1_config_t['DisplayAuthors'], #a, 'authors', author_etal, 'cs1 config'); | |||
| 			else | |||
| 				control.maximum, author_etal = get_display_names (A['DisplayAuthors'], #a, 'authors', author_etal, A:ORIGIN ('DisplayAuthors')); | |||
| 			end | |||
| 			if cfg.global_cs1_config_t['DisplayAuthors'] and utilities.is_set (A['DisplayAuthors']) then	-- when template has |display-authors=<something> which global setting has overridden | |||
| 				utilities.set_message ('maint_overridden_setting');				-- set a maint message | |||
| 			end | |||
| 			last_first_list = list_people (control, a, author_etal); | 			last_first_list = list_people (control, a, author_etal); | ||
| Line 3,531: | Line 3,592: | ||
| 		if utilities.is_set (Minutes) then | 		if utilities.is_set (Minutes) then | ||
| 			if utilities.is_set (Time) then		--TODO: make a function for this and similar? | 			if utilities.is_set (Time) then		--TODO: make a function for this and similar? | ||
| 				utilities.set_message ('err_redundant_parameters', {utilities.wrap_style ('parameter', 'minutes') .. '  | 				utilities.set_message ('err_redundant_parameters', {utilities.wrap_style ('parameter', 'minutes') .. cfg.presentation['sep_list_pair'] .. utilities.wrap_style ('parameter', 'time')}); | ||
| 			end | 			end | ||
| 			Position = " " .. Minutes .. " " .. cfg.messages['minutes']; | 			Position = " " .. Minutes .. " " .. cfg.messages['minutes']; | ||
| Line 3,693: | Line 3,754: | ||
| 	local Archived; | 	local Archived; | ||
| 	if utilities.is_set (ArchiveURL) then | 	if utilities.is_set (ArchiveURL) then | ||
| 		if not utilities.is_set (ArchiveDate) then								-- ArchiveURL set but ArchiveDate not set | |||
| 		if  | 			utilities.set_message ('err_archive_missing_date');					-- emit an error message | ||
| 			utilities.set_message (' | 			ArchiveURL = '';													-- empty string for concatenation | ||
| 			ArchiveDate = '';													-- empty string for concatenation | |||
| 		end | |||
| 	else														 | |||
| 		if utilities.is_set (ArchiveDate) then									-- ArchiveURL not set but ArchiveDate is set | |||
| 			utilities.set_message ('err_archive_date_missing_url');				-- emit an error message | |||
| 			ArchiveURL = '';													-- empty string for concatenation | |||
| 			ArchiveDate = '';													-- empty string for concatenation | 			ArchiveDate = '';													-- empty string for concatenation | ||
| 		end | 		end | ||
| 	end | |||
| 	if utilities.is_set (ArchiveURL) then | |||
| 		local arch_text; | |||
| --		if not utilities.is_set (ArchiveDate) then | |||
| --			utilities.set_message ('err_archive_missing_date'); | |||
| --			ArchiveDate = '';													-- empty string for concatenation | |||
| --		end | |||
| 		if "live" == UrlStatus then | 		if "live" == UrlStatus then | ||
| 			arch_text = cfg.messages['archived']; | 			arch_text = cfg.messages['archived']; | ||
| Line 3,732: | Line 3,807: | ||
| 			end	 | 			end	 | ||
| 		else																	-- OriginalUrl not set | 		else																	-- OriginalUrl not set | ||
| 			utilities.set_message ('err_archive_missing_url'); | 			utilities.set_message ('err_archive_missing_url'); | ||
| 			Archived = '';														-- empty string for concatenation | 			Archived = '';														-- empty string for concatenation | ||
| Line 4,267: | Line 4,340: | ||
| 	local suggestions = {};														-- table where we store suggestions if we need to loadData them | 	local suggestions = {};														-- table where we store suggestions if we need to loadData them | ||
| 	local error_text;															-- used as a flag | 	local error_text;															-- used as a flag | ||
| 	local capture;																-- the single supported capture when matching unknown parameters using patterns | 	local capture;																-- the single supported capture when matching unknown parameters using patterns | ||