update to citeproc-js 1.0.165

This commit is contained in:
Simon Kornblith 2011-05-14 16:11:00 +00:00
parent 283118b206
commit bf80266804

View file

@ -1840,7 +1840,7 @@ CSL.DateParser = function () {
}; };
CSL.Engine = function (sys, style, lang, forceLang) { CSL.Engine = function (sys, style, lang, forceLang) {
var attrs, langspec, localexml, locale; var attrs, langspec, localexml, locale;
this.processor_version = "1.0.163"; this.processor_version = "1.0.165";
this.csl_version = "1.0"; this.csl_version = "1.0";
this.sys = sys; this.sys = sys;
this.sys.xml = new CSL.System.Xml.Parsing(); this.sys.xml = new CSL.System.Xml.Parsing();
@ -3316,7 +3316,7 @@ CSL.getCitationCluster = function (inputList, citationID) {
CSL.Output.Queue.adjustPunctuation(this, this.output.queue, mystk); CSL.Output.Queue.adjustPunctuation(this, this.output.queue, mystk);
composite = this.output.string(this, this.output.queue); composite = this.output.string(this, this.output.queue);
this.tmp.suppress_decorations = false; this.tmp.suppress_decorations = false;
if (item && item["author-only"]) { if ("string" === typeof composite) {
this.tmp.suppress_decorations = false; this.tmp.suppress_decorations = false;
return composite; return composite;
} }
@ -6294,6 +6294,7 @@ CSL.Node.text = {
func = function (state, Item) { func = function (state, Item) {
var idx, value; var idx, value;
value = state.getVariable(Item, "page", form); value = state.getVariable(Item, "page", form);
value = value.replace("\u2013", "-", "g");
if (value) { if (value) {
idx = value.indexOf("-"); idx = value.indexOf("-");
if (idx > -1) { if (idx > -1) {
@ -8419,6 +8420,7 @@ CSL.Util.PageRangeMangler.getFunction = function (state) {
}; };
listify = function (str) { listify = function (str) {
var m, lst, ret; var m, lst, ret;
str = str.replace("\u2013", "-", "g");
m = str.match(/([a-zA-Z]*[0-9]+\s*-\s*[a-zA-Z]*[0-9]+)/g); m = str.match(/([a-zA-Z]*[0-9]+\s*-\s*[a-zA-Z]*[0-9]+)/g);
lst = str.split(/[a-zA-Z]*[0-9]+\s*-\s*[a-zA-Z]*[0-9]+/); lst = str.split(/[a-zA-Z]*[0-9]+\s*-\s*[a-zA-Z]*[0-9]+/);
if (lst.length === 0) { if (lst.length === 0) {
@ -8504,7 +8506,7 @@ CSL.Util.PageRangeMangler.getFunction = function (state) {
}; };
if (!state.opt["page-range-format"]) { if (!state.opt["page-range-format"]) {
ret_func = function (str) { ret_func = function (str) {
return str; return str.replace("-", "\u2013", "g");
}; };
} else if (state.opt["page-range-format"] === "expanded") { } else if (state.opt["page-range-format"] === "expanded") {
ret_func = function (str) { ret_func = function (str) {
@ -9221,7 +9223,8 @@ CSL.Registry.prototype.init = function (myitems, uncited_flag) {
CSL.Registry.prototype.dodeletes = function (myhash) { CSL.Registry.prototype.dodeletes = function (myhash) {
var otheritems, key, ambig, pos, len, items, kkey, mypos, id; var otheritems, key, ambig, pos, len, items, kkey, mypos, id;
if ("string" === typeof myhash) { if ("string" === typeof myhash) {
myhash = {myhash: true}; myhash = {};
myhash[myhash] = true;
} }
for (key in this.registry) { for (key in this.registry) {
if (this.registry.hasOwnProperty(key) && !myhash[key]) { if (this.registry.hasOwnProperty(key) && !myhash[key]) {
@ -9488,6 +9491,7 @@ CSL.Registry.NameReg = function (state) {
param = 2; param = 2;
dagopt = state.opt["disambiguate-add-givenname"]; dagopt = state.opt["disambiguate-add-givenname"];
gdropt = state.opt["givenname-disambiguation-rule"]; gdropt = state.opt["givenname-disambiguation-rule"];
var gdropt_orig = gdropt;
if (gdropt === "by-cite") { if (gdropt === "by-cite") {
gdropt = "all-names"; gdropt = "all-names";
} }
@ -9499,7 +9503,7 @@ CSL.Registry.NameReg = function (state) {
if ("undefined" === typeof this.namereg[pkey] || "undefined" === typeof this.namereg[pkey].ikey[ikey]) { if ("undefined" === typeof this.namereg[pkey] || "undefined" === typeof this.namereg[pkey].ikey[ikey]) {
return param; return param;
} }
if (param < request_base) { if (gdropt_orig === "by-cite" && param < request_base) {
param = request_base; param = request_base;
} }
if (!dagopt) { if (!dagopt) {
@ -9584,7 +9588,15 @@ CSL.Registry.NameReg = function (state) {
this.namereg[pkey].ikey[ikey].skey[skey].items.push("" + item_id); this.namereg[pkey].ikey[ikey].skey[skey].items.push("" + item_id);
} }
} }
return param; if (!state.registry.registry[item_id]) {
if (form == "short") {
return 0;
} else if ("string" == typeof initials) {
return 1
}
} else {
return param;
}
}; };
delitems = function (ids) { delitems = function (ids) {
var i, item, pos, len, posA, posB, id, fullkey, llen, ppos, otherid; var i, item, pos, len, posA, posB, id, fullkey, llen, ppos, otherid;
@ -9608,7 +9620,7 @@ CSL.Registry.NameReg = function (state) {
continue; continue;
} }
items = this.namereg[pkey].items; items = this.namereg[pkey].items;
if (skey) { if (skey && this.namereg[pkey].ikey[ikey] && this.namereg[pkey].ikey[ikey].skey[skey]) {
myitems = this.namereg[pkey].ikey[ikey].skey[skey].items; myitems = this.namereg[pkey].ikey[ikey].skey[skey].items;
posB = myitems.indexOf("" + id); posB = myitems.indexOf("" + id);
if (posB > -1) { if (posB > -1) {
@ -9622,7 +9634,7 @@ CSL.Registry.NameReg = function (state) {
ret[this.namereg[pkey].ikey[ikey].items[ppos]] = true; ret[this.namereg[pkey].ikey[ikey].items[ppos]] = true;
} }
} }
if (ikey) { if (ikey && this.namereg[pkey].ikey[ikey]) {
posB = this.namereg[pkey].ikey[ikey].items.indexOf("" + id); posB = this.namereg[pkey].ikey[ikey].items.indexOf("" + id);
if (posB > -1) { if (posB > -1) {
items = this.namereg[pkey].ikey[ikey].items.slice(); items = this.namereg[pkey].ikey[ikey].items.slice();
@ -9774,7 +9786,7 @@ CSL.Disambiguation.prototype.disNames = function (ismax) {
mybase = CSL.cloneAmbigConfig(this.base); mybase = CSL.cloneAmbigConfig(this.base);
mybase.year_suffix = false; mybase.year_suffix = false;
this.state.registry.registerAmbigToken(this.akey, "" + this.partners[0].id, mybase); this.state.registry.registerAmbigToken(this.akey, "" + this.partners[0].id, mybase);
this.lists[this.listpos] = [this.base, this.nonpartners]; this.lists[this.listpos] = [this.base, []];
} else if (this.nonpartners.length === 1) { } else if (this.nonpartners.length === 1) {
mybase = CSL.cloneAmbigConfig(this.base); mybase = CSL.cloneAmbigConfig(this.base);
mybase.year_suffix = false; mybase.year_suffix = false;
@ -9808,7 +9820,7 @@ CSL.Disambiguation.prototype.disGivens = function (ismax) {
} }
mybase = CSL.cloneAmbigConfig(this.base); mybase = CSL.cloneAmbigConfig(this.base);
mybase.year_suffix = false; mybase.year_suffix = false;
this.state.registry.registerAmbigToken(this.akey, "" + this.partners[0].id, mybase); this.state.registry.registerAmbigToken(this.akey, "" + this.partners[0].id, this.base);
this.state.registry.registerAmbigToken(this.akey, "" + this.nonpartners[0].id, mybase); this.state.registry.registerAmbigToken(this.akey, "" + this.nonpartners[0].id, mybase);
this.lists[this.listpos] = [this.base, []]; this.lists[this.listpos] = [this.base, []];
} else if (this.clashes[1] === 0) { } else if (this.clashes[1] === 0) {
@ -9973,6 +9985,7 @@ CSL.Disambiguation.prototype.initVars = function (akey) {
this.lists = []; this.lists = [];
this.base = false; this.base = false;
this.akey = akey; this.akey = akey;
this.advance_mode = false;
myItemBundles = []; myItemBundles = [];
myIds = this.ambigcites[akey]; myIds = this.ambigcites[akey];
if (myIds && myIds.length > 1) { if (myIds && myIds.length > 1) {