[BACK]Return to eqn.c CVS log [TXT][DIR] Up to [cvsweb.bsd.lv] / mandoc

Diff for /mandoc/eqn.c between version 1.25 and 1.28

version 1.25, 2011/07/22 10:36:58 version 1.28, 2011/07/22 14:26:32
Line 39  enum eqn_rest {
Line 39  enum eqn_rest {
         EQN_EOF          EQN_EOF
 };  };
   
   enum    eqn_symt {
           EQNSYM_alpha,
           EQNSYM_beta,
           EQNSYM_chi,
           EQNSYM_delta,
           EQNSYM_epsilon,
           EQNSYM_eta,
           EQNSYM_gamma,
           EQNSYM_iota,
           EQNSYM_kappa,
           EQNSYM_lambda,
           EQNSYM_mu,
           EQNSYM_nu,
           EQNSYM_omega,
           EQNSYM_omicron,
           EQNSYM_phi,
           EQNSYM_pi,
           EQNSYM_ps,
           EQNSYM_rho,
           EQNSYM_sigma,
           EQNSYM_tau,
           EQNSYM_theta,
           EQNSYM_upsilon,
           EQNSYM_xi,
           EQNSYM_zeta,
           EQNSYM_DELTA,
           EQNSYM_GAMMA,
           EQNSYM_LAMBDA,
           EQNSYM_OMEGA,
           EQNSYM_PHI,
           EQNSYM_PI,
           EQNSYM_PSI,
           EQNSYM_SIGMA,
           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  eqnstr {  struct  eqnstr {
         const char      *name;          const char      *name;
         size_t           sz;          size_t           sz;
Line 54  struct eqnpart {
Line 117  struct eqnpart {
         int             (*fp)(struct eqn_node *);          int             (*fp)(struct eqn_node *);
 };  };
   
   struct  eqnsym {
           struct eqnstr    str;
           const char      *sym;
   };
   
 enum    eqnpartt {  enum    eqnpartt {
         EQN_DEFINE = 0,          EQN_DEFINE = 0,
         EQN_SET,          EQN_SET,
Line 118  static const struct eqnstr eqnpiles[EQNPILE__MAX] = {
Line 186  static const struct eqnstr eqnpiles[EQNPILE__MAX] = {
         { "lpile", 5 }, /* EQNPILE_LPILE */          { "lpile", 5 }, /* EQNPILE_LPILE */
 };  };
   
   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 */
           { { "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 */  /* ARGSUSED */
 enum rofferr  enum rofferr
 eqn_read(struct eqn_node **epp, int ln,  eqn_read(struct eqn_node **epp, int ln,
Line 260  eqn_box(struct eqn_node *ep, struct eqn_box *last)
Line 390  eqn_box(struct eqn_node *ep, struct eqn_box *last)
         size_t           sz;          size_t           sz;
         const char      *start;          const char      *start;
         char            *left;          char            *left;
           char             sym[64];
         enum eqn_rest    c;          enum eqn_rest    c;
         int              i, size;          int              i, size;
         struct eqn_box  *bp;          struct eqn_box  *bp;
Line 309  eqn_box(struct eqn_node *ep, struct eqn_box *last)
Line 440  eqn_box(struct eqn_node *ep, struct eqn_box *last)
                         return(EQN_ERR);                          return(EQN_ERR);
                 }                  }
                 left = mandoc_strndup(start, sz);                  left = mandoc_strndup(start, sz);
                 if (EQN_DESCOPE != (c = eqn_eqn(ep, last)))                  c = eqn_eqn(ep, last);
                   if (last->last)
                           last->last->left = left;
                   else
                           free(left);
                   if (EQN_DESCOPE != c)
                         return(c);                          return(c);
                 assert(last->last);                  assert(last->last);
                 last->last->left = left;  
                 eqn_rewind(ep);                  eqn_rewind(ep);
                 start = eqn_nexttok(ep, &sz);                  start = eqn_nexttok(ep, &sz);
                 assert(start);                  assert(start);
                 if (STRNEQ(start, sz, "right", 5))                  if ( ! STRNEQ(start, sz, "right", 5))
                         return(EQN_DESCOPE);                          return(EQN_DESCOPE);
                 if (NULL == (start = eqn_nexttok(ep, &sz))) {                  if (NULL == (start = eqn_nexttok(ep, &sz))) {
                         EQN_MSG(MANDOCERR_EQNEOF, ep);                          EQN_MSG(MANDOCERR_EQNEOF, ep);
Line 383  eqn_box(struct eqn_node *ep, struct eqn_box *last)
Line 518  eqn_box(struct eqn_node *ep, struct eqn_box *last)
   
         bp = eqn_box_alloc(last);          bp = eqn_box_alloc(last);
         bp->type = EQN_TEXT;          bp->type = EQN_TEXT;
           for (i = 0; i < (int)EQNSYM__MAX; i++)
                   if (EQNSTREQ(&eqnsyms[i].str, start, sz)) {
                           sym[63] = '\0';
                           snprintf(sym, 62, "\\[%s]", eqnsyms[i].sym);
                           bp->text = mandoc_strdup(sym);
                           return(EQN_OK);
                   }
   
         bp->text = mandoc_strndup(start, sz);          bp->text = mandoc_strndup(start, sz);
         return(EQN_OK);          return(EQN_OK);
 }  }

Legend:
Removed from v.1.25  
changed lines
  Added in v.1.28

CVSweb