From a3810626213aab3d3df8ecfc0e8df4e3c10cef6c Mon Sep 17 00:00:00 2001 From: aurimasv Date: Fri, 27 Apr 2012 00:27:44 -0500 Subject: [PATCH] Simon: closes #1732, Creator sequence breaks in RDF export with > 10 creators (thanks Frank) --- chrome/content/zotero/xpcom/rdf/serialize.js | 29 +++++++++++++++++++- 1 file changed, 28 insertions(+), 1 deletion(-) diff --git a/chrome/content/zotero/xpcom/rdf/serialize.js b/chrome/content/zotero/xpcom/rdf/serialize.js index c9fb3b6864..ae5db64f8d 100644 --- a/chrome/content/zotero/xpcom/rdf/serialize.js +++ b/chrome/content/zotero/xpcom/rdf/serialize.js @@ -673,7 +673,34 @@ __Serializer.prototype.statementsToXML = function(sts) { var results = []; var type = null, t, st; var sts = stats.subjects[sz.toStr(subject)]; // relevant statements - sts.sort(); + + // Sort only on the predicate, leave the order at object + // level undisturbed. This leaves multilingual content in + // the order of entry (for partner literals), which helps + // readability. + // + // For the predicate sort, we attempt to split the uri + // as a hint to the sequence, as sequenced items seems + // to be of the form http://example.com#_1, http://example.com#_2, + // et cetera. Probably not the most optimal of fixes, but + // it does work. + sts.sort(function(a,b) { + var aa = a.predicate.uri.split('#_'); + var bb = a.predicate.uri.split('#_'); + if (aa[0] > bb[0]) { + return 1; + } else if (aa[0] < bb[0]) { + return -1; + } else if ("undefined" !== typeof aa[1] && "undefined" !== typeof bb[1]) { + if (parseInt(aa[1], 10) > parseInt(bb[1], 10)) { + return 1; + } else if (parseInt(aa[1], 10) < parseInt(bb[1], 10)) { + return -1; + } + } + return 0; + }); + for (var i=0; i