00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036 #ifndef INCL_SYMBIAN_LOG
00037 #define INCL_SYMBIAN_LOG
00038
00040 #include "base/Log.h"
00041 #include "base/util/StringBuffer.h"
00042 #include <f32file.h>
00043 #include "base/globalsdef.h"
00044
00045
00046 #define SYMBIAN_LOG_HEADER "Funambol Symbian Sync Client Log"
00047 #define SYMBIAN_LOG_PATH "C:\\data\\"
00048 #define SYMBIAN_LOG_NAME "synclog.txt"
00049
00050 #define SYMBIAN_LOG_SIZE (500 * 1024) // bytes
00051
00052 #define ERR_SEMAPHORE_CREATION 30
00053 #define ERR_SEMAPHORE_CREATION_MSG "Error creating Log Semaphore"
00054
00055 BEGIN_NAMESPACE
00056
00057
00058 class SymbianLog : public Log {
00059
00060 private:
00061
00062 void printMessage(const char* level, const char* msg, PLATFORM_VA_LIST argList);
00063 void RollLogFile(void);
00064 TInt LogSize(void);
00065
00067 RFs fsSession;
00068
00070 RFile file;
00071
00073 RBuf iLogName;
00075 RBuf iRollLogName;
00077 RBuf iLogFileName;
00079 RBuf iLogPathName;
00080
00085 RSemaphore iSemaphore;
00086
00087
00088 StringBuffer iFormattedBias;
00089
00090 void createFormattedBias();
00091
00092 StringBuffer createHeader(const char* title = NULL);
00093
00094
00099 StringBuffer createCurrentTime(bool complete);
00100
00101
00102 public:
00103
00104 SymbianLog(bool reset = false, const char* path = NULL, const char* name = NULL);
00105 virtual ~SymbianLog();
00106
00107 void setLogPath(const char* configLogPath);
00108 void setLogName(const char* configLogName);
00109 void reset (const char* title = NULL);
00110
00111 void error (const char* msg, ...);
00112 void info (const char* msg, ...);
00113 void debug (const char* msg, ...);
00114 void developer(const char* msg, ...);
00115
00117 size_t getLogSize();
00118 };
00119
00120
00121 END_NAMESPACE
00122
00124 #endif // INCL_SYMBIAN_LOG