Merge branch 'master' of git.irl.cs.ucla.edu:ndn/sync
diff --git a/model/sync-app-data-fetch.h b/model/sync-app-data-fetch.h
index 1bba3a6..3816e4e 100644
--- a/model/sync-app-data-fetch.h
+++ b/model/sync-app-data-fetch.h
@@ -36,10 +36,22 @@
 class AppDataFetch
 {
 public:
+	/**
+	 * @param dataCallback the callback function to process data
+	 */
 	AppDataFetch(boost::function<void (boost::shared_ptr<DataBuffer>)>
 	dataCallback);
+
 	void setDataCallback(boost::function<void (boost::shared_ptr<DataBuffer>)>
 	dataCallback) {m_dataCallback = dataCallback;}
+
+	/**
+	 * @breif fetch data for a certain name prefix
+	 *
+	 * @param prefix the prefix for the data
+	 * @param startSeq the start of sequence number range (inclusive)
+	 * @param endSeq the end of sequence number range (inclusive)
+	 */
 	void fetch(string prefix, long startSeq, long endSeq);
 
 private:
diff --git a/model/sync-app-data-publish.h b/model/sync-app-data-publish.h
index 3859153..162abf5 100644
--- a/model/sync-app-data-publish.h
+++ b/model/sync-app-data-publish.h
@@ -34,19 +34,47 @@
 
 /**
  * \ingroup sync
- * @brief publishes application data and keeps track of most recently published
- * data
+ * @brief publishes application data using incrementing sequence number (for
+ * each sequence namber and keeps track of most recently published data for 
+ * each name prefix
  */
 class AppDataPublish
 {
 public:
-	std::pair<std::string, boost::shared_ptr<const DataBuffer> > getRecentData();
+	AppDataPublish();
+	~AppDataPublish() {};
+
+	/**
+	 * @brief get the name (including sequence number) and the content
+	 * (unencoded, just XML stanza) of the most recent published data
+	 *
+	 * @param prefix the name prefix to look for 
+	 * @return the pair of name and content
+	 */
+	std::pair<std::string, boost::shared_ptr<const DataBuffer> >
+	getRecentData(std::string prefix);
+
+	/**
+	 * brief get the most recent sequence number for a name prefix
+	 */
+	 long getHighestSeq(std:string prefix);
+
+	/**
+	 * @brief publish data for a name prefix, updates the corresponding
+	 * sequence number and recent data
+	 *
+	 * @param name data prefix
+	 * @param dataBuffer the data itself
+	 * @param freshness the freshness for the data object
+	 * @return whether the publish succeeded
+	 */
 	bool publishData(std::string name, boost::shared_ptr<DataBufer> dataBuffer,
 	int freshness);
   
 private:
-	boost::shared_ptr<CcnxWrapper> ccnxHandle;
-	std::pair<std::string, boost::shared_ptr<DataBuffer> > recentData;
+	boost::unordered_map<string, long> m_sequenceLog;
+	boost::shared_ptr<CcnxWrapper> m_ccnxHandle;
+	std::pair<std::string, boost::shared_ptr<DataBuffer> > m_recentData;
 };
 
 } // Sync
diff --git a/model/sync-app-socket.h b/model/sync-app-socket.h
index 5e44617..e4b6133 100644
--- a/model/sync-app-socket.h
+++ b/model/sync-app-socket.h
@@ -33,11 +33,32 @@
 class SyncAppSocket
 {
 public:
+	/**
+	 * @brief the constructor for SyncAppSocket; the parameter syncPrefix
+	 * should be passed to the constructor of m_syncAppWrapper; the other
+	 * parameter should be passed to the constructor of m_fetcher; furthermore,
+	 * the fetch function of m_fetcher should be a second paramter passed to
+	 * the constructor of m_syncAppWrapper, so that m_syncAppWrapper can tell
+	 * m_fetcher to fetch the actual app data after it learns the names
+	 *
+	 * @param syncPrefix the name prefix for Sync Interest
+	 * @param dataCallback the callback to process data
+	 */
 	SyncAppSocket(std::string syncPrefix, boost::function<void
-	(boost::shared_ptr<DataBuffer>)>);
+	(boost::shared_ptr<DataBuffer>)> dataCallback);
+
 	~SyncAppSocket();
-	bool publishData(std::string prefix, boost::shared_ptr<DataBuffer>
-	dataBuffer);
+
+	/**
+	 * @brief publish data from local client and tell SyncAppWrapper to update
+	 * the sync tree by adding the local names
+	 * 
+	 * @param prefix the name prefix for the data
+	 * @param dataBuffer the data itself
+	 * @param freshness the freshness time for the data (in seconds)
+	 */
+	bool publish(std::string prefix, boost::shared_ptr<DataBuffer>
+	dataBuffer, int freshness);
 private:
 	boost::shared_ptr<AppDataFetch> m_fetcher;
 	boost::shared_ptr<AppDataPublish> m_publisher;
