X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=sympathy.git;a=blobdiff_plain;f=src%2Fprototypes.h;h=e96cb1bd39c95f46e3ea119bcc6138da7f26ea46;hp=9c5eec4ec59649b3d918af54b7364d08c00c96e1;hb=3e72a1f6fc28777c26e4fb109867bd2a3c7b89b0;hpb=4145f7369d761b32a10309a2623d98e64de7f444 diff --git a/src/prototypes.h b/src/prototypes.h index 9c5eec4..e96cb1b 100644 --- a/src/prototypes.h +++ b/src/prototypes.h @@ -1,6 +1,6 @@ /* ansi.c */ extern int ansi_dispatch(ANSI *a, Context *c); -extern ANSI *ansi_new_from_terminal(TTY *t); +extern ANSI *ansi_new_from_terminal(TTY *t, int utf8); /* crt.c */ extern void crt_erase(CRT *c, CRT_Pos s, CRT_Pos e, int ea, int color); extern void crt_cls(CRT *c); @@ -13,42 +13,50 @@ extern ANSI *ansi_new_html(FILE *f); /* libsympathy.c */ /* render.c */ /* version.c */ +extern char *libsympathy_version(void); /* vt102.c */ +extern int vt102_cmd_length[128]; +extern int vt102_cmd_termination[128]; +extern void vt102_crt_update(Context *c); +extern void vt102_do_resize(Context *c); extern void vt102_log_line(Context *c, int line); extern void vt102_history(Context *c, CRT_Pos t, CRT_Pos b); extern void vt102_clip_cursor(VT102 *v, CRT_Pos tl, CRT_Pos br); extern void vt102_cursor_normalize(VT102 *v); extern void vt102_cursor_carriage_return(VT102 *v); extern void vt102_cursor_advance_line(Context *c); +extern void vt102_cursor_retreat_line(Context *c); extern void vt102_do_pending_wrap(Context *c); extern void vt102_cursor_advance(Context *c); -extern void vt102_cursor_retard(VT102 *v); +extern void vt102_cursor_retreat(VT102 *v); extern void vt102_reset_tabs(VT102 *v); extern void vt102_cursor_advance_tab(VT102 *v); -extern void vt102_cursor_retard_tab(VT102 *v); +extern void vt102_cursor_retreat_tab(VT102 *v); extern int vt102_cursor_home(VT102 *v); extern int vt102_cursor_absolute(VT102 *v, int x, int y); extern int vt102_cursor_relative(VT102 *v, int x, int y); extern void vt102_delete_from_line(VT102 *v, CRT_Pos p); extern void vt102_insert_into_line(VT102 *v, CRT_Pos p); -extern void vt102_change_mode(VT102 *v, int private, char *ns, int set); -extern void vt102_parse_mode_string(VT102 *v, char *buf, int len); +extern void vt102_change_mode(Context *c, int private, char *ns, int set); +extern void vt102_parse_mode_string(Context *c, char *buf, int len); extern void vt102_change_attr(VT102 *v, char *na); extern void vt102_parse_attr_string(VT102 *v, char *buf, int len); extern void vt102_save_state(VT102 *v); extern void vt102_restore_state(VT102 *v); -extern void vt102_regular_char(Context *c, VT102 *v, char ch); +extern void vt102_regular_char(Context *c, VT102 *v, uint32_t ch); +extern int vt102_send_id(Context *c, char *buf); extern void vt102_scs(Context *c, int g, int s); -extern void vt102_parse_esc(Context *c, int ch); extern void vt102_parse_csi(Context *c, char *buf, int len); +extern void vt102_parse_esc(Context *c); extern void vt102_status_line(VT102 *v, char *str); extern void vt102_parser_reset(VT102_parser *p); -extern void vt102_reset_state(VT102 *v); +extern void vt102_reset_state(Context *c); extern void vt102_parse_char(Context *c, int ch); extern void vt102_send(Context *c, uint8_t key); -extern void vt102_reset(VT102 *v); -extern VT102 *vt102_new(void); +extern void vt102_reset(Context *c); +extern VT102 *vt102_new(CRT_Pos *size); extern void vt102_set_ansi(VT102 *v, int ansi); +extern void vt102_resize(Context *c, CRT_Pos size); extern void vt102_free(VT102 *v); /* tty.c */ extern void tty_pre_select(TTY *t, fd_set *rfds, fd_set *wfds); @@ -58,6 +66,7 @@ extern void tty_set_baud(TTY *t, int rate); extern void tty_send_break(TTY *t); extern void tty_set_flow(TTY *t, int flow); extern void tty_hangup(TTY *t); +extern void tty_winch(TTY *t, CRT_Pos size); extern void tty_parse_reset(Context *c); extern void tty_analyse(Context *c); extern TTY_Parser *tty_parser_new(void); @@ -77,7 +86,7 @@ extern int ring_space(Ring *r); extern int ring_bytes(Ring *r); extern Ring *ring_new(int n); /* ptty.c */ -extern TTY *ptty_open(char *path, char *argv[]); +extern TTY *ptty_open(char *path, char *argv[], CRT_Pos *size); /* terminal.c */ extern int terminal_winches; extern void terminal_atexit(void); @@ -90,8 +99,9 @@ extern int wrap_read(int fd, void *buf, int len); extern int wrap_write(int fd, void *buf, int len); extern void set_nonblocking(int fd); extern void set_blocking(int fd); -extern void raw_termios(struct termios *termios); extern void default_termios(struct termios *termios); +extern void client_termios(struct termios *termios); +extern int fput_cp(FILE *f, uint32_t ch); /* log.c */ extern Log *file_log_new(char *fn); extern void log_f(Log *log, char *fmt, ...); @@ -110,6 +120,8 @@ extern int ipc_msg_send_sendbreak(Socket *s); extern int ipc_msg_send_setflow(Socket *s, int flow); extern int ipc_msg_send_setansi(Socket *s, int ansi); extern int ipc_msg_send_hangup(Socket *s); +extern int ipc_msg_send_setsize(Socket *s, CRT_Pos size); +extern int ipc_msg_send_reset(Socket *s); /* slide.c */ extern void slide_free(Slide *s); extern void slide_consume(Slide *s, int n); @@ -131,7 +143,7 @@ extern int socket_write(Socket *s, void *buf, int len); /* serial.c */ extern TTY *serial_open(char *path, int lock_mode); /* cmd.c */ -extern void cmd_parse(Cmd *c, Context *ctx, char *buf); +extern int cmd_parse(Cmd *c, Context *ctx, char *buf); extern void cmd_show_status(Cmd *c, Context *ctx); extern int cmd_key(Cmd *c, Context *ctx, int key); extern int cmd_activate(Cmd *c, Context *ctx); @@ -158,5 +170,14 @@ extern void serial_lock_free(Serial_lock *l); extern Serial_lock *serial_lock_new(char *dev, int mode); /* utf8.c */ extern void utf8_flush(Context *c); -extern void utf8_parse(Context *c, int ch); +extern void utf8_parse(Context *c, uint32_t ch); extern UTF8 *utf8_new(void); +extern int utf8_encode(char *ptr, int ch); +extern void utf8_emit(TTY *t, int ch); +/* vt102_charset.c */ +extern uint32_t vt102_charset_c0[128]; +extern uint32_t vt102_charset_us[128]; +extern uint32_t vt102_charset_uk[128]; +extern uint32_t vt102_charset_vt52[128]; +extern uint32_t vt102_charset_gl[128]; +extern uint32_t *charset_from_csid[];