fixed a bug in nlsr_sync.c
diff --git a/nlsr-sync-0.0/nlsr_sync.c b/nlsr-sync-0.0/nlsr_sync.c
index d2ba580..6029c4d 100644
--- a/nlsr-sync-0.0/nlsr_sync.c
+++ b/nlsr-sync-0.0/nlsr_sync.c
@@ -203,49 +203,48 @@
 }
 
 
-char *
-get_content_by_content_name(char *content_name)
+//char *
+void 
+get_content_by_content_name(char *content_name, unsigned char *content_data)
 {
 
-    struct ccn_charbuf *name = NULL;
-    struct ccn_charbuf *templ = NULL;
-    struct ccn_charbuf *resultbuf = NULL;
-    struct ccn_parsed_ContentObject pcobuf = { 0 };
-    int res;
-    int allow_stale = 0;
-    int content_only = 1;
-    int scope = -1;
-    const unsigned char *ptr;
-    size_t length;
-    int resolve_version = CCN_V_HIGHEST;
-    int timeout_ms = 3000;
-    const unsigned lifetime_default = CCN_INTEREST_LIFETIME_SEC << 12;
-    unsigned lifetime_l12 = lifetime_default;
-    int get_flags = 0;
-    
+	struct ccn_charbuf *name = NULL;
+	struct ccn_charbuf *templ = NULL;
+	struct ccn_charbuf *resultbuf = NULL;
+	struct ccn_parsed_ContentObject pcobuf = { 0 };
+	int res;
+	int allow_stale = 0;
+	int content_only = 1;
+	int scope = -1;
+	const unsigned char *ptr; 
+	size_t length;
+	int resolve_version = CCN_V_HIGHEST;
+	int timeout_ms = 3000;
+	const unsigned lifetime_default = CCN_INTEREST_LIFETIME_SEC << 12;
+	unsigned lifetime_l12 = lifetime_default;
+	int get_flags = 0;
 
-    name = ccn_charbuf_create();
-    res = ccn_name_from_uri(name,content_name);
-    if (res < 0) {
-        fprintf(stderr, "Bad ccn URI: %s\n", content_name);
-        exit(1);
-    }
-  
-   
+	name = ccn_charbuf_create();
+	res = ccn_name_from_uri(name,content_name);
+	if (res < 0) {
+		fprintf(stderr, "Bad ccn URI: %s\n", content_name);
+		exit(1);
+	}
+
 	if (allow_stale || lifetime_l12 != lifetime_default || scope != -1) {
-        templ = ccn_charbuf_create();
-        ccn_charbuf_append_tt(templ, CCN_DTAG_Interest, CCN_DTAG);
-        ccn_charbuf_append_tt(templ, CCN_DTAG_Name, CCN_DTAG);
-        ccn_charbuf_append_closer(templ); /* </Name> */
+		templ = ccn_charbuf_create();
+		ccn_charbuf_append_tt(templ, CCN_DTAG_Interest, CCN_DTAG);
+		ccn_charbuf_append_tt(templ, CCN_DTAG_Name, CCN_DTAG);
+		ccn_charbuf_append_closer(templ); /* </Name> */
 		if (allow_stale) {
 			ccn_charbuf_append_tt(templ, CCN_DTAG_AnswerOriginKind, CCN_DTAG);
 			ccnb_append_number(templ,
-							   CCN_AOK_DEFAULT | CCN_AOK_STALE);
+					CCN_AOK_DEFAULT | CCN_AOK_STALE);
 			ccn_charbuf_append_closer(templ); /* </AnswerOriginKind> */
 		}
-        if (scope != -1) {
-            ccnb_tagged_putf(templ, CCN_DTAG_Scope, "%d", scope);
-        }
+		if (scope != -1) {
+			ccnb_tagged_putf(templ, CCN_DTAG_Scope, "%d", scope);
+		}
 		if (lifetime_l12 != lifetime_default) {
 			/*
 			 * Choose the interest lifetime so there are at least 3
@@ -257,32 +256,35 @@
 				buf[i] = lifetime_l12 & 0xff;
 			ccnb_append_tagged_blob(templ, CCN_DTAG_InterestLifetime, buf, sizeof(buf));
 		}
-        ccn_charbuf_append_closer(templ); /* </Interest> */
-    }
-    resultbuf = ccn_charbuf_create();
-    if (resolve_version != 0) {
-        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;
-        }
-    }
-    res = ccn_get(nlsr->ccn, name, templ, timeout_ms, resultbuf, &pcobuf, NULL, get_flags);
-    if (res >= 0) {
-        ptr = resultbuf->buf;
-        length = resultbuf->length;
-        if (content_only)
-            ccn_content_get_value(ptr, length, &pcobuf, &ptr, &length);
-    }
-    ccn_charbuf_destroy(&resultbuf);
-    ccn_charbuf_destroy(&templ);
-    ccn_charbuf_destroy(&name);   
-	return (char *)ptr;
+		ccn_charbuf_append_closer(templ); /* </Interest> */
+	}
+	resultbuf = ccn_charbuf_create();
+	if (resolve_version != 0) {
+		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;
+		}
+	}
+	res = ccn_get(nlsr->ccn, name, templ, timeout_ms, resultbuf, &pcobuf, NULL, get_flags);
+	if (res >= 0) {
+		ptr = resultbuf->buf;
+		length = resultbuf->length;
+		if (content_only){
+			ccn_content_get_value(ptr, length, &pcobuf, &ptr, &length);
+			content_data = (unsigned char *) calloc(length, sizeof(char *));
+			memcpy (content_data, ptr, length);
+		}
+	}
+	ccn_charbuf_destroy(&resultbuf);
+	ccn_charbuf_destroy(&templ);
+	ccn_charbuf_destroy(&name);   
+	//return (unsigned char *)ptr;
 }
 
 void 