diff --git a/model/sync-app-wrapper.h b/model/sync-app-wrapper.h
index 97137ac..e9490e7 100644
--- a/model/sync-app-wrapper.h
+++ b/model/sync-app-wrapper.h
@@ -40,15 +40,32 @@
 class SyncAppWrapper
 {
 public:
+	/**
+	 * @brief constructor for this class; 
+	 * @param syncPrefix the name prefix to use for the Sync Interest
+	 * @param fetch the fetch function, which will be called to actually fetch
+	 * the app data when new remote names are learned
+	 */
 	SyncAppWrapper(std::string syncPrefix, boost::function<void (string, long,
 	long)> fetch);
+
 	~SyncAppWrapper();
 	/**
 	 * a wrapper for the same func in SyncApp
 	 */
 	void addLocalNames(std::string prefix, long seq);
+
+	/**
+	 * @brief respond to the Sync Interest; a lot of logic needs to go in here
+	 * @param interest the Sync Interest in string format
+	 */
 	void respondSyncInterest(std::string interest);	
-	void processSyncData(boost::shared_ptr<DataBuffer> databuffer);
+
+	/**
+	 * @brief process the fetched sync data
+	 * @param dataBuffer the sync data
+	 */
+	void processSyncData(boost::shared_ptr<DataBuffer> dataBuffer);
 
 private:
 	sendSyncInterest();
diff --git a/model/sync-ccnx-wrapper.h b/model/sync-ccnx-wrapper.h
index eaa86cf..4153606 100644
--- a/model/sync-ccnx-wrapper.h
+++ b/model/sync-ccnx-wrapper.h
@@ -31,7 +31,8 @@
 #include <ccn/bloom.h>
 }
 
-#include <boost/thread.hpp>
+#include <boost/thread/recursive_mutex.hpp>
+#include <boost/thread/thread.hpp>
 #include <boost/shared_ptr.hpp>
 #include <string>
 #include "sync-data-buffer.h"
@@ -52,7 +53,8 @@
 	ccn* m_handle;
 	ccn_keystore *m_keyStore;
 	ccn_charbuf *m_keyLoactor;
-	boost::mutex m_mutex;
+	// to lock, use "boost::recursive_mutex::scoped_lock scoped_lock(mutex);
+	boost::recursive_mutex m_mutex;
 	boost::shared_ptr<boos::thread> m_thread;
 
 private:
@@ -65,19 +67,43 @@
 
 public:
   
-
+  /**
+   * @brief initialize the wrapper; a lot of things needs to be done. 1) init
+   * keystore 2) init keylocator 3) start a thread to hold a loop of ccn_run 
+   *
+   */
    CcnxWrapper();
    ~CcnxWrapper();
+
   /**
-   * @brief send Interest 
+   * @brief send Interest; need to grab lock m_mutex first
    *
    * @param strInterest the Interest name
-   * @param callback the callback function to deal with the returned data
+   * @param dataCallback the callback function to deal with the returned data
+   * @return the return code of ccn_express_interest 
    */
    int sendInterest(std::string strInterest, boost::function<void
-   (boost::shared_ptr<DataBuffer>)> processData);
+   (boost::shared_ptr<DataBuffer>)> dataCallback);
+
+  /**
+   * @brief set Interest filter (specify what interest you want to receive 
+   *
+   * @param prefix the prefix of Interest
+   * @param interestCallback the callback function to deal with the returned data
+   * @return the return code of ccn_set_interest_filter
+   */
    int sendInterestFilter(std::string prefix, boost::function<void (std::string)>
-   processInterest);
+   interestCallback);
+
+  /**
+   * @brief publish data and put it to local ccn content store; need to grab
+   * lock m_mutex first
+   *
+   * @param name the name for the data object
+   * @param dataBuffer the data to be published
+   * @param freshness the freshness time for the data object
+   * @return code generated by ccnx library calls, >0 if success
+   */
    int publishData(std::string name, boost::shared_ptr<DataBuffer> dataBuffer,
    int freshness);
 
diff --git a/model/sync-data-buffer.h b/model/sync-data-buffer.h
index f471b9a..dd6dbb8 100644
--- a/model/sync-data-buffer.h
+++ b/model/sync-data-buffer.h
@@ -39,7 +39,8 @@
 
 /**
  * \ingroup sync
- * @brief DataBuffer Interface
+ * @brief DataBuffer Interface to be used by CcnxWrapper and all other data
+ * publish/request/processing related functions
  */
 class DataBuffer {
 public:
@@ -60,10 +61,15 @@
 	AppDataBuffer(const unsigned char *buffer, size_t len);
 	AppDataBuffer(const DataBuffer *DataBuffer);
 	AppDataBuffer &operator=(const DataBuffer *DataBuffer);
+
+	/**
+	 * @brief reset the buffer and len
+	 */
 	virtual void setBufferAndLength(const unsigned char *buffer, size_t len);
-	virtual ~DataBuffer();
-	virtual size_t length() {return len;}
-	virtual const unsigned char *buffer() { return const_cast<const unsigned char *> (buffer); }
+	virtual ~AppDataBuffer();
+	virtual size_t length() {return m_len;}
+	virtual const unsigned char *buffer() { return const_cast<const unsigned
+	char *> (m_buffer); }
 
 private:
 	unsigned char *m_buffer;
@@ -78,6 +84,10 @@
  */
 class SyncDataBuffer : DataBuffer{
 public:
+	/**
+	 * @brief decorates some object that implements DataBuffer interface
+	 * primary usage here is to decorate AppDataBuffer
+	 */
 	SyncDataBuffer(DataBuffer *dataBuffer) { m_dataBuffer = dataBuffer;}
 	virtual ~SyncDataBuffer(){};	
 	virtual size_t length() {m_dataBuffer->length();}