Update the address bar with the name in the returned ContentObject.  (Don't show the sequence number unless in the original URI.)
diff --git a/js/ccnxProtocol.xpi b/js/ccnxProtocol.xpi
index 15b71e5..4a92f4a 100644
--- a/js/ccnxProtocol.xpi
+++ b/js/ccnxProtocol.xpi
Binary files differ
diff --git a/js/ccnxProtocol/components/ccnxProtocolService.js b/js/ccnxProtocol/components/ccnxProtocolService.js
index 12da336..91b590c 100644
--- a/js/ccnxProtocol/components/ccnxProtocolService.js
+++ b/js/ccnxProtocol/components/ccnxProtocolService.js
@@ -46,9 +46,12 @@
                     nameString = nameString.substr(colonIndex + 1, nameString.length - colonIndex - 1);

                 

 				var name = new Name(nameString);

+                // TODO: Strip off an ending implicit digest before checking the last component?

+                var uriEndsWithSequence = endsWithSequence(name);

+                

 			    // 131.179.141.18 is lioncub.metwi.ucla.edu .

 				var ndn = new NDN('131.179.141.18');

-				

+                				

 				var ContentClosure = function ContentClosure() {

                     // Inherit from Closure.

                     Closure.call(this);

@@ -70,9 +73,21 @@
 					contentListener.onReceivedContent(content, 

                         contentTypeEtc.contentType, contentTypeEtc.contentCharset);

                     

-                    // Assume that onReceivedContent sends all the content immediately and that

-                    //   the gURLBar is updated if the content is for the main window.

+                    // Assume that onReceivedContent sends all the content immediately and updatse

+                    //   the gURLBar if the content is for the main window.

                     var urlBar = mostRecentWindow.gURLBar;

+                    if (urlBar && urlBar.value == aURI.spec) {

+                        // Assume the URI is for the window.  Update the URL bar.

+                        // Show the name without the ending sequence (unless the original URI had it).

+                        if (!uriEndsWithSequence && endsWithSequence(contentObject.name)) {

+                            var nameWithoutSequence = new Name

+                                (contentObject.name.components.slice

+                                 (0, contentObject.name.components.length - 1));

+                            urlBar.value = "ccnx:" + nameWithoutSequence.to_uri();

+                        }

+                        else

+                            urlBar.value = "ccnx:" + contentObject.name.to_uri();

+                    }

                     

                     return Closure.RESULT_OK;

 				};

@@ -114,18 +129,27 @@
         

         var str = DataUtils.toString(component).toLowerCase();

         if (str.indexOf(".gif") >= 0) 

-            return { contentType:  "image/gif", charset:  "ISO-8859-1" }

+            return { contentType: "image/gif", charset: "ISO-8859-1" }

     	else if (str.indexOf(".jpg") >= 0 ||

     			 str.indexOf(".jpeg") >= 0) 

-            return { contentType:  "image/jpeg", charset:  "ISO-8859-1" }

+            return { contentType: "image/jpeg", charset: "ISO-8859-1" }

     	else if (str.indexOf(".png") >= 0) 

-            return { contentType:  "image/png", charset:  "ISO-8859-1" }

+            return { contentType: "image/png", charset: "ISO-8859-1" }

         else if (str.indexOf(".bmp") >= 0) 

-            return { contentType:  "image/bmp", charset:  "ISO-8859-1" }

+            return { contentType: "image/bmp", charset: "ISO-8859-1" }

     	else if (str.indexOf(".css") >= 0) 

-            return { contentType:  "text/css", charset: "utf-8" }

+            return { contentType: "text/css", charset: "utf-8" }

     }

     

     // default

     return { contentType: "text/html", charset: "utf-8" };

 }

+

+/*

+ * Return true if the last component in the name is a sequence..

+ */

+function endsWithSequence(name) {

+    return name.components != null && name.components.length >= 1 &&

+        name.components[name.components.length - 1].length >= 1 &&

+        name.components[name.components.length - 1][0] == 0;

+}
\ No newline at end of file
diff --git a/js/ccnxProtocol/modules/ndn-js.jsm b/js/ccnxProtocol/modules/ndn-js.jsm
index f720696..8134e79 100644
--- a/js/ccnxProtocol/modules/ndn-js.jsm
+++ b/js/ccnxProtocol/modules/ndn-js.jsm
@@ -657,7 +657,7 @@
 /*
  * @author: ucla-cs
  * See COPYING for copyright and distribution information.
- * This class represents a Name
+ * This class represents a Name as an array of components where each is a byte array.
  */
  
 
@@ -712,20 +712,34 @@
 	return blobArrays;
 };
 
