summaryrefslogtreecommitdiff
path: root/src/xine-engine/monitor.h
blob: 316e855d7a25dd054ff511231ddc80f4a32118b2 (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
105
106
107
108
109
110
111
112
113
114
/* 
 * Copyright (C) 2000-2001 the xine project
 * 
 * This file is part of xine, a unix video player.
 * 
 * xine is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 * 
 * xine is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 * 
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA
 *
 * $Id: monitor.h,v 1.4 2001/09/06 18:38:12 jkeil Exp $
 *
 * debug print and profiling functions
 *
 */
 
#ifndef HAVE_MONITOR_H
#define HAVE_MONITOR_H

#ifdef __cplusplus
extern "C" {
#endif

#include <inttypes.h>

extern uint32_t xine_debug;

#define VERBOSE        (xine_debug & 0x8000>>1)   // 16384
#define METRONOM       (xine_debug & 0x8000>>2)   //  8192
#define AUDIO          (xine_debug & 0x8000>>3)   //  4096
#define DEMUX          (xine_debug & 0x8000>>4)   //  2048
#define INPUT          (xine_debug & 0x8000>>5)   //  1024
#define VIDEO          (xine_debug & 0x8000>>6)   //   512
#define VPTS           (xine_debug & 0x8000>>7)   //   256
#define MPEG           (xine_debug & 0x8000>>8)   //   128
#define VAVI           (xine_debug & 0x8000>>9)   //    64
#define AC3            (xine_debug & 0x8000>>10)  //    32
#define LOOP           (xine_debug & 0x8000>>11)  //    16
#define GUI            (xine_debug & 0x8000>>12)  //     8

#ifdef	__GNUC__
#define perr(FMT,ARGS...) {fprintf(stderr, FMT, ##ARGS);fflush(stderr);}
#else	/* C99 version: */
#define perr(...)	  {fprintf(stderr, __VA_ARGS__);fflush(stderr);}
#endif

#ifdef DEBUG

/*
 * Debug stuff
 */

//#define perr(FMT,ARGS...) {fprintf(stderr, FMT, ##ARGS);fflush(stderr);}

#ifdef	__GNUC__
#define xprintf(LVL, FMT, ARGS...) {                                          \
                                     if(LVL) {                                \
                                       printf(FMT, ##ARGS);          	      \
                                     }                                        \
                                   }
#else	/* C99 version: */
#define xprintf(LVL, ...) {						      \
                                     if(LVL) {                                \
                                       printf(__VA_ARGS__);       	      \
                                     }                                        \
                                   }
#endif

/*
 * profiling
 */

void profiler_init ();

void profiler_set_label (int id, char *label);

void profiler_start_count (int id);

void profiler_stop_count (int id);

void profiler_print_results ();

#else /* no DEBUG, release version */

//#define perr(FMT,ARGS...) 

#ifdef	__GNUC__
#define xprintf(LVL, FMT, ARGS...) 
#else	/* C99 version: */
#define xprintf(LVL, ...) 
#endif

#define profiler_init()
#define profiler_set_label(id, label)
#define profiler_start_count(id)
#define profiler_stop_count(id)
#define profiler_print_results()

#endif /* DEBUG*/

#ifdef __cplusplus
}
#endif

#endif /* HAVE_MONITOR_H */