Sətir 1: |
Sətir 1: |
| + | --------------------------------------------------------------------- |
| + | -- Module:Citation - Lua module for Citation auxiliary templates |
| + | --------------------------------------------------------------------- |
| + | -- For the {{citation}} formatting functions, see: Module:Citation/CS1 |
| + | -- (see NOTES at bottom) |
| + | --require "mw.text" |
| | | |
| + | local z = { |
| + | wikitext = require("Module:Wikitext"), |
| + | extensiontags = { |
| + | nowiki = true, |
| + | ref = true, |
| + | gallery = true, |
| + | pre = true, |
| + | source = true, |
| + | categorytree = true, |
| + | charinsert = true, |
| + | hiero = true, |
| + | imagemap = true, |
| + | inputbox = true, |
| + | math = true, |
| + | poem = true, |
| + | ref = true, |
| + | references = true, |
| + | syntaxhighlight = true, |
| + | timeline = true, |
| + | } |
| + | } |
| + | |
| + | function trim( str ) |
| + | if str == nil then |
| + | return nil; |
| + | end |
| + | return str:match( "^%s*(.-)%s*$" ); |
| + | end |
| + | |
| + | function hideinprint(content) |
| + | return content |
| + | end |
| + | |
| + | function onlyinprint(content) |
| + | return "" |
| + | end |
| + | |
| + | -- This returns a string with HTML character entities for wikitext markup characters. |
| + | function wikiescape(text) |
| + | text = text:gsub( '[&\'%[%]{|}]', { |
| + | ['&'] = '&', |
| + | ["'"] = ''', |
| + | ['['] = '[', |
| + | [']'] = ']', |
| + | ['{'] = '{', |
| + | ['|'] = '|', |
| + | ['}'] = '}' } ); |
| + | return text; |
| + | end |
| + | |
| + | function createTag(t, frame) |
| + | local name = t.name or "!-- --" |
| + | local content = t.contents or "" |
| + | local attrs = {} |
| + | if ( z.extensiontags[name] ) then |
| + | -- We have to preprocess these, so that they are properly turned into so-called "strip markers" in the generated wikitext. |
| + | if ( not frame ) then error ("Please supply an extra frame argument to the createTag() function.") end |
| + | local params = {} |
| + | for n,v in pairs(t.params) do |
| + | table.insert(params, "|" .. n .. "=" .. v) |
| + | end |
| + | return frame:preprocess("{{#tag:" .. name .. "|" .. content .. table.concat(params) .. "}}") |
| + | else |
| + | for n,v in pairs(t.params) do |
| + | if (v) then |
| + | table.insert(attrs, n .. "=\"" .. wikiescape(v) .. "\"") |
| + | else |
| + | table.insert(attrs, n) |
| + | end |
| + | end |
| + | if ("" == content) then |
| + | return "<" .. name .. " " .. table.concat(attrs, " ") .. "/>" |
| + | else |
| + | return "<" .. name .. " " .. table.concat(attrs, " ") .. ">" .. content .. "</" .. name .. ">" |
| + | end |
| + | end |
| + | end |
| + | |
| + | --[[ |
| + | This is a clone of mw.text.nowiki. When the mw.text library is installed, |
| + | this can be replaced by a call to that library. ]] |
| + | function nowiki( s ) |
| + | -- string.gsub is safe here, because we're only caring about ASCII chars |
| + | s = string.gsub( s, '["&\'<=>%[%]{|}]', { |
| + | ['"'] = '"', |
| + | ['&'] = '&', |
| + | ["'"] = ''', |
| + | ['<'] = '<', |
| + | ['='] = '=', |
| + | ['>'] = '>', |
| + | ['['] = '[', |
| + | [']'] = ']', |
| + | ['{'] = '{', |
| + | ['|'] = '|', |
| + | ['}'] = '}', |
| + | } ) |
| + | s = string.sub( string.gsub( '\n' .. s, '\n[#*:;]', { |
| + | ["\n#"] = "\n#", |
| + | ["\n*"] = "\n*", |
| + | ["\n:"] = "\n:", |
| + | ["\n;"] = "\n;", |
| + | } ), 2 ) |
| + | s = string.gsub( s, '://', '://' ) |
| + | s = string.gsub( s, 'ISBN ', 'ISBN ' ) |
| + | s = string.gsub( s, 'RFC ', 'RFC ' ) |
| + | |
| + | return s |
| + | end |
| + | |
| + | function externallinkid(args) |
| + | local sep = args.separator or " " |
| + | args.suffix = args.suffix or "" |
| + | local url_string = args.id |
| + | if args.encode == true or args.encode == nil then |
| + | url_string = mw.uri.encode( url_string ); |
| + | end |
| + | |
| + | local t0 = onlyinprint(args.label .. sep .. args.id) |
| + | local t1 = hideinprint("[[" .. args.link .. "|" .. args.label .. "]]" .. sep .. "[" .. args.prefix .. url_string .. args.suffix .. " " .. nowiki(args.id) .. "]") |
| + | |
| + | return t0 .. t1 |
| + | end |
| + | |
| + | function doi(id, inactive, nocat) |
| + | local cat = "" |
| + | local text; |
| + | if ( inactive ~= nil ) then |
| + | text = "[[Digital object identifier|doi]]:" .. id; |
| + | cat = cat .. "[[Category:Pages with DOIs inactive since " .. selectyear(inactive) .. "]]" |
| + | inactive = " (inactive " .. inactive .. ")" |
| + | else |
| + | text = externallinkid({link="Digital object identifier",label="doi",prefix="http://dx.doi.org/",id=id,separator=":"}) |
| + | inactive = "" |
| + | end |
| + | if ( string.sub(id,1,3) ~= "10." ) then |
| + | cat = cat .. "[[Category:Pages with DOI errors]]" .. '<span class="error"> Bad DOI (expected "10." prefix) in code number</span>' |
| + | end |
| + | if ( nocat and nocat ~= "" ) then cat = "" end |
| + | return text .. inactive .. cat |
| + | end |
| + | |
| + | function selectyear( str ) |
| + | local lang = mw.getContentLanguage(); |
| + | local good, result; |
| + | good, result = pcall( lang.formatDate, lang, 'Y', str ) |
| + | if good then |
| + | return result; |
| + | else |
| + | return ''; |
| + | end |
| + | end |
| + | |
| + | function anchorid(label, args) |
| + | local P1 = trim(args[1]) or "" |
| + | local P2 = trim(args[2]) or "" |
| + | local P3 = trim(args[3]) or "" |
| + | local P4 = trim(args[4]) or "" |
| + | local P5 = trim(args[5]) or "" |
| + | local anchor = P1 .. P2 .. P3 .. P4 .. P5; |
| + | if anchor ~= '' then -- See bug description in Citation/CS1 |
| + | anchor = mw.uri.anchorEncode( anchor ); |
| + | end |
| + | |
| + | return label .. anchor |
| + | end |
| + | |
| + | function refid(label, args) |
| + | local p = args.p or "" |
| + | local pp = args.pp or "" |
| + | local loc = args.loc or "" |
| + | return anchorid(label, args) .. p .. pp .. loc |
| + | end |
| + | |
| + | function name(args) |
| + | local P1 = trim(args[1]) or "" |
| + | if ( args[5] ~= nil) then |
| + | return P1 .. " et al." |
| + | else |
| + | local P2 = trim(args[2]) or "" |
| + | local P3 = trim(args[3]) or "" |
| + | local P4 = trim(args[4]) or "" |
| + | if ( args[4] ~= nil ) then |
| + | P4 = " " .. P4 |
| + | P3 = " & " .. P3 |
| + | P2 = ", " .. P2 |
| + | elseif ( args[3] ~= nil ) then |
| + | P3 = " " .. P3 |
| + | P2 = " & " .. P2 |
| + | elseif ( args[2] ~= nil ) then |
| + | P2 = " " .. P2 |
| + | end |
| + | return P1 .. P2 .. P3 .. P4 |
| + | end |
| + | end |
| + | |
| + | function crossref(frame, label, args) |
| + | local config = frame.args -- the arguments passed BY the template, in the wikitext of the template itself |
| + | local LB = config.BracketLeft or "" |
| + | local RB = config.BracketRight or "" |
| + | local anchor = args.ref or args.Ref or anchorid( label, args) |
| + | local text = name(args) |
| + | local loc = args.loc |
| + | local page |
| + | local pages = args.pp or args.pages |
| + | if pages == nil or pages == '' then |
| + | page = args.p or args.page; |
| + | end |
| + | if nil == loc then loc = "" else loc = " " .. loc end |
| + | if ( page ~= nil ) then |
| + | local pagesep = config.PageSep or ", p. " |
| + | loc = loc .. pagesep .. page |
| + | end |
| + | if ( pages ~= nil ) then |
| + | local pagessep = config.PagesSep or ", pp. " |
| + | loc = loc .. pagessep .. pages |
| + | end |
| + | local pagename = args.pagename or "" |
| + | local ps = args.Postscript or "" |
| + | return LB .. "[[" .. pagename .. "#" .. anchor .. "|" .. text .. "]]" .. loc .. RB .. ps |
| + | end |
| + | |
| + | function r0(frame, name, group, page) |
| + | if ( name == nil ) then return "" end |
| + | if ( group == nil ) then group = "" end |
| + | local p = "" |
| + | if ( page ~= nil ) then |
| + | local contents = ":" .. page |
| + | p = createTag({name="sup",contents=contents,params={class="reference",style="white-space:nowrap;"}}) |
| + | end |
| + | return createTag({name="ref",contents="",params={name=name,group=group}}, frame) .. p |
| + | end |
| + | |
| + | function reflist0(frame, config, args) |
| + | local contents = args.refs or "" |
| + | local liststyle = args.liststyle |
| + | local count = args[1] |
| + | local width = args.colwidth |
| + | local group = args.group or config.default_group |
| + | if ( nil == tonumber(count) and nil == width ) then |
| + | width = count |
| + | count = nil |
| + | end |
| + | if ( nil == liststyle ) then |
| + | if ( "upper-alpha" == group or "lower-alpha" == group or "upper-roman" == group or "lower-roman" == group or "upper-greek" == group or "lower-greek" == group ) then |
| + | liststyle = group |
| + | else |
| + | liststyle = config.default_liststyle |
| + | end |
| + | end |
| + | local params = {} |
| + | params.class = "reflist" |
| + | params.style = z.wikitext.liststyle(liststyle) |
| + | if ( nil ~= count ) then |
| + | params.class = params.class .. " references-column-count references-column-count-" .. count |
| + | params.style = params.style .. " " .. z.wikitext.columncountstyle(count) |
| + | end |
| + | if ( nil ~= width ) then |
| + | params.class = params.class .. " references-column-width" |
| + | params.style = params.style .. " " .. z.wikitext.columnwidthstyle(width) |
| + | end |
| + | local references = createTag({name="references",contents=contents,params={group=group}}, frame) |
| + | return createTag({name="div",contents=references,params=params}) |
| + | end |
| + | |
| + | function refbegin0(frame, config, args) |
| + | local liststyle = args.liststyle |
| + | local indent = args.indent |
| + | local indentsize = args.indentsize |
| + | local count = args[1] |
| + | local width = args.colwidth |
| + | if ( nil == tonumber(count) and nil == width ) then |
| + | width = count |
| + | count = nil |
| + | end |
| + | if ( nil == liststyle ) then |
| + | if ( "upper-alpha" == group or "lower-alpha" == group or "upper-roman" == group or "lower-roman" == group or "upper-greek" == group or "lower-greek" == group ) then |
| + | liststyle = group |
| + | else |
| + | liststyle = config.default_liststyle |
| + | end |
| + | end |
| + | local params = {} |
| + | params.class = "refbegin" |
| + | params.style = z.wikitext.liststyle(liststyle) |
| + | if ( nil ~= count ) then |
| + | params.class = params.class .. " references-column-count references-column-count-" .. count |
| + | params.style = params.style .. " " .. z.wikitext.columncountstyle(count) |
| + | end |
| + | if ( nil ~= width ) then |
| + | params.class = params.class .. " references-column-width" |
| + | params.style = params.style .. " " .. z.wikitext.columnwidthstyle(width) |
| + | end |
| + | local dlopen |
| + | if ( nil ~= indent ) then |
| + | dlopen = z.wikitext.OpenHTMLTag({name="dl",params={style="text-indent: -" .. (indentsize or "3.2") .. "em;"}}) |
| + | else |
| + | dlopen = "" |
| + | end |
| + | return z.wikitext.OpenHTMLTag({name="div",params=params}) .. dlopen |
| + | end |
| + | |
| + | function refend0(frame, config, args) |
| + | local indent = args.indent |
| + | local dlclose |
| + | if ( nil ~= indent ) then |
| + | dlclose = "</dl>" |
| + | else |
| + | dlclose = "" |
| + | end |
| + | return dlclose .. "</div>" |
| + | end |
| + | |
| + | -- This is used by {{doi}} to create DOI links in the style used in citations. |
| + | function z.doi(frame) |
| + | local pframe = frame:getParent() |
| + | local id = pframe.args.id or pframe.args[1] or "" |
| + | return doi(id) |
| + | end |
| + | |
| + | -- This is used by {{ISSN}} to create ISSN links in the style used in citations. |
| + | function z.ISSN(frame) |
| + | local pframe = frame:getParent() |
| + | local Name = pframe.args[1] or "" |
| + | return hideinprint("[[International Standard Serial Number|ISSN]] [http://www.worldcat.org/search?fq=x0:jrnl&q=n2:" .. Name .. " " .. Name .. "]") |
| + | end |
| + | |
| + | -- This is used by templates such as {{SfnRef}} to create the (encoded) anchor name for a Harvard cross-reference hyperlink. |
| + | function z.SFNID(frame) |
| + | local pframe = frame:getParent() |
| + | return anchorid('FOOTNOTE', pframe.args) |
| + | end |
| + | |
| + | -- This is used by templates such as {{Harvard citation}} to create the Harvard cross-reference text. |
| + | function z.Harvard(frame) |
| + | local pframe = frame:getParent() |
| + | return crossref(frame, pframe.args) |
| + | end |
| + | |
| + | -- This is used by templates such as {{sfn}} to create the entire cross-reference. |
| + | function z.sfn(frame) |
| + | local pframe = frame:getParent() |
| + | pframe.args.Postscript = pframe.args.postscript or pframe.args.ps or "."; |
| + | |
| + | local content = crossref(frame, 'CITEREF', pframe.args) |
| + | local args = { name = refid( 'FOOTNOTE', pframe.args) } |
| + | return createTag({name = "ref", contents = content, params = args}, frame) |
| + | end |
| + | |
| + | -- This is used by template {{r}}. |
| + | function z.r(frame) |
| + | local pframe = frame:getParent() |
| + | local config = frame.args -- the arguments passed BY the template, in the wikitext of the template itself |
| + | local args = pframe.args -- the arguments passed TO the template, in the wikitext that instantiates the template |
| + | args.page1 = args.page1 or args.page |
| + | local text = "" |
| + | -- This would be shorter using ipairs(), but that doesn't work on an arguments table supplied to a template. |
| + | local index = 1 |
| + | while args[index] ~= nil do |
| + | local arg = args[index] |
| + | local t = r0(frame, arg, args.group, args["page" .. index]) |
| + | text = text .. t |
| + | index = index + 1 |
| + | end |
| + | return text |
| + | end |
| + | |
| + | -- This is used by template {{ref label}}. |
| + | function z.reflabel(frame) |
| + | local pframe = frame:getParent() |
| + | local config = frame.args -- the arguments passed BY the template, in the wikitext of the template itself |
| + | local args = pframe.args -- the arguments passed TO the template, in the wikitext that instantiates the template |
| + | local P1 = args[1] or "" |
| + | local P2 = args[2] or "" |
| + | local P3 = args[3] or "" |
| + | local id = nil |
| + | local contents = "[[#endnote_" .. P1 .. P3 .. "|[" .. P2 .. "]]]" |
| + | local params = {} |
| + | params.class="reference" |
| + | if ( args.noid == nil or args.noid == "" ) then params.id = "ref_" .. P1 .. P3 end |
| + | return createTag({name="sup",contents=contents,params=params}) |
| + | end |
| + | |
| + | -- This is used by template {{note label}}. |
| + | function z.notelabel(frame) |
| + | local pframe = frame:getParent() |
| + | local config = frame.args -- the arguments passed BY the template, in the wikitext of the template itself |
| + | local args = pframe.args -- the arguments passed TO the template, in the wikitext that instantiates the template |
| + | local id = args[1] or "" |
| + | local arrow = args[3] or "" |
| + | local postscript = args[4] or "" |
| + | local contents |
| + | if arrow ~= "" then |
| + | local sup_arrow = createTag({name="sup",contents=arrow,params={}}) |
| + | contents = "[[#ref_" .. id .. arrow .. "|<b>" .. sup_arrow .. "</b>]]" .. postscript |
| + | if "none" == arrow then arrow = "^" end -- Change this AFTER using it in the ID parameter and the contents. |
| + | else |
| + | contents = (args[2] or "") .. postscript |
| + | end |
| + | local params = { class="citation wikicite" } |
| + | if id ~= "" and ( args.noid == nil or args.noid == "" ) then |
| + | params.id = mw.uri.anchorEncode("endnote_" .. id .. arrow) |
| + | end |
| + | return createTag({name="span",contents=contents,params=params}) |
| + | end |
| + | |
| + | -- This is used by templates {{reflist}} and {{notelist}}. |
| + | function z.reflist(frame) |
| + | local pframe = frame:getParent() |
| + | local config = frame.args -- the arguments passed BY the template, in the wikitext of the template itself |
| + | local args = pframe.args -- the arguments passed TO the template, in the wikitext that instantiates the template |
| + | return reflist0(frame, config, args) |
| + | end |
| + | |
| + | -- This is used by template {{refbegin}}. |
| + | function z.refbegin(frame) |
| + | local pframe = frame:getParent() |
| + | local config = frame.args -- the arguments passed BY the template, in the wikitext of the template itself |
| + | local args = pframe.args -- the arguments passed TO the template, in the wikitext that instantiates the template |
| + | return refbegin0(frame, config, args) |
| + | end |
| + | |
| + | -- This is used by template {{refend}}. |
| + | function z.refend(frame) |
| + | local pframe = frame:getParent() |
| + | local config = frame.args -- the arguments passed BY the template, in the wikitext of the template itself |
| + | local args = pframe.args -- the arguments passed TO the template, in the wikitext that instantiates the template |
| + | return refend0(frame, config, args) |
| + | end |
| + | |
| + | -- This is used by template {{efn}}. |
| + | function z.efn(frame) |
| + | local pframe = frame:getParent() |
| + | local config = frame.args -- the arguments passed BY the template, in the wikitext of the template itself |
| + | local args = pframe.args -- the arguments passed TO the template, in the wikitext that instantiates the template |
| + | return createTag({name="ref",contents=(args[1] or ""),params={name=args.name,group=config.default_group}}, frame) |
| + | end |
| + | |
| + | return z |
| + | --------------------------------------------------------------------- |
| + | --NOTES |
| + | -- |
| + | -- NOTE A1: This Lua module was originally designed to handle a mix |
| + | -- of citation styles, crossing Vancouver style with Wikipedia's |
| + | -- local Citation Style 1 (CS1) from {Template:Citation/core}. |
| + | -- However, the conflicting positions of parameters, scattered |
| + | -- in twisted locations across this module, led to a separate |
| + | -- variation just to untangle the CS1 format of citations. |
| + | -- |
| + | -- NOTE D2: The placement of dots and other separators between the |
| + | -- displayed parameters has been a continual headache, to keep |
| + | -- coordinated with the data in parentheses "(data)". There |
| + | -- has been a need to pre-check for the existence of related |
| + | -- options, to keep from putting double-dots ".." in some cases. |
| + | -- In particular, the omission of the "title=" parameter has led |
| + | -- to several cases of a spurious dot ". ." because the original |
| + | -- design had treated the title as a mandatory parameter. |
| + | -- |
| + | ------------------------------------------------------------------------ |
| + | --HISTORY: |
| + | --18Oct2012 Fixed lead-space in Chapter by omitting " ". |
| + | --18Oct2012 Fixed lead-space in Chapter/Title as end " " of Authors/Date/... |
| + | --19Oct2012 Put HISTORY comments to log major changes (not typos). |
| + | --19Oct2012 Fixed extra dot ".." in Title by omitting at end of "tcommon=...". |
| + | --19Oct2012 For pages, put   in "p. " etc. |
| + | --19Oct2012 Enhanced "pages=" to detect lone page as "p." else "pp." prefix. |
| + | --19Oct2012 Fixed to show "." after Periodical name (work, newspaper...). |
| + | --19Oct2012 Fixed web-link to have spaces "[... Archived] from the original". |
| + | --19Oct2012 Fixed to show ";" between authors & coauthors. |
| + | --19Oct2012 Fixed to omit extra "." after coauthors. |
| + | --20Oct2012 Fixed COinS data to not urlencode all, as "ctx_ver=Z39.88-2004" |
| + | --20Oct2012 Fixed COinS to not end as "&" but use lead "&rft...=" form. |
| + | --20Oct2012 Fixed COinS to not url.encode page's "rfr_id=..." pagename. |
| + | --20Oct2012 Fixed COinS data when "web" to default to rft.genre "book". |
| + | --05Nov2012 Add a span wrapper even when there is no Ref parameter |
| + | --15Feb2013 Added Agency for "agency=xx". |
| + | --19Feb2013 Put NOTES comments to explain module operation. |
| + | --19Feb2013 Copied as Module:Citation/CS1 to alter to match wp:CS1 form. |
| + | --19Feb2013 Changed OrigYear to use [__] for CS1 style. |
| + | --19Feb2013 Fixed to not show duplicate Publisher/Agency. |
| + | --19Feb2013 Moved page-number parameters to after final date. |
| + | --19Feb2013 Fixed to not put double-dots after title again. |
| + | --20Feb2013 Changed to omit dot "." if already ends with dot. |
| + | --20Feb2013 If class "journal" shows Publisher after Periodical/Series. |
| + | --20Feb2013 Shifted Format to after Language, and Others after Volume. |
| + | --20Feb2013 Set AccessDate + <span class="reference-accessdate"> |
| + | --20Feb2013 Fixed url when deadurl=no. |
| + | --20Feb2013 Added sepc for separator character between parameters. |
| + | --20Feb2013 Put "OCLC" for "Online Computer Library Center". |
| + | --20Feb2013 Fix empty "authorlink=" as person.link ~= "". |
| + | --20Feb2013 Added space after AuthorSep & AuthorNameSep. |
| + | --21Feb2013 Added args.contributor (was missing parameter). |
| + | --21Feb2013 Fixed EditorSep (was misspelled "EdithorSep"). |
| + | --21Feb2013 Set OCinSdata.rft_val_fmt = "info:ofi/fmt:kev:mtx:book" |
| + | --21Feb2013 Checked to omit blank codes (asin= | doi= etc.). |
| + | --21Feb2013 Set enddot to end line if not config.CitationClass "citation". |
| + | --21Feb2013 Fixed to show "issn=x" as the ISSN code. |
| + | --21Feb2013 Fixed to show "id=x" after Zbl code. |
| + | --21Feb2013 Changed to omit double-dot before date when already dot. |
| + | --21Feb2013 Order config.CitationClass "citation": Volume, Issue, Publisher. |
| + | --21Feb2013 Put warning "Bad DOI (expected "10."..)" in DOI result. |
| + | --21Feb2013 Automatically unbolded volume+comma when > 4 long. |
| + | --21Feb2013 Changed to allow lowercase "asin-tld". |
| + | --22Feb2013 Fixed ref=harv to extract Year from Date. |
| + | --22Feb2013 Set Harvard refer. span id if config.CitationClass "citation". |
| + | --22Feb2013 Fixed config.CitationClass "citation" as span class="citation". |
| + | --22Feb2013 Capitalized "Archived/Retrieved" only when sepc is dot ".". |
| + | --23Feb2013 Fixed author editor for "in" or "In" and put space after sepc. |
| + | --23Feb2013 Changed to omit dot in "et al." when sepc is "." separator. |
| + | --23Feb2013 Fixed "author1-first" to also get args.given or args.given1. |
| + | --23Feb2013 Fixed args.article to set Title, after Periodical is Title. |
| + | --23Feb2013 Fixed to allow blank Title (such as "contribution=mytitle"). |
| + | --23Feb2013 Fixed double-dot ".." at end of Editors list |
| + | --26Feb2013 Moved "issue=" data to show before "page=". |
| + | --26Feb2013 Moved "type=" data to show after "format=". |
| + | --26Feb2013 For "pmc=" link, omitted suffix "/?tool=pmcentrez". |
| + | --27Feb2013 For coauthors, omitted extra separator after authors. |
| + | --27Feb2013 For date, allowed empty date to use month/day/year. |
| + | --27Feb2013 Fixed double-dot ".." at end of authors/coauthors list. |
| + | --27Feb2013 Reset editor suffix as ", ed." when date exists. |
| + | --27Feb2013 Removed duplicate display of "others=" data. |
| + | --27Feb2013 Removed parentheses "( )" around "department" TitleNote. |
| + | --05Mar2013 Moved Language to follow Periodical or Series. |
| + | --05Mar2013 Fixed Edition to follow Series or Volume. |
| + | --05Mar2013 Fixed class encyclopaedia to show article as quoted Chapter. |
| + | --05Mar2013 Fixed class encyclopaedia to show page as "pp." or "p.". |
| + | --07Mar2013 Changed class encyclopaedia to omit "( )" around publisher. |
| + | --07Mar2013 Fixed end double-dot by string.sub(idcommon,-1,-1) was "-1,1". |
| + | --13Mar2013 Removed enddot "." after "quote=" parameter. |
| + | --13Mar2013 Changed config.CitationClass "news" to use "p." page format. |
| + | --13Mar2013 Fixed missing "location=" when "web" or "encyclopaedia". |
| + | --14Mar2013 Fixed end double-dot after book/work title. |
| + | --14Mar2013 Fixed double-dot before "p." or "pp." page number. |
| + | --14Mar2013 Fixed config.CitationClass "book" to use p./pp. page. |
| + | -- |
| + | --End |