summaryrefslogtreecommitdiff
path: root/include/sat-ui-debug.h
blob: 4b77d32ec41ee1a108ff4cd754284ed6fb2a3c1e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
/*
 * Copyright (c) 2012-2013 Samsung Electronics Co., Ltd.
 *
 * Licensed under the Flora License, Version 1.1 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://floralicense.org/license/
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#ifndef __SATUI_DEBUG_H__
#define __SATUI_DEBUG_H__

/*
 * SYSLOG_INFO(), SYSLOG_ERR(), SYSLOG_DBG() are syslog() wrappers.
 * PRT_INFO(), PRT_ERR(), PRT_DBG() are fprintf() wrappers.
 *
 * If SLP_DEBUG is not defined, SYSLOG_DBG() and PRT_DBG() is ignored.
 *
 * IF SLP_SYSLOG_OUT or SLP_DAEMON is defined,
 *   INFO(), ERR(), DBG() are SYSLOG_XXX()
 * Otherwise,
 *   They are PRT_XXX()
 *
 *
 * warn_if(exrp, fmt, ...)
 *   If expr is true, The fmt string is printed using ERR().
 *
 * ret_if(), retv_if(), retm_if(), retvm_if()
 *   If expr is true, current function return.
 *   Postfix 'v' means that it has a return value and 'm' means that it has output message.
 *
 */

#define SAT_UI_LOG_TAG "SAT_UI"
#include <dlog.h>
#include <stdio.h>

#if 0
#define DBG(fmt, arg...) \
	do { \
		LOGD(""fmt"\n", ##arg); \
	} while(0)
#endif


#define DBG(fmt, arg...) \
	do { \
		LOG(LOG_INFO, SAT_UI_LOG_TAG, "[SAT_UI][%s:%d] "fmt"\n",  __func__, __LINE__, ##arg); \
	} while(0)
/*
#define DBG(fmt, arg...) \
	do { \
		FILE *fp; \
		fp = fopen("/opt/media/sat_log.txt","a"); \
		fprintf(fp,"[SAT-UI][%s:%d]"fmt"\n",__func__,__LINE__, ##arg); \
		fclose(fp); \
	} while(0)
*/

#define ERR(fmt, arg...) \
	do { \
		LOGE(""fmt"\n", ##arg); \
	} while(0)

#  define warn_if(expr, fmt, arg...) do { \
		if(expr) { \
			DBG("(%s) -> "fmt, #expr, ##arg); \
		} \
	} while (0)
#  define ret_if(expr) do { \
		if(expr) { \
			DBG("(%s) -> %s() return", #expr, __FUNCTION__); \
			return; \
		} \
	} while (0)
#  define retv_if(expr, val) do { \
		if(expr) { \
			DBG("(%s) -> %s() return", #expr, __FUNCTION__); \
			return (val); \
		} \
	} while (0)
#  define retm_if(expr, fmt, arg...) do { \
		if(expr) { \
			ERR(fmt, ##arg); \
			DBG("(%s) -> %s() return", #expr, __FUNCTION__); \
			return; \
		} \
	} while (0)
#  define retvm_if(expr, val, fmt, arg...) do { \
		if(expr) { \
			ERR(fmt, ##arg); \
			DBG("(%s) -> %s() return", #expr, __FUNCTION__); \
			return (val); \
		} \
	} while (0)

#endif /* __SATUI_DEBUG_H__ */