Module:Citation/CS1/Whitelist: Difference between revisions
< Module:Citation | CS1
Content added Content deleted
imported>Rox m (1 revision imported) |
m (1 revision imported) |
||
(5 intermediate revisions by 4 users not shown) | |||
Line 1: | Line 1: | ||
− | |||
--[[--------------------------< S U P P O R T E D P A R A M E T E R S >-------------------------------------- |
--[[--------------------------< S U P P O R T E D P A R A M E T E R S >-------------------------------------- |
||
Line 5: | Line 4: | ||
true - these parameters are valid and supported parameters |
true - these parameters are valid and supported parameters |
||
false - these parameters are deprecated but still supported |
false - these parameters are deprecated but still supported |
||
+ | tracked - these parameters are valid and supported parameters tracked in an eponymous properties category |
||
nil - these parameters are no longer supported. remove entirely |
nil - these parameters are no longer supported. remove entirely |
||
]] |
]] |
||
− | local |
+ | local basic_arguments_t = { |
['accessdate'] = true, |
['accessdate'] = true, |
||
['access-date'] = true, |
['access-date'] = true, |
||
Line 20: | Line 20: | ||
['article'] = true, |
['article'] = true, |
||
['article-format'] = true, |
['article-format'] = true, |
||
+ | ['article-number'] = true, -- {{cite journal}}, {{cite conference}}; {{citation}} when |journal= has a value |
||
['article-url'] = true, |
['article-url'] = true, |
||
['article-url-access'] = true, |
['article-url-access'] = true, |
||
Line 35: | Line 36: | ||
['author-link'] = true, |
['author-link'] = true, |
||
['author-mask'] = true, |
['author-mask'] = true, |
||
− | ['authors'] = true, |
||
['bibcode'] = true, |
['bibcode'] = true, |
||
['bibcode-access'] = true, |
['bibcode-access'] = true, |
||
['biorxiv'] = true, -- cite biorxiv; here because allowed in cite ... as identifier |
['biorxiv'] = true, -- cite biorxiv; here because allowed in cite ... as identifier |
||
− | ['booktitle'] = true, |
||
− | ['book-title'] = true, |
||
− | ['cartography'] = true, |
||
['chapter'] = true, |
['chapter'] = true, |
||
['chapter-format'] = true, |
['chapter-format'] = true, |
||
− | ['chapterurl'] = true, |
||
['chapter-url'] = true, |
['chapter-url'] = true, |
||
['chapter-url-access'] = true, |
['chapter-url-access'] = true, |
||
['citeseerx'] = true, -- cite citeseerx; here because allowed in cite ... as identifier |
['citeseerx'] = true, -- cite citeseerx; here because allowed in cite ... as identifier |
||
['collaboration'] = true, |
['collaboration'] = true, |
||
− | ['conference'] = true, |
||
− | ['conference-format'] = true, |
||
− | ['conferenceurl'] = false, |
||
− | ['conference-url'] = true, |
||
['contribution'] = true, |
['contribution'] = true, |
||
['contribution-format'] = true, |
['contribution-format'] = true, |
||
− | ['contributionurl'] = false, |
||
['contribution-url'] = true, |
['contribution-url'] = true, |
||
['contribution-url-access'] = true, |
['contribution-url-access'] = true, |
||
Line 66: | Line 57: | ||
['contributor-mask'] = true, |
['contributor-mask'] = true, |
||
['date'] = true, |
['date'] = true, |
||
− | ['degree'] = true, |
||
['department'] = true, |
['department'] = true, |
||
['df'] = true, |
['df'] = true, |
||
Line 76: | Line 66: | ||
['display-subjects'] = true, |
['display-subjects'] = true, |
||
['display-translators'] = true, |
['display-translators'] = true, |
||
− | ['docket'] = true, |
||
['doi'] = true, |
['doi'] = true, |
||
['DOI'] = true, |
['DOI'] = true, |
||
Line 98: | Line 87: | ||
['entry-url-access'] = true, |
['entry-url-access'] = true, |
||
['eprint'] = true, -- cite arxiv; here because allowed in cite ... as identifier |
['eprint'] = true, -- cite arxiv; here because allowed in cite ... as identifier |
||
− | ['event'] = true, -- synonym of conference in /Config, but used in Cite speech? |
||
['first'] = true, |
['first'] = true, |
||
['format'] = true, |
['format'] = true, |
||
Line 105: | Line 93: | ||
['HDL'] = true, |
['HDL'] = true, |
||
['hdl-access'] = true, |
['hdl-access'] = true, |
||
− | ['host'] = true, |
+ | ['host'] = true, -- unique to certain templates? |
['id'] = true, |
['id'] = true, |
||
['ID'] = true, |
['ID'] = true, |
||
− | ['institution'] = true, |
+ | ['institution'] = true, -- constrain to cite thesis? |
['interviewer'] = true, |
['interviewer'] = true, |
||
['interviewer-first'] = true, |
['interviewer-first'] = true, |
||
Line 118: | Line 106: | ||
['isbn'] = true, |
['isbn'] = true, |
||
['ISBN'] = true, |
['ISBN'] = true, |
||
− | ['isbn13'] = true, |
||
− | ['ISBN13'] = true, |
||
['ismn'] = true, |
['ismn'] = true, |
||
['ISMN'] = true, |
['ISMN'] = true, |
||
Line 134: | Line 120: | ||
['language'] = true, |
['language'] = true, |
||
['last'] = true, |
['last'] = true, |
||
− | ['laydate'] = false, |
||
− | ['lay-date'] = true, |
||
− | ['laysource'] = false, |
||
− | ['lay-source'] = true, |
||
− | ['lay-format'] = true, |
||
− | ['layurl'] = false, |
||
− | ['lay-url'] = true, |
||
['lccn'] = true, |
['lccn'] = true, |
||
['LCCN'] = true, |
['LCCN'] = true, |
||
Line 146: | Line 125: | ||
['magazine'] = true, |
['magazine'] = true, |
||
['medium'] = true, |
['medium'] = true, |
||
+ | ['medrxiv'] = true, -- cite medrxiv; here because allowed in cite ... as identifier |
||
− | ['minutes'] = true, |
||
+ | ['minutes'] = true, -- constrain to cite AV media and podcast? |
||
['mode'] = true, |
['mode'] = true, |
||
['mr'] = true, |
['mr'] = true, |
||
['MR'] = true, |
['MR'] = true, |
||
− | ['name-list-format'] = true, |
||
['name-list-style'] = true, |
['name-list-style'] = true, |
||
['newspaper'] = true, |
['newspaper'] = true, |
||
− | ['nopp'] = true, |
||
['no-pp'] = true, |
['no-pp'] = true, |
||
['no-tracking'] = true, |
['no-tracking'] = true, |
||
Line 172: | Line 150: | ||
['page'] = true, |
['page'] = true, |
||
['pages'] = true, |
['pages'] = true, |
||
− | ['people'] = true, |
||
['periodical'] = true, |
['periodical'] = true, |
||
['place'] = true, |
['place'] = true, |
||
Line 182: | Line 159: | ||
['postscript'] = true, |
['postscript'] = true, |
||
['pp'] = true, |
['pp'] = true, |
||
− | ['publicationdate'] = true, |
||
['publication-date'] = true, |
['publication-date'] = true, |
||
− | ['publicationplace'] = true, |
||
['publication-place'] = true, |
['publication-place'] = true, |
||
['publisher'] = true, |
['publisher'] = true, |
||
Line 200: | Line 175: | ||
['script-chapter'] = true, |
['script-chapter'] = true, |
||
['script-contribution'] = true, |
['script-contribution'] = true, |
||
+ | ['script-encyclopaedia'] = true, |
||
+ | ['script-encyclopedia'] = true, |
||
['script-entry'] = true, |
['script-entry'] = true, |
||
['script-journal'] = true, |
['script-journal'] = true, |
||
Line 210: | Line 187: | ||
['script-website'] = true, |
['script-website'] = true, |
||
['script-work'] = true, |
['script-work'] = true, |
||
− | ['season'] = true, |
||
['section'] = true, |
['section'] = true, |
||
['section-format'] = true, |
['section-format'] = true, |
||
− | ['sectionurl'] = false, |
||
['section-url'] = true, |
['section-url'] = true, |
||
['section-url-access'] = true, |
['section-url-access'] = true, |
||
['series'] = true, |
['series'] = true, |
||
+ | ['ssrn'] = true, -- cite ssrn; these three here because allowed in cite ... as identifier |
||
− | ['serieslink'] = true, |
||
− | ['series-link'] = true, |
||
− | ['seriesno'] = false, |
||
− | ['series-no'] = true, |
||
− | ['series-number'] = true, |
||
− | ['ssrn'] = true, -- cite ssrn; these two here because allowed in cite ... as identifier |
||
['SSRN'] = true, |
['SSRN'] = true, |
||
+ | ['ssrn-access'] = true, |
||
['subject'] = true, |
['subject'] = true, |
||
+ | ['subject-first'] = true, |
||
+ | ['subject-given'] = true, |
||
+ | ['subject-last'] = true, |
||
['subject-link'] = true, |
['subject-link'] = true, |
||
['subject-mask'] = true, |
['subject-mask'] = true, |
||
+ | ['subject-surname'] = true, |
||
['surname'] = true, |
['surname'] = true, |
||
['s2cid'] = true, |
['s2cid'] = true, |
||
Line 232: | Line 207: | ||
['s2cid-access'] = true, |
['s2cid-access'] = true, |
||
['template-doc-demo'] = true, |
['template-doc-demo'] = true, |
||
− | ['time'] = true, |
+ | ['time'] = true, -- constrain to cite av media and podcast? |
+ | ['time-caption'] = true, -- constrain to cite av media and podcast? |
||
− | ['timecaption'] = false, |
||
− | ['time-caption'] = true, |
||
['title'] = true, |
['title'] = true, |
||
− | ['titlelink'] = false, |
||
['title-link'] = true, |
['title-link'] = true, |
||
+ | ['title-note'] = true, |
||
['translator'] = true, |
['translator'] = true, |
||
['translator-first'] = true, |
['translator-first'] = true, |
||
Line 248: | Line 222: | ||
['trans-chapter'] = true, |
['trans-chapter'] = true, |
||
['trans-contribution'] = true, |
['trans-contribution'] = true, |
||
+ | ['trans-encyclopaedia'] = true, |
||
+ | ['trans-encyclopedia'] = true, |
||
['trans-entry'] = true, |
['trans-entry'] = true, |
||
['trans-journal'] = true, |
['trans-journal'] = true, |
||
Line 273: | Line 249: | ||
['zbl'] = true, |
['zbl'] = true, |
||
['ZBL'] = true, |
['ZBL'] = true, |
||
− | } |
+ | } |
− | local |
+ | local numbered_arguments_t = { |
['author#'] = true, |
['author#'] = true, |
||
['author-first#'] = true, |
['author-first#'] = true, |
||
Line 335: | Line 311: | ||
['last#'] = true, |
['last#'] = true, |
||
['subject#'] = true, |
['subject#'] = true, |
||
+ | ['subject-first#'] = true, |
||
+ | ['subject#-first'] = true, |
||
+ | ['subject-given#'] = true, |
||
+ | ['subject#-given'] = true, |
||
+ | ['subject-last#'] = true, |
||
+ | ['subject#-last'] = true, |
||
['subject-link#'] = true, |
['subject-link#'] = true, |
||
['subject#-link'] = true, |
['subject#-link'] = true, |
||
['subject-mask#'] = true, |
['subject-mask#'] = true, |
||
['subject#-mask'] = true, |
['subject#-mask'] = true, |
||
+ | ['subject-surname#'] = true, |
||
+ | ['subject#-surname'] = true, |
||
['surname#'] = true, |
['surname#'] = true, |
||
['translator#'] = true, |
['translator#'] = true, |
||
Line 353: | Line 337: | ||
['translator-mask#'] = true, |
['translator-mask#'] = true, |
||
['translator#-mask'] = true, |
['translator#-mask'] = true, |
||
− | } |
+ | } |
--[[--------------------------< P R E P R I N T S U P P O R T E D P A R A M E T E R S >-------------------- |
--[[--------------------------< P R E P R I N T S U P P O R T E D P A R A M E T E R S >-------------------- |
||
− | Cite arXiv, cite biorxiv, cite citeseerx, and cite ssrn are preprint templates that use the limited |
+ | Cite arXiv, cite biorxiv, cite citeseerx, cite medrxiv, and cite ssrn are preprint templates that use the limited |
− | defined in the limited_basic_arguments and limited_numbered_arguments tables. Those lists are |
+ | set of parameters defined in the limited_basic_arguments and limited_numbered_arguments tables. Those lists are |
− | template-specific list of parameters that are required by the particular template and may be |
+ | supplemented with a template-specific list of parameters that are required by the particular template and may be |
− | preprint templates. Some of these parameters may also be available to the general cs1|2 |
+ | exclusive to one of the preprint templates. Some of these parameters may also be available to the general cs1|2 |
+ | templates. |
||
− | Same conventions for true/false/nil as above. |
+ | Same conventions for true/false/tracked/nil as above. |
]] |
]] |
||
− | local |
+ | local preprint_arguments_t = { |
arxiv = { |
arxiv = { |
||
['arxiv'] = true, -- cite arxiv and arxiv identifiers |
['arxiv'] = true, -- cite arxiv and arxiv identifiers |
||
Line 378: | Line 363: | ||
citeseerx = { |
citeseerx = { |
||
['citeseerx'] = true, |
['citeseerx'] = true, |
||
+ | }, |
||
+ | medrxiv = { |
||
+ | ['medrxiv'] = true, |
||
}, |
}, |
||
ssrn = { |
ssrn = { |
||
['ssrn'] = true, |
['ssrn'] = true, |
||
['SSRN'] = true, |
['SSRN'] = true, |
||
+ | ['ssrn-access'] = true, |
||
}, |
}, |
||
} |
} |
||
Line 388: | Line 377: | ||
--[[--------------------------< L I M I T E D S U P P O R T E D P A R A M E T E R S >---------------------- |
--[[--------------------------< L I M I T E D S U P P O R T E D P A R A M E T E R S >---------------------- |
||
+ | cite arxiv, cite biorxiv, cite citeseerx, cite medrxiv, and cite ssrn templates are preprint templates so are |
||
− | This is an experiment that attempts to use validate() and a limited list of valid parameters to validate the |
||
+ | allowed only a limited subset of parameters allowed to all other cs1|2 templates. The limited subset is defined |
||
− | parameters provided in a cite arxiv, cite biorxiv, or cite citeseerx templates. These parameters are common to |
||
+ | here. |
||
− | all three templates |
||
+ | |||
+ | This list of parameters also used by {{cite document}} |
||
− | Same conventions for true/false/nil as above. |
+ | Same conventions for true/false/tracked/nil as above. |
]] |
]] |
||
− | local |
+ | local limited_basic_arguments_t = { |
['at'] = true, |
['at'] = true, |
||
['author'] = true, |
['author'] = true, |
||
Line 406: | Line 397: | ||
['authorlink'] = true, |
['authorlink'] = true, |
||
['author-mask'] = true, |
['author-mask'] = true, |
||
− | ['authors'] = true, |
||
['collaboration'] = true, |
['collaboration'] = true, |
||
['date'] = true, |
['date'] = true, |
||
Line 416: | Line 406: | ||
['last'] = true, |
['last'] = true, |
||
['mode'] = true, |
['mode'] = true, |
||
− | ['name-list-format'] = true, |
||
['name-list-style'] = true, |
['name-list-style'] = true, |
||
['no-tracking'] = true, |
['no-tracking'] = true, |
||
Line 431: | Line 420: | ||
['title'] = true, |
['title'] = true, |
||
['trans-title'] = true, |
['trans-title'] = true, |
||
− | ['url'] = true, |
||
− | ['URL'] = true, |
||
['vauthors'] = true, |
['vauthors'] = true, |
||
['year'] = true, |
['year'] = true, |
||
− | } |
+ | } |
− | local |
+ | local limited_numbered_arguments_t = { |
['author#'] = true, |
['author#'] = true, |
||
['author-first#'] = true, |
['author-first#'] = true, |
||
Line 465: | Line 452: | ||
table are the template's CitationClass parameter value |
table are the template's CitationClass parameter value |
||
− | Same conventions for true/false/nil as above. |
+ | Same conventions for true/false/tracked/nil as above. |
]] |
]] |
||
− | local |
+ | local unique_arguments_t = { |
['audio-visual'] = { |
['audio-visual'] = { |
||
+ | ['people'] = true, |
||
['transcript'] = true, |
['transcript'] = true, |
||
['transcript-format'] = true, |
['transcript-format'] = true, |
||
− | ['transcripturl'] = true, |
||
['transcript-url'] = true, |
['transcript-url'] = true, |
||
+ | }, |
||
+ | conference = { |
||
+ | ['book-title'] = true, |
||
+ | ['conference'] = true, |
||
+ | ['conference-format'] = true, |
||
+ | ['conference-url'] = true, |
||
+ | ['event'] = true, |
||
}, |
}, |
||
episode = { |
episode = { |
||
Line 480: | Line 474: | ||
['air-date'] = true, |
['air-date'] = true, |
||
['credits'] = true, |
['credits'] = true, |
||
− | ['episodelink'] = true, -- alias of |title-link= |
||
['episode-link'] = true, -- alias of |title-link= |
['episode-link'] = true, -- alias of |title-link= |
||
['network'] = true, |
['network'] = true, |
||
+ | ['people'] = true, |
||
+ | ['season'] = true, |
||
+ | ['series-link'] = true, |
||
+ | ['series-no'] = true, |
||
+ | ['series-number'] = true, |
||
['station'] = true, |
['station'] = true, |
||
['transcript'] = true, |
['transcript'] = true, |
||
['transcript-format'] = true, |
['transcript-format'] = true, |
||
− | ['transcripturl'] = true, |
||
['transcript-url'] = true, |
['transcript-url'] = true, |
||
}, |
}, |
||
mailinglist = { |
mailinglist = { |
||
− | ['mailinglist'] = true, |
||
['mailing-list'] = true, |
['mailing-list'] = true, |
||
}, |
}, |
||
map = { |
map = { |
||
+ | ['cartography'] = true, |
||
['inset'] = true, |
['inset'] = true, |
||
['map'] = true, |
['map'] = true, |
||
['map-format'] = true, |
['map-format'] = true, |
||
− | ['mapurl'] = true, |
||
['map-url'] = true, |
['map-url'] = true, |
||
['map-url-access'] = true, |
['map-url-access'] = true, |
||
Line 509: | Line 505: | ||
['message-id'] = true, |
['message-id'] = true, |
||
['newsgroup'] = true, |
['newsgroup'] = true, |
||
+ | }, |
||
+ | report = { |
||
+ | ['docket'] = true, |
||
}, |
}, |
||
serial = { |
serial = { |
||
Line 515: | Line 514: | ||
['credits'] = true, |
['credits'] = true, |
||
['episode'] = true, -- cite serial only TODO: make available to cite episode? |
['episode'] = true, -- cite serial only TODO: make available to cite episode? |
||
− | [' |
+ | ['episode-link'] = true, -- alias of |title-link= |
− | ['episode-link'] = true, |
||
['network'] = true, |
['network'] = true, |
||
+ | ['people'] = true, |
||
+ | ['series-link'] = true, |
||
['station'] = true, |
['station'] = true, |
||
+ | }, |
||
+ | speech = { |
||
+ | ['conference'] = true, |
||
+ | ['conference-format'] = true, |
||
+ | ['conference-url'] = true, |
||
+ | ['event'] = true, |
||
+ | }, |
||
+ | thesis = { |
||
+ | ['degree'] = true, |
||
+ | ['docket'] = true, |
||
}, |
}, |
||
} |
} |
||
+ | |||
+ | |||
+ | --[[--------------------------< C I T E _ D O C U M E N T >---------------------------------------------------- |
||
+ | |||
+ | Special case for cite document. This template takes the limited basic and limited enumerated parameters plus |
||
+ | others that are apply only to standalone published sources that cannot be cited any other way; no url, book, |
||
+ | periodical, etc parameters; limited support for name lists and named identifiers. |
||
+ | |||
+ | when validating parameters in {{cite document}} templates, the basic and |
||
+ | |||
+ | ]] |
||
+ | |||
+ | local document_arguments_t = { |
||
+ | ['bibcode'] = true, |
||
+ | ['bibcode-access'] = true, |
||
+ | ['doi'] = true, |
||
+ | ['DOI'] = true, |
||
+ | ['doi-access'] = true, |
||
+ | ['doi-broken-date'] = true, |
||
+ | ['hdl'] = true, |
||
+ | ['HDL'] = true, |
||
+ | ['hdl-access'] = true, |
||
+ | ['id'] = true, |
||
+ | ['ID'] = true, |
||
+ | ['jfm'] = true, |
||
+ | ['JFM'] = true, |
||
+ | ['lang'] = true, |
||
+ | ['location'] = true, |
||
+ | ['mr'] = true, |
||
+ | ['MR'] = true, |
||
+ | ['no-pp'] = true, |
||
+ | ['orig-date'] = true, |
||
+ | ['origyear'] = true, |
||
+ | ['orig-year'] = true, |
||
+ | ['osti'] = true, |
||
+ | ['OSTI'] = true, |
||
+ | ['osti-access'] = true, |
||
+ | ['place'] = true, |
||
+ | ['publisher'] = true, |
||
+ | ['quote-page'] = true, |
||
+ | ['quote-pages'] = true, |
||
+ | ['script-quote'] = true, |
||
+ | ['script-title'] = true, |
||
+ | ['title-link'] = true, |
||
+ | ['translator'] = true, |
||
+ | ['translator-first'] = true, |
||
+ | ['translator-given'] = true, |
||
+ | ['translator-last'] = true, |
||
+ | ['translator-surname'] = true, |
||
+ | ['translator-link'] = true, |
||
+ | ['translator-mask'] = true, |
||
+ | ['trans-quote'] = true, |
||
+ | ['type'] = true, |
||
+ | ['zbl'] = true, |
||
+ | ['ZBL'] = true, |
||
+ | } |
||
+ | |||
+ | local document_numbered_arguments_t = { |
||
+ | ['translator#'] = true, |
||
+ | ['translator-first#'] = true, |
||
+ | ['translator#-first'] = true, |
||
+ | ['translator-given#'] = true, |
||
+ | ['translator#-given'] = true, |
||
+ | ['translator-last#'] = true, |
||
+ | ['translator#-last'] = true, |
||
+ | ['translator-surname#'] = true, |
||
+ | ['translator#-surname'] = true, |
||
+ | ['translator-link#'] = true, |
||
+ | ['translator#-link'] = true, |
||
+ | ['translator-mask#'] = true, |
||
+ | ['translator#-mask'] = true, |
||
+ | } |
||
+ | |||
+ | |||
+ | --[[--------------------------< L I S T _ C O M B I N E >------------------------------------------------------ |
||
+ | |||
+ | makes one table from a list of tables. <lists_t> is a sequence of tables to be combined |
||
+ | |||
+ | ]] |
||
+ | |||
+ | local function list_combine (lists_t) |
||
+ | local out_t = {}; |
||
+ | |||
+ | for _, list_t in ipairs (lists_t) do -- for each list in <lists_t> |
||
+ | for k, v in pairs (list_t) do -- extract each k/v pair |
||
+ | out_t[k] = v; -- add to <out_t> |
||
+ | end |
||
+ | end |
||
+ | return out_t; -- and done |
||
+ | end |
||
Line 530: | Line 630: | ||
local function template_list_get (t) |
local function template_list_get (t) |
||
− | local |
+ | local out_t = {}; -- a table for output |
for k, _ in pairs (t) do -- spin through the table and collect the keys |
for k, _ in pairs (t) do -- spin through the table and collect the keys |
||
− | table.insert ( |
+ | table.insert (out_t, k) -- add each key to the output table |
end |
end |
||
− | return |
+ | return out_t; -- and done |
end |
end |
||
Line 542: | Line 642: | ||
return { |
return { |
||
+ | preprint_arguments_t = preprint_arguments_t, |
||
− | basic_arguments = basic_arguments, |
||
+ | preprint_template_list_t = template_list_get (preprint_arguments_t), -- make a template list from preprint_arguments{} table |
||
− | numbered_arguments = numbered_arguments, |
||
+ | unique_arguments_t = unique_arguments_t, |
||
− | limited_basic_arguments = limited_basic_arguments, |
||
+ | unique_param_template_list_t = template_list_get (unique_arguments_t), -- make a template list from unique_arguments{} table |
||
− | limited_numbered_arguments = limited_numbered_arguments, |
||
+ | |||
− | |||
+ | document_parameters_t = list_combine ({limited_basic_arguments_t, limited_numbered_arguments_t, document_arguments_t, document_numbered_arguments_t}); |
||
− | preprint_arguments = preprint_arguments, |
||
+ | common_parameters_t = list_combine ({basic_arguments_t, numbered_arguments_t}); |
||
− | preprint_template_list = template_list_get (preprint_arguments), -- make a template list from preprint_arguments{} table |
||
+ | limited_parameters_t = list_combine ({limited_basic_arguments_t, limited_numbered_arguments_t}); |
||
− | unique_arguments = unique_arguments, |
||
− | unique_param_template_list = template_list_get (unique_arguments), -- make a template list from unique_arguments{} table |
||
}; |
}; |
Latest revision as of 12:30, 23 August 2024
Documentation for this module may be created at Module:Citation/CS1/Whitelist/doc
--[[--------------------------< S U P P O R T E D P A R A M E T E R S >-------------------------------------- Because a steady-state signal conveys no useful information, whitelist.basic_arguments[] list items can have three values: true - these parameters are valid and supported parameters false - these parameters are deprecated but still supported tracked - these parameters are valid and supported parameters tracked in an eponymous properties category nil - these parameters are no longer supported. remove entirely ]] local basic_arguments_t = { ['accessdate'] = true, ['access-date'] = true, ['agency'] = true, ['archivedate'] = true, ['archive-date'] = true, ['archive-format'] = true, ['archiveurl'] = true, ['archive-url'] = true, ['article'] = true, ['article-format'] = true, ['article-number'] = true, -- {{cite journal}}, {{cite conference}}; {{citation}} when |journal= has a value ['article-url'] = true, ['article-url-access'] = true, ['arxiv'] = true, -- cite arxiv; here because allowed in cite ... as identifier ['asin'] = true, ['ASIN'] = true, ['asin-tld'] = true, ['at'] = true, ['author'] = true, ['author-first'] = true, ['author-given'] = true, ['author-last'] = true, ['author-surname'] = true, ['authorlink'] = true, ['author-link'] = true, ['author-mask'] = true, ['bibcode'] = true, ['bibcode-access'] = true, ['biorxiv'] = true, -- cite biorxiv; here because allowed in cite ... as identifier ['chapter'] = true, ['chapter-format'] = true, ['chapter-url'] = true, ['chapter-url-access'] = true, ['citeseerx'] = true, -- cite citeseerx; here because allowed in cite ... as identifier ['collaboration'] = true, ['contribution'] = true, ['contribution-format'] = true, ['contribution-url'] = true, ['contribution-url-access'] = true, ['contributor'] = true, ['contributor-first'] = true, ['contributor-given'] = true, ['contributor-last'] = true, ['contributor-surname'] = true, ['contributor-link'] = true, ['contributor-mask'] = true, ['date'] = true, ['department'] = true, ['df'] = true, ['dictionary'] = true, ['display-authors'] = true, ['display-contributors'] = true, ['display-editors'] = true, ['display-interviewers'] = true, ['display-subjects'] = true, ['display-translators'] = true, ['doi'] = true, ['DOI'] = true, ['doi-access'] = true, ['doi-broken-date'] = true, ['edition'] = true, ['editor'] = true, ['editor-first'] = true, ['editor-given'] = true, ['editor-last'] = true, ['editor-surname'] = true, ['editor-link'] = true, ['editor-mask'] = true, ['eissn'] = true, ['EISSN'] = true, ['encyclopaedia'] = true, ['encyclopedia'] = true, ['entry'] = true, ['entry-format'] = true, ['entry-url'] = true, ['entry-url-access'] = true, ['eprint'] = true, -- cite arxiv; here because allowed in cite ... as identifier ['first'] = true, ['format'] = true, ['given'] = true, ['hdl'] = true, ['HDL'] = true, ['hdl-access'] = true, ['host'] = true, -- unique to certain templates? ['id'] = true, ['ID'] = true, ['institution'] = true, -- constrain to cite thesis? ['interviewer'] = true, ['interviewer-first'] = true, ['interviewer-given'] = true, ['interviewer-last'] = true, ['interviewer-surname'] = true, ['interviewer-link'] = true, ['interviewer-mask'] = true, ['isbn'] = true, ['ISBN'] = true, ['ismn'] = true, ['ISMN'] = true, ['issn'] = true, ['ISSN'] = true, ['issue'] = true, ['jfm'] = true, ['JFM'] = true, ['journal'] = true, ['jstor'] = true, ['JSTOR'] = true, ['jstor-access'] = true, ['lang'] = true, ['language'] = true, ['last'] = true, ['lccn'] = true, ['LCCN'] = true, ['location'] = true, ['magazine'] = true, ['medium'] = true, ['medrxiv'] = true, -- cite medrxiv; here because allowed in cite ... as identifier ['minutes'] = true, -- constrain to cite AV media and podcast? ['mode'] = true, ['mr'] = true, ['MR'] = true, ['name-list-style'] = true, ['newspaper'] = true, ['no-pp'] = true, ['no-tracking'] = true, ['number'] = true, ['oclc'] = true, ['OCLC'] = true, ['ol'] = true, ['OL'] = true, ['ol-access'] = true, ['orig-date'] = true, ['origyear'] = true, ['orig-year'] = true, ['osti'] = true, ['OSTI'] = true, ['osti-access'] = true, ['others'] = true, ['p'] = true, ['page'] = true, ['pages'] = true, ['periodical'] = true, ['place'] = true, ['pmc'] = true, ['PMC'] = true, ['pmc-embargo-date'] = true, ['pmid'] = true, ['PMID'] = true, ['postscript'] = true, ['pp'] = true, ['publication-date'] = true, ['publication-place'] = true, ['publisher'] = true, ['quotation'] = true, ['quote'] = true, ['quote-page'] = true, ['quote-pages'] = true, ['ref'] = true, ['rfc'] = true, ['RFC'] = true, ['sbn'] = true, ['SBN'] = true, ['scale'] = true, ['script-article'] = true, ['script-chapter'] = true, ['script-contribution'] = true, ['script-encyclopaedia'] = true, ['script-encyclopedia'] = true, ['script-entry'] = true, ['script-journal'] = true, ['script-magazine'] = true, ['script-newspaper'] = true, ['script-periodical'] = true, ['script-quote'] = true, ['script-section'] = true, ['script-title'] = true, ['script-website'] = true, ['script-work'] = true, ['section'] = true, ['section-format'] = true, ['section-url'] = true, ['section-url-access'] = true, ['series'] = true, ['ssrn'] = true, -- cite ssrn; these three here because allowed in cite ... as identifier ['SSRN'] = true, ['ssrn-access'] = true, ['subject'] = true, ['subject-first'] = true, ['subject-given'] = true, ['subject-last'] = true, ['subject-link'] = true, ['subject-mask'] = true, ['subject-surname'] = true, ['surname'] = true, ['s2cid'] = true, ['S2CID'] = true, ['s2cid-access'] = true, ['template-doc-demo'] = true, ['time'] = true, -- constrain to cite av media and podcast? ['time-caption'] = true, -- constrain to cite av media and podcast? ['title'] = true, ['title-link'] = true, ['title-note'] = true, ['translator'] = true, ['translator-first'] = true, ['translator-given'] = true, ['translator-last'] = true, ['translator-surname'] = true, ['translator-link'] = true, ['translator-mask'] = true, ['trans-article'] = true, ['trans-chapter'] = true, ['trans-contribution'] = true, ['trans-encyclopaedia'] = true, ['trans-encyclopedia'] = true, ['trans-entry'] = true, ['trans-journal'] = true, ['trans-magazine'] = true, ['trans-newspaper'] = true, ['trans-periodical'] = true, ['trans-quote'] = true, ['trans-section'] = true, ['trans-title'] = true, ['trans-website'] = true, ['trans-work'] = true, ['type'] = true, ['url'] = true, ['URL'] = true, ['url-access'] = true, ['url-status'] = true, ['vauthors'] = true, ['veditors'] = true, ['version'] = true, ['via'] = true, ['volume'] = true, ['website'] = true, ['work'] = true, ['year'] = true, ['zbl'] = true, ['ZBL'] = true, } local numbered_arguments_t = { ['author#'] = true, ['author-first#'] = true, ['author#-first'] = true, ['author-given#'] = true, ['author#-given'] = true, ['author-last#'] = true, ['author#-last'] = true, ['author-surname#'] = true, ['author#-surname'] = true, ['author-link#'] = true, ['author#-link'] = true, ['authorlink#'] = true, ['author#link'] = true, ['author-mask#'] = true, ['author#-mask'] = true, ['contributor#'] = true, ['contributor-first#'] = true, ['contributor#-first'] = true, ['contributor-given#'] = true, ['contributor#-given'] = true, ['contributor-last#'] = true, ['contributor#-last'] = true, ['contributor-surname#'] = true, ['contributor#-surname'] = true, ['contributor-link#'] = true, ['contributor#-link'] = true, ['contributor-mask#'] = true, ['contributor#-mask'] = true, ['editor#'] = true, ['editor-first#'] = true, ['editor#-first'] = true, ['editor-given#'] = true, ['editor#-given'] = true, ['editor-last#'] = true, ['editor#-last'] = true, ['editor-surname#'] = true, ['editor#-surname'] = true, ['editor-link#'] = true, ['editor#-link'] = true, ['editor-mask#'] = true, ['editor#-mask'] = true, ['first#'] = true, ['given#'] = true, ['host#'] = true, ['interviewer#'] = true, ['interviewer-first#'] = true, ['interviewer#-first'] = true, ['interviewer-given#'] = true, ['interviewer#-given'] = true, ['interviewer-last#'] = true, ['interviewer#-last'] = true, ['interviewer-surname#'] = true, ['interviewer#-surname'] = true, ['interviewer-link#'] = true, ['interviewer#-link'] = true, ['interviewer-mask#'] = true, ['interviewer#-mask'] = true, ['last#'] = true, ['subject#'] = true, ['subject-first#'] = true, ['subject#-first'] = true, ['subject-given#'] = true, ['subject#-given'] = true, ['subject-last#'] = true, ['subject#-last'] = true, ['subject-link#'] = true, ['subject#-link'] = true, ['subject-mask#'] = true, ['subject#-mask'] = true, ['subject-surname#'] = true, ['subject#-surname'] = true, ['surname#'] = true, ['translator#'] = true, ['translator-first#'] = true, ['translator#-first'] = true, ['translator-given#'] = true, ['translator#-given'] = true, ['translator-last#'] = true, ['translator#-last'] = true, ['translator-surname#'] = true, ['translator#-surname'] = true, ['translator-link#'] = true, ['translator#-link'] = true, ['translator-mask#'] = true, ['translator#-mask'] = true, } --[[--------------------------< P R E P R I N T S U P P O R T E D P A R A M E T E R S >-------------------- Cite arXiv, cite biorxiv, cite citeseerx, cite medrxiv, and cite ssrn are preprint templates that use the limited set of parameters defined in the limited_basic_arguments and limited_numbered_arguments tables. Those lists are supplemented with a template-specific list of parameters that are required by the particular template and may be exclusive to one of the preprint templates. Some of these parameters may also be available to the general cs1|2 templates. Same conventions for true/false/tracked/nil as above. ]] local preprint_arguments_t = { arxiv = { ['arxiv'] = true, -- cite arxiv and arxiv identifiers ['class'] = true, ['eprint'] = true, -- cite arxiv and arxiv identifiers }, biorxiv = { ['biorxiv'] = true, }, citeseerx = { ['citeseerx'] = true, }, medrxiv = { ['medrxiv'] = true, }, ssrn = { ['ssrn'] = true, ['SSRN'] = true, ['ssrn-access'] = true, }, } --[[--------------------------< L I M I T E D S U P P O R T E D P A R A M E T E R S >---------------------- cite arxiv, cite biorxiv, cite citeseerx, cite medrxiv, and cite ssrn templates are preprint templates so are allowed only a limited subset of parameters allowed to all other cs1|2 templates. The limited subset is defined here. This list of parameters also used by {{cite document}} Same conventions for true/false/tracked/nil as above. ]] local limited_basic_arguments_t = { ['at'] = true, ['author'] = true, ['author-first'] = true, ['author-given'] = true, ['author-last'] = true, ['author-surname'] = true, ['author-link'] = true, ['authorlink'] = true, ['author-mask'] = true, ['collaboration'] = true, ['date'] = true, ['df'] = true, ['display-authors'] = true, ['first'] = true, ['given'] = true, ['language'] = true, ['last'] = true, ['mode'] = true, ['name-list-style'] = true, ['no-tracking'] = true, ['p'] = true, ['page'] = true, ['pages'] = true, ['postscript'] = true, ['pp'] = true, ['quotation'] = true, ['quote'] = true, ['ref'] = true, ['surname'] = true, ['template-doc-demo'] = true, ['title'] = true, ['trans-title'] = true, ['vauthors'] = true, ['year'] = true, } local limited_numbered_arguments_t = { ['author#'] = true, ['author-first#'] = true, ['author#-first'] = true, ['author-given#'] = true, ['author#-given'] = true, ['author-last#'] = true, ['author#-last'] = true, ['author-surname#'] = true, ['author#-surname'] = true, ['author-link#'] = true, ['author#-link'] = true, ['authorlink#'] = true, ['author#link'] = true, ['author-mask#'] = true, ['author#-mask'] = true, ['first#'] = true, ['given#'] = true, ['last#'] = true, ['surname#'] = true, } --[[--------------------------< U N I Q U E _ A R G U M E N T S >---------------------------------------------- Some templates have unique parameters. Those templates and their unique parameters are listed here. Keys in this table are the template's CitationClass parameter value Same conventions for true/false/tracked/nil as above. ]] local unique_arguments_t = { ['audio-visual'] = { ['people'] = true, ['transcript'] = true, ['transcript-format'] = true, ['transcript-url'] = true, }, conference = { ['book-title'] = true, ['conference'] = true, ['conference-format'] = true, ['conference-url'] = true, ['event'] = true, }, episode = { ['airdate'] = true, ['air-date'] = true, ['credits'] = true, ['episode-link'] = true, -- alias of |title-link= ['network'] = true, ['people'] = true, ['season'] = true, ['series-link'] = true, ['series-no'] = true, ['series-number'] = true, ['station'] = true, ['transcript'] = true, ['transcript-format'] = true, ['transcript-url'] = true, }, mailinglist = { ['mailing-list'] = true, }, map = { ['cartography'] = true, ['inset'] = true, ['map'] = true, ['map-format'] = true, ['map-url'] = true, ['map-url-access'] = true, ['script-map'] = true, ['sections'] = true, ['sheet'] = true, ['sheets'] = true, ['trans-map'] = true, }, newsgroup = { ['message-id'] = true, ['newsgroup'] = true, }, report = { ['docket'] = true, }, serial = { ['airdate'] = true, ['air-date'] = true, ['credits'] = true, ['episode'] = true, -- cite serial only TODO: make available to cite episode? ['episode-link'] = true, -- alias of |title-link= ['network'] = true, ['people'] = true, ['series-link'] = true, ['station'] = true, }, speech = { ['conference'] = true, ['conference-format'] = true, ['conference-url'] = true, ['event'] = true, }, thesis = { ['degree'] = true, ['docket'] = true, }, } --[[--------------------------< C I T E _ D O C U M E N T >---------------------------------------------------- Special case for cite document. This template takes the limited basic and limited enumerated parameters plus others that are apply only to standalone published sources that cannot be cited any other way; no url, book, periodical, etc parameters; limited support for name lists and named identifiers. when validating parameters in {{cite document}} templates, the basic and ]] local document_arguments_t = { ['bibcode'] = true, ['bibcode-access'] = true, ['doi'] = true, ['DOI'] = true, ['doi-access'] = true, ['doi-broken-date'] = true, ['hdl'] = true, ['HDL'] = true, ['hdl-access'] = true, ['id'] = true, ['ID'] = true, ['jfm'] = true, ['JFM'] = true, ['lang'] = true, ['location'] = true, ['mr'] = true, ['MR'] = true, ['no-pp'] = true, ['orig-date'] = true, ['origyear'] = true, ['orig-year'] = true, ['osti'] = true, ['OSTI'] = true, ['osti-access'] = true, ['place'] = true, ['publisher'] = true, ['quote-page'] = true, ['quote-pages'] = true, ['script-quote'] = true, ['script-title'] = true, ['title-link'] = true, ['translator'] = true, ['translator-first'] = true, ['translator-given'] = true, ['translator-last'] = true, ['translator-surname'] = true, ['translator-link'] = true, ['translator-mask'] = true, ['trans-quote'] = true, ['type'] = true, ['zbl'] = true, ['ZBL'] = true, } local document_numbered_arguments_t = { ['translator#'] = true, ['translator-first#'] = true, ['translator#-first'] = true, ['translator-given#'] = true, ['translator#-given'] = true, ['translator-last#'] = true, ['translator#-last'] = true, ['translator-surname#'] = true, ['translator#-surname'] = true, ['translator-link#'] = true, ['translator#-link'] = true, ['translator-mask#'] = true, ['translator#-mask'] = true, } --[[--------------------------< L I S T _ C O M B I N E >------------------------------------------------------ makes one table from a list of tables. <lists_t> is a sequence of tables to be combined ]] local function list_combine (lists_t) local out_t = {}; for _, list_t in ipairs (lists_t) do -- for each list in <lists_t> for k, v in pairs (list_t) do -- extract each k/v pair out_t[k] = v; -- add to <out_t> end end return out_t; -- and done end --[[--------------------------< T E M P L A T E _ L I S T _ G E T >-------------------------------------------- gets a list of the templates from table t ]] local function template_list_get (t) local out_t = {}; -- a table for output for k, _ in pairs (t) do -- spin through the table and collect the keys table.insert (out_t, k) -- add each key to the output table end return out_t; -- and done end --[[--------------------------< E X P O R T E D T A B L E S >------------------------------------------------ ]] return { preprint_arguments_t = preprint_arguments_t, preprint_template_list_t = template_list_get (preprint_arguments_t), -- make a template list from preprint_arguments{} table unique_arguments_t = unique_arguments_t, unique_param_template_list_t = template_list_get (unique_arguments_t), -- make a template list from unique_arguments{} table document_parameters_t = list_combine ({limited_basic_arguments_t, limited_numbered_arguments_t, document_arguments_t, document_numbered_arguments_t}); common_parameters_t = list_combine ({basic_arguments_t, numbered_arguments_t}); limited_parameters_t = list_combine ({limited_basic_arguments_t, limited_numbered_arguments_t}); };