[open-ils-commits] r20114 - branches/rel_2_0/Open-ILS/src/perlmods/OpenILS/WWW (dbs)

svn at svn.open-ils.org svn at svn.open-ils.org
Fri Apr 15 16:18:10 EDT 2011


Author: dbs
Date: 2011-04-15 16:18:05 -0400 (Fri, 15 Apr 2011)
New Revision: 20114

Modified:
   branches/rel_2_0/Open-ILS/src/perlmods/OpenILS/WWW/SuperCat.pm
Log:
Protect dumb JavaScript engines from having to deal with actual Unicode

The holdings_xml format did not include an XML declaration, but adding that
as we do here still does not make the Firefox and Chromium JS engines capable
of consuming XML that contains Unicode content outside of the base ASCII
range.

So, we invoke entityize() to convert anything outside of the realm of
ASCII to XML entities. An alternative would be to invoke entityize() in
OpenILS::Application::SuperCat::unAPI::acn but it's not clear if that
would interfere with any other uses.

With this change, library names / copy location names with Unicode content
can be displayed correctly on the search results page.


Modified: branches/rel_2_0/Open-ILS/src/perlmods/OpenILS/WWW/SuperCat.pm
===================================================================
--- branches/rel_2_0/Open-ILS/src/perlmods/OpenILS/WWW/SuperCat.pm	2011-04-15 20:14:42 UTC (rev 20113)
+++ branches/rel_2_0/Open-ILS/src/perlmods/OpenILS/WWW/SuperCat.pm	2011-04-15 20:18:05 UTC (rev 20114)
@@ -680,12 +680,19 @@
 		return 404;
 	}
 
-	print "Content-type: application/xml; charset=utf-8\n\n$data";
+	print "Content-type: application/xml; charset=utf-8\n\n";
 
+	# holdings_xml format comes back to us without an XML declaration
+	# and without being entityized; fix that here
 	if ($base_format eq 'holdings_xml') {
+		print "<?xml version='1.0' encoding='UTF-8' ?>\n";
+		print $U->entityize($data);
+
 		while (my $c = $req->recv) {
-			print $c->content;
+			print $U->entityize($c->content);
 		}
+	} else {
+		print $data;
 	}
 
 	return Apache2::Const::OK;



More information about the open-ils-commits mailing list