2 * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 * @file old_style_log_provider.cpp
18 * @author Przemyslaw Dobrowolski (p.dobrowolsk@samsung.com)
20 * @brief This file is the implementation file of old style log provider
23 #include <dpl/log/old_style_log_provider.h>
24 #include <dpl/colors.h>
33 namespace // anonymous
35 using namespace DPL::Colors::Text;
36 const char *DEBUG_BEGIN = GREEN_BEGIN;
37 const char *DEBUG_END = GREEN_END;
38 const char *INFO_BEGIN = CYAN_BEGIN;
39 const char *INFO_END = CYAN_END;
40 const char *ERROR_BEGIN = RED_BEGIN;
41 const char *ERROR_END = RED_END;
42 const char *WARNING_BEGIN = BOLD_GOLD_BEGIN;
43 const char *WARNING_END = BOLD_GOLD_END;
44 const char *PEDANTIC_BEGIN = PURPLE_BEGIN;
45 const char *PEDANTIC_END = PURPLE_END;
47 std::string GetFormattedTime()
52 gettimeofday(&tv, NULL);
53 localtime_r(&tv.tv_sec, &localNowTime);
58 "%02i:%02i:%02i.%03i",
62 static_cast<int>(tv.tv_usec / 1000));
65 } // namespace anonymous
67 std::string OldStyleLogProvider::FormatMessage(const char *message,
72 std::ostringstream val;
74 val << std::string("[") << GetFormattedTime() << std::string("] [") <<
75 static_cast<unsigned long>(pthread_self()) << "/" <<
76 static_cast<int>(getpid()) << std::string("] [") <<
77 LocateSourceFileName(filename) << std::string(":") << line <<
78 std::string("] ") << function << std::string("(): ") << message;
83 OldStyleLogProvider::OldStyleLogProvider(bool showDebug,
88 m_showDebug(showDebug),
90 m_showWarning(showWarning),
91 m_showError(showError),
92 m_showPedantic(showPedantic),
96 OldStyleLogProvider::OldStyleLogProvider(bool showDebug,
102 m_showDebug(showDebug),
103 m_showInfo(showInfo),
104 m_showWarning(showWarning),
105 m_showError(showError),
106 m_showPedantic(showPedantic),
107 m_printStdErr(printStdErr)
110 void OldStyleLogProvider::Debug(const char *message,
111 const char *filename,
113 const char *function)
117 fprintf(stderr, "%s%s%s\n", DEBUG_BEGIN,
118 FormatMessage(message, filename, line,
119 function).c_str(), DEBUG_END);
121 fprintf(stdout, "%s%s%s\n", DEBUG_BEGIN,
122 FormatMessage(message, filename, line,
123 function).c_str(), DEBUG_END);
128 void OldStyleLogProvider::Info(const char *message,
129 const char *filename,
131 const char *function)
135 fprintf(stderr, "%s%s%s\n", INFO_BEGIN,
136 FormatMessage(message, filename, line,
137 function).c_str(), INFO_END);
139 fprintf(stdout, "%s%s%s\n", INFO_BEGIN,
140 FormatMessage(message, filename, line,
141 function).c_str(), INFO_END);
146 void OldStyleLogProvider::Warning(const char *message,
147 const char *filename,
149 const char *function)
153 fprintf(stderr, "%s%s%s\n", WARNING_BEGIN,
154 FormatMessage(message, filename, line,
155 function).c_str(), WARNING_END);
157 fprintf(stdout, "%s%s%s\n", WARNING_BEGIN,
158 FormatMessage(message, filename, line,
159 function).c_str(), WARNING_END);
164 void OldStyleLogProvider::Error(const char *message,
165 const char *filename,
167 const char *function)
171 fprintf(stderr, "%s%s%s\n", ERROR_BEGIN,
172 FormatMessage(message, filename, line,
173 function).c_str(), ERROR_END);
175 fprintf(stdout, "%s%s%s\n", ERROR_BEGIN,
176 FormatMessage(message, filename, line,
177 function).c_str(), ERROR_END);
182 void OldStyleLogProvider::Pedantic(const char *message,
183 const char *filename,
185 const char *function)
187 if (m_showPedantic) {
189 fprintf(stderr, "%s%s%s\n", PEDANTIC_BEGIN,
190 FormatMessage(message, filename, line,
191 function).c_str(), PEDANTIC_END);
193 fprintf(stdout, "%s%s%s\n", PEDANTIC_BEGIN,
194 FormatMessage(message, filename, line,
195 function).c_str(), PEDANTIC_END);