File: xtruss.h

package info (click to toggle)
xtruss 0.0~git20241011.27fafffe-1
  • links: PTS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,172 kB
  • sloc: ansic: 17,121; sh: 20; makefile: 2
file content (96 lines) | stat: -rw-r--r-- 3,648 bytes parent folder | download
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
struct set {
    tree234 *strings; /* sorted list of dynamically allocated "char *"s */
    bool include; /* whether the tree is things to include or exclude */
};
bool in_set(struct set *s, const char *string);

struct xtruss_platform;

typedef struct xtruss_state xtruss_state;
struct xtruss_state {
    Conf *conf;
    int sizelimit;
    char *logfile;

    bool proxy_only;
    bool print_server_startup, print_client_ids, raw_hex_dump;
    struct set requests_to_log, events_to_log;

    char **subcommand;
    const char *env_disp, *env_auth;

    bool xrecord, xrselectclient, xrskipatoms, xrexit;
    unsigned xrclientid;

    FILE *outfp;
    bool outfp_needs_closing;
    struct X11Display *x11disp;
    Socket **x11sockets;
    int n_x11sockets;

    unsigned num_clients_seen;
    unsigned newclientid;
    struct request *currreq;
    int exit_status;           /* set to >= 0 when it's time to die */

    struct xtruss_platform *platform;
};

/* Provided by platform-independent xtruss code */
xtruss_state *xtruss_new(void);
void xtruss_cmdline(xtruss_state *xs, int argc, char **argv);
void xtruss_start(xtruss_state *xs);
void xtruss_xrecord_start(xtruss_state *xs);
void xtruss_proxy_start(xtruss_state *xs);

/* Provided by the platform-specific module */
void xtruss_start_subprocess(xtruss_state *xs);

struct xlog;
typedef enum XLogType {
    XLOG_FULL,       /* full X connection including welcome message */
    XLOG_BARE,       /* data from X RECORD, omitting welcome message */
} XLogType;

struct xlog *xlog_new(xtruss_state *xs, XLogType type);
void xlog_free(struct xlog *xl);

void xlog_c2s(struct xlog *xl, const void *vdata, int len);
void xlog_s2c(struct xlog *xl, const void *vdata, int len);

void xlog_set_clientid(struct xlog *xl, unsigned clientid);
unsigned xlog_get_clientid(struct xlog *xl);
void xlog_set_endianness(struct xlog *xl, char endian);
void xlog_set_next_seq(struct xlog *xl, int seq);
void xlog_use_welcome_message(struct xlog *xl, const void *vdata, int len);
void xlog_intern_atom(struct xlog *xl, char *name, unsigned long val);

const char *xlog_translate_error(int errcode);
const char *xlog_translate_event(int eventtype);

/*
 * Macro used in coroutine-structured parts of the code. Expects the
 * coroutine to have a variable 'data' of char-pointer type, and 'len'
 * of integer type, containing the last data block passed to the
 * coroutine. Collects data from those variables, calling crReturnV as
 * necessary to fill them up, and appends it to the output strbuf
 * until that strbuf has at least the desired length.
 *
 * This macro isn't safe against side effects in its parameters: it
 * can't be, because it can't unilaterally allocate more space to
 * store copies of them in any structure preserved across crReturn.
 *
 * Note also that the parameters themselves must be expressions that
 * can survive a crReturn!
 */
#define crReadUpTo(sb, desired_length) do {                             \
        while ((sb)->len < (desired_length)) {                          \
            while (len <= 0)                                            \
                crReturnV;                                              \
            size_t Need = (desired_length) - (sb)->len;                 \
            size_t Got = (Need < len ? Need : len);                     \
            put_data(sb, data, Got);                                    \
            data += Got;                                                \
            len -= Got;                                                 \
        }                                                               \
    } while (0)