1 /* 2 * CDDL HEADER START 3 * 4 * The contents of this file are subject to the terms of the 5 * Common Development and Distribution License (the "License"). 6 * You may not use this file except in compliance with the License. 7 * 8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9 * or http://www.opensolaris.org/os/licensing. 10 * See the License for the specific language governing permissions 11 * and limitations under the License. 12 * 13 * When distributing Covered Code, include this CDDL HEADER in each 14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15 * If applicable, add the following below this CDDL HEADER, with the 16 * fields enclosed by brackets "[]" replaced with your own identifying 17 * information: Portions Copyright [yyyy] [name of copyright owner] 18 * 19 * CDDL HEADER END 20 */ 21 /* 22 * Copyright 2008 Sun Microsystems, Inc. All rights reserved. 23 * Use is subject to license terms. 24 * 25 * Copyright 2020 Joyent, Inc. 26 */ 27 28 #ifndef _MDB_IO_H 29 #define _MDB_IO_H 30 31 #ifdef __cplusplus 32 extern "C" { 33 #endif 34 35 #ifdef _MDB 36 37 #include <sys/types.h> 38 #include <setjmp.h> 39 #include <stdarg.h> 40 #include <stdio.h> 41 42 typedef struct mdb_iob mdb_iob_t; /* I/O buffer */ 43 typedef struct mdb_io mdb_io_t; /* I/O implementation */ 44 struct mdb_arg; /* Argument structure */ 45 46 #define MDB_IOB_DEFTAB 8 /* Default tabstop */ 47 #define MDB_IOB_DEFMARGIN 16 /* Default margin width */ 48 #define MDB_IOB_DEFROWS 24 /* Default rows */ 49 #define MDB_IOB_DEFCOLS 80 /* Default columns */ 50 51 #define MDB_IOB_RDONLY 0x0001 /* Buffer is for reading */ 52 #define MDB_IOB_WRONLY 0x0002 /* Buffer is for writing */ 53 #define MDB_IOB_EOF 0x0004 /* Read buffer has reached EOF */ 54 #define MDB_IOB_ERR 0x0008 /* Underlying i/o error occurred */ 55 #define MDB_IOB_INDENT 0x0010 /* Lines are auto-indented */ 56 #define MDB_IOB_PGENABLE 0x0020 /* Pager enabled */ 57 #define MDB_IOB_PGSINGLE 0x0040 /* Line-at-a-time pager active */ 58 #define MDB_IOB_PGCONT 0x0080 /* Continue paging until next reset */ 59 #define MDB_IOB_AUTOWRAP 0x0100 /* Auto-wrap if next chunk won't fit */ 60 #define MDB_IOB_TTYLIKE 0x0200 /* Input is interactive like a tty */ 61 62 typedef struct mdb_iob_stack { 63 mdb_iob_t *stk_top; /* Topmost stack element */ 64 size_t stk_size; /* Number of stack elements */ 65 } mdb_iob_stack_t; 66 67 typedef struct mdb_iob_ctx { 68 jmp_buf ctx_rpcb; /* Read-side context label */ 69 jmp_buf ctx_wpcb; /* Write-side context label */ 70 void *ctx_rptr; /* Read-side client data */ 71 void *ctx_wptr; /* Write-side client data */ 72 void *ctx_data; /* Pointer to client data */ 73 mdb_iob_t *ctx_iob; /* Storage for iob save/restore */ 74 } mdb_iob_ctx_t; 75 76 #define MDB_IOB_RDIOB 0 /* Index for pipe's read-side iob */ 77 #define MDB_IOB_WRIOB 1 /* Index for pipe's write-side iob */ 78 79 typedef void mdb_iobsvc_f(mdb_iob_t *, mdb_iob_t *, mdb_iob_ctx_t *); 80 81 #define MDBIOC (('m' << 24) | ('d' << 16) | ('b' << 8)) 82 83 #define MDB_IOC_CTTY (MDBIOC | 0x01) /* Clear child tty settings */ 84 #define MDB_IOC_TSET (MDBIOC | 0x02) /* Set terminal type */ 85 #define MDB_IOC_GETFD (MDBIOC | 0x04) /* Get file descriptor (if any) */ 86 87 88 typedef void mdb_table_print_f(void *); 89 90 #define MDB_TBL_DONE 0 91 #define MDB_TBL_PRNT 1 92 #define MDB_TBL_FUNC 2 93 94 extern mdb_io_t *mdb_io_hold(mdb_io_t *); 95 extern void mdb_io_rele(mdb_io_t *); 96 extern void mdb_io_destroy(mdb_io_t *); 97 98 extern mdb_iob_t *mdb_iob_create(mdb_io_t *, uint_t); 99 extern void mdb_iob_pipe(mdb_iob_t **, mdb_iobsvc_f *, mdb_iobsvc_f *); 100 extern void mdb_iob_destroy(mdb_iob_t *); 101 102 extern void mdb_iob_flush(mdb_iob_t *); 103 extern void mdb_iob_nlflush(mdb_iob_t *); 104 extern void mdb_iob_discard(mdb_iob_t *); 105 106 extern void mdb_iob_push_io(mdb_iob_t *, mdb_io_t *); 107 extern mdb_io_t *mdb_iob_pop_io(mdb_iob_t *); 108 109 extern void mdb_iob_resize(mdb_iob_t *, size_t, size_t); 110 extern void mdb_iob_setpager(mdb_iob_t *, mdb_io_t *); 111 extern void mdb_iob_clearlines(mdb_iob_t *); 112 extern void mdb_iob_tabstop(mdb_iob_t *, size_t); 113 extern void mdb_iob_margin(mdb_iob_t *, size_t); 114 extern void mdb_iob_setbuf(mdb_iob_t *, void *, size_t); 115 116 extern void mdb_iob_setflags(mdb_iob_t *, uint_t); 117 extern void mdb_iob_clrflags(mdb_iob_t *, uint_t); 118 extern uint_t mdb_iob_getflags(mdb_iob_t *); 119 120 extern void mdb_iob_vprintf(mdb_iob_t *, const char *, va_list); 121 extern void mdb_iob_aprintf(mdb_iob_t *, const char *, const struct mdb_arg *); 122 extern void mdb_iob_printf(mdb_iob_t *, const char *, ...); 123 124 extern size_t mdb_iob_vsnprintf(char *, size_t, const char *, va_list); 125 extern size_t mdb_iob_asnprintf(char *, size_t, const char *, 126 const struct mdb_arg *); 127 extern size_t mdb_iob_snprintf(char *, size_t, const char *, ...); 128 129 extern void mdb_iob_nputs(mdb_iob_t *, const char *, size_t); 130 extern void mdb_iob_puts(mdb_iob_t *, const char *); 131 extern void mdb_iob_putc(mdb_iob_t *, int); 132 133 extern void mdb_iob_fill(mdb_iob_t *, int, size_t); 134 extern void mdb_iob_ws(mdb_iob_t *, size_t); 135 extern void mdb_iob_tab(mdb_iob_t *); 136 extern void mdb_iob_nl(mdb_iob_t *); 137 138 extern ssize_t mdb_iob_ngets(mdb_iob_t *, char *, size_t); 139 extern int mdb_iob_getc(mdb_iob_t *); 140 extern int mdb_iob_ungetc(mdb_iob_t *, int); 141 extern int mdb_iob_eof(mdb_iob_t *); 142 extern int mdb_iob_err(mdb_iob_t *); 143 144 extern ssize_t mdb_iob_read(mdb_iob_t *, void *, size_t); 145 extern ssize_t mdb_iob_write(mdb_iob_t *, const void *, size_t); 146 extern int mdb_iob_ctl(mdb_iob_t *, int, void *); 147 extern const char *mdb_iob_name(mdb_iob_t *); 148 extern size_t mdb_iob_lineno(mdb_iob_t *); 149 extern size_t mdb_iob_gettabstop(mdb_iob_t *); 150 extern size_t mdb_iob_getmargin(mdb_iob_t *); 151 152 extern void mdb_iob_set_autowrap(mdb_iob_t *); 153 154 extern void mdb_iob_stack_create(mdb_iob_stack_t *); 155 extern void mdb_iob_stack_destroy(mdb_iob_stack_t *); 156 extern void mdb_iob_stack_push(mdb_iob_stack_t *, mdb_iob_t *, size_t); 157 extern mdb_iob_t *mdb_iob_stack_pop(mdb_iob_stack_t *); 158 extern size_t mdb_iob_stack_size(mdb_iob_stack_t *); 159 160 extern const char *mdb_iob_format2str(const char *); 161 162 /* 163 * Available i/o backend constructors for common MDB code. These are 164 * implemented in the corresponding .c files. 165 */ 166 extern mdb_io_t *mdb_logio_create(mdb_io_t *); 167 extern mdb_io_t *mdb_fdio_create_path(const char **, const char *, int, mode_t); 168 extern mdb_io_t *mdb_fdio_create_named(int fd, const char *); 169 extern mdb_io_t *mdb_fdio_create(int); 170 extern mdb_io_t *mdb_strio_create(const char *); 171 extern mdb_io_t *mdb_termio_create(const char *, mdb_io_t *, mdb_io_t *); 172 extern mdb_io_t *mdb_pipeio_create(mdb_iobsvc_f *, mdb_iobsvc_f *); 173 extern mdb_io_t *mdb_nullio_create(void); 174 extern mdb_io_t *mdb_memio_create(char *, size_t); 175 176 /* 177 * Functions for testing whether the given iob is of a given backend type: 178 */ 179 extern int mdb_iob_isastr(mdb_iob_t *); 180 extern int mdb_iob_isatty(mdb_iob_t *); 181 extern int mdb_iob_isapipe(mdb_iob_t *); 182 183 extern void mdb_table_print(uint_t, const char *, ...); 184 185 extern int mdb_setupterm(const char *, mdb_io_t *, int *); 186 187 extern int mdb_fdio_fileno(mdb_io_t *); 188 189 #endif /* _MDB */ 190 191 #ifdef __cplusplus 192 } 193 #endif 194 195 #endif /* _MDB_IO_H */