ttrace.h 1.5 KB
Newer Older
dengyihao's avatar
dengyihao 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
/*
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
 *
 * This program is free software: you can use, redistribute, and/or modify
 * it under the terms of the GNU Affero General Public License, version 3
 * or later ("AGPL"), as published by the Free Software Foundation.
 *
 * This program 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.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
 */
#ifndef _TD_TRACE_H_
#define _TD_TRACE_H_

#include <stdlib.h>

#ifdef __cplusplus
extern "C" {
#endif

dengyihao's avatar
dengyihao 已提交
24
#pragma(push, 1)
dengyihao's avatar
dengyihao 已提交
25 26

typedef struct STraceId {
dengyihao's avatar
dengyihao 已提交
27 28 29
  int64_t rootId;
  int64_t msgId;
} STraceId;
dengyihao's avatar
dengyihao 已提交
30

dengyihao's avatar
dengyihao 已提交
31
#pragma(pop)
dengyihao's avatar
dengyihao 已提交
32

dengyihao's avatar
dengyihao 已提交
33 34 35 36
#define TRACE_SET_ROOTID(traceId, root) \
  do {                                  \
    (traceId)->rootId = root;           \
  } while (0);
dengyihao's avatar
dengyihao 已提交
37

dengyihao's avatar
dengyihao 已提交
38
#define TRACE_GET_ROOTID(traceId) (traceId)->rootId
dengyihao's avatar
dengyihao 已提交
39

dengyihao's avatar
dengyihao 已提交
40 41 42 43 44 45 46
#define TRACE_SET_MSGID(traceId, mId) \
  do {                                \
    (traceId)->msgId = mId;           \
  } while (0)

#define TRACE_GET_MSGID(traceId) (traceId)->msgId

dengyihao's avatar
dengyihao 已提交
47 48 49
#define TRACE_TO_STR(traceId, buf)                                                \
  do {                                                                            \
    sprintf(buf, "0x%" PRIx64 ":0x%" PRIx64 "", traceId->rootId, traceId->msgId); \
dengyihao's avatar
dengyihao 已提交
50
  } while (0)
dengyihao's avatar
dengyihao 已提交
51 52 53 54 55 56

#ifdef __cplusplus
}
#endif

#endif