-process_incoming_sync_content_lsa(char *content_data)
+process_incoming_sync_content_lsa( unsigned char *content_data)
 {
 
 
@@ -316,7 +318,7 @@
 	//if ( nlsr->detailed_logging )
 	//	writeLogg(__FILE__,__FUNCTION__,__LINE__,"LSA Data\n");	
 
-	if( strlen(content_data ) > 0 )
+	if( strlen((char *)content_data ) > 0 )
 	{
 
 		orig_router=strtok_r((char *)content_data,sep,&rem);
@@ -389,6 +391,8 @@
 	int ls_type;
 	long int ls_id=0;
 
+	unsigned char *content_data = NULL;
+
 	char *time_stamp=(char *)malloc(20);
 	memset(time_stamp,0,20);
 	get_current_timestamp_micro(time_stamp);
@@ -422,14 +426,16 @@
 			if ( is_new_name_lsa == 1 )
 			{
 				printf("New NAME LSA.....\n");	
-				char *content_data=get_content_by_content_name(ccn_charbuf_as_string(uri));
+				//content_data=get_content_by_content_name(ccn_charbuf_as_string(uri));
+				get_content_by_content_name(ccn_charbuf_as_string(uri), content_data);
 				printf("Content Data: %s \n",content_data);
 				process_incoming_sync_content_lsa(content_data);
 			}
 			else 
 			{
 				printf("Name LSA / Newer Name LSA already xists in LSDB\n");
-				char *content_data=get_content_by_content_name(ccn_charbuf_as_string(uri));
+				//content_data=get_content_by_content_name(ccn_charbuf_as_string(uri));
+				get_content_by_content_name(ccn_charbuf_as_string(uri),content_data);
 				printf("Content Data: %s \n",content_data);
 			}
 		}
@@ -454,7 +460,8 @@
 			if ( is_new_adj_lsa == 1 )
 			{
 				printf("New Adj LSA.....\n");	
-				char *content_data=get_content_by_content_name(ccn_charbuf_as_string(uri));
+				//content_data=get_content_by_content_name(ccn_charbuf_as_string(uri));
+				get_content_by_content_name(ccn_charbuf_as_string(uri), content_data);
 				printf("Content Data: %s \n",content_data);
 				process_incoming_sync_content_lsa(content_data);			
 			}
@@ -462,7 +469,7 @@
 			{
 
 				printf("Adj LSA / Newer Adj LSA already exists in LSDB\n");
-				char *content_data=get_content_by_content_name(ccn_charbuf_as_string(uri));
+				get_content_by_content_name(ccn_charbuf_as_string(uri), content_data);
 				printf("Content Data: %s \n",content_data);
 			}
 		}
@@ -472,8 +479,8 @@
 		}
 	}
 
+	free(content_data);
 	ccn_charbuf_destroy(&uri);
-
 }
 
 int