DSMCC Version 1.0
DTVKit DSMCC Documentation
 All Data Structures Files Functions Typedefs
sfm_debug.h
Go to the documentation of this file.
1 /*******************************************************************************
2  * Copyright © 2014 The DTVKit Open Software Foundation Ltd (www.dtvkit.org)
3  * Copyright © 2004 Ocean Blue Software Ltd
4  *
5  * This file is part of a DTVKit Software Component
6  * You are permitted to copy, modify or distribute this file subject to the terms
7  * of the DTVKit 1.0 Licence which can be found in licence.txt or at www.dtvkit.org
8  *
9  * THIS CODE AND INFORMATION ARE PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND,
10  * EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES
11  * OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR PURPOSE.
12  *
13  * If you or your organisation is not a member of DTVKit then you have access
14  * to this source code outside of the terms of the licence agreement
15  * and you are expected to delete this and any associated files immediately.
16  * Further information on DTVKit, membership and terms can be found at www.dtvkit.org
17  *******************************************************************************/
24 #ifndef _SFM_DEBUG_H
25 #define _SFM_DEBUG_H
26 
27 #ifndef NDEBUG
28 
29  #include <stdio.h>
30  #include <assert.h>
31  #define ASSERT(condition) assert(condition);
32 
33  #define ERRLOG(x, ...) if ( sfm->setup.errPrintf ) \
34  sfm->setup.errPrintf( "%s:%d " x "\n", __FUNCTION__, __LINE__, ##__VA_ARGS__);
35 
36  #define DBGLOG(t,x, ...) if ( sfm->setup.dbgPrintf && (sfm->setup.dbgState & t) ) \
37  sfm->setup.dbgPrintf( "%s:%d " x "\n", __FUNCTION__, __LINE__, ##__VA_ARGS__);
38 
39 #else
40 
41  #define ASSERT(condition)
42 
43  #define ERRLOG(x, ...)
44  #define DBGLOG(t,x, ...)
45 
46 #endif
47 
48 #ifdef DEBUG_FUNCS
49  #define FUNCTION_START(x) DBGLOG(DF_FUNC," start")
50  #define FUNCTION_FINISH(x) DBGLOG(DF_FUNC," finish")
51 #else
52  #define FUNCTION_START(x)
53  #define FUNCTION_FINISH(x)
54 #endif
55 
56 #endif /*SFM_DEBUG_H*/