tizen 2.3 release
[framework/web/wearable/wrt-security.git] / commons / 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 Exception* Exception::m_lastException = NULL;
29 unsigned int Exception::m_exceptionCount = 0;
30 void (*Exception::m_terminateHandler)() = NULL;
31
32 void LogUnhandledException(const std::string &str)
33 {
34     // Logging to console
35     printf("%s\n", str.c_str());
36
37     // Logging to dlog
38     LogPedantic(str);
39 }
40
41 void LogUnhandledException(const std::string &str,
42                            const char *filename,
43                            int line,
44                            const char *function)
45 {
46     // Logging to console
47     std::ostringstream msg;
48     msg << "\033[1;5;31m\n=== [" << filename << ":" << line << "] " <<
49     function << " ===\033[m";
50     msg << str;
51     printf("%s\n", msg.str().c_str());
52
53     // Logging to dlog
54     DPL::Log::LogSystemSingleton::Instance().Error(
55         str.c_str(), filename, line, function);
56 }
57 } // namespace DPL