Motr  M0
debug.h
Go to the documentation of this file.
1 /* -*- C -*- */
2 /*
3  * Copyright (c) 2013-2020 Seagate Technology LLC and/or its Affiliates
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  * For any questions about this software or licensing,
18  * please email opensource@seagate.com or cortx-questions@seagate.com.
19  *
20  */
21 
22 
23 #include "lib/trace.h" /* M0_LOG */
24 
50 #ifndef NET_TEST_MODULE_NAME
51 M0_BASSERT("NET_TEST_MODULE_NAME should be defined "
52  "before including debug.h" == NULL);
53 #endif
54 
55 #ifndef LOGD_VAR_NAME
56 #define LOGD_VAR_NAME(module_name) \
57  M0_CAT(m0_net_test_logd_, module_name)
58 #endif
59 
65 
66 #ifndef LOGD_VAR_DECLARE
67 #define LOGD_VAR_DECLARE(module_name) \
68  extern bool LOGD_VAR_NAME(module_name);
69 #endif
70 
71 #undef LOGD
72 #define LOGD(...) \
73  do { \
74  if (LOGD_VAR_NAME(NET_TEST_MODULE_NAME)) \
75  M0_LOG(M0_DEBUG, __VA_ARGS__); \
76  } while (0)
77 
78 
83 /*
84  * Local variables:
85  * c-indentation-style: "K&R"
86  * c-basic-offset: 8
87  * tab-width: 8
88  * fill-column: 79
89  * scroll-step: 1
90  * End:
91  */
#define LOGD_VAR_NAME(module_name)
Definition: debug.h:56
#define NULL
Definition: misc.h:38
#define NET_TEST_MODULE_NAME
Definition: commands.c:34
M0_BASSERT("NET_TEST_MODULE_NAME should be defined " "before including debug.h"==NULL)