-.\" $Id: eqn.7,v 1.15 2011/07/22 13:48:52 kristaps Exp $
+.\" $Id: eqn.7,v 1.16 2011/07/22 14:26:32 kristaps Exp $
.\"
.\" Copyright (c) 2011 Kristaps Dzonsons <kristaps@bsd.lv>
.\"
Unless within a quoted string, white-space (and enclosing literal quote
pairs) is thrown away.
Quoted strings are not scanned for replacement definitions.
-The following text tokens are translated into an acceptable front-end
-format, if available: alpha, beta, chi, delta, epsilon, eta, gamma,
-iota, kappa, lambda, mu, nu, omega, omicron, phi, pi, psi, rho, sigma,
-tau, theta, upsilon, xi, zeta, DELTA, GAMMA, LAMBDA, OMEGA, PHI, PI,
-PSI, SIGMA, THETA, UPSILON, and XI.
+.Pp
+The following TEXT terms are translated into a rendered glyph, if
+available: alpha, beta, chi, delta, epsilon, eta, gamma, iota, kappa,
+lambda, mu, nu, omega, omicron, phi, pi, psi, rho, sigma, tau, theta,
+upsilon, xi, zeta, DELTA, GAMMA, LAMBDA, OMEGA, PHI, PI, PSI, SIGMA,
+THETA, UPSILON, XI, inter (intersection), union (union), prod (product),
+int (integral), sum (summation), grad (gradient), del (vector
+differential), times (multiply), cdot (centre-dot), nothing (zero-width
+space), approx (approximately equals), prime (prime), half (one-half),
+partial (partial differential), inf (infinity), >> (much greater), <<
+(much less), \-> (left arrow), <\- (right arrow), += (plus-minus), !=
+(not equal), == (equivalence), <= (less-than-equal), and >=
+(more-than-equal).
.Pp
The following control statements are available:
.Bl -tag -width Ds
-/* $Id: eqn.c,v 1.27 2011/07/22 13:40:15 kristaps Exp $ */
+/* $Id: eqn.c,v 1.28 2011/07/22 14:26:32 kristaps Exp $ */
/*
* Copyright (c) 2011 Kristaps Dzonsons <kristaps@bsd.lv>
*
EQNSYM_THETA,
EQNSYM_UPSILON,
EQNSYM_XI,
+ EQNSYM_inter,
+ EQNSYM_union,
+ EQNSYM_prod,
+ EQNSYM_int,
+ EQNSYM_sum,
+ EQNSYM_grad,
+ EQNSYM_del,
+ EQNSYM_times,
+ EQNSYM_cdot,
+ EQNSYM_nothing,
+ EQNSYM_approx,
+ EQNSYM_prime,
+ EQNSYM_half,
+ EQNSYM_partial,
+ EQNSYM_inf,
+ EQNSYM_muchgreat,
+ EQNSYM_muchless,
+ EQNSYM_larrow,
+ EQNSYM_rarrow,
+ EQNSYM_pm,
+ EQNSYM_nequal,
+ EQNSYM_equiv,
+ EQNSYM_lessequal,
+ EQNSYM_moreequal,
EQNSYM__MAX
};
struct eqnsym {
struct eqnstr str;
- char sym;
+ const char *sym;
};
enum eqnpartt {
};
static const struct eqnsym eqnsyms[EQNSYM__MAX] = {
- { { "alpha", 5 }, 'a' }, /* EQNSYM_alpha */
- { { "beta", 4 }, 'b' }, /* EQNSYM_beta */
- { { "chi", 3 }, 'x' }, /* EQNSYM_chi */
- { { "delta", 5 }, 'd' }, /* EQNSYM_delta */
- { { "epsilon", 7 }, 'e' }, /* EQNSYM_epsilon */
- { { "eta", 3 }, 'y' }, /* EQNSYM_eta */
- { { "gamma", 5 }, 'g' }, /* EQNSYM_gamma */
- { { "iota", 4 }, 'i' }, /* EQNSYM_iota */
- { { "kappa", 5 }, 'k' }, /* EQNSYM_kappa */
- { { "lambda", 6 }, 'l' }, /* EQNSYM_lambda */
- { { "mu", 2 }, 'm' }, /* EQNSYM_mu */
- { { "nu", 2 }, 'n' }, /* EQNSYM_nu */
- { { "omega", 5 }, 'w' }, /* EQNSYM_omega */
- { { "omicron", 7 }, 'o' }, /* EQNSYM_omicron */
- { { "phi", 3 }, 'f' }, /* EQNSYM_phi */
- { { "pi", 2 }, 'p' }, /* EQNSYM_pi */
- { { "psi", 2 }, 'q' }, /* EQNSYM_psi */
- { { "rho", 3 }, 'r' }, /* EQNSYM_rho */
- { { "sigma", 5 }, 's' }, /* EQNSYM_sigma */
- { { "tau", 3 }, 't' }, /* EQNSYM_tau */
- { { "theta", 5 }, 'h' }, /* EQNSYM_theta */
- { { "upsilon", 7 }, 'u' }, /* EQNSYM_upsilon */
- { { "xi", 2 }, 'c' }, /* EQNSYM_xi */
- { { "zeta", 4 }, 'z' }, /* EQNSYM_zeta */
- { { "DELTA", 5 }, 'D' }, /* EQNSYM_DELTA */
- { { "GAMMA", 5 }, 'G' }, /* EQNSYM_GAMMA */
- { { "LAMBDA", 6 }, 'L' }, /* EQNSYM_LAMBDA */
- { { "OMEGA", 5 }, 'W' }, /* EQNSYM_OMEGA */
- { { "PHI", 3 }, 'F' }, /* EQNSYM_PHI */
- { { "PI", 2 }, 'P' }, /* EQNSYM_PI */
- { { "PSI", 3 }, 'Q' }, /* EQNSYM_PSI */
- { { "SIGMA", 5 }, 'S' }, /* EQNSYM_SIGMA */
- { { "THETA", 5 }, 'H' }, /* EQNSYM_THETA */
- { { "UPSILON", 7 }, 'U' }, /* EQNSYM_UPSILON */
- { { "XI", 2 }, 'C' }, /* EQNSYM_XI */
+ { { "alpha", 5 }, "*a" }, /* EQNSYM_alpha */
+ { { "beta", 4 }, "*b" }, /* EQNSYM_beta */
+ { { "chi", 3 }, "*x" }, /* EQNSYM_chi */
+ { { "delta", 5 }, "*d" }, /* EQNSYM_delta */
+ { { "epsilon", 7 }, "*e" }, /* EQNSYM_epsilon */
+ { { "eta", 3 }, "*y" }, /* EQNSYM_eta */
+ { { "gamma", 5 }, "*g" }, /* EQNSYM_gamma */
+ { { "iota", 4 }, "*i" }, /* EQNSYM_iota */
+ { { "kappa", 5 }, "*k" }, /* EQNSYM_kappa */
+ { { "lambda", 6 }, "*l" }, /* EQNSYM_lambda */
+ { { "mu", 2 }, "*m" }, /* EQNSYM_mu */
+ { { "nu", 2 }, "*n" }, /* EQNSYM_nu */
+ { { "omega", 5 }, "*w" }, /* EQNSYM_omega */
+ { { "omicron", 7 }, "*o" }, /* EQNSYM_omicron */
+ { { "phi", 3 }, "*f" }, /* EQNSYM_phi */
+ { { "pi", 2 }, "*p" }, /* EQNSYM_pi */
+ { { "psi", 2 }, "*q" }, /* EQNSYM_psi */
+ { { "rho", 3 }, "*r" }, /* EQNSYM_rho */
+ { { "sigma", 5 }, "*s" }, /* EQNSYM_sigma */
+ { { "tau", 3 }, "*t" }, /* EQNSYM_tau */
+ { { "theta", 5 }, "*h" }, /* EQNSYM_theta */
+ { { "upsilon", 7 }, "*u" }, /* EQNSYM_upsilon */
+ { { "xi", 2 }, "*c" }, /* EQNSYM_xi */
+ { { "zeta", 4 }, "*z" }, /* EQNSYM_zeta */
+ { { "DELTA", 5 }, "*D" }, /* EQNSYM_DELTA */
+ { { "GAMMA", 5 }, "*G" }, /* EQNSYM_GAMMA */
+ { { "LAMBDA", 6 }, "*L" }, /* EQNSYM_LAMBDA */
+ { { "OMEGA", 5 }, "*W" }, /* EQNSYM_OMEGA */
+ { { "PHI", 3 }, "*F" }, /* EQNSYM_PHI */
+ { { "PI", 2 }, "*P" }, /* EQNSYM_PI */
+ { { "PSI", 3 }, "*Q" }, /* EQNSYM_PSI */
+ { { "SIGMA", 5 }, "*S" }, /* EQNSYM_SIGMA */
+ { { "THETA", 5 }, "*H" }, /* EQNSYM_THETA */
+ { { "UPSILON", 7 }, "*U" }, /* EQNSYM_UPSILON */
+ { { "XI", 2 }, "*C" }, /* EQNSYM_XI */
+ { { "inter", 5 }, "ca" }, /* EQNSYM_inter */
+ { { "union", 5 }, "cu" }, /* EQNSYM_union */
+ { { "prod", 4 }, "product" }, /* EQNSYM_prod */
+ { { "int", 3 }, "integral" }, /* EQNSYM_int */
+ { { "sum", 3 }, "sum" }, /* EQNSYM_sum */
+ { { "grad", 4 }, "gr" }, /* EQNSYM_grad */
+ { { "del", 3 }, "gr" }, /* EQNSYM_del */
+ { { "times", 5 }, "mu" }, /* EQNSYM_times */
+ { { "cdot", 4 }, "pc" }, /* EQNSYM_cdot */
+ { { "nothing", 7 }, "&" }, /* EQNSYM_nothing */
+ { { "approx", 6 }, "~~" }, /* EQNSYM_approx */
+ { { "prime", 5 }, "aq" }, /* EQNSYM_prime */
+ { { "half", 4 }, "12" }, /* EQNSYM_half */
+ { { "partial", 7 }, "pd" }, /* EQNSYM_partial */
+ { { "inf", 3 }, "if" }, /* EQNSYM_inf */
+ { { ">>", 2 }, ">>" }, /* EQNSYM_muchgreat */
+ { { "<<", 2 }, "<<" }, /* EQNSYM_muchless */
+ { { "<-", 2 }, "<-" }, /* EQNSYM_larrow */
+ { { "->", 2 }, "->" }, /* EQNSYM_rarrow */
+ { { "+-", 2 }, "+-" }, /* EQNSYM_pm */
+ { { "!=", 2 }, "!=" }, /* EQNSYM_nequal */
+ { { "==", 2 }, "==" }, /* EQNSYM_equiv */
+ { { "<=", 2 }, "<=" }, /* EQNSYM_lessequal */
+ { { ">=", 2 }, ">=" }, /* EQNSYM_moreequal */
};
/* ARGSUSED */
size_t sz;
const char *start;
char *left;
- char sym[5];
+ char sym[64];
enum eqn_rest c;
int i, size;
struct eqn_box *bp;
bp->type = EQN_TEXT;
for (i = 0; i < (int)EQNSYM__MAX; i++)
if (EQNSTREQ(&eqnsyms[i].str, start, sz)) {
- sym[0] = '\\';
- sym[1] = '(';
- sym[2] = '*';
- sym[3] = eqnsyms[i].sym;
- sym[4] = '\0';
+ sym[63] = '\0';
+ snprintf(sym, 62, "\\[%s]", eqnsyms[i].sym);
bp->text = mandoc_strdup(sym);
return(EQN_OK);
}