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 #include <cstring>
00034 #include <sys/time.h>
00035
00036 #include "Log.h"
00037 #include "LogSelector.h"
00038
00039
00040 using namespace std;
00041
00042 LogSelector::ThreadIdMap LogSelector::threadIds;
00043 const std::string* LogSelector::prefix = NULL;
00044
00045 LogSelector::LogSelector(const string& n,
00046 FILE* f,
00047 LogSelectorTimestamp lts,
00048 LogSelectorName ln,
00049 LogSelectorThreadId ltid,
00050 LogSelectorOutput lso) :
00051 name(n),
00052 fp(f),
00053 logTimestamp(lts),
00054 logName(ln),
00055 logThreadId(ltid),
00056 logOutput(lso) {
00057 }
00058
00059 LogSelector::~LogSelector() {
00060 }
00061
00062 string LogSelector::getName() const {
00063 return name;
00064 }
00065
00066 string LogSelector::getSelectorHeader() const {
00067
00068 string r = (prefix && (logTimestamp != LOG_TIMESTAMP_DISABLED||logThreadId == LOG_THREADID_ENABLED||logName == LOG_NAME_ENABLED))?*prefix:"";
00069
00070 if (logTimestamp != LOG_TIMESTAMP_DISABLED) {
00071 struct timeval clock_;
00072 struct timezone tz_;
00073 gettimeofday(&clock_, &tz_);
00074
00075 if (logTimestamp == LOG_TIMESTAMP_HUMAN) {
00076 r += "[";
00077 r += ctime((const time_t*)&(clock_.tv_sec));
00078
00079 r = r.substr(0, r.size() - 1);
00080 r += "] ";
00081 }
00082 else if (logTimestamp == LOG_TIMESTAMP_EPOCH) {
00083 double now = clock_.tv_sec + (double)clock_.tv_usec/1000000.0;
00084 char tmp[32];
00085 sprintf(tmp, "%f ", now);
00086 r += tmp;
00087 }
00088 }
00089
00090
00091 if (logThreadId == LOG_THREADID_ENABLED) {
00092 unsigned int tid = Log::ThreadSpecific::getVtid();
00093
00094
00095
00096
00097
00098
00099
00100
00101
00102
00103
00104 char tmp[32];
00105 snprintf(tmp, 31, "%02d ", tid);
00106 r += tmp;
00107 }
00108
00109 if (logName == LOG_NAME_ENABLED) {
00110 r += "[";
00111 r += name;
00112 r += "] ";
00113 }
00114
00115 return r;
00116 }
00117
00118
00119 string LogSelector::getSerializedSelectorHeader() const {
00120 string r = "";
00121 struct timeval clock_;
00122 struct timezone tz_;
00123 gettimeofday(&clock_, &tz_);
00124
00125 double now = clock_.tv_sec + (double)clock_.tv_usec/1000000.0;
00126 mace::serialize(r, &now);
00127
00128 unsigned int tid = Log::ThreadSpecific::getVtid();
00129 mace::serialize(r, &tid);
00130
00131 return r;
00132 }
00133
00134
00135 FILE* LogSelector::getFile() const {
00136 return fp;
00137 }
00138
00139 LogSelectorTimestamp LogSelector::getLogTimestamp() const {
00140 return logTimestamp;
00141 }
00142
00143 LogSelectorName LogSelector::getLogName() const {
00144 return logName;
00145 }
00146
00147 LogSelectorThreadId LogSelector::getLogThreadId() const {
00148 return logThreadId;
00149 }
00150
00151 LogSelectorOutput LogSelector::getLogSelectorOutput() const {
00152 return logOutput;
00153 }
00154