RTI Connext DDS Micro  Version 2.4.6
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
osapi_log_impl.h
Go to the documentation of this file.
1 /*
2  * FILE: osapi_log_impl.h - Implementation of Log functions
3  *
4  * Copyright 2008-2015 Real-Time Innovations, Inc.
5  *
6  * No duplications, whole or partial, manual or electronic, may be made
7  * without express written permission. Any such copies, or
8  * revisions thereof, must display this notice unaltered.
9  * This code contains trade secrets of Real-Time Innovations, Inc.
10  *
11  * Modification History
12  * --------------------
13  * 07mar2013,tk Updated
14  * 22sep2011,tk Updated
15  * 23sep2008,yy Created
16  */
17 /*ce
18  * \file
19  * \brief Implementation of log functionality
20  */
21 #include "osapi/osapi_config.h"
22 
23 #ifndef osapi_log_impl_h
24 #define osapi_log_impl_h
25 
26 #define OSAPI_TRACEKIND_NONE 0x00
27 #define OSAPI_TRACEKIND_NET 0x01
28 #define OSAPI_TRACEKIND_DDS 0x02
29 #define OSAPI_TRACEKIND_THREAD 0x04
30 
31 #define NETIO_FORMAT(s_) "NETIO ...: " s_
32 #define DDSC_FORMAT(s_) "DDS .....: " s_
33 #define THREAD_FORMAT(s_) "THREAD ..: " s_
34 
35 #if !OSAPI_ENABLE_TRACE
36 
37 #define OSAPI_TRACE(title_,final_)
38 #define OSAPI_TRACE_DDS(title_,final_)
39 #define OSAPI_TRACE_NET(title_,final_)
40 #define OSAPI_TRACE_THREAD(title_,final_)
41 #define OSAPI_TRACE_INT32(name_,value_,final_)
42 #define OSAPI_TRACE_STRING(name_,value_,final_)
43 #define OSAPI_TRACE_GUID(name_,value_,final_)
44 #define OSAPI_TRACE_PTR(name_,value_,final_)
45 #define OSAPI_TRACE_A4_AS_INT32(name_,value_,final_)
46 #define OSAPI_TRACE_A12_AS_INT32(name_,value_,final_)
47 
48 #define OSAPI_TRACE_ONLY_VARIABLE(x_) (void)(x_)
49 
50 #else
51 
52 #define OSAPI_TRACE_ONLY_VARIABLE(x_)
53 
54 #define OSAPI_TRACE(title_,final_) \
55  OSAPI_gv_TraceFunction(OSAPI_TRACE_KIND(OSAPI_TRACEKIND_NONE),\
56  OSAPI_TRACETYPE_HEADER,title_,0,NULL,NULL,final_);
57 
58 #define OSAPI_TRACE_KIND(c_) OSAPI_gv_TraceMask,OSAPI_gv_TraceFunctionParam,\
59  (c_),RTI_MODULE_NAME,__FILE__,__FUNCTION__,__LINE__
60 
61 #define OSAPI_TRACE_DDS(title_,final_) \
62  OSAPI_gv_TraceFunction(OSAPI_TRACE_KIND(OSAPI_TRACEKIND_DDS),\
63  OSAPI_TRACETYPE_HEADER,DDSC_FORMAT(title_),0,NULL,NULL,final_);
64 
65 #define OSAPI_TRACE_NET(title_,final_) \
66  OSAPI_gv_TraceFunction(OSAPI_TRACE_KIND(OSAPI_TRACEKIND_NET),\
67  OSAPI_TRACETYPE_HEADER,NETIO_FORMAT(title_),0,NULL,NULL,final_);
68 
69 #define OSAPI_TRACE_THREAD(title_,final_) \
70  OSAPI_gv_TraceFunction(OSAPI_TRACE_KIND(OSAPI_TRACEKIND_THREAD),\
71  OSAPI_TRACETYPE_HEADER,THREAD_FORMAT(title_),0,NULL,NULL,final_);
72 
73 #define OSAPI_TRACE_INT32(name_,value_,final_) \
74  OSAPI_gv_TraceFunction(OSAPI_TRACE_KIND(OSAPI_TRACEKIND_NONE),\
75  OSAPI_TRACETYPE_INT32,name_,value_,NULL,NULL,final_);
76 
77 #define OSAPI_TRACE_STRING(name_,value_,final_) \
78  OSAPI_gv_TraceFunction(OSAPI_TRACE_KIND(OSAPI_TRACEKIND_NONE),\
79  OSAPI_TRACETYPE_STRING,name_,0,NULL,value_,final_);
80 
81 #define OSAPI_TRACE_GUID(name_,value_,final_) \
82  OSAPI_gv_TraceFunction(OSAPI_TRACE_KIND(OSAPI_TRACEKIND_NONE),\
83  OSAPI_TRACETYPE_GUID,name_,0,value_,NULL,final_);
84 
85 #define OSAPI_TRACE_PTR(name_,value_,final_) \
86  OSAPI_gv_TraceFunction(OSAPI_TRACE_KIND(OSAPI_TRACEKIND_NONE),\
87  OSAPI_TRACETYPE_PTR,name_,0,value_,NULL,final_);
88 
89 #define OSAPI_TRACE_A4_AS_INT32(name_,value_,final_) \
90  OSAPI_gv_TraceFunction(OSAPI_TRACE_KIND(OSAPI_TRACEKIND_NONE),\
91  OSAPI_TRACETYPE_V4_AS_INT32 ,name_,0,value_,NULL,final_);
92 
93 #define OSAPI_TRACE_A12_AS_INT32(name_,value_,final_) \
94  OSAPI_gv_TraceFunction(OSAPI_TRACE_KIND(OSAPI_TRACEKIND_NONE),\
95  OSAPI_TRACETYPE_V12_AS_INT32,name_,0,value_,NULL,final_);
96 
97 #endif
98 
99 #define OSAPI_PRECONDITION_PARAM OSAPI_LOGKIND_PRECONDITION,0,\
100  OSAPI_LOG_MSG_PN_X2_STD_PARAM
101 
102 /*\ci
103  * \brief Add a pre-condition check independent of whether debug or release
104  * libraries are built.
105  *
106  * \sa OSAPI_LOG_PRECONDITION
107  */
108 #if OSAPI_ENABLE_LOG
109 #define OSAPI_PRECONDITION_ALWAYS(cond_,action_,args_) \
110 if ((cond_)) \
111 {\
112  OSAPI_Log_entry_create(OSAPI_PRECONDITION_PARAM,RTI_FALSE);\
113  args_;\
114  action_;\
115 }
116 #else
117 #define OSAPI_PRECONDITION_ALWAYS(cond_,action_,args_) \
118 if ((cond_)) \
119 {\
120  action_;\
121 }
122 #endif
123 
124 #if OSAPI_ENABLE_PRECONDITION
125 
126 /*ci
127  * \brief Precondition test macro
128  *
129  * \details
130  *
131  * This macro is used to perform pre-condition checks, typically on
132  * function arguments. The macro automatically adds a log-entry and
133  * the user _must_ add at least one pre-condition argument, the one that
134  * filed, or more. The last argument added must have the is_final flag
135  * set to RTI_TRUE.
136  *
137  * Example:
138  *
139  * Consider the function:
140  *
141  * RTI_BOOL
142  * A_Function(void *pointer)
143  * {
144  * OSAPI_LOG_PRECONDITION(pointer != NULL, return RTI_FALSE,
145  * OSAPI_Log_entry_add_pointer("pointer",pointer,RTI_TRUE);)
146  *
147  * .....
148  * }
149  *
150  * This function tests whether the input pointer is NULL or not, and it its
151  * NULL adds the name and value of the pointer to the log-entry.
152  *
153  * RTI_BOOL
154  * Another_Function(void *pointer,RTI_INT32 length)
155  * {
156  * OSAPI_LOG_PRECONDITION(pointer != NULL || length > 100, return RTI_FALSE,
157  * OSAPI_Log_entry_add_pointer("pointer",pointer,RTI_FALSE);
158  * OSAPI_Log_entry_add_int("length",length,RTI_TRUE);)
159  *
160  * .....
161  * }
162  *
163  * This function tests whether the input pointer is NULL or not and that the
164  * length <= 100, otherwise both the arguments are added to the log-buffer.
165  * Note that the last entry as is_final set to RTI_TRUE to indicate to no
166  * more entries should be added to that current log-entries.
167  *
168  *
169  * \sa OSAPI_Log_entry_add_int
170  * \sa OSAPI_Log_entry_add_string
171  * \sa OSAPI_Log_entry_add_pointer
172  *
173  */
174 #if OSAPI_ENABLE_LOG
175 #define OSAPI_PRECONDITION(cond_,action_,args_) \
176 if ((cond_)) \
177 {\
178  OSAPI_Log_entry_create(OSAPI_PRECONDITION_PARAM,RTI_FALSE);\
179  args_;\
180  action_;\
181 }
182 #else
183 #define OSAPI_PRECONDITION(cond_,action_,args_) \
184 if ((cond_)) \
185 {\
186  action_;\
187 }
188 #endif
189 
190 #else
191 
192 #define OSAPI_PRECONDITION(cond_,action_,args_)
193 
194 #endif
195 
196 #endif /* osapi_log_impl_h */

RTI Connext DDS Micro Version 2.4.6 Copyright © Mon Jan 25 2016 Real-Time Innovations, Inc