2019-02-23 06:25:01 +08:00
|
|
|
#ifndef TR2_DST_H
|
|
|
|
#define TR2_DST_H
|
|
|
|
|
|
|
|
struct strbuf;
|
2019-04-16 04:39:47 +08:00
|
|
|
#include "trace2/tr2_sysenv.h"
|
2019-02-23 06:25:01 +08:00
|
|
|
|
|
|
|
struct tr2_dst {
|
2019-04-16 04:39:47 +08:00
|
|
|
enum tr2_sysenv_variable sysenv_var;
|
2019-02-23 06:25:01 +08:00
|
|
|
int fd;
|
|
|
|
unsigned int initialized : 1;
|
|
|
|
unsigned int need_close : 1;
|
2019-10-05 06:08:21 +08:00
|
|
|
unsigned int too_many_files : 1;
|
2019-02-23 06:25:01 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Disable TRACE2 on the destination. In TRACE2 a destination (DST)
|
|
|
|
* wraps a file descriptor; it is associated with a TARGET which
|
|
|
|
* defines the formatting.
|
|
|
|
*/
|
|
|
|
void tr2_dst_trace_disable(struct tr2_dst *dst);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Return the file descriptor for the DST.
|
|
|
|
* If 0, the dst is closed or disabled.
|
|
|
|
*/
|
|
|
|
int tr2_dst_get_trace_fd(struct tr2_dst *dst);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Return true if the DST is opened for writing.
|
|
|
|
*/
|
|
|
|
int tr2_dst_trace_want(struct tr2_dst *dst);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Write a single line/message to the trace file.
|
|
|
|
*/
|
|
|
|
void tr2_dst_write_line(struct tr2_dst *dst, struct strbuf *buf_line);
|
|
|
|
|
|
|
|
#endif /* TR2_DST_H */
|