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
|
/* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
* Copyright 2019 MariaDB Corporation Ab. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-1301 USA
*/
#pragma once
#include "config.h"
#include <stdbool.h>
void ms3debug_set(bool enabled);
bool ms3debug_get(void);
#define ms3debug(MSG, ...) do { \
if (ms3debug_get()) \
{ \
fprintf(stderr, "[libmarias3] %s:%d " MSG "\n", __FILE__, __LINE__, ##__VA_ARGS__); \
} \
} while(0)
#define ms3debug_hex(DATA, LEN) do { \
size_t hex_it; \
fprintf(stderr, "[libmarias3] %s:%d packet hex: ", __FILE__, __LINE__); \
for (hex_it = 0; hex_it < LEN ; hex_it++) \
{ \
fprintf(stderr, "%02X ", (unsigned char)DATA[hex_it]); \
} \
fprintf(stderr, "\n"); \
fprintf(stderr, "[libmarias3] %s:%d printable packet data: ", __FILE__, __LINE__); \
for (hex_it = 0; hex_it < LEN ; hex_it++) \
{ \
if (((unsigned char)DATA[hex_it] < 0x32) or (((unsigned char)DATA[hex_it] > 0x7e))) \
{ \
fprintf(stderr, "."); \
} \
else \
{ \
fprintf(stderr, "%c", (unsigned char)DATA[hex_it]); \
} \
} \
fprintf(stderr, "\n"); \
} while(0)
|