Freeing unfreed memory
diff --git a/nlsr-sync-0.0/nlsr_sync.c b/nlsr-sync-0.0/nlsr_sync.c
index 289cf39..f3ad3c4 100644
--- a/nlsr-sync-0.0/nlsr_sync.c
+++ b/nlsr-sync-0.0/nlsr_sync.c
@@ -29,7 +29,8 @@
 #include "nlsr_sync.h"
 #include "nlsr_lsdb.h"
 #include "utility.h"
-//test method
+
+
 char *
 hex_string(unsigned char *s, size_t l)
 {
@@ -66,33 +67,31 @@
     else
         ccn_charbuf_append_string(uri, "(null)");
 
-    //if ( nlsr->debugging )
-    	//printf("%s %s %s\n", ccn_charbuf_as_string(uri), hexL, hexR);
-
+  
     if ( nlsr->debugging )
 	printf("Response from sync in the name: %s \n",ccn_charbuf_as_string(uri));	
 
     fflush(stdout);
     free(hexL);
     free(hexR);
-    ccn_charbuf_destroy(&uri);
+    //ccn_charbuf_destroy(&uri);
 
 
-	//--Doing ourthing from here
+	//--Doing our thing from here
  	struct ccn_indexbuf cid={0};
 
     	struct ccn_indexbuf *components=&cid;
-    	ccn_name_split (name, components);
-    	ccn_name_chop(name,components,-3);
+    	ccn_name_split (uri, components);
+    	ccn_name_chop(uri,components,-3);
 
-	process_content_from_sync(name,components);
+	process_content_from_sync(uri,components);
 
 
- 
+	ccn_charbuf_destroy(&uri); 
 
   return(0);
 }
-//test method
+
 
 int 
 get_lsa_position(struct ccn_charbuf * ccnb, struct ccn_indexbuf *comps)
@@ -101,8 +100,7 @@
 	
 	
 	int res,i;
-	int lsa_position=0; 	//Obaid: Hoque make it -1, 0 is also an index
-				//	I didn't change it as it might break the code. 	
+	int lsa_position=0; 	 	
 	int name_comps=(int)comps->n;
 
 	for(i=0;i<name_comps;i++)
@@ -129,10 +127,6 @@
 	int lsa_position=0;
 	int len=0;
 
-	//lsa_position=get_lsa_position(interest_ccnb,interest_comps);
-	
-	//printf("LSA Position: %d \n",lsa_position);
-	
 	
 	struct ccn_indexbuf cid={0};
     	struct ccn_indexbuf *components=&cid;
@@ -140,7 +134,7 @@
 	ccn_name_from_uri(name,nlsr->slice_prefix);
     	ccn_name_split (name, components);
 	lsa_position=components->n-2;
-	//printf("LSA Position from Slice Prefix Component: %d \n",(int)components->n-2);
+
     	ccn_charbuf_destroy(&name);
 	
 
@@ -170,7 +164,8 @@
 	memcpy(name_part->name,neighbor,strlen(neighbor)+1);
 	name_part->length=strlen(neighbor)+1;
 
-	
+	// Add 01/31/2013
+	free(neighbor);
 }
 
 void 
@@ -222,7 +217,9 @@
 	memcpy(name_part->name,neighbor,strlen(neighbor)+1);
 	name_part->length=strlen(neighbor)+1;
 
-	
+	// 01/31/2013
+	free(neighbor);
+	ccn_charbuf_destroy(&name);
 }
 
 
@@ -286,7 +283,6 @@
 		res = ccn_resolve_version(nlsr->ccn, name, resolve_version, 500);
 		if (res >= 0) {
 			ccn_uri_append(resultbuf, name->buf, name->length, 1);
-			//fprintf(stderr, "== %s\n",ccn_charbuf_as_string(resultbuf));
 			resultbuf->length = 0;
 		}
 	}
@@ -303,7 +299,6 @@
 	ccn_charbuf_destroy(&resultbuf);
 	ccn_charbuf_destroy(&templ);
 	ccn_charbuf_destroy(&name);   
-	//return (unsigned char *)ptr;
 }
 
 void 
@@ -571,28 +566,10 @@
 	if (content_data != NULL)
 		free(content_data);
 	ccn_charbuf_destroy(&uri);
+	//01/31/2013	
+	free(time_stamp);
 }
 
-int
-sync_callback(struct ccns_name_closure *nc,
-        struct ccn_charbuf *lhash,
-        struct ccn_charbuf *rhash,
-        struct ccn_charbuf *name)
-{
-
-
-    	struct ccn_indexbuf cid={0};
-
-    	struct ccn_indexbuf *components=&cid;
-    	ccn_name_split (name, components);
-    	ccn_name_chop(name,components,-3);
-
-	process_content_from_sync(name,components);
-
-    	return(0);
-}
-
-
 void
 sync_monitor(char *topo_prefix, char *slice_prefix)
 {
@@ -616,8 +593,11 @@
 
     ccns_slice_set_topo_prefix(nlsr->slice, topo, prefix);
     nlsr->closure->callback = &sync_cb;
-    //nlsr->closure->callback = &sync_callback;
     nlsr->ccns = ccns_open(nlsr->ccn, nlsr->slice, nlsr->closure, roothash, NULL);
+
+    //01/31/2013
+    ccn_charbuf_destroy(&prefix);
+    ccn_charbuf_destroy(&topo);
 }
 
 struct ccn_charbuf *
@@ -748,17 +728,14 @@
  
   
     res = ccns_write_slice(nlsr->ccn, slice, slice_name);
- /*
-// 	Obaid: commenting out the following lines to resolve a bug. 
-//	If commenting them can resolve the issue, then we 
-//	need to call them before terminating the program.
+ 
+    //01/31/2013
     ccns_slice_destroy(&slice);
     ccn_charbuf_destroy(&prefix);
     ccn_charbuf_destroy(&topo);
     ccn_charbuf_destroy(&clause);
     ccn_charbuf_destroy(&slice_name);
     ccn_charbuf_destroy(&slice_uri);
-*/
 
     return 0;
 }