Tizen 2.0 Release
[framework/web/wrt-commons.git] / modules / core / src / exception.cpp
1 /*
2  * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
3  *
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
7  *
8  *        http://www.apache.org/licenses/LICENSE-2.0
9  *
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.
15  */
16 /*
17  * @file        exception.cpp
18  * @author      Przemyslaw Dobrowolski (p.dobrowolsk@samsung.com)
19  * @version     1.0
20  * @brief       This file is the implementation of exception system
21  */
22 #include <stddef.h>
23 #include <dpl/exception.h>
24 #include <dpl/log/log.h>
25 #include <cstdio>
26
27 namespace DPL
28 {
29 Exception* Exception::m_lastException = NULL;
30 unsigned int Exception::m_exceptionCount = 0;
31 void (*Exception::m_terminateHandler)() = NULL;
32
33 void LogUnhandledException(const std::string &str)
34 {
35     // Logging to console
36     printf("%s\n", str.c_str());
37
38     // Logging to dlog
39     LogPedantic(str);
40 }
41
42 void LogUnhandledException(const std::string &str, const char *filename, int line, const char *function)
43 {
44     // Logging to console
45     std::ostringstream msg;
46     msg << "\033[1;5;31m\n=== [" << filename << ":" << line << "] " << function << " ===\033[m";
47     msg << str;
48     printf("%s\n", msg.str().c_str());
49
50     // Logging to dlog
51     DPL::Log::LogSystemSingleton::Instance().Error(str.c_str(), filename, line, function);
52 }
53 } // namespace DPL