ref: 54aeeafab3117a7cbbcb5b96a21d22101f78eac2
dir: /xroff.h/
/* converting scales */ #define SC_IN (dev_res) /* inch in units */ #define SC_PT (SC_IN / 72) /* point in units */ #define SC_EM (n_s * SC_IN / 72) #define SC_DW (SC_EM / 3) /* default width */ #define SC_HT (n_s * SC_PT) /* character height */ /* predefined array limits */ #define PATHLEN 1024 /* path length */ #define NFILES 16 /* number of input files */ #define NFONTS 32 /* number of fonts */ #define FNLEN 32 /* font name length */ #define NGLYPHS 512 /* glyphs in fonts */ #define GNLEN 32 /* glyph name length */ #define ILNLEN 256 /* line limit of input files */ #define LNLEN 4000 /* line buffer length (ren.c/out.c) */ #define NWORDS 1000 /* number of words in line buffer */ #define NARGS 9 /* number of macro arguments */ #define RLEN 4 /* register/macro name */ #define NPREV 16 /* environment stack depth */ #define NTRAPS 1024 /* number of traps per page */ #define NIES 128 /* number of nested .ie commands */ /* escape sequences */ #define ESC_Q "bCDhHlLNoSvwxX" /* quoted escape sequences */ #define ESC_P "*fgkns" /* 1 or 2-char escape sequences */ #define MAX(a, b) ((a) > (b) ? (a) : (b)) #define LEN(a) (sizeof(a) / sizeof((a)[0])) /* number registers */ int num_get(int id, int inc); void num_set(int id, int val); void num_inc(int id, int val); void num_del(int id); char *num_str(int id); int *nreg(int id); int eval(char *s, int unit); int eval_up(char **s, int unit); int eval_re(char *s, int orig, int unit); /* string registers */ void str_set(int id, char *s); void str_dset(int id, void *d); char *str_get(int id); void *str_dget(int id); void str_rm(int id); void str_rn(int src, int dst); /* saving and restoring registers before and after printing diverted lines */ void odiv_beg(void); void odiv_end(void); /* enviroments */ void env_init(void); void env_free(void); struct adj *env_adj(void); /* device related variables */ extern int dev_res; extern int dev_uwid; extern int dev_hor; extern int dev_ver; struct glyph { char name[FNLEN]; /* name of the glyph */ char id[FNLEN]; /* device-dependent glyph identifier */ struct font *font; /* glyph font */ int wid; /* character width */ int type; /* character type; ascender/descender */ }; struct font { char name[FNLEN]; struct glyph glyphs[NGLYPHS]; int nglyphs; int spacewid; int special; char c[NGLYPHS][FNLEN]; /* character names in charset */ struct glyph *g[NGLYPHS]; /* character glyphs in charset */ int n; /* number of characters in charset */ }; /* output device functions */ int dev_open(char *path); void dev_close(void); int dev_mnt(int pos, char *id, char *name); int dev_font(char *id); int charwid(int wid, int sz); /* font-related functions */ struct font *font_open(char *path); void font_close(struct font *fn); struct glyph *font_glyph(struct font *fn, char *id); struct glyph *font_find(struct font *fn, char *name); /* glyph handling functions */ struct glyph *dev_glyph(char *c, int fn); struct glyph *dev_glyph_byid(char *id, int fn); int dev_spacewid(void); /* different layers of neatroff */ int in_next(void); /* input layer */ int cp_next(void); /* copy-mode layer */ int tr_next(void); /* troff layer */ void in_push(char *s, char **args); void in_pushnl(char *s, char **args); void in_so(char *path); /* .so request */ void in_nx(char *path); /* .nx request */ void in_ex(void); /* .nx request */ void in_queue(char *path); /* .ex request */ char *in_arg(int i); /* look up argument */ int in_nargs(void); /* number of arguments */ void in_back(int c); /* push back input character */ int in_top(void); /* the first pushed-back character */ char *in_filename(void); /* current filename */ void cp_blk(int skip); /* skip or read the next line or block */ void cp_wid(int enable); /* control inlining \w requests */ #define cp_back in_back /* cp.c is stateless */ void tr_first(void); /* read until the first non-command line */ /* rendering */ void render(void); /* read from in.c and print the output */ int ren_wid(int (*next)(void), void (*back)(int)); void ren_tl(int (*next)(void), void (*back)(int)); void out_line(char *s); /* output the given rendered line */ int out_draw(char *s, char *cc); void out(char *s, ...); /* output troff cmd */ void ren_hline(struct adj *adj, char *arg); /* horizontal line */ void ren_vline(struct adj *adj, char *arg); /* vertical line */ void ren_bracket(struct adj *adj, char *arg); /* \b */ void ren_over(struct adj *adj, char *arg); /* \o */ /* troff commands */ void tr_bp(char **args); void tr_br(char **args); void tr_ce(char **args); void tr_ch(char **args); void tr_di(char **args); void tr_divbeg(char **args); void tr_divend(char **args); void tr_dt(char **args); void tr_ev(char **args); void tr_fi(char **args); void tr_fp(char **args); void tr_ft(char **args); void tr_in(char **args); void tr_ll(char **args); void tr_mk(char **args); void tr_ne(char **args); void tr_nf(char **args); void tr_ns(char **args); void tr_os(char **args); void tr_pn(char **args); void tr_ps(char **args); void tr_rs(char **args); void tr_rt(char **args); void tr_sp(char **args); void tr_sv(char **args); void tr_ti(char **args); void tr_wh(char **args); void tr_init(void); /* helpers */ void errmsg(char *msg, ...); int utf8len(int c); char *utf8get(char *d, char *s); void schar_read(char *d, int (*next)(void)); int schar_jump(char *d, int (*next)(void), void (*back)(int)); /* variable length string buffer */ struct sbuf { char *s; int sz; int n; }; void sbuf_init(struct sbuf *sbuf); void sbuf_done(struct sbuf *sbuf); char *sbuf_buf(struct sbuf *sbuf); void sbuf_add(struct sbuf *sbuf, int c); void sbuf_append(struct sbuf *sbuf, char *s); void sbuf_putnl(struct sbuf *sbuf); int sbuf_empty(struct sbuf *sbuf); /* diversions */ #define DIV_BEG ".&<" #define DIV_END ".&>" /* adjustment */ #define AD_L 0 #define AD_B 1 #define AD_C 3 #define AD_R 5 struct adj *adj_alloc(void); void adj_free(struct adj *adj); int adj_fill(struct adj *adj, int ad_b, int fill, char *dst, int *ll, int *in, int *ti, int *els_neg, int *els_pos); void adj_put(struct adj *adj, int wid, char *s, ...); void adj_swid(struct adj *adj, int swid); int adj_full(struct adj *adj, int fill); int adj_empty(struct adj *adj, int fill); int adj_wid(struct adj *adj); void adj_ll(struct adj *adj, int ll); void adj_in(struct adj *adj, int in); void adj_ti(struct adj *adj, int ti); void adj_els(struct adj *adj, int els); void adj_conf(struct adj *adj, int *ll, int *in, int *ti); /* builtin number registers; n_X for .X register */ #define REG(c1, c2) ((c1) * 256 + (c2)) #define n_a (*nreg(REG('.', 'a'))) #define n_d (*nreg(REG('.', 'd'))) #define n_f (*nreg(REG('.', 'f'))) #define n_h (*nreg(REG('.', 'h'))) #define n_i (*nreg(REG('.', 'i'))) #define n_j (*nreg(REG('.', 'j'))) #define n_l (*nreg(REG('.', 'l'))) #define n_L (*nreg(REG('.', 'L'))) #define n_n (*nreg(REG('.', 'n'))) #define n_o (*nreg(REG('.', 'o'))) #define n_p (*nreg(REG('.', 'p'))) #define n_s (*nreg(REG('.', 's'))) #define n_u (*nreg(REG('.', 'u'))) #define n_v (*nreg(REG('.', 'v'))) #define n_ct (*nreg(REG('c', 't'))) #define n_dl (*nreg(REG('d', 'l'))) #define n_dn (*nreg(REG('d', 'n'))) #define n_nl (*nreg(REG('n', 'l'))) #define n_pg (*nreg(REG('%', '\0'))) /* % */ #define n_lb (*nreg(REG(0, 'b'))) /* input line beg */ #define n_ce (*nreg(REG(0, 'c'))) /* .ce remaining */ #define n_f0 (*nreg(REG(0, 'f'))) /* last .f */ #define n_i0 (*nreg(REG(0, 'i'))) /* last .i */ #define n_l0 (*nreg(REG(0, 'l'))) /* last .l */ #define n_L0 (*nreg(REG(0, 'L'))) /* last .L */ #define n_mk (*nreg(REG(0, 'm'))) /* .mk internal register */ #define n_na (*nreg(REG(0, 'n'))) /* .na mode */ #define n_ns (*nreg(REG(0, 'N'))) /* .ns mode */ #define n_o0 (*nreg(REG(0, 'o'))) /* last .o */ #define n_s0 (*nreg(REG(0, 's'))) /* last .s */ #define n_sv (*nreg(REG(0, 'S'))) /* .sv value */ #define n_lt (*nreg(REG(0, 't'))) /* .lt value */ #define n_t0 (*nreg(REG(0, 'T'))) /* previous .lt value */ #define n_v0 (*nreg(REG(0, 'v'))) /* last .v */ /* functions for implementing read-only registers */ int f_nexttrap(void); /* .t */ int f_divreg(void); /* .z */ int f_hpos(void); /* .k */