summaryrefslogtreecommitdiffstats
path: root/storage/maria/libmarias3/src/debug.h
blob: 7e4f1d2c4362cb0aa5f21d47c9b69d991f2df195 (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
/* 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)