]> git.proxmox.com Git - libgit2.git/blame - src/trace.h
New upstream version 1.4.3+dfsg.1
[libgit2.git] / src / trace.h
CommitLineData
b5ec5430
ET
1/*
2 * Copyright (C) the libgit2 contributors. All rights reserved.
3 *
4 * This file is part of libgit2, distributed under the GNU GPL v2 with
5 * a Linking Exception. For full terms see the included COPYING file.
6 */
7#ifndef INCLUDE_trace_h__
8#define INCLUDE_trace_h__
9
eae0bfdc
PP
10#include "common.h"
11
b5ec5430 12#include <git2/trace.h>
e579e0f7 13#include "str.h"
b5ec5430
ET
14
15struct git_trace_data {
16 git_trace_level_t level;
22a2d3d5 17 git_trace_cb callback;
b5ec5430
ET
18};
19
20extern struct git_trace_data git_trace__data;
21
22GIT_INLINE(void) git_trace__write_fmt(
23 git_trace_level_t level,
c25aa7cd
PP
24 const char *fmt,
25 va_list ap)
b5ec5430 26{
22a2d3d5 27 git_trace_cb callback = git_trace__data.callback;
e579e0f7 28 git_str message = GIT_STR_INIT;
1fed6b07 29
e579e0f7 30 git_str_vprintf(&message, fmt, ap);
1fed6b07 31
e579e0f7 32 callback(level, git_str_cstr(&message));
b5ec5430 33
e579e0f7 34 git_str_dispose(&message);
b5ec5430
ET
35}
36
c25aa7cd
PP
37#define git_trace_level() (git_trace__data.level)
38
39GIT_INLINE(void) git_trace(git_trace_level_t level, const char *fmt, ...)
40{
41 if (git_trace__data.level >= level &&
42 git_trace__data.callback != NULL) {
43 va_list ap;
44
45 va_start(ap, fmt);
46 git_trace__write_fmt(level, fmt, ap);
47 va_end(ap);
48 }
49}
b5ec5430 50
b5ec5430 51#endif