-Name.createNameArray=function(name){
-
-
-	name = unescape(name);
-	
+Name.createNameArray=function(name) {
 	var array = name.split('/');
-
+    var colonIndex = array[0].indexOf(':');
+    if (colonIndex >= 0) {
+        name = name.substr(colonIndex + 1, name.length - colonIndex - 1);
+        array = name.split('/');
+    }
 	
 	if(name[0]=="/")
-		array=array.slice(1,array.length);
-		
+		array=array.slice(1,array.length);		
 	if(name[name.length-1]=="/")
 		array=array.slice(0,array.length-1);
-	
+    
+    // Unescape the components.
+    for (var i = 0; i < array.length; ++i) {
+        var component = unescape(array[i]);
+        
+        if (component.match(/[^.]/) == null) {
+            // Special case for component of only periods.  Remove 3 periods.
+            if (component.length <= 3)
+                array[i] = "";
+            else
+                array[i] = component.substr(3, component.length - 3);
+        }
+        else
+            array[i] = component;
+    }
+
 	return array;
 }
 
@@ -764,6 +778,49 @@
 	return this.components.push(param);
 };
 
+// Return the escaped name string according to "CCNx URI Scheme".  Does not include "ccnx:".
+Name.prototype.to_uri = function() {	
+	var result = "";
+	
+	for(var i = 0; i < this.components.length; ++i)
+		result += "/"+ Name.toEscapedString(this.components[i]);
+	
+	return result;	
+};
+
+/**
+ * Return component as an escaped string according to "CCNx URI Scheme".
+ * We can't use encodeURIComponent because that doesn't encode all the characters we want to.
+ */
+Name.toEscapedString = function(component) {
+    var result = "";
+    var gotNonDot = false;
+    for (var i = 0; i < component.length; ++i) {
+        if (component[i] != 0x2e) {
+            gotNonDot = true;
+            break;
+        }
+    }
+    if (!gotNonDot) {
+        // Special case for component of zero or more periods.  Add 3 periods.
+        result = "...";
+        for (var i = 0; i < component.length; ++i)
+            result += ".";
+    }
+    else {
+        for (var i = 0; i < component.length; ++i) {
+            var value = component[i];
+            // Check for 0-9, A-Z, a-z, (+), (-), (.), (_)
+            if (value >= 0x30 && value <= 0x39 || value >= 0x41 && value <= 0x5a ||
+                value >= 0x61 && value <= 0x7a || value == 0x2b || value == 0x2d || 
+                value == 0x2e || value == 0x5f)
+                result += String.fromCharCode(value);
+            else
+                result += "%" + (value < 16 ? "0" : "") + value.toString(16).toUpperCase();
+        }
+    }
+    return result;
+};
 
 /*
  * @author: ucla-cs
@@ -1893,11 +1950,10 @@
 		//TODO check if the length of the PublisherPublicKeyDigest is correct ( Security reason)
 
 		if (this.publisherPublicKeyDigest.length != this.PUBLISHER_ID_LEN) {
+			if (LOG > 0)
+                console.log('LENGTH OF PUBLISHER ID IS WRONG! Expected ' + this.PUBLISHER_ID_LEN + ", got " + this.publisherPublicKeyDigest.length);
 			
-			console.log('LENGTH OF PUBLISHER ID IS WRONG! Expected ' + this.PUBLISHER_ID_LEN + ", got " + this.publisherPublicKeyDigest.length);
-			
-			//this.publisherPublicKeyDigest = new PublisherPublicKeyDigest(this.PublisherPublicKeyDigest).PublisherKeyDigest;
-		
+			//this.publisherPublicKeyDigest = new PublisherPublicKeyDigest(this.PublisherPublicKeyDigest).PublisherKeyDigest;		
 		}
 	};
 
@@ -2118,7 +2174,7 @@
 ForwardingEntry.prototype.from_ccnb =function(
 	//XMLDecoder 
 	decoder) 
-	//throws Error when name == "ContentDecodingException"
+	//throws ContentDecodingException
 	{
 			decoder.readStartElement(this.getElementLabel());
 			if (decoder.peekStartElement(CCNProtocolDTags.Action)) {
@@ -3820,7 +3876,9 @@
 DataUtils.decodeUtf8 = function (utftext) {
 		var string = "";
 		var i = 0;
-		var c = c1 = c2 = 0;
+		var c = 0;
+        var c1 = 0;
+        var c2 = 0;
  
 		while ( i < utftext.length ) {
  
@@ -3837,7 +3895,7 @@
 			}
 			else {
 				c2 = utftext.charCodeAt(i+1);
-				c3 = utftext.charCodeAt(i+2);
+				var c3 = utftext.charCodeAt(i+2);
 				string += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));
 				i += 3;
 			}
@@ -3905,7 +3963,37 @@
     }
 
     return true;
-}
+};
+
+/*
+ * Convert the big endian byte array to an unsigned int.
+ * Don't check for overflow.
+ */
+DataUtils.bigEndianToUnsignedInt = function(bytes) {
+    var result = 0;
+    for (var i = 0; i < bytes.length; ++i) {
+        result <<= 8;
+        result += bytes[i];
+    }
+    return result;
+};
+
+/*
+ * Convert the int value to a new big endian byte array and return.
+ * If value is 0 or negative, return []. 
+ */
+DataUtils.nonNegativeIntToBigEndian = function(value) {
+    var result = [];
+    if (value <= 0)
+        return result;
+    
+    while (value != 0) {
+        result.unshift(value & 0xff);
+        value >>= 8;
+    }
+    return result;
+};
+
 /*
  * This file contains utilities to help encode and decode NDN objects.
  * author: ucla-cs