Line 1: |
Line 1: |
| | | |
− | --[[--------------------------< U N C A T E G O R I Z E D _ N A M E S P A C E S >------------------------------
| |
− |
| |
− | List of namespaces that should not be included in citation error categories. Same as setting notracking = true by default
| |
− |
| |
− | Note: Namespace names should use underscores instead of spaces.
| |
− |
| |
− | ]]
| |
− | local uncategorized_namespaces = { 'User', 'Talk', 'User_talk', 'Wikipedia_talk', 'File_talk', 'Template_talk', 'Help_talk', 'Category_talk', 'Portal_talk', 'Book_talk', 'Draft_talk', 'Education_Program_talk', 'Module_talk', 'MediaWiki_talk' };
| |
− |
| |
− | local uncategorized_subpages = {'/[Ss]andbox', '/[Tt]estcases'}; -- list of Lua patterns found in page names of pages we should not categorize
| |
− |
| |
− |
| |
− | --[[--------------------------< M E S S A G E S >--------------------------------------------------------------
| |
− |
| |
− | Translation table
| |
− |
| |
− | The following contains fixed text that may be output as part of a citation.
| |
− | This is separated from the main body to aid in future translations of this
| |
− | module.
| |
− |
| |
− | ]]
| |
− |
| |
− | local messages = {
| |
− | ['archived-dead'] = 'Archived from $1 on $2',
| |
− | ['archived-not-dead'] = '$1 from the original on $2',
| |
− | ['archived-missing'] = 'Archived from the original$1 on $2',
| |
− | ['archived'] = 'Archived',
| |
− | ['by'] = 'By', -- contributions to authored works: introduction, foreword, afterword
| |
− | ['cartography'] = 'Cartography by $1',
| |
− | ['editor'] = 'ed.',
| |
− | ['editors'] = 'eds.',
| |
− | ['edition'] = '($1 ed.)',
| |
− | ['episode'] = 'Episode $1',
| |
− | ['et al'] = 'et al.',
| |
− | ['in'] = 'In', -- edited works
| |
− | ['inactive'] = 'inactive',
| |
− | ['inset'] = '$1 inset',
| |
− | ['interview'] = 'Interviewed by $1',
| |
− | ['lay summary'] = 'Lay summary',
| |
− | ['newsgroup'] = '[[Usenet newsgroup|Newsgroup]]: $1',
| |
− | ['original'] = 'the original',
| |
− | ['published'] = ' (published $1)',
| |
− | ['retrieved'] = 'Retrieved $1',
| |
− | ['season'] = 'Season $1',
| |
− | ['section'] = '§ $1',
| |
− | ['sections'] = '§§ $1',
| |
− | ['series'] = 'Series $1',
| |
− | ['translated'] = 'Translated by $1',
| |
− | ['type'] = ' ($1)', -- for titletype
| |
− | ['written'] = 'Written at $1',
| |
− |
| |
− | ['vol'] = '$1 Vol. $2', -- $1 is sepc; bold journal style volume is in presentation{}
| |
− | ['vol-no'] = '$1 Vol. $2 no. $3', -- sepc, volume, issue
| |
− | ['issue'] = '$1 No. $2', -- $1 is sepc
| |
− |
| |
− | ['j-vol'] = '$1 $2', -- sepc, volume; bold journal volume is in presentation{}
| |
− | ['j-issue'] = ' ($1)',
| |
− |
| |
− | ['nopp'] = '$1 $2'; -- page(s) without prefix; $1 is sepc
| |
− |
| |
− | ['p-prefix'] = "$1 p. $2", -- $1 is sepc
| |
− | ['pp-prefix'] = "$1 pp. $2", -- $1 is sepc
| |
− | ['j-page(s)'] = ': $1', -- same for page and pages
| |
− |
| |
− | ['sheet'] = '$1 Sheet $2', -- $1 is sepc
| |
− | ['sheets'] = '$1 Sheets $2', -- $1 is sepc
| |
− | ['j-sheet'] = ': Sheet $1',
| |
− | ['j-sheets'] = ': Sheets $1',
| |
− |
| |
− | ['subscription'] = '<span class="cs1-subscription">(Subscription required (<span title="The site requires a paid subscription to access this page.">help</span>))</span>' ..
| |
− | '[[Category:Pages containing links to subscription-only content]]',
| |
− |
| |
− | ['registration']='<span class="cs1-registration">(Registration required (<span title="The site requires registration to access this page.">help</span>))</span>' ..
| |
− | '[[Category:Pages with login required references or sources]]',
| |
− |
| |
− | ['language'] = '(in $1)',
| |
− | ['via'] = " – via $1",
| |
− | ['event'] = 'Event occurs at',
| |
− | ['minutes'] = 'minutes in',
| |
− |
| |
− | ['parameter-separator'] = ', ',
| |
− | ['parameter-final-separator'] = ', and ',
| |
− | ['parameter-pair-separator'] = ' and ',
| |
− |
| |
− | -- Determines the location of the help page
| |
− | ['help page link'] = 'Help:CS1 errors',
| |
− | ['help page label'] = 'help',
| |
− |
| |
− | -- Internal errors (should only occur if configuration is bad)
| |
− | ['undefined_error'] = 'Called with an undefined error condition',
| |
− | ['unknown_manual_ID'] = 'Unrecognized manual ID mode',
| |
− | ['unknown_ID_mode'] = 'Unrecognized ID mode',
| |
− | ['unknown_argument_map'] = 'Argument map not defined for this variable',
| |
− | ['bare_url_no_origin'] = 'Bare url found but origin indicator is nil or empty',
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< E T _ A L _ P A T T E R N S >--------------------------------------------------
| |
− |
| |
− | This table provides Lua patterns for the phrase "et al" and variants in name text
| |
− | (author, editor, etc.). The main module uses these to identify and emit the 'etal' message.
| |
− |
| |
− | ]]
| |
− |
| |
− | local et_al_patterns = {
| |
− | "[;,]? *[\"']*%f[%a][Ee][Tt]%.? *[Aa][Ll][%.\"']*$", -- variations on the 'et al' theme
| |
− | "[;,]? *[\"']*%f[%a][Ee][Tt]%.? *[Aa][Ll][Ii][Aa][%.\"']*$", -- variations on the 'et alia' theme
| |
− | "[;,]? *%f[%a]and [Oo]thers", -- and alternate to et al.
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< E D I T O R _ M A R K U P _ P A T T E R N S >----------------------------------
| |
− |
| |
− | This table provides Lua patterns for the phrase "ed" and variants in name text
| |
− | (author, editor, etc.). The main module uses these to identify and emit the
| |
− | 'extra_text_names' message. (It is not the only series of patterns for this message.)
| |
− |
| |
− | ]]
| |
− | local editor_markup_patterns = { -- these patterns match annotations at end of name
| |
− | '%f[%(%[][%(%[]%s*[Ee][Dd][Ss]?%.?%s*[%)%]]?$', -- (ed) or (eds): leading '(', case insensitive 'ed', optional 's', '.' and/or ')'
| |
− | '[,%.%s]%f[e]eds?%.?$', -- ed or eds: without '('or ')'; case sensitive (ED could be initials Ed could be name)
| |
− | '%f[%(%[][%(%[]%s*[Ee][Dd][Ii][Tt][Oo][Rr][Ss]?%.?%s*[%)%]]?$', -- (editor) or (editors): leading '(', case insensitive, optional '.' and/or ')'
| |
− | '[,%.%s]%f[Ee][Ee][Dd][Ii][Tt][Oo][Rr][Ss]?%.?$', -- editor or editors: without '('or ')'; case insensitive
| |
− |
| |
− | -- these patterns match annotations at beginning of name
| |
− | '^eds?[%.,;]', -- ed. or eds.: lower case only, optional 's', requires '.'
| |
− | '^[%(%[]%s*[Ee][Dd][Ss]?%.?%s*[%)%]]', -- (ed) or (eds): also sqare brackets, case insensitive, optional 's', '.'
| |
− | '^[%(%[]?%s*[Ee][Dd][Ii][Tt][Oo][Rr][Ss]?%A', -- (editor or (editors: also sq brackets, case insensitive, optional brackets, 's'
| |
− | '^[%(%[]?%s*[Ee][Dd][Ii][Tt][Ee][Dd]%A', -- (edited: also sq brackets, case insensitive, optional brackets
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< P R E S E N T A T I O N >------------------------------------------------------
| |
− |
| |
− | Fixed presentation markup. Originally part of citation_config.messages it has been moved into its own, more semantically
| |
− | correct place.
| |
− |
| |
− | ]]
| |
− |
| |
− | local presentation =
| |
− | {
| |
− | -- Error output
| |
− | -- .error class is specified at https://git.wikimedia.org/blob/mediawiki%2Fcore.git/9553bd02a5595da05c184f7521721fb1b79b3935/skins%2Fcommon%2Fshared.css#L538
| |
− | -- .citation-comment class is specified at Help:CS1_errors#Controlling_error_message_display
| |
− | ['hidden-error'] = '<span class="cs1-hidden-error error citation-comment">$1</span>',
| |
− | ['visible-error'] = '<span class="cs1-visible-error error citation-comment">$1</span>',
| |
− | ['hidden-maint'] = '<span class="cs1-maint citation-comment">$1</span>',
| |
− |
| |
− | ['accessdate'] = '<span class="reference-accessdate">$1$2</span>', -- to allow editors to hide accessdate using personal css
| |
− |
| |
− | ['bdi'] = '<bdi$1>$2</bdi>', -- bidirectional isolation used with |script-title= and the like
| |
− |
| |
− | ['cite'] = '<cite class="$1">$2</cite>'; -- |ref= not set so no id="..." attribute
| |
− | ['cite-id'] = '<cite id="$1" class="$2">$3</cite>'; -- for use when |ref= is set
| |
− |
| |
− | ['format'] = ' <span class="cs1-format">($1)</span>', -- for |format=, |chapter-format=, etc
| |
− |
| |
− | -- various access levels, for |access=, |doi-access=, |arxiv=, ...
| |
− | -- narrow no-break space   may work better than nowrap css. Or not? browser support?
| |
− |
| |
− | ['ext-link-access-signal'] = '<span class="$1" title="$2">$3</span>', -- external link with appropriate lock icon
| |
− | ['free'] = {class='cs1-lock-free', title='Freely accessible'}, -- classes defined in Module:Citation/CS1/styles.css
| |
− | ['registration'] = {class='cs1-lock-registration', title='Free registration required'},
| |
− | ['limited'] = {class='cs1-lock-limited', title='Free access subject to limited trial, subscription normally required'},
| |
− | ['subscription'] = {class='cs1-lock-subscription', title='Paid subscription required'},
| |
− |
| |
− | ['interwiki-icon'] = '<span class="$1" title="$2">$3</span>',
| |
− | ['class-wikisource'] = 'cs1-ws-icon',
| |
− |
| |
− | ['italic-title'] = "''$1''",
| |
− |
| |
− | ['kern-left'] = '<span class="cs1-kern-left">$1</span>$2', -- spacing to use when title contains leading single or double quote mark
| |
− | ['kern-right'] = '$1<span class="cs1-kern-right">$2</span>', -- spacing to use when title contains trailing single or double quote mark
| |
− |
| |
− | -- these for simple wikilinked titles [["text]], [[text"]] and [["text"]]
| |
− | -- span wraps entire wikilink
| |
− | ['kern-wl-left'] = '<span class="cs1-kern-wl-left">$1</span>', -- when title contains leading single or double quote mark
| |
− | ['kern-wl-right'] = '<span class="cs1-kern-wl-left">$1</span>', -- when title contains trailing single or double quote mark
| |
− | ['kern-wl-both'] = '<span class="cs1-kern-wl-left cs1-kern-wl-right">$1</span>', -- when title contains leading and trailing single or double quote marks
| |
− |
| |
− | ['nowrap1'] = '<span class="nowrap">$1</span>', -- for nowrapping an item: <span ...>yyyy-mm-dd</span>
| |
− | ['nowrap2'] = '<span class="nowrap">$1</span> $2', -- for nowrapping portions of an item: <span ...>dd mmmm</span> yyyy (note white space)
| |
− |
| |
− | ['ocins'] = '<span title="$1" class="Z3988"></span>',
| |
− |
| |
− | ['parameter'] = '<code class="cs1-code">|$1=</code>',
| |
− |
| |
− | ['ps_cs1'] = '.'; -- cs1 style postscript (terminal) character
| |
− | ['ps_cs2'] = ''; -- cs2 style postscript (terminal) character (empty string)
| |
− |
| |
− | ['quoted-text'] = '<q>$1</q>', -- for wrapping |quote= content
| |
− | ['quoted-title'] = '"$1"',
| |
− |
| |
− | ['sep_cs1'] = '.', -- cs1 element separator
| |
− | ['sep_cs2'] = ',', -- cs2 separator
| |
− | ['sep_nl'] = ';', -- cs1|2 style name-list separator between authors is a semicolon
| |
− | ['sep_name'] = ', ', -- cs1|2 style last/first separator is <comma><space>
| |
− | ['sep_nl_vanc'] = ',', -- Vancouver style name-list separator between authors is a comma
| |
− | ['sep_name_vanc'] = ' ', -- Vancouver style last/first separator is a space
| |
− |
| |
− | ['trans-italic-title'] = "[''$1'']",
| |
− | ['trans-quoted-title'] = "[$1]",
| |
− | ['vol-bold'] = '$1 <b>$2</b>', -- sepc, volume; for bold journal cites; for other cites ['vol'] in messages{}
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< A L I A S E S >----------------------------------------------------------------
| |
− |
| |
− | Aliases table for commonly passed parameters
| |
− |
| |
− | ]]
| |
− |
| |
− | local aliases = {
| |
− | ['AccessDate'] = {'access-date', 'accessdate'},
| |
− | ['Agency'] = 'agency',
| |
− | ['AirDate'] = {'air-date', 'airdate'},
| |
− | ['ArchiveDate'] = {'archive-date', 'archivedate'},
| |
− | ['ArchiveFormat'] = 'archive-format',
| |
− | ['ArchiveURL'] = {'archive-url', 'archiveurl'},
| |
− | ['ASINTLD'] = {'ASIN-TLD', 'asin-tld'},
| |
− | ['At'] = 'at',
| |
− | ['Authors'] = {'authors', 'people', 'credits'},
| |
− | ['BookTitle'] = {'book-title', 'booktitle'},
| |
− | ['Cartography'] = 'cartography',
| |
− | ['Chapter'] = {'chapter', 'contribution', 'entry', 'article', 'section'},
| |
− | ['ChapterFormat'] = {'chapter-format', 'contribution-format', 'entry-format', 'article-format', 'section-format'};
| |
− | ['ChapterURL'] = {'chapter-url', 'chapterurl', 'contribution-url', 'contributionurl', 'entry-url', 'article-url', 'section-url', 'sectionurl'},
| |
− | ['ChapterUrlAccess'] = {'chapter-url-access', 'contribution-url-access', 'entry-url-access', 'article-url-access', 'section-url-access'},
| |
− | ['Class'] = 'class', -- cite arxiv and arxiv identifiers
| |
− | ['Collaboration'] = 'collaboration',
| |
− | ['Conference'] = {'conference', 'event'},
| |
− | ['ConferenceFormat'] = {'conference-format', 'event-format'},
| |
− | ['ConferenceURL'] = {'conference-url', 'conferenceurl', 'event-url', 'eventurl'},
| |
− | ['Contribution'] = 'contribution', -- introduction, foreword, afterword, etc; required when |contributor= set
| |
− | ['Date'] = 'date',
| |
− | ['DeadURL'] = {'dead-url', 'deadurl'},
| |
− | ['Degree'] = 'degree',
| |
− | ['DF'] = 'df',
| |
− | ['DisplayAuthors'] = {'display-authors', 'displayauthors'},
| |
− | ['DisplayContributors'] = 'display-contributors',
| |
− | ['DisplayEditors'] = {'display-editors', 'displayeditors'},
| |
− | ['DisplayInterviewers'] = 'display-interviewers',
| |
− | ['DisplayTranslators'] = 'display-translators',
| |
− | ['Docket'] = 'docket',
| |
− | ['DoiBroken'] = {'doi-broken', 'doi-broken-date', 'doi-inactive-date'},
| |
− | ['Edition'] = 'edition',
| |
− | ['Editors'] = 'editors',
| |
− | ['Embargo'] = 'embargo',
| |
− | ['Encyclopedia'] = {'encyclopedia', 'encyclopaedia'}, -- this one only used by citation
| |
− | ['Episode'] = 'episode', -- cite serial only TODO: make available to cite episode?
| |
− | ['Format'] = 'format',
| |
− | ['ID'] = {'id', 'ID'},
| |
− | ['IgnoreISBN'] = {'ignore-isbn-error', 'ignoreisbnerror'},
| |
− | ['Inset'] = 'inset',
| |
− | ['Issue'] = {'issue', 'number'},
| |
− | ['Language'] = {'language', 'lang'},
| |
− | ['LastAuthorAmp'] = {'last-author-amp', 'lastauthoramp'},
| |
− | ['LayDate'] = {'lay-date', 'laydate'},
| |
− | ['LayFormat'] = 'lay-format',
| |
− | ['LaySource'] = {'lay-source', 'laysource'},
| |
− | ['LayURL'] = {'lay-url', 'lay-summary', 'layurl', 'laysummary'},
| |
− | ['MailingList'] = {'mailinglist', 'mailing-list'}, -- cite mailing list only
| |
− | ['Map'] = 'map', -- cite map only
| |
− | ['MapFormat'] = 'map-format', -- cite map only
| |
− | ['MapURL'] = {'mapurl', 'map-url'}, -- cite map only
| |
− | ['MessageID'] = 'message-id',
| |
− | ['Minutes'] = 'minutes',
| |
− | ['Mode'] = 'mode',
| |
− | ['NameListFormat'] = 'name-list-format',
| |
− | ['Network'] = 'network',
| |
− | ['NoPP'] = {'no-pp', 'nopp'},
| |
− | ['NoTracking'] = {'template-doc-demo', 'no-cat', 'nocat',
| |
− | 'no-tracking', 'notracking'},
| |
− | ['Number'] = 'number', -- this case only for cite techreport
| |
− | ['OrigYear'] = {'orig-year', 'origyear'},
| |
− | ['Others'] = 'others',
| |
− | ['Page'] = {'p', 'page'},
| |
− | ['Pages'] = {'pp', 'pages'},
| |
− | ['Periodical'] = {'journal', 'newspaper', 'magazine', 'work',
| |
− | 'website', 'periodical', 'encyclopedia', 'encyclopaedia', 'dictionary', 'mailinglist'},
| |
− | ['Place'] = {'place', 'location'},
| |
− | ['PostScript'] = 'postscript',
| |
− | ['PublicationDate'] = {'publicationdate', 'publication-date'},
| |
− | ['PublicationPlace'] = {'publication-place', 'publicationplace'},
| |
− | ['PublisherName'] = {'publisher', 'distributor', 'institution', 'newsgroup'},
| |
− | ['Quote'] = {'quote', 'quotation'},
| |
− | ['Ref'] = 'ref',
| |
− | ['RegistrationRequired'] = 'registration',
| |
− | ['Scale'] = 'scale',
| |
− | ['ScriptChapter'] = 'script-chapter',
| |
− | ['ScriptTitle'] = 'script-title',
| |
− | ['Section'] = 'section',
| |
− | ['Season'] = 'season',
| |
− | ['Sections'] = 'sections', -- cite map only
| |
− | ['Series'] = {'series', 'version'},
| |
− | ['SeriesSeparator'] = 'series-separator',
| |
− | ['SeriesLink'] = {'series-link', 'serieslink'},
| |
− | ['SeriesNumber'] = {'series-number', 'series-no', 'seriesnumber', 'seriesno'},
| |
− | ['Sheet'] = 'sheet', -- cite map only
| |
− | ['Sheets'] = 'sheets', -- cite map only
| |
− | ['Station'] = 'station',
| |
− | ['SubscriptionRequired'] = 'subscription',
| |
− | ['Time'] = 'time',
| |
− | ['TimeCaption'] = {'time-caption', 'timecaption'},
| |
− | ['Title'] = 'title',
| |
− | ['TitleLink'] = {'title-link', 'episode-link', 'titlelink', 'episodelink'},
| |
− | ['TitleNote'] = 'department',
| |
− | ['TitleType'] = {'type', 'medium'},
| |
− | ['TransChapter'] = 'trans-chapter',
| |
− | ['TransMap'] = 'trans-map', -- cite map only
| |
− | ['Transcript'] = 'transcript',
| |
− | ['TranscriptFormat'] = 'transcript-format',
| |
− | ['TranscriptURL'] = {'transcript-url', 'transcripturl'},
| |
− | ['TransTitle'] = 'trans-title',
| |
− | ['URL'] = {'url', 'URL'},
| |
− | ['UrlAccess'] = {'url-access'},
| |
− | ['Vauthors'] = 'vauthors',
| |
− | ['Veditors'] = 'veditors',
| |
− | ['Via'] = 'via',
| |
− | ['Volume'] = 'volume',
| |
− | ['Year'] = 'year',
| |
− |
| |
− | ['AuthorList-First'] = {"first#", "given#", "author-first#", "author#-first"},
| |
− | ['AuthorList-Last'] = {"last#", "author#", "surname#", "author-last#", "author#-last", "subject#", 'host#'},
| |
− | ['AuthorList-Link'] = {"authorlink#", "author-link#", "author#-link", "subjectlink#", "author#link", "subject-link#", "subject#-link", "subject#link"},
| |
− | ['AuthorList-Mask'] = {"author-mask#", "authormask#", "author#mask", "author#-mask"},
| |
− |
| |
− | ['ContributorList-First'] = {'contributor-first#', 'contributor#-first', 'contributor-given#', 'contributor#-given'},
| |
− | ['ContributorList-Last'] = {'contributor#', 'contributor-last#', 'contributor#-last', 'contributor-surname#', 'contributor#-surname'},
| |
− | ['ContributorList-Link'] = {'contributor-link#', 'contributor#-link'},
| |
− | ['ContributorList-Mask'] = {'contributor-mask#', 'contributor#-mask'},
| |
− |
| |
− | ['EditorList-First'] = {"editor-first#", "editor#-first", "editor-given#", "editor#-given"},
| |
− | ['EditorList-Last'] = {"editor#", "editor-last#", "editor#-last", "editor-surname#", "editor#-surname"},
| |
− | ['EditorList-Link'] = {"editor-link#", "editor#-link", "editorlink#", "editor#link"},
| |
− | ['EditorList-Mask'] = {"editor-mask#", "editor#-mask", "editormask#", "editor#mask"},
| |
− |
| |
− | ['InterviewerList-First'] = {'interviewer-first#', 'interviewer#-first'},
| |
− | ['InterviewerList-Last'] = {'interviewer#', 'interviewer-last#', 'interviewer#-last'},
| |
− | ['InterviewerList-Link'] = {'interviewer-link#', 'interviewer#-link'},
| |
− | ['InterviewerList-Mask'] = {'interviewer-mask#', 'interviewer#-mask'},
| |
− |
| |
− | ['TranslatorList-First'] = {'translator-first#', 'translator#-first', 'translator-given#', 'translator#-given'},
| |
− | ['TranslatorList-Last'] = {'translator#', 'translator-last#', 'translator#-last', 'translator-surname#', 'translator#-surname'},
| |
− | ['TranslatorList-Link'] = {'translator-link#', 'translator#-link'},
| |
− | ['TranslatorList-Mask'] = {'translator-mask#', 'translator#-mask'},
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< S P E C I A L C A S E T R A N S L A T I O N S >----------------------------
| |
− |
| |
− | This table is primarily here to support internationalization. Translations in this table are used, for example,
| |
− | when an error message, category name, etc is extracted from the English alias key. There may be other cases where
| |
− | this translation table may be useful.
| |
− |
| |
− | ]]
| |
− |
| |
− | local special_case_translation = {
| |
− | ['AuthorList'] = 'authors list', -- these for multiple names maint categories
| |
− | ['ContributorList'] = 'contributors list',
| |
− | ['EditorList'] = 'editors list',
| |
− | ['InterviewerList'] = 'interviewers list',
| |
− | ['TranslatorList'] = 'translators list',
| |
− |
| |
− | ['authors'] = 'authors', -- used in get_display_names()
| |
− | ['contributors'] = 'contributors',
| |
− | ['editors'] = 'editors',
| |
− | ['interviewers'] = 'interviewers',
| |
− | ['translators'] = 'translators',
| |
− |
| |
− | ['archived_copy'] = '^archived?%s+copy$', -- lua pattern to match pseudo title used by Internet Archive bot and others as place holder for unknown |title= value
| |
− | -- used with CS1 maint: Archived copy as title
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< D E F A U L T S >--------------------------------------------------------------
| |
− |
| |
− | Default parameter values
| |
− |
| |
− | TODO: keep this? Only one default?
| |
− | ]]
| |
− |
| |
− | local defaults = {
| |
− | ['DeadURL'] = 'yes',
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< D A T E _ N A M E S >----------------------------------------------------------
| |
− |
| |
− | This table of tables lists local language date names and fallback English date names. The code in Date_validation
| |
− | will look first in the local table for valid date names. If date names are not found in the local table, the code
| |
− | will look in the English table.
| |
− |
| |
− | Because citations can be copied to the local wiki from en.wiki, the English is required when the date-name translation
| |
− | function date_name_xlate() is used.
| |
− |
| |
− | In these tables, season numbering is defined by ISO DIS 8601:2016 part 2 §4.7 'Divisions of a year'. The standard
| |
− | defines various divisions using numbers 21-41. cs1|2 only supports generic seasons. ISO DIS 8601:2016 does support
| |
− | the distinction between north and south hemispere seasons but cs1|2 has no way to make that distinction.
| |
− |
| |
− | The standard does not address 'named' dates so, for the purposes of cs1|2, Christmas is defined here as 99, which
| |
− | should be out of the ISO DIS 8601:2016 range of uses for a while.
| |
− |
| |
− | ]]
| |
− |
| |
− | local date_names = {
| |
− | ['en'] = { -- English
| |
− | ['long'] = {['January']=1, ['February']=2, ['March']=3, ['April']=4, ['May']=5, ['June']=6, ['July']=7, ['August']=8, ['September']=9, ['October']=10, ['November']=11, ['December']=12},
| |
− | ['short'] = {['Jan']=1, ['Feb']=2, ['Mar']=3, ['Apr']=4, ['May']=5, ['Jun']=6, ['Jul']=7, ['Aug']=8, ['Sep']=9, ['Oct']=10, ['Nov']=11, ['Dec']=12},
| |
− | ['season'] = {['Winter']=24, ['Spring']=21, ['Summer']=22, ['Fall']=23, ['Autumn']=23},
| |
− | ['named'] = {['Christmas']=99},
| |
− | },
| |
− | ['local'] = { -- replace these English date names with the local language equivalents
| |
− | ['long'] = {['January']=1, ['February']=2, ['March']=3, ['April']=4, ['May']=5, ['June']=6, ['July']=7, ['August']=8, ['September']=9, ['October']=10, ['November']=11, ['December']=12},
| |
− | ['short'] = {['Jan']=1, ['Feb']=2, ['Mar']=3, ['Apr']=4, ['May']=5, ['Jun']=6, ['Jul']=7, ['Aug']=8, ['Sep']=9, ['Oct']=10, ['Nov']=11, ['Dec']=12},
| |
− | ['season'] = {['Winter']=24, ['Spring']=21, ['Summer']=22, ['Fall']=23, ['Autumn']=23},
| |
− | ['named'] = {['Christmas']=99},
| |
− | },
| |
− | ['inv_local_l'] = {}, -- used in date reformatting; copy of date_names['local'].long where k/v are inverted: [1]='<local name>' etc
| |
− | ['inv_local_s'] = {}, -- used in date reformatting; copy of date_names['local'].short where k/v are inverted: [1]='<local name>' etc
| |
− | ['local_digits'] = {['0'] = '0', ['1'] = '1', ['2'] = '2', ['3'] = '3', ['4'] = '4', ['5'] = '5', ['6'] = '6', ['7'] = '7', ['8'] = '8', ['9'] = '9'}, -- used to convert local language digits to Western 0-9
| |
− | ['xlate_digits'] = {},
| |
− | }
| |
− |
| |
− | for name, i in pairs (date_names['local'].long) do -- this table is ['name'] = i
| |
− | date_names['inv_local_l'][i] = name; -- invert to get [i] = 'name' for conversions from ymd
| |
− | end
| |
− |
| |
− | for name, i in pairs (date_names['local'].short) do -- this table is ['name'] = i
| |
− | date_names['inv_local_s'][i] = name; -- invert to get [i] = 'name' for conversions from ymd
| |
− | end
| |
− |
| |
− | for ld, ed in pairs (date_names.local_digits) do -- make a digit translation table for simple date translation from en to local language using local_digits table
| |
− | date_names.xlate_digits [ed] = ld; -- en digit becomes index with local digit as the value
| |
− | end
| |
− |
| |
− | local df_template_patterns = { -- table of redirects to {{Use dmy dates}} and {{Use mdy dates}}
| |
− | '{{ *[Uu]se (dmy) dates *[|}]', -- 915k -- sorted by approximate transclusion count
| |
− | '{{ *[Uu]se *(mdy) *dates *[|}]', -- 161k
| |
− | '{{ *[Uu]se (DMY) dates *[|}]', -- 2929
| |
− | '{{ *[Uu]se *(dmy) *[|}]', -- 250 + 34
| |
− | '{{ *([Dd]my) *[|}]', -- 272
| |
− | '{{ *[Uu]se (MDY) dates *[|}]', -- 173
| |
− | '{{ *[Uu]se *(mdy) *[|}]', -- 59 + 12
| |
− | '{{ *([Mm]dy) *[|}]', -- 9
| |
− | '{{ *[Uu]se (MDY) *[|}]', -- 3
| |
− | '{{ *([Dd]MY) *[|}]', -- 2
| |
− | '{{ *([Mm]DY) *[|}]', -- 0
| |
− | -- '{{ *[Uu]se(mdy) *[|}]',
| |
− | -- '{{ *[Uu]se(mdy)dates *[|}]',
| |
− | -- '{{ *[Uu]se(dmy) *[|}]',
| |
− | }
| |
− |
| |
− | local function get_date_format ()
| |
− | local content = mw.title.getCurrentTitle():getContent() or ''; -- get the content of the article
| |
− | for _, pattern in ipairs (df_template_patterns) do -- loop through the patterns looking for {{Use dmy dates}} or {{Use mdy dates}} or any of their redirects
| |
− | local start, _, match = content:find(pattern); -- match is the three letters indicating desired date format
| |
− | if match then
| |
− | content = content:match ('%b{}', start); -- get the whole template
| |
− | if content:match ('| *cs1%-dates *= *[lsy][sy]?') then -- look for |cs1-dates=publication date length access-/archive-date length
| |
− | return match:lower() .. '-' .. content:match ('| *cs1%-dates *= *([lsy][sy]?)');
| |
− | else
| |
− | return match:lower() .. '-all'; -- no |cs1-style= k/v pair; return value appropriate for use in |df=
| |
− | end
| |
− | end
| |
− | end
| |
− | end
| |
− | local global_df = get_date_format ();
| |
− |
| |
− |
| |
− | --[[--------------------------< V O L U M E , I S S U E , P A G E S >----------------------------------------
| |
− |
| |
− | These tables hold cite class values (from the template invocation) and identify those templates that support
| |
− | |volume=, |issue=, and |page(s)= parameters. Cite conference and cite map require further qualification which
| |
− | is handled in the main module.
| |
− |
| |
− | ]]
| |
− |
| |
− | local templates_using_volume = {'citation', 'audio-visual', 'book', 'conference', 'encyclopaedia', 'interview', 'journal', 'magazine', 'map', 'news', 'report', 'techreport', 'thesis'}
| |
− | local templates_using_issue = {'citation', 'conference', 'episode', 'interview', 'journal', 'magazine', 'map', 'news'}
| |
− | local templates_not_using_page = {'audio-visual', 'episode', 'mailinglist', 'newsgroup', 'podcast', 'serial', 'sign', 'speech'}
| |
− |
| |
− |
| |
− | --[[--------------------------< K E Y W O R D S >--------------------------------------------------------------
| |
− |
| |
− | This table holds keywords for those parameters that have defined sets of acceptible keywords.
| |
− |
| |
− | ]]
| |
− |
| |
− | local keywords = {
| |
− | ['yes_true_y'] = {'yes', 'true', 'y'}, -- ignore-isbn-error, last-author-amp, no-tracking, nopp, registration, subscription
| |
− | -- ['deadurl'] = {'yes', 'true', 'y', 'no', 'unfit', 'usurped', 'unfit no archive', 'usurped no archive'}, -- hidden 2016-04-10; see Help_talk:Citation_Style_1#Recycled_urls
| |
− | ['deadurl'] = {'yes', 'true', 'y', 'no', 'unfit', 'usurped', 'bot: unknown'},
| |
− | ['mode'] = {'cs1', 'cs2', 'mla'},
| |
− | ['name-list-format'] = {'vanc'},
| |
− | ['contribution'] = {'afterword', 'foreword', 'introduction', 'preface'}, -- generic contribution titles that are rendered unquoted in the 'chapter' position
| |
− | ['date-format'] = {'dmy', 'dmy-all', 'mdy', 'mdy-all', 'ymd', 'ymd-all'},
| |
− | -- ['date-format'] = {'dmy', 'dmy-all', 'mdy', 'mdy-all', 'ymd', 'ymd-all', 'yMd', 'yMd-all'}, -- not supported at en.wiki
| |
− | ['url-access'] = {'subscription', 'limited', 'registration'}, -- access level of a URL (subscription required, limited access, free registration required), free to read by default
| |
− | ['id-access'] = {'free'}, -- access level of an identifier (free to read), subscription required (or no full text) by default
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< S T R I P M A R K E R S >------------------------------------------------------
| |
− |
| |
− | Common pattern definition location for stripmarkers so that we don't have to go hunting for them if (when)
| |
− | MediaWiki changes their form.
| |
− |
| |
− | ]]
| |
− |
| |
− | local stripmarkers = {
| |
− | ['any'] = '\127[^\127]*UNIQ%-%-(%a+)%-[%a%d]+%-QINU[^\127]*\127', -- capture returns name of stripmarker
| |
− | ['math'] = '\127[^\127]*UNIQ%-%-math%-[%a%d]+%-QINU[^\127]*\127' -- math stripmarkers used in coins_cleanup() and coins_replace_math_stripmarker()
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< I N V I S I B L E _ C H A R A C T E R S >--------------------------------------
| |
− |
| |
− | This table holds non-printing or invisible characters indexed either by name or by Unicode group. Values are decimal
| |
− | representations of UTF-8 codes. The table is organized as a table of tables because the lua pairs keyword returns
| |
− | table data in an arbitrary order. Here, we want to process the table from top to bottom because the entries at
| |
− | the top of the table are also found in the ranges specified by the entries at the bottom of the table.
| |
− |
| |
− | Also here is a pattern that recognizes stripmarkers that begin and end with the delete characters. The nowiki
| |
− | stripmarker is not an error but some others are because the parameter values that include them become part of the
| |
− | template's metadata before stripmarker replacement.
| |
− |
| |
− | ]]
| |
− |
| |
− | local invisible_chars = {
| |
− | {'replacement', '\239\191\189'}, -- U+FFFD, EF BF BD
| |
− | {'zero width joiner', '\226\128\141'}, -- U+200D, E2 80 8D
| |
− | {'zero width space', '\226\128\139'}, -- U+200B, E2 80 8B
| |
− | {'hair space', '\226\128\138'}, -- U+200A, E2 80 8A
| |
− | {'soft hyphen', '\194\173'}, -- U+00AD, C2 AD
| |
− | {'horizontal tab', '\009'}, -- U+0009 (HT), 09
| |
− | {'line feed', '\010'}, -- U+000A (LF), 0A
| |
− | {'carriage return', '\013'}, -- U+000D (CR), 0D
| |
− | {'stripmarker', stripmarkers.any}, -- stripmarker; may or may not be an error; capture returns the stripmaker type
| |
− | {'delete', '\127'}, -- U+007F (DEL), 7F; must be done after stripmarker test
| |
− | {'C0 control', '[\000-\008\011\012\014-\031]'}, -- U+0000–U+001F (NULL–US), 00–1F (except HT, LF, CR (09, 0A, 0D))
| |
− | {'C1 control', '[\194\128-\194\159]'}, -- U+0080–U+009F (XXX–APC), C2 80 – C2 9F
| |
− | -- {'Specials', '[\239\191\185-\239\191\191]'}, -- U+FFF9-U+FFFF, EF BF B9 – EF BF BF
| |
− | -- {'Private use area', '[\238\128\128-\239\163\191]'}, -- U+E000–U+F8FF, EE 80 80 – EF A3 BF
| |
− | -- {'Supplementary Private Use Area-A', '[\243\176\128\128-\243\191\191\189]'}, -- U+F0000–U+FFFFD, F3 B0 80 80 – F3 BF BF BD
| |
− | -- {'Supplementary Private Use Area-B', '[\244\128\128\128-\244\143\191\189]'}, -- U+100000–U+10FFFD, F4 80 80 80 – F4 8F BF BD
| |
− | }
| |
− |
| |
− | --[[
| |
− | Indic script makes use of zero width joiner as a character modifier so zwj characters must be left in. This
| |
− | pattern covers all of the unicode characters for these languages:
| |
− | Devanagari 0900–097F – https://unicode.org/charts/PDF/U0900.pdf
| |
− | Devanagari extended A8E0–A8FF – https://unicode.org/charts/PDF/UA8E0.pdf
| |
− | Bengali 0980–09FF – https://unicode.org/charts/PDF/U0980.pdf
| |
− | Gurmukhi 0A00–0A7F – https://unicode.org/charts/PDF/U0A00.pdf
| |
− | Gujarati 0A80–0AFF – https://unicode.org/charts/PDF/U0A80.pdf
| |
− | Oriya 0B00–0B7F – https://unicode.org/charts/PDF/U0B00.pdf
| |
− | Tamil 0B80–0BFF – https://unicode.org/charts/PDF/U0B80.pdf
| |
− | Telugu 0C00–0C7F – https://unicode.org/charts/PDF/U0C00.pdf
| |
− | Kannada 0C80–0CFF – https://unicode.org/charts/PDF/U0C80.pdf
| |
− | Malayalam 0D00–0D7F – https://unicode.org/charts/PDF/U0D00.pdf
| |
− | plus the not-necessarily Indic scripts for Sinhala and Burmese:
| |
− | Sinhala 0D80-0DFF - https://unicode.org/charts/PDF/U0D80.pdf
| |
− | Myanmar 1000-109F - https://unicode.org/charts/PDF/U1000.pdf
| |
− | Myanmar extended A AA60-AA7F - https://unicode.org/charts/PDF/UAA60.pdf
| |
− | Myanmar extended B A9E0-A9FF - https://unicode.org/charts/PDF/UA9E0.pdf
| |
− | the pattern is used by has_invisible_chars() and coins_cleanup()
| |
− | TODO: find a better place for this?
| |
− | ]]
| |
− |
| |
− | local indic_script = '[\224\164\128-\224\181\191\224\163\160-\224\183\191\225\128\128-\225\130\159\234\167\160-\234\167\191\234\169\160-\234\169\191]';
| |
− |
| |
− |
| |
− | --[[--------------------------< L A N G U A G E S >------------------------------------------------------------
| |
− |
| |
− | This table is used to hold ISO 639-1 two-character language codes that apply only to |script-title= and |script-chapter=
| |
− |
| |
− | ]]
| |
− |
| |
− | local script_lang_codes = {
| |
− | 'am', 'ar', 'be', 'bg', 'bn', 'bs', 'dv', 'el', 'fa', 'gu', -- ISO 639-1 codes only for |script-title= and |script-chapter=
| |
− | 'he', 'hi', 'hy', 'ja', 'ka', 'kk', 'km', 'kn', 'ko', 'ku',
| |
− | 'mk', 'ml', 'mn', 'mr', 'my', 'ne', 'ps', 'ru', 'sd', 'si',
| |
− | 'sr', 'ta', 'tg', 'th', 'uk', 'ug', 'ur', 'uz', 'yi', 'zh'
| |
− | };
| |
− |
| |
− |
| |
− | --[[--------------------------< L A N G U A G E R E M A P P I N G >------------------------------------------
| |
− |
| |
− | These tables hold language information that is different (correct) from MediaWiki's definitions
| |
− |
| |
− | ]]
| |
− |
| |
− | local lang_code_remap = { -- used for |language= and |script-title= / |script-chapter=
| |
− | ['als'] = 'Tosk Albanian', -- MediaWiki returns Alemannisch
| |
− | ['bh'] = 'Bihari', -- MediaWiki uses 'bh' as a subdomain name for Bhojpuri wWikipedia: bh.wikipedia.org
| |
− | ['bn'] = 'Bengali', -- MediaWiki returns Bangla
| |
− | ['ca-valencia'] = 'Valencian', -- IETF variant of Catalan
| |
− | ['crh'] = 'Crimean Tatar', -- synonymous with Crimean Turkish (return value from {{#language:crh|en}})
| |
− | }
| |
− |
| |
− | local lang_name_remap = { -- used for |language=
| |
− | ['alemannisch'] = {'Swiss German', 'gsw'}, -- not an ISO or IANA language name; MediaWiki uses 'als' as a subdomain name for Alemannic Wikipedia: als.wikipedia.org
| |
− | ['bangla'] = {'Bengali', 'bn'}, -- MediaWiki returns Bangla (the endonym) but we want Bengali (the exonym); here we remap
| |
− | ['bengali'] = {'Bengali', 'bn'}, -- MediaWiki doesn't use exonym so here we provide correct language name and 639-1 code
| |
− | ['bihari'] = {'Bihari', 'bh'}, -- MediaWiki replaces 'Bihari' with 'Bhojpuri' so 'Bihari' cannot be found
| |
− | ['bhojpuri'] = {'Bhojpuri', 'bho'}, -- MediaWiki uses 'bh' as a subdomain name for Bhojpuri Wikipedia: bh.wikipedia.org
| |
− | ['crimean tatar'] = {'Crimean Tatar', 'crh'}, -- MediaWiki uses 'crh' as a subdomain name for Crimean Tatar Wikipedia: crh.wikipedia.org
| |
− | ['tosk albanian'] = {'Tosk Albanian', 'als'}, -- MediaWiki replaces 'Tosk Albanian' with 'Alemannisch' so 'Tosk Albanian' cannot be found
| |
− | ['valencian'] = {'Valencian', 'ca'}, -- variant of Catalan; categorizes as Catalan
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< M A I N T E N A N C E _ C A T E G O R I E S >----------------------------------
| |
− |
| |
− | Here we name maintenance categories to be used in maintenance messages.
| |
− |
| |
− | ]]
| |
− |
| |
− | local maint_cats = {
| |
− | ['ASIN'] = 'CS1 maint: ASIN uses ISBN',
| |
− | ['archived_copy'] = 'CS1 maint: Archived copy as title',
| |
− | ['authors'] = 'CS1 maint: Uses authors parameter',
| |
− | ['bot:_unknown'] = 'CS1 maint: BOT: original-url status unknown',
| |
− | ['date_format'] = 'CS1 maint: Date format',
| |
− | ['date_year'] = 'CS1 maint: Date and year',
| |
− | ['disp_name'] = 'CS1 maint: display-$1', -- $1 is authors, contributors, editors, interviewers, translators; gets value from special_case_translation table
| |
− | ['editors'] = 'CS1 maint: Uses editors parameter',
| |
− | ['embargo'] = 'CS1 maint: PMC embargo expired',
| |
− | ['english'] = 'CS1 maint: English language specified',
| |
− | ['extra_text'] = 'CS1 maint: Extra text',
| |
− | ['extra_text_names'] = 'CS1 maint: Extra text: $1', -- $1 is <name>s list; gets value from special_case_translation table
| |
− | ['ignore_isbn_err'] = 'CS1 maint: Ignored ISBN errors',
| |
− | ['mult_names'] = 'CS1 maint: Multiple names: $1', -- $1 is <name>s list; gets value from special_case_translation table
| |
− | ['others'] = 'CS1 maint: others',
| |
− | ['pmc_format'] = 'CS1 maint: PMC format',
| |
− | ['unfit'] = 'CS1 maint: Unfit url',
| |
− | ['unknown_lang'] = 'CS1 maint: Unrecognized language',
| |
− | ['untitled'] = 'CS1 maint: Untitled periodical',
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< P R O P E R T I E S _ C A T E G O R I E S >------------------------------------
| |
− |
| |
− | Here we name properties categories
| |
− |
| |
− | ]]
| |
− |
| |
− | local prop_cats = {
| |
− | ['foreign_lang_source'] = 'CS1 $1-language sources ($2)', -- |language= categories; $1 is language name, $2 is ISO639-1 code
| |
− | ['foreign_lang_source_2'] = 'CS1 foreign language sources (ISO 639-2)|$1', -- |language= category; a cat for ISO639-2 languages; $1 is the ISO 639-2 code
| |
− | ['script'] = 'CS1 uses foreign language script', -- when language specified by |script-title=xx: doesn't have its own category
| |
− | ['script_with_name'] = 'CS1 uses $1-language script ($2)', -- |script-title=xx: has matching category; $1 is language name, $2 is ISO639-1 code
| |
− | ['jul_greg_uncertainty'] = 'CS1: Julian–Gregorian uncertainty', -- probably temporary cat to identify scope of template with dates 1 October 1582 – 1 January 1926
| |
− | ['long_vol'] = 'CS1: long volume value', -- probably temporary cat to identify scope of |volume= values longer than 4 charachters
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< T I T L E _ T Y P E S >--------------------------------------------------------
| |
− |
| |
− | Here we map a template's CitationClass to TitleType (default values for |type= parameter)
| |
− |
| |
− | ]]
| |
− |
| |
− | local title_types = {
| |
− | ['AV-media-notes'] = 'Media notes',
| |
− | ['interview'] = 'Interview',
| |
− | ['mailinglist'] = 'Mailing list',
| |
− | ['map'] = 'Map',
| |
− | ['podcast'] = 'Podcast',
| |
− | ['pressrelease'] = 'Press release',
| |
− | ['report'] = 'Report',
| |
− | ['techreport'] = 'Technical report',
| |
− | ['thesis'] = 'Thesis',
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< E R R O R _ C O N D I T I O N S >----------------------------------------------
| |
− |
| |
− | Error condition table
| |
− |
| |
− | The following contains a list of IDs for various error conditions defined in the code. For each ID, we specify a
| |
− | text message to display, an error category to include, and whether the error message should be wrapped as a hidden comment.
| |
− |
| |
− | Anchor changes require identical changes to matching anchor in Help:CS1 errors
| |
− |
| |
− | ]]
| |
− |
| |
− | local error_conditions = {
| |
− | accessdate_missing_url = {
| |
− | message = '<code class="cs1-code">|access-date=</code> requires <code class="cs1-code">|url=</code>',
| |
− | anchor = 'accessdate_missing_url',
| |
− | category = 'Pages using citations with accessdate and no URL',
| |
− | hidden = false
| |
− | },
| |
− | archive_missing_date = {
| |
− | message = '<code class="cs1-code">|archive-url=</code> requires <code class="cs1-code">|archive-date=</code>',
| |
− | anchor = 'archive_missing_date',
| |
− | category = 'Pages with archiveurl citation errors',
| |
− | hidden = false
| |
− | },
| |
− | archive_missing_url = {
| |
− | message = '<code class="cs1-code">|archive-url=</code> requires <code class="cs1-code">|url=</code>',
| |
− | anchor = 'archive_missing_url',
| |
− | category = 'Pages with archiveurl citation errors',
| |
− | hidden = false
| |
− | },
| |
− | archive_url = {
| |
− | message = '<code class="cs1-code">|archive-url=</code> is malformed: $1',
| |
− | anchor = 'archive_url',
| |
− | category = 'Pages with archiveurl citation errors',
| |
− | hidden = false
| |
− | },
| |
− | arxiv_missing = {
| |
− | message = '<code class="cs1-code">|arxiv=</code> required',
| |
− | anchor = 'arxiv_missing',
| |
− | category = 'CS1 errors: arXiv', -- same as bad arxiv
| |
− | hidden = false
| |
− | },
| |
− | arxiv_params_not_supported = {
| |
− | message = 'Unsupported parameter(s) in cite arXiv',
| |
− | anchor = 'arxiv_params_not_supported',
| |
− | category = 'CS1 errors: arXiv', -- same as bad arxiv
| |
− | hidden = false
| |
− | },
| |
− | bad_arxiv = {
| |
− | message = 'Check <code class="cs1-code">|arxiv=</code> value',
| |
− | anchor = 'bad_arxiv',
| |
− | category = 'CS1 errors: arXiv',
| |
− | hidden = false
| |
− | },
| |
− | bad_asin = {
| |
− | message = 'Check <code class="cs1-code">|asin=</code> value',
| |
− | anchor = 'bad_asin',
| |
− | category ='CS1 errors: ASIN',
| |
− | hidden = false
| |
− | },
| |
− | bad_bibcode = {
| |
− | message = 'Check <code class="cs1-code">|bibcode=</code> $1',
| |
− | anchor = 'bad_bibcode',
| |
− | category = 'CS1 errors: bibcode',
| |
− | hidden = false
| |
− | },
| |
− | bad_biorxiv = {
| |
− | message = 'Check <code class="cs1-code">|biorxiv=</code> value',
| |
− | anchor = 'bad_biorxiv',
| |
− | category = 'CS1 errors: bioRxiv',
| |
− | hidden = false
| |
− | },
| |
− | bad_citeseerx = {
| |
− | message = 'Check <code class="cs1-code">|citeseerx=</code> value',
| |
− | anchor = 'bad_citeseerx',
| |
− | category = 'CS1 errors: citeseerx',
| |
− | hidden = false
| |
− | },
| |
− | bad_date = {
| |
− | message = 'Check date values in: <code class="cs1-code">$1</code>',
| |
− | anchor = 'bad_date',
| |
− | category = 'CS1 errors: dates',
| |
− | hidden = false
| |
− | },
| |
− | bad_doi = {
| |
− | message = 'Check <code class="cs1-code">|doi=</code> value',
| |
− | anchor = 'bad_doi',
| |
− | category = 'CS1 errors: DOI',
| |
− | hidden = false
| |
− | },
| |
− | bad_hdl = {
| |
− | message = 'Check <code class="cs1-code">|hdl=</code> value',
| |
− | anchor = 'bad_hdl',
| |
− | category = 'CS1 errors: HDL',
| |
− | hidden = false
| |
− | },
| |
− | bad_isbn = {
| |
− | message = 'Check <code class="cs1-code">|isbn=</code> value: $1',
| |
− | anchor = 'bad_isbn',
| |
− | category = 'CS1 errors: ISBN',
| |
− | hidden = false
| |
− | },
| |
− | bad_ismn = {
| |
− | message = 'Check <code class="cs1-code">|ismn=</code> value',
| |
− | anchor = 'bad_ismn',
| |
− | category = 'CS1 errors: ISMN',
| |
− | hidden = false
| |
− | },
| |
− | bad_issn = {
| |
− | message = 'Check <code class="cs1-code">|$1issn=</code> value',
| |
− | anchor = 'bad_issn',
| |
− | category = 'CS1 errors: ISSN',
| |
− | hidden = false
| |
− | },
| |
− | bad_jfm = {
| |
− | message = 'Check <code class="cs1-code">|jfm=</code> value',
| |
− | anchor = 'bad_jfm',
| |
− | category = 'CS1 errors: JFM',
| |
− | hidden = false
| |
− | },
| |
− | bad_lccn = {
| |
− | message = 'Check <code class="cs1-code">|lccn=</code> value',
| |
− | anchor = 'bad_lccn',
| |
− | category = 'CS1 errors: LCCN',
| |
− | hidden = false
| |
− | },
| |
− | bad_usenet_id = {
| |
− | message = 'Check <code class="cs1-code">|message-id=</code> value',
| |
− | anchor = 'bad_message_id',
| |
− | category = 'CS1 errors: message-id',
| |
− | hidden = false
| |
− | },
| |
− | bad_mr = {
| |
− | message = 'Check <code class="cs1-code">|mr=</code> value',
| |
− | anchor = 'bad_mr',
| |
− | category = 'CS1 errors: MR',
| |
− | hidden = false
| |
− | },
| |
− | bad_ol = {
| |
− | message = 'Check <code class="cs1-code">|ol=</code> value',
| |
− | anchor = 'bad_ol',
| |
− | category = 'CS1 errors: OL',
| |
− | hidden = false
| |
− | },
| |
− | bad_paramlink = { -- for |title-link=, |author/editor/translator-link=, |series-link=, |episode-link=
| |
− | message = 'Check <code class="cs1-code">|$1=</code> value',
| |
− | anchor = 'bad_paramlink',
| |
− | category = 'CS1 errors: parameter link',
| |
− | hidden = false
| |
− | },
| |
− | bad_pmc = {
| |
− | message = 'Check <code class="cs1-code">|pmc=</code> value',
| |
− | anchor = 'bad_pmc',
| |
− | category = 'CS1 errors: PMC',
| |
− | hidden = false
| |
− | },
| |
− | bad_pmid = {
| |
− | message = 'Check <code class="cs1-code">|pmid=</code> value',
| |
− | anchor = 'bad_pmid',
| |
− | category = 'CS1 errors: PMID',
| |
− | hidden = false
| |
− | },
| |
− | bad_oclc = {
| |
− | message = 'Check <code class="cs1-code">|oclc=</code> value',
| |
− | anchor = 'bad_oclc',
| |
− | category = 'CS1 errors: OCLC',
| |
− | hidden = false
| |
− | },
| |
− | bad_ssrn = {
| |
− | message = 'Check <code class="cs1-code">|ssrn=</code> value',
| |
− | anchor = 'bad_ssrn',
| |
− | category = 'CS1 errors: SSRN',
| |
− | hidden = false
| |
− | },
| |
− | bad_url = {
| |
− | message = 'Check $1 value',
| |
− | anchor = 'bad_url',
| |
− | category = 'Pages with URL errors',
| |
− | hidden = false
| |
− | },
| |
− | bad_zbl = {
| |
− | message = 'Check <code class="cs1-code">|zbl=</code> value',
| |
− | anchor = 'bad_zbl',
| |
− | category = 'CS1 errors: ZBL',
| |
− | hidden = false
| |
− | },
| |
− | bare_url_missing_title = {
| |
− | message = '$1 missing title',
| |
− | anchor = 'bare_url_missing_title',
| |
− | category = 'Pages with citations having bare URLs',
| |
− | hidden = false
| |
− | },
| |
− | biorxiv_missing = {
| |
− | message = '<code class="cs1-code">|biorxiv=</code> required',
| |
− | anchor = 'biorxiv_missing',
| |
− | category = 'CS1 errors: bioRxiv', -- same as bad bioRxiv
| |
− | hidden = false
| |
− | },
| |
− | chapter_ignored = {
| |
− | message = '<code class="cs1-code">|$1=</code> ignored',
| |
− | anchor = 'chapter_ignored',
| |
− | category = 'CS1 errors: chapter ignored',
| |
− | hidden = false
| |
− | },
| |
− | citation_missing_title = {
| |
− | message = 'Missing or empty <code class="cs1-code">|$1=</code>',
| |
− | anchor = 'citation_missing_title',
| |
− | category = 'Pages with citations lacking titles',
| |
− | hidden = false
| |
− | },
| |
− | citeseerx_missing = {
| |
− | message = '<code class="cs1-code">|citeseerx=</code> required',
| |
− | anchor = 'citeseerx_missing',
| |
− | category = 'CS1 errors: citeseerx', -- same as bad citeseerx
| |
− | hidden = false
| |
− | },
| |
− | cite_web_url = { -- this error applies to cite web and to cite podcast
| |
− | message = 'Missing or empty <code class="cs1-code">|url=</code>',
| |
− | anchor = 'cite_web_url',
| |
− | category = 'Pages using web citations with no URL',
| |
− | hidden = false
| |
− | },
| |
− | class_ignored = {
| |
− | message = '<code class="cs1-code">|class=</code> ignored',
| |
− | anchor = 'class_ignored',
| |
− | category = 'CS1 errors: class',
| |
− | hidden = false
| |
− | },
| |
− | contributor_ignored = {
| |
− | message = '<code class="cs1-code">|contributor=</code> ignored',
| |
− | anchor = 'contributor_ignored',
| |
− | category = 'CS1 errors: contributor',
| |
− | hidden = false
| |
− | },
| |
− | contributor_missing_required_param = {
| |
− | message = '<code class="cs1-code">|contributor=</code> requires <code class="cs1-code">|$1=</code>',
| |
− | anchor = 'contributor_missing_required_param',
| |
− | category = 'CS1 errors: contributor',
| |
− | hidden = false
| |
− | },
| |
− | deprecated_params = {
| |
− | message = 'Cite uses deprecated parameter <code class="cs1-code">|$1=</code>',
| |
− | anchor = 'deprecated_params',
| |
− | category = 'CS1 errors: deprecated parameters',
| |
− | hidden = false
| |
− | },
| |
− | empty_citation = {
| |
− | message = 'Empty citation',
| |
− | anchor = 'empty_citation',
| |
− | category = 'Pages with empty citations',
| |
− | hidden = false
| |
− | },
| |
− | etal = {
| |
− | message = 'Explicit use of et al. in: <code class="cs1-code">|$1=</code>',
| |
− | anchor = 'explicit_et_al',
| |
− | category = 'CS1 errors: Explicit use of et al.',
| |
− | hidden = false
| |
− | },
| |
− | first_missing_last = {
| |
− | message = '<code class="cs1-code">|$1=</code> missing <code class="cs1-code">|$2=</code>', -- $1 is first alias, $2 is matching last alias
| |
− | anchor = 'first_missing_last',
| |
− | category = 'CS1 errors: missing name', -- author, contributor, editor, interviewer, translator
| |
− | hidden = false
| |
− | },
| |
− | format_missing_url = {
| |
− | message = '<code class="cs1-code">|$1=</code> requires <code class="cs1-code">|$2=</code>',
| |
− | anchor = 'format_missing_url',
| |
− | category = 'Pages using citations with format and no URL',
| |
− | hidden = false
| |
− | },
| |
− | invalid_param_val = {
| |
− | message = 'Invalid <code class="cs1-code">|$1=$2</code>',
| |
− | anchor = 'invalid_param_val',
| |
− | category = 'CS1 errors: invalid parameter value',
| |
− | hidden = false
| |
− | },
| |
− | invisible_char = {
| |
− | message = '$1 in $2 at position $3',
| |
− | anchor = 'invisible_char',
| |
− | category = 'CS1 errors: invisible characters',
| |
− | hidden = false
| |
− | },
| |
− | missing_name = {
| |
− | message = 'Missing <code class="cs1-code">|$1$2=</code>', -- $1 is modified NameList; $2 is enumerator
| |
− | anchor = 'missing_name',
| |
− | category = 'CS1 errors: missing name', -- author, contributor, editor, interviewer, translator
| |
− | hidden = false
| |
− | },
| |
− | missing_pipe = {
| |
− | message = 'Missing pipe in: <code class="cs1-code">|$1=</code>',
| |
− | anchor = 'missing_pipe',
| |
− | category = 'CS1 errors: Missing pipe',
| |
− | hidden = false
| |
− | },
| |
− | param_access_requires_param = {
| |
− | message = '<code class="cs1-code">|$1-access=</code> requires <code class="cs1-code">|$1=</code>',
| |
− | anchor = 'param_access_requires_param',
| |
− | category = 'CS1 errors: param-access',
| |
− | hidden = false
| |
− | },
| |
− | param_has_ext_link = {
| |
− | message = 'External link in <code class="cs1-code">$1</code>',
| |
− | anchor = 'param_has_ext_link',
| |
− | category = 'CS1 errors: external links',
| |
− | hidden = false
| |
− | },
| |
− | parameter_ignored = {
| |
− | message = 'Unknown parameter <code class="cs1-code">|$1=</code> ignored',
| |
− | anchor = 'parameter_ignored',
| |
− | category = 'Pages with citations using unsupported parameters',
| |
− | hidden = false
| |
− | },
| |
− | parameter_ignored_suggest = {
| |
− | message = 'Unknown parameter <code class="cs1-code">|$1=</code> ignored (<code class="cs1-code">|$2=</code> suggested)',
| |
− | anchor = 'parameter_ignored_suggest',
| |
− | category = 'Pages with citations using unsupported parameters',
| |
− | hidden = false
| |
− | },
| |
− | redundant_parameters = {
| |
− | message = 'More than one of $1 specified',
| |
− | anchor = 'redundant_parameters',
| |
− | category = 'Pages with citations having redundant parameters',
| |
− | hidden = false
| |
− | },
| |
− | text_ignored = {
| |
− | message = 'Text "$1" ignored',
| |
− | anchor = 'text_ignored',
| |
− | category = 'Pages with citations using unnamed parameters',
| |
− | hidden = false
| |
− | },
| |
− | trans_missing_title = {
| |
− | message = '<code class="cs1-code">|trans-$1=</code> requires <code class="cs1-code">|$1=</code>',
| |
− | anchor = 'trans_missing_title',
| |
− | category = 'CS1 errors: translated title',
| |
− | hidden = false
| |
− | },
| |
− | vancouver = {
| |
− | message = 'Vancouver style error: $1',
| |
− | anchor = 'vancouver',
| |
− | category = 'CS1 errors: Vancouver style',
| |
− | hidden = false
| |
− | },
| |
− | wikilink_in_url = {
| |
− | message = 'URL–wikilink conflict', -- uses ndash
| |
− | anchor = 'wikilink_in_url',
| |
− | category = 'CS1 errors: URL–wikilink conflict', -- uses ndash
| |
− | hidden = false
| |
− | },
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< I D _ H A N D L E R S >--------------------------------------------------------
| |
− |
| |
− | The following contains a list of values for various defined identifiers. For each identifier we specify a
| |
− | variety of information necessary to properly render the identifier in the citation.
| |
− |
| |
− | parameters: a list of parameter aliases for this identifier
| |
− | link: Wikipedia article name
| |
− | q: wikidata q number for the identifier
| |
− | label: the alternate name to apply to link
| |
− | mode: 'manual' when there is a specific function in the code to handle the identifier;
| |
− | 'external' for identifiers that link outside of Wikipedia;
| |
− | prefix: the first part of a url that will be concatenated with a second part which usually contains the identifier
| |
− | encode: true if uri should be percent encoded; otherwise false
| |
− | COinS: identifier link or keyword for use in COinS:
| |
− | for identifiers registered at info-uri.info use: info:....
| |
− | for identifiers that have COinS keywords, use the keyword: rft.isbn, rft.issn, rft.eissn
| |
− | for others make a url using the value in prefix, use the keyword: pre (not checked; any text other than 'info' or 'rft' works here)
| |
− | set to nil to leave the identifier out of the COinS
| |
− | separator: character or text between label and the identifier in the rendered citation
| |
− | access: use this parameter to set the access level for all instances of this identifier.
| |
− | the value must be a valid access level for an identifier (see ['id-access'] in this file).
| |
− | custom_access: to enable custom access level for an identifier, set this parameter
| |
− | to the parameter that should control it (normally 'id-access')
| |
− | ]]
| |
− |
| |
− | local id_handlers = {
| |
− | ['ARXIV'] = {
| |
− | parameters = {'arxiv', 'eprint'},
| |
− | link = 'arXiv',
| |
− | q = 'Q118398',
| |
− | label = 'arXiv',
| |
− | mode = 'manual',
| |
− | prefix = '//arxiv.org/abs/', -- protocol relative tested 2013-09-04
| |
− | encode = false,
| |
− | COinS = 'info:arxiv',
| |
− | separator = ':',
| |
− | access = 'free', -- free to read
| |
− | },
| |
− | ['ASIN'] = {
| |
− | parameters = { 'asin', 'ASIN' },
| |
− | link = 'Amazon Standard Identification Number',
| |
− | q = 'Q1753278',
| |
− | label = 'ASIN',
| |
− | mode = 'manual',
| |
− | prefix = '//www.amazon.',
| |
− | COinS = nil, -- no COinS for this id (needs thinking on implementation because |asin-tld=)
| |
− | separator = ' ',
| |
− | encode = false;
| |
− | },
| |
− | ['BIBCODE'] = {
| |
− | parameters = {'bibcode'},
| |
− | link = 'Bibcode',
| |
− | q = 'Q25754',
| |
− | label = 'Bibcode',
| |
− | mode = 'manual',
| |
− | prefix = 'http://adsabs.harvard.edu/abs/',
| |
− | encode = false,
| |
− | COinS = 'info:bibcode',
| |
− | separator = ':',
| |
− | custom_access = 'bibcode-access',
| |
− | },
| |
− | ['BIORXIV'] = {
| |
− | parameters = {'biorxiv'},
| |
− | link = 'bioRxiv',
| |
− | q = 'Q19835482',
| |
− | label = 'bioRxiv',
| |
− | mode = 'manual',
| |
− | prefix = '//doi.org/10.1101/',
| |
− | COinS = 'pre', -- use prefix value
| |
− | access = 'free', -- free to read
| |
− | encode = true,
| |
− | separator = ' ',
| |
− | },
| |
− | ['CITESEERX'] = {
| |
− | parameters = {'citeseerx'},
| |
− | link = 'CiteSeerX',
| |
− | q = 'Q2715061',
| |
− | label = 'CiteSeerX',
| |
− | mode = 'manual', -- manual for custom validation of the "doi"
| |
− | prefix = '//citeseerx.ist.psu.edu/viewdoc/summary?doi=',
| |
− | COinS = 'pre', -- use prefix value
| |
− | access = 'free', -- free to read
| |
− | encode = true,
| |
− | separator = ' ',
| |
− | },
| |
− | ['DOI'] = {
| |
− | parameters = { 'doi', 'DOI' },
| |
− | link = 'Digital object identifier',
| |
− | q = 'Q25670',
| |
− | label = 'doi',
| |
− | mode = 'manual',
| |
− | prefix = '//doi.org/',
| |
− | COinS = 'info:doi',
| |
− | separator = ':',
| |
− | encode = true,
| |
− | custom_access = 'doi-access',
| |
− | },
| |
− | ['EISSN'] = {
| |
− | parameters = {'eissn', 'EISSN'},
| |
− | link = 'International_Standard_Serial_Number#Electronic_ISSN',
| |
− | q = 'Q46339674',
| |
− | label = 'eISSN',
| |
− | mode = 'manual',
| |
− | prefix = '//www.worldcat.org/issn/',
| |
− | COinS = 'rft.eissn',
| |
− | encode = false,
| |
− | separator = ' ',
| |
− | },
| |
− | ['HDL'] = {
| |
− | parameters = { 'hdl', 'HDL' },
| |
− | link = 'Handle System',
| |
− | q = 'Q3126718',
| |
− | label = 'hdl',
| |
− | mode = 'manual',
| |
− | prefix = '//hdl.handle.net/',
| |
− | COinS = 'info:hdl',
| |
− | separator = ':',
| |
− | encode = true,
| |
− | custom_access = 'hdl-access',
| |
− | },
| |
− | ['ISBN'] = {
| |
− | parameters = {'isbn', 'ISBN', 'isbn13', 'ISBN13'},
| |
− | link = 'International Standard Book Number',
| |
− | q = 'Q33057',
| |
− | label = 'ISBN',
| |
− | mode = 'manual',
| |
− | prefix = 'Special:BookSources/',
| |
− | COinS = 'rft.isbn',
| |
− | separator = ' ',
| |
− | },
| |
− | ['ISMN'] = {
| |
− | parameters = {'ismn', 'ISMN'},
| |
− | link = 'International Standard Music Number',
| |
− | q = 'Q1666938',
| |
− | label = 'ISMN',
| |
− | mode = 'manual',
| |
− | prefix = '', -- not currently used;
| |
− | COinS = 'nil', -- nil because we can't use pre or rft or info:
| |
− | separator = ' ',
| |
− | },
| |
− | ['ISSN'] = {
| |
− | parameters = {'issn', 'ISSN'},
| |
− | link = 'International Standard Serial Number',
| |
− | q = 'Q131276',
| |
− | label = 'ISSN',
| |
− | mode = 'manual',
| |
− | prefix = '//www.worldcat.org/issn/',
| |
− | COinS = 'rft.issn',
| |
− | encode = false,
| |
− | separator = ' ',
| |
− | },
| |
− | ['JFM'] = {
| |
− | parameters = {'jfm', 'JFM'},
| |
− | link = 'Jahrbuch über die Fortschritte der Mathematik',
| |
− | q = '',
| |
− | label = 'JFM',
| |
− | mode = 'manual',
| |
− | prefix = '//zbmath.org/?format=complete&q=an:',
| |
− | COinS = 'pre', -- use prefix value
| |
− | encode = true,
| |
− | separator = ' ',
| |
− | },
| |
− | ['JSTOR'] = {
| |
− | parameters = {'jstor', 'JSTOR'},
| |
− | link = 'JSTOR',
| |
− | q = 'Q1420342',
| |
− | label = 'JSTOR',
| |
− | mode = 'external',
| |
− | prefix = '//www.jstor.org/stable/', -- protocol relative tested 2013-09-04
| |
− | COinS = 'pre', -- use prefix value
| |
− | encode = false,
| |
− | separator = ' ',
| |
− | custom_access = 'jstor-access',
| |
− | },
| |
− | ['LCCN'] = {
| |
− | parameters = {'LCCN', 'lccn'},
| |
− | link = 'Library of Congress Control Number',
| |
− | q = 'Q620946',
| |
− | label = 'LCCN',
| |
− | mode = 'manual',
| |
− | prefix = '//lccn.loc.gov/', -- protocol relative tested 2015-12-28
| |
− | COinS = 'info:lccn', -- use prefix value
| |
− | encode = false,
| |
− | separator = ' ',
| |
− | },
| |
− | ['MR'] = {
| |
− | parameters = {'MR', 'mr'},
| |
− | link = 'Mathematical Reviews',
| |
− | q = 'Q211172',
| |
− | label = 'MR',
| |
− | mode = 'manual',
| |
− | prefix = '//www.ams.org/mathscinet-getitem?mr=', -- protocol relative tested 2013-09-04
| |
− | COinS = 'pre', -- use prefix value
| |
− | encode = true,
| |
− | separator = ' ',
| |
− | },
| |
− | ['OCLC'] = {
| |
− | parameters = {'OCLC', 'oclc'},
| |
− | link = 'OCLC',
| |
− | q = 'Q190593',
| |
− | label = 'OCLC',
| |
− | mode = 'manual',
| |
− | prefix = '//www.worldcat.org/oclc/',
| |
− | COinS = 'info:oclcnum',
| |
− | encode = true,
| |
− | separator = ' ',
| |
− | },
| |
− | ['OL'] = {
| |
− | parameters = { 'ol', 'OL' },
| |
− | link = 'Open Library',
| |
− | q = 'Q1201876',
| |
− | label = 'OL',
| |
− | mode = 'manual',
| |
− | prefix = '//openlibrary.org/',
| |
− | COinS = nil, -- no COinS for this id (needs thinking on implementation because /authors/books/works/OL)
| |
− | separator = ' ',
| |
− | encode = true,
| |
− | custom_access = 'ol-access',
| |
− | },
| |
− | ['OSTI'] = {
| |
− | parameters = {'OSTI', 'osti'},
| |
− | link = 'Office of Scientific and Technical Information',
| |
− | q = 'Q2015776',
| |
− | label = 'OSTI',
| |
− | mode = 'external',
| |
− | prefix = '//www.osti.gov/biblio/', -- protocol relative tested 2018-09-12
| |
− | COinS = 'pre', -- use prefix value
| |
− | encode = true,
| |
− | separator = ' ',
| |
− | custom_access = 'osti-access',
| |
− | },
| |
− | ['PMC'] = {
| |
− | parameters = {'PMC', 'pmc'},
| |
− | link = 'PubMed Central',
| |
− | q = 'Q229883',
| |
− | label = 'PMC',
| |
− | mode = 'manual',
| |
− | prefix = '//www.ncbi.nlm.nih.gov/pmc/articles/PMC',
| |
− | suffix = " ",
| |
− | COinS = 'pre', -- use prefix value
| |
− | encode = true,
| |
− | separator = ' ',
| |
− | access = 'free', -- free to read
| |
− | },
| |
− | ['PMID'] = {
| |
− | parameters = {'PMID', 'pmid'},
| |
− | link = 'PubMed Identifier',
| |
− | q = '',
| |
− | label = 'PMID',
| |
− | mode = 'manual',
| |
− | prefix = '//www.ncbi.nlm.nih.gov/pubmed/',
| |
− | COinS = 'info:pmid',
| |
− | encode = false,
| |
− | separator = ' ',
| |
− | },
| |
− | ['RFC'] = {
| |
− | parameters = {'RFC', 'rfc'},
| |
− | link = 'Request for Comments',
| |
− | q = 'Q212971',
| |
− | label = 'RFC',
| |
− | mode = 'external',
| |
− | prefix = '//tools.ietf.org/html/rfc',
| |
− | COinS = 'pre', -- use prefix value
| |
− | encode = false,
| |
− | separator = ' ',
| |
− | access = 'free', -- free to read
| |
− | },
| |
− | ['SSRN'] = {
| |
− | parameters = {'SSRN', 'ssrn'},
| |
− | link = 'Social Science Research Network',
| |
− | q = 'Q7550801',
| |
− | label = 'SSRN',
| |
− | mode = 'manual',
| |
− | prefix = '//ssrn.com/abstract=', -- protocol relative tested 2013-09-04
| |
− | COinS = 'pre', -- use prefix value
| |
− | encode = true,
| |
− | separator = ' ',
| |
− | access = 'free', -- always free to read
| |
− | },
| |
− | ['USENETID'] = {
| |
− | parameters = {'message-id'},
| |
− | link = 'Usenet',
| |
− | q = 'Q193162',
| |
− | label = 'Usenet:',
| |
− | mode = 'manual',
| |
− | prefix = 'news:',
| |
− | encode = false,
| |
− | COinS = 'pre', -- use prefix value
| |
− | separator = ' ',
| |
− | },
| |
− | ['ZBL'] = {
| |
− | parameters = {'ZBL', 'zbl'},
| |
− | link = 'Zentralblatt MATH',
| |
− | q = 'Q190269',
| |
− | label = 'Zbl',
| |
− | mode = 'manual',
| |
− | prefix = '//zbmath.org/?format=complete&q=an:',
| |
− | COinS = 'pre', -- use prefix value
| |
− | encode = true,
| |
− | separator = ' ',
| |
− | },
| |
− | }
| |
− |
| |
− |
| |
− | --[[--------------------------< E X P O R T E D T A B L E S >------------------------------------------------
| |
− | ]]
| |
− |
| |
− | return {
| |
− | aliases = aliases,
| |
− | special_case_translation = special_case_translation,
| |
− | defaults = defaults,
| |
− | date_names = date_names,
| |
− | error_conditions = error_conditions,
| |
− | editor_markup_patterns = editor_markup_patterns,
| |
− | et_al_patterns = et_al_patterns,
| |
− | global_df = global_df,
| |
− | id_handlers = id_handlers,
| |
− | keywords = keywords,
| |
− | stripmarkers=stripmarkers,
| |
− | invisible_chars = invisible_chars,
| |
− | indic_script = indic_script,
| |
− | maint_cats = maint_cats,
| |
− | messages = messages,
| |
− | presentation = presentation,
| |
− | prop_cats = prop_cats,
| |
− | script_lang_codes = script_lang_codes,
| |
− | lang_code_remap = lang_code_remap,
| |
− | lang_name_remap = lang_name_remap,
| |
− | title_types = title_types,
| |
− | uncategorized_namespaces = uncategorized_namespaces,
| |
− | uncategorized_subpages = uncategorized_subpages,
| |
− | templates_using_volume = templates_using_volume,
| |
− | templates_using_issue = templates_using_issue,
| |
− | templates_not_using_page = templates_not_using_page,
| |
− | }
| |