X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fprototypes.h;h=a084d3219972cfeeb2ef2af8dcf2beb69fd0102e;hb=82aed0c41cd917fdf9cdb20db788fe9da0662eba;hp=f818c8893e8fdf38f154da4bc679f93ecdf19ccc;hpb=0ed6cb44b131fe292d26a21f3068de2ac58e76ee;p=sympathy.git diff --git a/src/prototypes.h b/src/prototypes.h index f818c88..a084d32 100644 --- a/src/prototypes.h +++ b/src/prototypes.h @@ -1,37 +1,15 @@ /* ansi.c */ -extern void ansi_move(ANSI *a, CRT_Pos p); -extern void ansi_showhide_cursor(ANSI *a, int hide); -extern void ansi_force_attr_normal(ANSI *a); -extern void ansi_set_color(ANSI *a, int color); -extern void ansi_set_attr(ANSI *a, int attr); -extern void ansi_render(ANSI *a, CRT_CA ca); -extern void ansi_cls(ANSI *a); -extern void ansi_draw_line(ANSI *a, CRT_CA *cap, int y); -extern void ansi_resize_check(ANSI *a); -extern void ansi_history(ANSI *a, History *h); -extern void ansi_draw(ANSI *a, CRT *c); -extern void ansi_reset(ANSI *a, CRT *c); -extern void ansi_terminal_reset(ANSI *a); -extern void ansi_flush_escape(ANSI *a, Context *c); -extern void ansi_parse_deckey(ANSI *a, Context *c); -extern void ansi_parse_ansikey(ANSI *a, Context *c); -extern void ansi_parse_escape(ANSI *a, Context *c); -extern void ansi_check_escape(ANSI *a, Context *c); -extern void ansi_parse_char(ANSI *a, Context *c, int ch); -extern void ansi_parse(ANSI *a, Context *c, char *buf, int len); extern int ansi_dispatch(ANSI *a, Context *c); -extern void ansi_update(ANSI *a, Context *c); +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); +extern void crt_erase(CRT *c, CRT_Pos s, CRT_Pos e, int ea, int color); extern void crt_cls(CRT *c); -extern void crt_scroll_up(CRT *c, CRT_Pos s, CRT_Pos e, int ea); -extern void crt_scroll_down(CRT *c, CRT_Pos s, CRT_Pos e, int ea); +extern void crt_scroll_up(CRT *c, CRT_Pos s, CRT_Pos e, int ea, int color); +extern void crt_scroll_down(CRT *c, CRT_Pos s, CRT_Pos e, int ea, int color); extern void crt_reset(CRT *c); extern void crt_insert(CRT *c, CRT_CA ca); /* html.c */ -extern void html_entity(FILE *f, int c); -extern void html_render(FILE *f, CRT_CA c); -extern void html_draw(FILE *f, CRT *c); +extern ANSI *ansi_new_html(FILE *f); /* libsympathy.c */ /* render.c */ /* version.c */ @@ -42,11 +20,12 @@ 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_advance(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_reset_tabs(VT102 *v); extern void vt102_cursor_advance_tab(VT102 *v); +extern void vt102_cursor_retard_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); @@ -58,25 +37,31 @@ 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, int ch); 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_status_line(VT102 *v, char *str); -extern void vt102_parse_char(Context *c, int ch); -extern int vt102_parse(Context *c, char *buf, int len); extern void vt102_parser_reset(VT102_parser *p); +extern void vt102_reset_state(VT102 *v); +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 int vt102_dispatch(Context *c); -extern int vt102_dispatch_one(Context *c); extern VT102 *vt102_new(void); +extern void vt102_set_ansi(VT102 *v, int ansi); extern void vt102_free(VT102 *v); /* tty.c */ extern void tty_pre_select(TTY *t, fd_set *rfds, fd_set *wfds); extern int tty_get_status(TTY *t, TTY_Status *s); +extern int tty_get_baud(TTY *t); 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_parse_reset(Context *c); +extern void tty_analyse(Context *c); +extern TTY_Parser *tty_parser_new(void); +extern void tty_parse(Context *c, uint8_t *buf, int len); /* keydis.c */ extern KeyDis *keydis_vt102_new(void); extern KeyDis *keydis_ipc_new(Socket *s); @@ -105,10 +90,11 @@ 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); /* log.c */ extern Log *file_log_new(char *fn); +extern void log_f(Log *log, char *fmt, ...); /* ipc.c */ extern IPC_Msg *ipc_check_for_message_in_slide(Slide *s); extern void ipc_consume_message_in_slide(Slide *s); @@ -122,6 +108,8 @@ extern int ipc_msg_send_status(Socket *s, char *buf); extern int ipc_msg_send_setbaud(Socket *s, int baud); 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); /* slide.c */ extern void slide_free(Slide *s); extern void slide_consume(Slide *s, int n); @@ -129,7 +117,10 @@ extern void slide_added(Slide *s, int n); extern Slide *slide_new(int n); extern void slide_expand(Slide *s, int n); /* symsocket.c */ +extern int wrap_recv(int fd, void *buf, int len); +extern int wrap_send(int fd, void *buf, int len); extern void socket_free(Socket *s); +extern void socket_free_parent(Socket *s); extern Socket *socket_listen(char *path); extern Socket *socket_accept(Socket *l); extern Socket *socket_connect(char *path); @@ -163,6 +154,10 @@ extern void lockfile_remove_stale(Filelist *fl); extern Filelist *lockfile_lock(Filelist *fl); extern void lockfile_unlock(Filelist *fl); extern int serial_lock_check(Serial_lock *l); -extern Serial_lock void serial_lock_free(Serial_lock *l); +extern void serial_lock_free(Serial_lock *l); extern Serial_lock *serial_lock_new(char *dev, int mode); -extern int main(int argc, char *argv[]); +/* utf8.c */ +extern void utf8_flush(Context *c); +extern void utf8_parse(Context *c, uint32_t ch); +extern UTF8 *utf8_new(void); +extern void utf8_emit(TTY *t, int ch);