-#ifdef _WINDOWS
- #define NOCOMM
- #define NOSOUND
- #define NODRIVERS
- #define STRICT
- #pragma warning(disable:4115) // kill rpcasync.h complaint
- #include <windows.h>
- #define MYLIBAPI __declspec(dllexport)
-#endif
-
-#include "texwin.h"
-
-#pragma warning(disable:4131) // old style declarator
-#pragma warning(disable:4135) // conversion between different integral types
-#pragma warning(disable:4127) // conditional expression is constant
-
-#include <setjmp.h>
-
-#define EXTERN extern
-
-#include "texd.h"
-
-#pragma warning(disable:4244) /* 96/Jan/10 */
-
-/* *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** */
-/* sec 0944 */
-void build_page (void)
-{
- halfword p;
- halfword q, r;
- integer b, c;
- integer pi;
-/* unsigned char n; */
- unsigned int n; /* 95/Jan/7 */
- scaled delta, h, w;
-
-/* begin if (link(contrib_head)=null)or output_active then return; l.19351 */
- if ((mem[contrib_head].hh.v.RH == 0)|| output_active)
- return;
- do {
- lab22: p = mem[contrib_head].hh.v.RH;
-/* if (last_glue != 262143L) */
- if (last_glue != empty_flag)
- delete_glue_ref(last_glue);
- last_penalty = 0;
- last_kern = 0;
- if (mem[p].hh.b0 == 10)
- {
- last_glue = mem[p + 1].hh.v.LH;
- incr(mem[last_glue].hh.v.RH);
- }
- else {
-
-/* last_glue = 262143L; */
- last_glue = empty_flag;
- if (mem[p].hh.b0 == 12)
- last_penalty = mem[p + 1].cint;
- else if (mem[p].hh.b0 == 11)
- last_kern = mem[p + 1].cint;
- }
- switch(mem[p].hh.b0)
- {
- case 0 :
- case 1 :
- case 2 :
- if (page_contents < 2)
- {
- if (page_contents == 0)
- freeze_page_specs(2);
- else
- page_contents = 2;
- q = new_skip_param(9);
- if (mem[temp_ptr + 1].cint > mem[p + 3].cint)
- mem[temp_ptr + 1].cint = mem[temp_ptr + 1].cint - mem[p + 3].cint;
- else
- mem[temp_ptr + 1].cint = 0;
- mem[q].hh.v.RH = p;
- mem[contrib_head].hh.v.RH = q;
- goto lab22;
- }
- else {
- page_so_far[1]= page_so_far[1]+ page_so_far[7]+ mem[p + 3].cint;
- page_so_far[7]= mem[p + 2].cint;
- goto lab80;
- }
- break;
- case 8 :
- goto lab80;
- break;
- case 10 :
- if (page_contents < 2)
- goto lab31;
- else if ((mem[page_tail].hh.b0 < 9))
- pi = 0;
- else
- goto lab90;
- break;
- case 11 :
- if (page_contents < 2)
- goto lab31;
- else if (mem[p].hh.v.RH == 0)
- return;
- else if (mem[mem[p].hh.v.RH].hh.b0 == 10)
- pi = 0;
- else
- goto lab90;
- break;
- case 12 :
- if (page_contents < 2)
- goto lab31;
- else
- pi = mem[p + 1].cint;
- break;
- case 4 :
- goto lab80;
- break;
- case 3 :
- {
- if (page_contents == 0)
- freeze_page_specs(1);
- n = mem[p].hh.b1;
- r = mem_top;
- while(n >= mem[mem[r].hh.v.RH].hh.b1)
- r = mem[r].hh.v.RH;
- n = n;
- if (mem[r].hh.b1 != n)
- {
- q = get_node(4);
- mem[q].hh.v.RH = mem[r].hh.v.RH;
- mem[r].hh.v.RH = q;
- r = q;
- mem[r].hh.b1 = n;
- mem[r].hh.b0 = 0;
- ensure_vbox(n);
- if (eqtb[(hash_size + 1578) + n].hh.v.RH == 0)
- mem[r + 3].cint = 0;
- else
- mem[r + 3].cint = mem[eqtb[(hash_size + 1578) + n].hh.v.RH + 3].cint + mem[eqtb[(hash_size + 1578) + n].hh.v.RH + 2].cint;
- mem[r + 2].hh.v.LH = 0;
- q = eqtb[(hash_size + 800) + n].hh.v.RH;
- if (eqtb[(hash_size + 3218) + n].cint == 1000)
- h = mem[r + 3].cint;
- else
- h = x_over_n(mem[r + 3].cint, 1000)* eqtb[(hash_size + 3218) + n].cint;
- page_so_far[0]= page_so_far[0]- h - mem[q + 1].cint;
- page_so_far[2 + mem[q].hh.b0]= page_so_far[2 + mem[q].hh.b0]+ mem[q + 2].cint;
- page_so_far[6]= page_so_far[6]+ mem[q + 3].cint;
- if ((mem[q].hh.b1 != 0)&&(mem[q + 3].cint != 0))
- {
- print_err("Infinite glue shrinkage inserted from");
- print_esc("skip");
- print_int(n);
- help3("The correction glue for page breaking with insertions",
- "must have finite shrinkability. But you may proceed,",
- "since the offensive shrinkability has been made finite.");
- error ();
- }
- }
- if (mem[r].hh.b0 == 1)
- insert_penalties = insert_penalties + mem[p + 1].cint;
- else {
- mem[r + 2].hh.v.RH = p;
- delta = page_so_far[0]- page_so_far[1]- page_so_far[7] + page_so_far[6];
- if (eqtb[(hash_size + 3218) + n].cint == 1000)
- h = mem[p + 3].cint;
- else
- h = x_over_n(mem[p + 3].cint, 1000)* eqtb[(hash_size + 3218) + n].cint;
- if (((h <= 0)||(h <= delta)) &&(mem[p + 3].cint + mem[r + 3].cint <= eqtb[(hash_size + 3751) + n].cint))
- {
- page_so_far[0]= page_so_far[0]- h;
- mem[r + 3].cint = mem[r + 3].cint + mem[p + 3].cint;
- }
- else {
- if (eqtb[(hash_size + 3218) + n].cint <= 0)
- w = 1073741823L; /* 2^30 - 1 */
- else {
- w = page_so_far[0]- page_so_far[1]- page_so_far[7];
- if (eqtb[(hash_size + 3218) + n].cint != 1000)
- w = x_over_n(w, eqtb[(hash_size + 3218) + n].cint)* 1000;
- }
- if (w > eqtb[(hash_size + 3751) + n].cint - mem[r + 3].cint)
- w = eqtb[(hash_size + 3751) + n].cint - mem[r + 3].cint;
- q = vert_break(mem[p + 4].hh.v.LH, w, mem[p + 2].cint);
- mem[r + 3].cint = mem[r + 3].cint + best_height_plus_depth;
- ;
-#ifdef STAT
- if (eqtb[(hash_size + 3196)].cint > 0)
- {
- begin_diagnostic ();
- print_nl("% split");
- print_int(n);
- print_string(" to");
- print_scaled(w);
- print_char(',');
- print_scaled(best_height_plus_depth);
- print_string(" p=");
- if (q == 0) /* if q=null l.19614 */
- print_int(-10000);
- else if (mem[q].hh.b0 == 12)
- print_int(mem[q + 1].cint);
- else print_char('0');
- end_diagnostic(false);
- }
-#endif /* STAT */
- if (eqtb[(hash_size + 3218) + n].cint != 1000)
- best_height_plus_depth = x_over_n(best_height_plus_depth, 1000) * eqtb[(hash_size + 3218) + n].cint;
- page_so_far[0]= page_so_far[0]- best_height_plus_depth;
- mem[r].hh.b0 = 1;
- mem[r + 1].hh.v.RH = q;
- mem[r + 1].hh.v.LH = p;
- if (q == 0)
- insert_penalties = insert_penalties - 10000;
- else if (mem[q].hh.b0 == 12)
- insert_penalties = insert_penalties + mem[q + 1].cint;
- }
- }
- goto lab80;
- }
- break;
- default:
- {
- confusion("page");
- return; // abort_flag set
- }
- break;
- }
- if (pi < 10000)/* pi may be used ... */
- {
- if (page_so_far[1]< page_so_far[0])
- if ((page_so_far[3]!= 0)||(page_so_far[4]!= 0)||(page_so_far[5]!= 0))
- b = 0;
- else
- b = badness(page_so_far[0]- page_so_far[1], page_so_far[2]);
- else if (page_so_far[1]- page_so_far[0]> page_so_far[6])
- b = 1073741823L; /* 2^30 - 1 */
- else
- b = badness(page_so_far[1]- page_so_far[0], page_so_far[6]);
- if (b < 1073741823L) /* 2^30 - 1 */
- if (pi <= -10000)
- c = pi;
- else if (b < 10000)
- c = b + pi + insert_penalties;
- else
- c = 100000L;
- else
- c = b;
- if (insert_penalties >= 10000)
- c = 1073741823L; /* 2^30 - 1 */
- ;
-#ifdef STAT
- if (eqtb[(hash_size + 3196)].cint > 0)
- {
- begin_diagnostic ();
- print_nl("%");
- print_string(" t=");
- print_totals ();
- print_string(" g=");
- print_scaled(page_so_far[0]);
- print_string(" b=");
- if (b == 1073741823L) /* 2^30 - 1 */
- print_char('*');
- else
- print_int(b);
- print_string(" p=");
- print_int(pi);
- print_string(" c=");
- if (c == 1073741823L) /* 2^30 - 1 */
- print_char('*');
- else print_int(c);
- if (c <= least_page_cost)
- print_char('#');
- end_diagnostic(false);
- }
-#endif /* STAT */
- if (c <= least_page_cost)
- {
- best_page_break = p;
- best_size = page_so_far[0];
- least_page_cost = c;
- r = mem[mem_top].hh.v.RH;
- while (r != mem_top) {
- mem[r + 2].hh.v.LH = mem[r + 2].hh.v.RH;
- r = mem[r].hh.v.RH;
- }
- }
- if ((c == 1073741823L)||(pi <= -10000)) /* 2^30 - 1 */
- {
- fire_up(p);
- if (output_active)return;
- goto lab30;
- }
- }
- if ((mem[p].hh.b0 < 10)||(mem[p].hh.b0 > 11))
- goto lab80;
- lab90: if (mem[p].hh.b0 == 11)
- q = p;
- else {
- q = mem[p + 1].hh.v.LH;
- page_so_far[2 + mem[q].hh.b0]= page_so_far[2 + mem[q].hh.b0]
- + mem[q + 2].cint;
- page_so_far[6]= page_so_far[6]+ mem[q + 3].cint;
- if ((mem[q].hh.b1 != 0)&&(mem[q + 3].cint != 0))
- {
- print_err("Infinite glue shrinkage found on current page");
- help4("The page about to be output contains some infinitely",
- "shrinkable glue, e.g., `\\vss' or `\\vskip 0pt minus 1fil'.",
- "Such glue doesn't belong there; but you can safely proceed,",
- "since the offensive shrinkability has been made finite.");
- error ();
- r = new_spec(q);
- mem[r].hh.b1 = 0;
- delete_glue_ref(q);
- mem[p + 1].hh.v.LH = r;
- q = r;
- }
- }
- page_so_far[1]= page_so_far[1]+ page_so_far[7]+ mem[q + 1].cint
- ;
- page_so_far[7]= 0;
- lab80: if (page_so_far[7]> page_max_depth)
- {
- page_so_far[1]= page_so_far[1]+ page_so_far[7]- page_max_depth;
- page_so_far[7]= page_max_depth;
- }
- mem[page_tail].hh.v.RH = p;
- page_tail = p;
- mem[contrib_head].hh.v.RH = mem[p].hh.v.RH;
- mem[p].hh.v.RH = 0;
- goto lab30;
- lab31: mem[contrib_head].hh.v.RH = mem[p].hh.v.RH;
- mem[p].hh.v.RH = 0;
- flush_node_list(p);
- lab30:;
- } while(!(mem[contrib_head].hh.v.RH == 0));
- if (nest_ptr == 0)
- tail = contrib_head;
- else nest[0].tail_field = contrib_head;
-}
-/* sec 1043 */
-void app_space (void)
-{
- halfword q;
- if ((space_factor >= 2000) && (eqtb[(hash_size + 795)].hh.v.RH != 0))
- q = new_param_glue(13);
- else {
- if (eqtb[(hash_size + 794)].hh.v.RH != 0)
- main_p = eqtb[(hash_size + 794)].hh.v.RH;
- else {
- main_p = font_glue[eqtb[(hash_size + 1834)].hh.v.RH];
- if (main_p == 0)
- {
- main_p = new_spec(0);
- main_k = param_base[eqtb[(hash_size + 1834)].hh.v.RH]+ 2;
- mem[main_p + 1].cint = font_info[main_k].cint;
- mem[main_p + 2].cint = font_info[main_k + 1].cint;
- mem[main_p + 3].cint = font_info[main_k + 2].cint;
- font_glue[eqtb[(hash_size + 1834)].hh.v.RH]= main_p;
- }
- }
- main_p = new_spec(main_p);
- if (space_factor >= 2000)
- mem[main_p + 1].cint = mem[main_p + 1].cint + font_info[7 + param_base[eqtb[(hash_size + 1834)].hh.v.RH]].cint;
- mem[main_p + 2].cint = xn_over_d(mem[main_p + 2].cint, cur_list.aux_field.hh.v.LH, 1000);
- mem[main_p + 3].cint = xn_over_d(mem[main_p + 3].cint, 1000, space_factor);
- q = new_glue(main_p);
- mem[main_p].hh.v.RH = 0;
- }
- mem[tail].hh.v.RH = q;
- tail = q;
-}
-/* called from tex8.c only */
-/* sec 1047 */
-void insert_dollar_sign (void)
-{
- back_input ();
- cur_tok = 804;
- print_err("Proceed; I'll discard its present contents.");
- help2("I've inserted a begin-math/end-math symbol since I think",
- "you left one out. Proceed, with fingers crossed.");
- ins_error ();
-}
-/* sec 1049 */
-void you_cant (void)
-{
- print_err("You can't use `");
- print_cmd_chr(cur_cmd, cur_chr);
- print_string("' in ");
- print_mode(mode);
-}
-/* sec 1050 */
-void report_illegal_case (void)
-{
- you_cant ();
- help4("Sorry, but I'm not programmed to handle this case;",
- "I'll just pretend that you didn't ask for it.",
- "If you're in the wrong mode, you might be able to",
- "return to the right one by typing `I}' or `I$' or `I\\par'.");
- error ();
-}
-/* sec 1051 */
-bool privileged (void)
-{
- register bool Result;
- if (mode > 0)Result = true;
- else {
- report_illegal_case ();
- Result = false;
- }
- return Result;
-}
-/* sec 1054 */
-bool its_all_over (void)
-{/* 10 */
- register bool Result;
- if (privileged ())
- {
- if ((page_head == page_tail) && (head == cur_list.tail_field) && (dead_cycles == 0))
- {
- Result = true;
- return(Result);
- }
- back_input ();
- {
- mem[tail].hh.v.RH = new_null_box ();
- tail = mem[tail].hh.v.RH;
- }
- mem[tail + 1].cint = eqtb[(hash_size + 3733)].cint;
- {
- mem[tail].hh.v.RH = new_glue(8);
- tail = mem[tail].hh.v.RH;
- }
- {
- mem[tail].hh.v.RH = new_penalty(-1073741824L);
- /* - 2^30 */
- tail = mem[tail].hh.v.RH;
- }
- build_page ();
- }
- Result = false;
- return Result;
-}
-/* sec 1060 */
-void append_glue (void)
-{
- small_number s;
- s = cur_chr;
- switch(s)
- {case 0 :
- cur_val = 4;
- break;
- case 1 :
- cur_val = 8;
- break;
- case 2 :
- cur_val = 12;
- break;
- case 3 :
- cur_val = 16;
- break;
- case 4 :
- scan_glue(2);
- break;
- case 5 :
- scan_glue(3);
- break;
- }
- {
- mem[tail].hh.v.RH = new_glue(cur_val);
- tail = mem[tail].hh.v.RH;
- }
- if (s >= 4)
- {
- decr(mem[cur_val].hh.v.RH);
- if (s > 4)
- mem[tail].hh.b1 = 99;
- }
-}
-/* sec 1161 */
-void append_kern (void)
-{
- quarterword s;
- s = cur_chr;
- scan_dimen(s == 99, false, false);
- {
- mem[tail].hh.v.RH = new_kern(cur_val);
- tail = mem[tail].hh.v.RH;
- }
- mem[tail].hh.b1 = s;
-}
-/* sec 1054 */
-void off_save (void)
-{
- halfword p;
- if (cur_group == 0)
- {
- print_err("Extra ");
- print_cmd_chr(cur_cmd, cur_chr);
- help1("Things are pretty mixed up, but I think the worst is over.");
- error ();
- } else {
- back_input ();
- p = get_avail ();
- mem[temp_head].hh.v.RH = p;
- print_err("Missing ");
- switch(cur_group)
- {case 14 :
- {
-/* mem[p].hh.v.LH = (hash_size + 4611); */
-/* mem[p].hh.v.LH = (hash_size + 4095 + 516); */
- mem[p].hh.v.LH = (hash_size + hash_extra + 4095 + 516); /* 96/Jan/10 */
- print_esc("endgroup");
- }
- break;
- case 15 :
- {
- mem[p].hh.v.LH = 804;
- print_char('$');
- }
- break;
- case 16 :
- {
-/* mem[p].hh.v.LH = (hash_size + 4612); */
-/* mem[p].hh.v.LH = (hash_size + 4095 + 517); */
- mem[p].hh.v.LH = (hash_size + hash_extra + 4095 + 517); /* 96/Jan/10 */
- mem[p].hh.v.RH = get_avail ();
- p = mem[p].hh.v.RH;
- mem[p].hh.v.LH = 3118;
- print_esc("right.");
- }
- break;
- default:
- {
- mem[p].hh.v.LH = 637;
- print_char('}');
- }
- break;
- }
- print_string(" inserted");
- begin_token_list(mem[temp_head].hh.v.RH, 4);
- help5("I've inserted something that you may have forgotten.",
- "(See the <inserted text> above.)",
- "With luck, this will get me unwedged. But if you",
- "really didn't forget anything, try typing `2' now; then",
- "my insertion and my current dilemma will both disappear.");
- error ();
- }
-}
-/* only called from tex8.c */
-/* sec 1069 */
-void extra_right_brace (void)
-{
- print_err("Extra }, or forgotten");
- switch(cur_group)
- {case 14 :
- print_esc("endgroup");
- break;
- case 15 :
- print_char('$');
- break;
- case 16 :
- print_esc("right");
- break;
- }
- help5("I've deleted a group-closing symbol because it seems to be",
- "spurious, as in `$x}$'. But perhaps the } is legitimate and",
- "you forgot something else, as in `\\hbox{$x}'. In such cases",
- "the way to recover is to insert both the forgotten and the",
- "deleted material, e.g., by typing `I$}'.");
- error ();
- incr(align_state);
-}
-/* sec 1070 */
-void normal_paragraph (void)
-{
-/* if looseness<>0 then eq_word_define(int_base+looseness_code,0); */
- if (eqtb[(hash_size + 3182)].cint != 0)
- eq_word_define((hash_size + 3182), 0);
- if (eqtb[(hash_size + 3747)].cint != 0)
- eq_word_define((hash_size + 3747), 0);
- if (eqtb[(hash_size + 3204)].cint != 1)
- eq_word_define((hash_size + 3204), 1);
- if (eqtb[(hash_size + 1312)].hh.v.RH != 0)
- eq_define((hash_size + 1312), 118, 0);
-}
-/* sec 1075 */
-void box_end_(integer boxcontext)
-{
- halfword p;
-/* if box_context<box_flag then ... 1073741824 2^30 */
- if (boxcontext < 1073741824L)
- {
- if (cur_box != 0)
- {
- mem[cur_box + 4].cint = boxcontext;
- if (abs(mode)== 1)
- {
- append_to_vlist(cur_box);
- if (adjust_tail != 0)
- {
- if (adjust_head != adjust_tail)
- {
- mem[tail].hh.v.RH = mem[adjust_head].hh
- .v.RH;
- tail = adjust_tail;
- }
- adjust_tail = 0;
- }
- if (mode > 0){
- build_page ();
- }
- }
- else {
- if (abs(mode)== 102)
- space_factor = 1000;
- else {
-
- p = new_noad ();
- mem[p + 1].hh.v.RH = 2;
- mem[p + 1].hh.v.LH = cur_box;
- cur_box = p;
- }
- mem[tail].hh.v.RH = cur_box;
- tail = cur_box;
- }
- }
- }
-
-/* following fixed 1994/Apr/5 1 day anno Yang --- moby sigh ... */
-
-/* else if box_context<box_flag+512 then ... */
-/* else if (boxcontext < 1073742336L)*/ /* 2^30 + 512 */
- else if (boxcontext < (1073741824L + 512)) /* 2^30 + 512 */
-/* else if box_context<box_flag+256 then ... */
-/* if (boxcontext < 1073742080L)*/ /* 2^30 + 256 */
- if (boxcontext < (1073741824L + 256))/* 2^30 + 256 */
-/* eq_define(box_base-box_flag+box_context,box_ref,cur_box) */
-/* eq_define((hash_size - 1073740246L) + boxcontext, 119, cur_box); */
- eq_define((hash_size + 1578 - 1073741824L) + boxcontext, 119, cur_box);
-/* else geq_define(box_base-box_flag-256+box_context,box_ref,cur_box) */
-/* else geq_define((hash_size - 1073740502L) + boxcontext, 119, cur_box); */
- else geq_define((hash_size + 1322 - 1073741824L) + boxcontext, 119, cur_box);
- else if (cur_box != 0)
-/* if (boxcontext > 1073742336L)*/ /* 2^30 + 512 */
- if (boxcontext > (1073741824L + 512)) /* 2^30 + 512 */
- {
- do {
- get_x_token ();
- } while(!((cur_cmd != 10)&&(cur_cmd != 0)));
-/* 424 in tex82.bug */
- if (((cur_cmd == 26) && (abs(mode)!= 1)) ||
- ((cur_cmd == 27) && (abs(mode)== 1)))
- {
-/* begin append_glue; subtype(tail):=box_context-(leader_flag-a_leaders); */
- append_glue ();
-/* -(2^30 + 513 - 100) */
- mem[tail].hh.b1 = boxcontext -(1073742237L);
- mem[tail + 1].hh.v.RH = cur_box;
- }
- else {
- print_err("Leaders not followed by proper glue");
- help3("You should say `\\leaders <box or rule><hskip or vskip>'.",
- "I found the <box or rule>, but there's no suitable",
- "<hskip or vskip>, so I'm ignoring these leaders.");
- back_error ();
- flush_node_list(cur_box);
- }
- }
- else ship_out(cur_box);
-}
-/* called only from tex8.c */
-/* sec 1079 */
-void begin_box_(integer boxcontext)
-{/* 10 30 */
- halfword p, q;
- quarterword m;
- halfword k;
- eight_bits n;
- switch(cur_chr){
- case 0 :
- {
- scan_eight_bit_int ();
- cur_box = eqtb[(hash_size + 1578) + cur_val].hh.v.RH;
- eqtb[(hash_size + 1578) + cur_val].hh.v.RH = 0;
- }
- break;
- case 1 :
- {
- scan_eight_bit_int ();
- cur_box = copy_node_list(eqtb[(hash_size + 1578) + cur_val].hh.v.RH);
- }
- break;
- case 2 :
- {
- cur_box = 0;
- if (abs(mode)== 203)
- {
- you_cant ();
- help1("Sorry; this \\lastbox will be void.");
- error ();
- }
- else if ((mode == 1)&&(head == cur_list
- .tail_field))
- {
- you_cant ();
- help2("Sorry...I usually can't take things from the current page.",
- "This \\lastbox will therefore be void.");
- error ();
- }
- else {
- if (!(tail >= hi_mem_min))
- if ((mem[tail].hh.b0 == 0)||(mem[cur_list
- .tail_field].hh.b0 == 1))
- {
- q = head;
- do {
- p = q;
- if (!(q >= hi_mem_min))
- if (mem[q].hh.b0 == 7)
- {
- {
- register integer for_end;
- m = 1;
- for_end = mem[q].hh.b1;
- if (m <= for_end) do
- p = mem[p].hh.v.RH;
- while(m++ < for_end);
- }
- if (p == tail)
- goto lab30;
- }
- q = mem[p].hh.v.RH;
- } while(!(q == tail));
- cur_box = tail;
- mem[cur_box + 4].cint = 0;
- tail = p;
- mem[p].hh.v.RH = 0;
- lab30:;
- }
- }
- }
- break;
- case 3 :
- {
- scan_eight_bit_int ();
- n = cur_val;
- if (! scan_keyword("to")) /* to */
- {
- print_err("Missing `to' inserted");
- help2("I'm working on `\\vsplit<box number> to <dimen>';",
- "will look for the <dimen> next.");
- error ();
- }
- scan_dimen(false, false, false);
- cur_box = vsplit(n, cur_val);
- }
- break;
- default:
- {
- k = cur_chr - 4;
- save_stack[save_ptr + 0].cint = boxcontext;
- if (k == 102)
- if ((boxcontext < 1073741824L)&& /* 2^30 */
- (abs(mode)== 1)
- )
- scan_spec(3, true);
- else scan_spec(2, true);
- else {
-
- if (k == 1)
- scan_spec(4, true);
- else {
-
- scan_spec(5, true);
- k = 1;
- }
- normal_paragraph ();
- }
- push_nest ();
- mode = - (integer) k;
- if (k == 1)
- {
- cur_list.aux_field.cint = ignore_depth;
- if (eqtb[(hash_size + 1318)].hh.v.RH != 0)/* everyhbox */
- begin_token_list(eqtb[(hash_size + 1318)].hh.v.RH, 11);
- }
- else {
-
- space_factor = 1000;
- if (eqtb[(hash_size + 1317)].hh.v.RH != 0)/* everyhbox */
- begin_token_list(eqtb[(hash_size + 1317)].hh.v.RH, 10);
- }
- return;
- }
- break;
- }
- box_end(boxcontext);
-}
-/* sec 1084 */
-void scan_box_(integer boxcontext)
-{
- do {
- get_x_token ();
- } while(!((cur_cmd != 10)&&(cur_cmd != 0)));
- if (cur_cmd == 20){
- begin_box(boxcontext);
- }
- else if ((boxcontext >= 1073742337L)&& /* (2^30 + 512 + 1) */
- ((cur_cmd == 36)||(cur_cmd == 35)))
- {
- cur_box = scan_rule_spec ();
- box_end(boxcontext);
- }
- else {
- print_err("A <box> was supposed to be here");
- help3("I was expecting to see \\hbox or \\vbox or \\copy or \\box or",
- "something like that. So you might find something missing in",
- "your output. But keep trying; you can fix this later.");
- back_error ();
- }
-}
-/****************************************************************************/
-void package_ (small_number);
-/****************************************************************************/
-/* sec 1091 */
-small_number norm_min_ (integer h)
-{register
-/* small_number Result; */
- int Result; /* 95/Jan/7 */
- if (h <= 0)
- Result = 1;
- else if (h >= 63)
- Result = 63;
- else Result = h;
- return Result;
-}
-/* sec 1091 */
-void new_graf_(bool indented)
-{
- prev_graf = 0;
- if ((mode == 1)||(head != cur_list
- .tail_field))
- {
- mem[tail].hh.v.RH = new_param_glue(2);
- tail = mem[tail].hh.v.RH;
- }
-/* used to be followingin 3.141 */
-/* cur_list .lhmfield = norm_min(eqtb[(hash_size + 3214)].cint); */
-/* cur_list .rhmfield = norm_min(eqtb[(hash_size + 3215)].cint); */
- push_nest ();
- mode = 102;
- space_factor = 1000;
-/* changes here since 3.141 */
- if (eqtb[(hash_size + 3213)].cint <= 0)
- cur_lang = 0;
- else if (eqtb[(hash_size + 3213)].cint > 255)
- cur_lang = 0;
- else cur_lang = eqtb[(hash_size + 3213)].cint;
- clang = cur_lang;
- prev_graf =(norm_min(eqtb[(hash_size + 3214)].cint)* 64 +
- norm_min(eqtb[(hash_size + 3215)].cint)) * 65536L + cur_lang;
-/* eqtb ??? hash_size ? hash_size + hash_extra ? norm_min etc */
-/* *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** */
- if (indented)
- {
- tail = new_null_box ();
- mem[head].hh.v.RH = tail;
- mem[tail + 1].cint = eqtb[(hash_size + 3730)].cint;
- }
- if (eqtb[(hash_size + 1314)].hh.v.RH != 0) /* everypar */
- begin_token_list(eqtb[(hash_size + 1314)].hh.v.RH, 7);
- if (nest_ptr == 1){
- build_page ();
- }
-}
-/* procedure indent_in_hmode; l.21058 */
-/* sec 1093 */
-void indent_in_hmode (void)
-{
- halfword p, q;
- if (cur_chr > 0)
- {
- p = new_null_box ();
- mem[p + 1].cint = eqtb[(hash_size + 3730)].cint;
- if (abs(mode)== 102)
- space_factor = 1000;
- else {
-
- q = new_noad ();
- mem[q + 1].hh.v.RH = 2;
- mem[q + 1].hh.v.LH = p;
- p = q;
- }
- {
- mem[tail].hh.v.RH = p;
- tail = mem[tail].hh.v.RH;
- }
- }
-}
-/* only called from tex8.c */
-/* sec 1095 */
-void head_for_vmode (void)
-{
- if (mode < 0)
- if (cur_cmd != 36){
- off_save ();
- }
- else {
- print_err("You can't use `");
- print_esc("hrule");
- print_string("' here except with leaders");
- help2("To put a horizontal rule in an hbox or an alignment,",
- "you should use \\leaders or \\hrulefill (see The TeXbook).");
- error ();
- }
- else {
-
- back_input ();
- cur_tok = par_token;
- back_input ();
- cur_input.index_field = 4;
- }
-}
-/* sec 1096 */
-void end_graf (void)
-{
- if (mode == 102)
- {
- if (head == tail)
- pop_nest ();
- else line_break(eqtb[(hash_size + 3169)].cint);
- normal_paragraph ();
- error_count = 0;
- }
-}
-/* only called form tex8.c */
-/* sec 1099 */
-void begin_insert_or_adjust (void)
-{
- if (cur_cmd == 38)
- cur_val = 255;
- else {
-
- scan_eight_bit_int ();
- if (cur_val == 255)
- {
- print_err("You can't ");
- print_esc("insert");
- print_int(255);
- help1("I'm changing to \\insert0; box 255 is special.");
- error ();
- cur_val = 0;
- }
- }
- save_stack[save_ptr + 0].cint = cur_val;
- incr(save_ptr);
- new_save_level(11);
- scan_left_brace ();
- normal_paragraph ();
- push_nest ();
- mode = -1;
- cur_list.aux_field.cint = ignore_depth;
-}
-/* sec 1101 */
-void make_mark (void)
-{
- halfword p;
- p = scan_toks(false, true);
- p = get_node(2);
- mem[p].hh.b0 = 4;
- mem[p].hh.b1 = 0;
- mem[p + 1].cint = def_ref;
- mem[tail].hh.v.RH = p;
- tail = p;
-}
-/* sec 1103 */
-void append_penalty (void)
-{
- scan_int ();
- {
- mem[tail].hh.v.RH = new_penalty(cur_val);
- tail = mem[tail].hh.v.RH;
- }
- if (mode == 1){
- build_page ();
- }
-}
-/* only called from tex8.c */
-/* sec 1105 */
-void delete_last (void)
-{/* 10 */
- halfword p, q;
- quarterword m;
- if ((mode == 1) && (tail == cur_list.head_field))
- {
-/* if ((cur_chr != 10)||(last_glue != 262143L)) */
- if ((cur_chr != 10)||(last_glue != empty_flag))
- {
- you_cant ();
- help2("Sorry...I usually can't take things from the current page.",
- "Try `I\\vskip-\\lastskip' instead.");
- if (cur_chr == 11)
- help_line[0] = "Try `I\\kern-\\last_kern' instead.";
- else if (cur_chr != 10)
- help_line[0] = "Perhaps you can make the output routine do it.";
- error ();
- }
- }
- else {
-
- if (!(tail >= hi_mem_min))
- if (mem[tail].hh.b0 == cur_chr)
- {
- q = head;
- do {
- p = q;
- if (!(q >= hi_mem_min))
- if (mem[q].hh.b0 == 7)
- {
- {
- register integer for_end;
- m = 1;
- for_end = mem[q].hh.b1;
- if (m <= for_end) do
- p = mem[p].hh.v.RH;
- while(m++ < for_end);
- }
- if (p == tail)
- return;
- }
- q = mem[p].hh.v.RH;
- } while(!(q == tail));
- mem[p].hh.v.RH = 0;
- flush_node_list(tail);
- tail = p;
- }
- }
-}
-/* only called from tex8.c */
-/* procedure unpackage; l.21256 */
-/* sec 1110 */
-void unpackage (void)
-{/* 10 */
- halfword p;
- char c;
- c = cur_chr;
- scan_eight_bit_int ();
- p = eqtb[(hash_size + 1578) + cur_val].hh.v.RH;
- if (p == 0)/* if p=null then return; l.21261 */
- return;
- if ((abs(mode)== 203)||((abs(mode)
- == 1)&&(mem[p].hh.b0 != 1)) ||((abs(mode)==
- 102)&&(mem[p].hh.b0 != 0)))
- {
- print_err("Incompatible list can't be unboxed");
- help3("Sorry, Pandora. (You sneaky devil.)",
- "I refuse to unbox an \\hbox in vertical mode or vice versa.",
- "And I can't open any boxes in math mode.");
- error ();
- return;
- }
- if (c == 1)
- mem[tail].hh.v.RH = copy_node_list(mem[p + 5].hh
- .v.RH);
- else {
-
- mem[tail].hh.v.RH = mem[p + 5].hh.v.RH;
- eqtb[(hash_size + 1578) + cur_val].hh.v.RH = 0;
- free_node(p, 7);
- }
- while(mem[tail].hh.v.RH != 0)tail = mem
- [tail].hh.v.RH;
-}
-/* sec 1113 */
-void append_italic_correction (void)
-{/* 10 */
- halfword p;
- internal_font_number f;
- if (tail != head)
- {
- if ((tail >= hi_mem_min))
- p = tail;
- else if (mem[tail].hh.b0 == 6)
- p = tail + 1;
- else return;
- f = mem[p].hh.b0;
- {
- mem[tail].hh.v.RH = new_kern(font_info[italic_base[
- f]+(font_info[char_base[f]+ mem[p].hh.b1].qqqq.b2)/ 4]
- .cint);
- tail = mem[tail].hh.v.RH;
- }
- mem[tail].hh.b1 = 1;
- }
-}
-/* sec 1117 */
-void append_discretionary (void)
-{
- integer c;
- {
- mem[tail].hh.v.RH = new_disc ();
- tail = mem[tail].hh.v.RH;
- }
- if (cur_chr == 1)
- {
- c = hyphen_char[eqtb[(hash_size + 1834)].hh.v.RH];
- if (c >= 0)
- if (c < 256)
- mem[tail + 1].hh.v.LH = new_character(eqtb[(hash_size + 1834)]
- .hh.v.RH, c);
- }
- else {
-
- incr(save_ptr);
- save_stack[save_ptr - 1].cint = 0;
- new_save_level(10);
- scan_left_brace ();
- push_nest ();
- mode = -102;
- space_factor = 1000;
- }
-}
-/* only called form tex8.c */
-/* sec 1119 */
-void build_discretionary (void)
-{/* 30 10 */
- halfword p, q;
- integer n;
- unsave ();
- q = head;
- p = mem[q].hh.v.RH;
- n = 0;
- while(p != 0){
-
- if (!(p >= hi_mem_min))
- if (mem[p].hh.b0 > 2)
- if (mem[p].hh.b0 != 11)
- if (mem[p].hh.b0 != 6)
- {
- print_err("Improper discretionary list");
- help1("Discretionary lists must contain only boxes and kerns.");
- error ();
- begin_diagnostic ();
- print_nl("The following discretionary sublist has been deleted:"); /* */
- show_box(p);
- end_diagnostic(true);
- flush_node_list(p);
- mem[q].hh.v.RH = 0;
- goto lab30;
- }
- q = p;
- p = mem[q].hh.v.RH;
- incr(n);
- }
- lab30:;
- p = mem[head].hh.v.RH;
- pop_nest ();
- switch(save_stack[save_ptr - 1].cint)
- {case 0 :
- mem[tail + 1].hh.v.LH = p;
- break;
- case 1 :
- mem[tail + 1].hh.v.RH = p;
- break;
- case 2 :
- {
- if ((n > 0)&&(abs(mode)== 203))
- {
- print_err("Illegal math ");
- print_esc("discretionary");
- help2("Sorry: The third part of a discretionary break must be",
- "empty, in math formulas. I had to delete your third part.");
- flush_node_list(p);
- n = 0;
- error ();
- }
- else mem[tail].hh.v.RH = p;
-/* if n <= max_quarterword then replace_count(tail) <- n; p.1120 */
-/* if (n <= 255) */ /* 94/Apr/4 ? */
- if (n <= max_quarterword) /* 96/Oct/12 ??? */
- mem[tail].hh.b1 = n;
- else {
- print_err("Discretionary list is too long");
- help2("Wow---I never thought anybody would tweak me here.",
- "You can't seriously need such a huge discretionary list?");
- error ();
- }
- if (n > 0)
- tail = q;
- decr(save_ptr);
- return;
- }
- break;
- }
- incr(save_stack[save_ptr - 1].cint);
- new_save_level(10);
- scan_left_brace ();
- push_nest ();
- mode = -102;
- space_factor = 1000;
-}
-/* called only from tex8.c */
-/* sec 1123 */
-void make_accent (void)
-{
- real s, t;
- halfword p, q, r;
- internal_font_number f;
- scaled a, h, x, w, delta;
- ffourquarters i;
- scan_char_num ();
- f = eqtb[(hash_size + 1834)].hh.v.RH;
- p = new_character(f, cur_val);
- if (p != 0)
- {
- x = font_info[5 + param_base[f]].cint;
- s = font_info[1 + param_base[f]].cint / ((double) 65536.0);
- a = font_info[width_base[f]+ font_info[char_base[f]+ mem[p]
- .hh.b1].qqqq.b0].cint;
- do_assignments ();
- q = 0;
- f = eqtb[(hash_size + 1834)].hh.v.RH;
- if ((cur_cmd == 11)||(cur_cmd == 12)||(cur_cmd == 68))
- q = new_character(f, cur_chr);
- else if (cur_cmd == 16)
- {
- scan_char_num ();
- q = new_character(f, cur_val);
- }
- else back_input ();
- if (q != 0)
- {
- t = font_info[1 + param_base[f]].cint / ((double) 65536.0);
- i = font_info[char_base[f]+ mem[q].hh.b1].qqqq;
- w = font_info[width_base[f]+ i.b0].cint;
- h = font_info[height_base[f]+(i.b1)/ 16].cint;
- if (h != x)
- {
- p = hpack(p, 0, 1);
- mem[p + 4].cint = x - h;
- }
- delta = round((w - a)/ ((double) 2.0)+ h * t - x * s);
- r = new_kern(delta);
- mem[r].hh.b1 = 2;
- mem[tail].hh.v.RH = r;
- mem[r].hh.v.RH = p;
- tail = new_kern(- (integer) a - delta);
- mem[tail].hh.b1 = 2;
- mem[p].hh.v.RH = tail;
- p = q;
- }
- mem[tail].hh.v.RH = p;
- tail = p;
- space_factor = 1000;
- }
-}
-/* sec 1127 */
-void align_error (void)
-{
- if (abs(align_state)> 2){
- print_err("Misplaced ");
- print_cmd_chr(cur_cmd, cur_chr);
- if (cur_tok == 1062) {
- help6("I can't figure out why you would want to use a tab mark",
- "here. If you just want an ampersand, the remedy is",
- "simple: Just type `I\\&' now. But if some right brace",
- "up above has ended a previous alignment prematurely,",
- "you're probably due for more error messages, and you",
- "might try typing `S' now just to see what is salvageable.");
- }
- else {
- help5("I can't figure out why you would want to use a tab mark",
- "or \\cr or \\span just now. If something like a right brace",
- "up above has ended a previous alignment prematurely,",
- "you're probably due for more error messages, and you",
- "might try typing `S' now just to see what is salvageable.");
- }
- error ();
- }
- else {
- back_input ();
- if (align_state < 0) {
- print_err("Missing { inserted");
- incr(align_state);
- cur_tok = 379; /* belowdisplayshortskip ? */
- }
- else {
- print_err("Missing } inserted");
- decr(align_state);
- cur_tok = 637;
- }
- help3("I've put in what seems to be necessary to fix",
- "the current column of the current alignment.",
- "Try to go on, since this might almost work.");
- ins_error ();
- }
-}
-/* sec 1129 */
-void noalign_error (void)
-{
- print_err("Misplaced ");
- print_esc("noalign");
- help2("I expect to see \\noalign only after the \\cr of",
- "an alignment. Proceed, and I'll ignore this case.");
- error ();
-}
-/* only called from tex8.c */
-/* sec 1129 */
-void omit_error (void)
-{
- print_err("Misplaced ");
- print_esc("omit");
- help2("I expect to see \\omit only after tab marks or the \\cr of",
- "an alignment. Proceed, and I'll ignore this case.");
- error ();
-}
-/* sec 1131 */
-void do_endv (void)
-{
- if (cur_group == 6) {
- end_graf ();
- if (fin_col ())fin_row ();
- }
- else off_save ();
-}
-/* only called form tex8.c */
-/* sec 1135 */
-void cs_error (void)
-{
- print_err("Extra ");
- print_esc("endcsname");
- help1("I'm ignoring this, since I wasn't doing a \\csname.");
- error ();
-}
-/* sec 1136 */
-void push_math_(group_code c)
-{
- push_nest ();
- mode = -203;
- cur_list.aux_field.cint = 0;
- new_save_level(c);
-}
-/* sec 1138 */
-void init_math (void)
-{/* 21 40 45 30 */
- scaled w;
- scaled l;
- scaled s;
- halfword p;
- halfword q;
- internal_font_number f;
- integer n;
- scaled v;
- scaled d;
- get_token ();
- if ((cur_cmd == 3)&&(mode > 0))
- {
- if (head == tail)
- {
- pop_nest ();
- w = -1073741823L; /* - (2^30 - 1) */
- }
- else {
-
- line_break(eqtb[(hash_size + 3170)].cint);
- v = mem[just_box + 4].cint + 2 * font_info[6 +
- param_base[eqtb[(hash_size + 1834)].hh.v.RH]].cint;
- w = -1073741823L; /* - (2^30 - 1) */
- p = mem[just_box + 5].hh.v.RH;
- while(p != 0){
-
- lab21: if ((p >= hi_mem_min))
- {
- f = mem[p].hh.b0;
- d = font_info[width_base[f]+ font_info[char_base[f]+ mem[p
- ].hh.b1].qqqq.b0].cint;
- goto lab40;
- }
- switch(mem[p].hh.b0)
- {case 0 :
- case 1 :
- case 2 :
- {
- d = mem[p + 1].cint;
- goto lab40;
- }
- break;
- case 6 :
- {
- mem[lig_trick]= mem[p + 1];
- mem[lig_trick].hh.v.RH = mem[p].hh.v.RH;
- p = lig_trick;
- goto lab21;
- }
- break;
- case 11 :
- case 9 :
- d = mem[p + 1].cint;
- break;
- case 10 :
- {
- q = mem[p + 1].hh.v.LH;
- d = mem[q + 1].cint;
- if (mem[just_box + 5].hh.b0 == 1)
- {
- if ((mem[just_box + 5].hh.b1 == mem[q].hh.b0)&&(mem
- [q + 2].cint != 0))
- v = 1073741823L; /* - (2^30 - 1) */
- }
- else if (mem[just_box + 5].hh.b0 == 2)
- {
- if ((mem[just_box + 5].hh.b1 == mem[q].hh.b1)&&(mem
- [q + 3].cint != 0))
- v = 1073741823L; /* - (2^30 - 1) */
- }
- if (mem[p].hh.b1 >= 100)
- goto lab40;
- }
- break;
- case 8 :
- d = 0;
- break;
- default:
- d = 0;
- break;
- }
- if (v < 1073741823L) /* - (2^30 - 1) */
- v = v + d;
- goto lab45;
- lab40: if (v < 1073741823L) /* - (2^30 - 1) */
- {
- v = v + d;
- w = v;
- }
- else {
-
- w = 1073741823L; /* - (2^30 - 1) */
- goto lab30;
- }
- lab45: p = mem[p].hh.v.RH;
- }
- lab30:;
- }
- if (eqtb[(hash_size + 1312)].hh.v.RH == 0)
- if ((eqtb[(hash_size + 3747)].cint != 0)&&(((eqtb[(hash_size + 3204)].cint >= 0)&&
- (prev_graf + 2 > eqtb[(hash_size + 3204)].cint)) ||(prev_graf +
- 1 < - (integer) eqtb[(hash_size + 3204)].cint)))
- {
- l = eqtb[(hash_size + 3733)].cint - abs(eqtb[(hash_size + 3747)].cint);
- if (eqtb[(hash_size + 3747)].cint > 0)
- s = eqtb[(hash_size + 3747)].cint;
- else s = 0;
- }
- else {
-
- l = eqtb[(hash_size + 3733)].cint;
- s = 0;
- }
- else {
-
- n = mem[eqtb[(hash_size + 1312)].hh.v.RH].hh.v.LH;
- if (prev_graf + 2 >= n)
- p = eqtb[(hash_size + 1312)].hh.v.RH + 2 * n;
- else p = eqtb[(hash_size + 1312)].hh.v.RH + 2 *(prev_graf + 2);
- s = mem[p - 1].cint;
- l = mem[p].cint;
- }
- push_math(15);
- mode = 203;
- eq_word_define((hash_size + 3207), -1);
- eq_word_define((hash_size + 3743), w);
- eq_word_define((hash_size + 3744), l);
- eq_word_define((hash_size + 3745), s);
- if (eqtb[(hash_size + 1316)].hh.v.RH != 0)/* everydisplay */
- begin_token_list(eqtb[(hash_size + 1316)].hh.v.RH, 9);
- if (nest_ptr == 1){
- build_page ();
- }
- }
- else {
-
- back_input ();
- {
- push_math(15);
- eq_word_define((hash_size + 3207), -1);
- if (eqtb[(hash_size + 1315)].hh.v.RH != 0)/* everymath */
- begin_token_list(eqtb[(hash_size + 1315)].hh.v.RH, 8);
- }
- }
-}
-/* sec 1142 */
-void start_eq_no (void)
-{
- save_stack[save_ptr + 0].cint = cur_chr;
- incr(save_ptr);
- {
- push_math(15);
- eq_word_define((hash_size + 3207), -1);
- if (eqtb[(hash_size + 1315)].hh.v.RH != 0)/* everymath */
- begin_token_list(eqtb[(hash_size + 1315)].hh.v.RH, 8);
- }
-}
-/* sec 1151 */
-void scan_math_(halfword p)
-{/* 20 21 10 */
- integer c;
- lab20: do {
- get_x_token ();
- } while(!((cur_cmd != 10)&&(cur_cmd != 0)));
- lab21: switch(cur_cmd)
- {case 11 :
- case 12 :
- case 68 :
- {
- c = eqtb[(hash_size + 2907) + cur_chr].hh.v.RH;
- if (c == 32768L)
- {
- {
- cur_cs = cur_chr + 1;
- cur_cmd = eqtb[cur_cs].hh.b0;
- cur_chr = eqtb[cur_cs].hh.v.RH;
- x_token ();
- back_input ();
- }
- goto lab20;
- }
- }
- break;
- case 16 :
- {
- scan_char_num ();
- cur_chr = cur_val;
- cur_cmd = 68;
- goto lab21;
- }
- break;
- case 17 :
- {
- scan_fifteen_bit_int ();
- c = cur_val;
- }
- break;
- case 69 :
- c = cur_chr;
- break;
- case 15 :
- {
- scan_twenty_seven_bit_int ();
- c = cur_val / 4096;
-/* c = cur_val >> 12; */
- }
- break;
- default:
- {
- back_input ();
- scan_left_brace ();
- save_stack[save_ptr + 0].cint = p;
- incr(save_ptr);
- push_math(9);
- return;
- }
- break;
- }
- mem[p].hh.v.RH = 1;
- mem[p].hh.b1 = c % 256;
-/* mem[p].hh.b1 = c & 255; */ /* last 8 bits */
- if ((c >= 28672)&& /* 32768 - 4096 ??? if (c>=var_code) and ... */
- ((eqtb[(hash_size + 3207)].cint >= 0)&&
- (eqtb[(hash_size + 3207)].cint < 16)))
- mem[p].hh.b0 = eqtb[(hash_size + 3207)].cint;
- else mem[p].hh.b0 =(c / 256)% 16;
-/* else mem[p].hh.b0 =(c >> 8)& 15; */ /* 4 bits to left */
-}
-/* sec 1155 */
-void set_math_char_(integer c)
-{
- halfword p;
- if (c >= 32768L)
- {
- cur_cs = cur_chr + 1; /* ??? */
-/* cur_cmd = eqtb[eqtbextra + cur_cs].hh.b0; */ /* was wrong ??? */
- cur_cmd = eqtb[cur_cs].hh.b0;
-/* cur_chr = eqtb[cur_cs].hh.v.RH; */ /* should have been eqtbextra ? */
- cur_chr = eqtb[cur_cs].hh.v.RH;
- x_token ();
- back_input ();
- }
- else {
-
- p = new_noad ();
- mem[p + 1].hh.v.RH = 1;
- mem[p + 1].hh.b1 = c % 256;
-/* mem[p + 1].hh.b1 = c & 255; */ /* last 8 bits */
- mem[p + 1].hh.b0 =(c / 256)% 16;
-/* mem[p + 1].hh.b0 =(c >> 8)& 15; */ /* 4 bits to left */
- if (c >= 28672) /* 32768 - 4096 ? */
- {
- if (((eqtb[(hash_size + 3207)].cint >= 0)&&(eqtb[(hash_size + 3207)].cint < 16))
- )
- mem[p + 1].hh.b0 = eqtb[(hash_size + 3207)].cint;
- mem[p].hh.b0 = 16;
- }
- else mem[p].hh.b0 = 16 +(c / 4096);
-/* else mem[p].hh.b0 = 16 +(c >> 12); */
- mem[tail].hh.v.RH = p;
- tail = p;
- }
-}
-/* sec 1159 */
-void math_limit_switch (void)
-{/* 10 */
- if (head != tail)
- if (mem[tail].hh.b0 == 17)
- {
- mem[tail].hh.b1 = cur_chr;
- return;
- }
- print_err("Limit controls must follow a math operator");
- help1("I'm ignoring this misplaced \\limits or \\nolimits command.");
- error ();
-}
-/* sec 1160 */
-void scan_delimiter_(halfword p, bool r)
-{
- if (r){
- scan_twenty_seven_bit_int ();
- }
- else {
-
- do {
- get_x_token ();
- } while(!((cur_cmd != 10)&&(cur_cmd != 0)));
- switch(cur_cmd)
- {case 11 :
- case 12 :
- cur_val = eqtb[(hash_size + 3474) + cur_chr].cint;
- break;
- case 15 :
- scan_twenty_seven_bit_int ();
- break;
- default:
- cur_val = -1;
- break;
- }
- }
- if (cur_val < 0)
- {
- print_err("Missing delimiter (. inserted)");
- help6("I was expecting to see something like `(' or `\\{' or",
- "`\\}' here. If you typed, e.g., `{' instead of `\\{', you",
- "should probably delete the `{' by typing `1' now, so that",
- "braces don't get unbalanced. Otherwise just proceed.",
- "Acceptable delimiters are characters whose \\delcode is",
- "nonnegative, or you can use `\\delimiter <delimiter code>'.");
- back_error ();
- cur_val = 0;
- }
-/* attempt to speed up - bkph */ /* is compiler smart enough already ? */
- mem[p].qqqq.b0 =(cur_val / 1048576L)% 16; /* 2^20 */
-/* mem[p].qqqq.b0 =(cur_val >> 20)& 15; */
- mem[p].qqqq.b1 =(cur_val / 4096)% 256;
-/* mem[p].qqqq.b1 =(cur_val >> 12)& 255; */
- mem[p].qqqq.b2 =(cur_val / 256)% 16;
-/* mem[p].qqqq.b2 =(cur_val >> 8)& 15; */
- mem[p].qqqq.b3 = cur_val % 256;
-/* mem[p].qqqq.b3 = cur_val & 255; */
-}
-/* sec 1163 */
-void math_radical (void)
-{
- {
- mem[tail].hh.v.RH = get_node(5);
- tail = mem[tail].hh.v.RH;
- }
- mem[tail].hh.b0 = 24;
- mem[tail].hh.b1 = 0;
- mem[tail + 1].hh = empty_field;
- mem[tail + 3].hh = empty_field;
- mem[tail + 2].hh = empty_field;
- scan_delimiter(tail + 4, true);
- scan_math(tail + 1);
-}
-/* sec 1165 */
-void math_ac (void)
-{
- if (cur_cmd == 45)
- {
- print_err("Please use ");
- print_esc("mathaccent");
- print_string(" for accents in math mode");
- help2("I'm changing \\accent to \\mathaccent here; wish me luck.",
- "(Accents are not the same in formulas as they are in text.)");
- error ();
- }
- {
- mem[tail].hh.v.RH = get_node(5);
- tail = mem[tail].hh.v.RH;
- }
- mem[tail].hh.b0 = 28;
- mem[tail].hh.b1 = 0;
- mem[tail + 1].hh = empty_field;
- mem[tail + 3].hh = empty_field;
- mem[tail + 2].hh = empty_field;
- mem[tail + 4].hh.v.RH = 1;
- scan_fifteen_bit_int ();
- mem[tail + 4].hh.b1 = cur_val % 256;
-/* mem[tail + 4].hh.b1 = cur_val & 255; */
- if ((cur_val >= 28672)&& /* 32768 - 4096 ? */
- ((eqtb[(hash_size + 3207)].cint >= 0)&&
- (eqtb[(hash_size + 3207)].cint < 16)))
- mem[tail + 4].hh.b0 = eqtb[(hash_size + 3207)].cint;
- else mem[tail + 4].hh.b0 =(cur_val / 256)% 16;
-/* else mem[tail + 4].hh.b0 =(cur_val >> 8)& 15; */
- scan_math(tail + 1);
-}
-/* sec 1172 */
-void append_choices (void)
-{
- {
- mem[tail].hh.v.RH = new_choice ();
- tail = mem[tail].hh.v.RH;
- }
- incr(save_ptr);
- save_stack[save_ptr - 1].cint = 0;
- push_math(13);
- scan_left_brace ();
-}
-/* sec 1184 */
-halfword fin_mlist_(halfword p)
-{register halfword Result;
- halfword q;
- if (cur_list.aux_field.cint != 0)
- {
- mem[cur_list.aux_field.cint + 3].hh.v.RH = 3;
- mem[cur_list.aux_field.cint + 3].hh.v.LH = mem[head]
- .hh.v.RH;
- if (p == 0)
- q = cur_list.aux_field.cint;
- else {
- q = mem[cur_list.aux_field.cint + 2].hh.v.LH;
- if (mem[q].hh.b0 != 30){
- confusion("right");
- return 0; // abort_flag set
- }
- mem[cur_list.aux_field.cint + 2].hh.v.LH = mem[q].hh.v.RH;
- mem[q].hh.v.RH = cur_list.aux_field.cint;
- mem[cur_list.aux_field.cint].hh.v.RH = p;
- }
- }
- else {
- mem[tail].hh.v.RH = p;
- q = mem[head].hh.v.RH;
- }
- pop_nest ();
- Result = q;
- return Result;
-}
-/* sec 1174 */
-void build_choices (void)
-{/* 10 */
- halfword p;
- unsave ();
- p = fin_mlist(0);
- switch(save_stack[save_ptr - 1].cint)
- {case 0 :
- mem[tail + 1].hh.v.LH = p;
- break;
- case 1 :
- mem[tail + 1].hh.v.RH = p;
- break;
- case 2 :
- mem[tail + 2].hh.v.LH = p;
- break;
- case 3 :
- {
- mem[tail + 2].hh.v.RH = p;
- decr(save_ptr);
- return;
- }
- break;
- }
- incr(save_stack[save_ptr - 1].cint);
- push_math(13);
- scan_left_brace ();
-}
-/* sec 1176 */
-void sub_sup (void)
-{
-/* small_number t; */
- int t; /* 95/Jan/7 */
- halfword p;
- t = 0;
- p = 0;
- if (tail != head)
- if ((mem[tail].hh.b0 >= 16)&&
- (mem[tail].hh.b0 < 30))
- {
- p = tail + 2 + cur_cmd - 7;
- t = mem[p].hh.v.RH;
- }
- if ((p == 0)||(t != 0))
- {
- {
- mem[tail].hh.v.RH = new_noad ();
- tail = mem[tail].hh.v.RH;
- }
- p = tail + 2 + cur_cmd - 7;
- if (t != 0)
- {
- if (cur_cmd == 7)
- {
- print_err("Double superscript");
- help1("I treat `x^1^2' essentially like `x^1{}^2'.");
- }
- else {
- print_err("Double subscript");
- help1("I treat `x_1_2' essentially like `x_1{}_2'.");
- }
- error ();
- }
- }
- scan_math(p);
-}
-/* used to continue here with math_fraction etc in tex7.c */
-/*****************************************************************************/
-/* moved down here to avoid pragma optimize questions 96/Sep/12 */
-/* #pragma optimize("g", off) */ /* for MC VS compiler */
-/* #pragma optimize("a", off) */ /* for MC VS compiler */
-/* sec 1086 */
-void package_(small_number c)
-{
- scaled h;
- halfword p;
- scaled d;
- d = eqtb[(hash_size + 3737)].cint;
- unsave ();
- save_ptr = save_ptr - 3;
- if (mode == -102)
- cur_box = hpack(mem[head].hh.v.RH, save_stack[save_ptr
- + 2].cint, save_stack[save_ptr + 1].cint);
- else {
- cur_box = vpackage(mem[head].hh.v.RH, save_stack[
- save_ptr + 2].cint, save_stack[save_ptr + 1].cint, d);
- if (c == 4)
- {
- h = 0;
- p = mem[cur_box + 5].hh.v.RH;
- if (p != 0)
- if (mem[p].hh.b0 <= 2)
- h = mem[p + 3].cint;
- mem[cur_box + 2].cint = mem[cur_box + 2].cint - h + mem[cur_box +
- 3].cint;
- mem[cur_box + 3].cint = h;
- }
- }
- pop_nest ();
- box_end(save_stack[save_ptr + 0].cint);
-}
-/* #pragma optimize("g", on) */ /* for MC VS compiler */
-/* #pragma optimize("a", on) */ /* for MC VS compiler */
-/* #pragma optimize("a",) */ /* 94/Jan/25 */
-#pragma optimize ("", on) /* 96/Sep/12 */
-/****************************************************************************/
+/* Copyright 2014 Clerk Ma\r
+\r
+ This program is free software; you can redistribute it and/or modify\r
+ it under the terms of the GNU General Public License as published by\r
+ the Free Software Foundation; either version 2 of the License, or\r
+ (at your option) any later version.\r
+\r
+ This program is distributed in the hope that it will be useful, but\r
+ WITHOUT ANY WARRANTY; without even the implied warranty of\r
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU\r
+ General Public License for more details.\r
+\r
+ You should have received a copy of the GNU General Public License\r
+ along with this program; if not, write to the Free Software\r
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA\r
+ 02110-1301 USA. */\r
+\r
+#define EXTERN extern\r
+\r
+#include "yandytex.h"\r
+\r
+/* sec 0994 */\r
+void build_page (void)\r
+{\r
+ pointer p;\r
+ pointer q, r;\r
+ integer b, c;\r
+ integer pi;\r
+ /* unsigned char n; */\r
+ unsigned int n;\r
+ scaled delta, h, w;\r
+\r
+ if ((link(contrib_head) == 0) || output_active)\r
+ return;\r
+\r
+ do\r
+ {\r
+continu:\r
+ p = link(contrib_head);\r
+\r
+ if (last_glue != max_halfword)\r
+ delete_glue_ref(last_glue);\r
+\r
+ last_penalty = 0;\r
+ last_kern = 0;\r
+\r
+ if (type(p) == glue_node)\r
+ {\r
+ last_glue = glue_ptr(p);\r
+ add_glue_ref(last_glue);\r
+ }\r
+ else\r
+ {\r
+ last_glue = max_halfword;\r
+\r
+ if (type(p) == penalty_node)\r
+ last_penalty = penalty(p);\r
+ else if (type(p) == kern_node)\r
+ last_kern = width(p);\r
+ }\r
+\r
+ switch (type(p))\r
+ {\r
+ case hlist_node:\r
+ case vlist_node:\r
+ case rule_node:\r
+ if (page_contents < box_there)\r
+ {\r
+ if (page_contents == 0)\r
+ freeze_page_specs(box_there);\r
+ else\r
+ page_contents = box_there;\r
+\r
+ q = new_skip_param(top_skip_code);\r
+\r
+ if (width(temp_ptr) > height(p))\r
+ width(temp_ptr) = width(temp_ptr) - height(p);\r
+ else\r
+ width(temp_ptr) = 0;\r
+\r
+ link(q) = p;\r
+ link(contrib_head) = q;\r
+ goto continu;\r
+ }\r
+ else\r
+ {\r
+ page_total = page_total + page_depth + height(p);\r
+ page_depth = depth(p);\r
+ goto contribute;\r
+ }\r
+ break;\r
+\r
+ case whatsit_node:\r
+ goto contribute;\r
+ break;\r
+\r
+ case glue_node:\r
+ if (page_contents < box_there)\r
+ goto done1;\r
+ else if (precedes_break(page_tail))\r
+ pi = 0;\r
+ else\r
+ goto update_heights;\r
+ break;\r
+\r
+ case kern_node:\r
+ if (page_contents < box_there)\r
+ goto done1;\r
+ else if (link(p) == 0)\r
+ return;\r
+ else if (type(link(p)) == glue_node)\r
+ pi = 0;\r
+ else\r
+ goto update_heights;\r
+ break;\r
+\r
+ case penalty_node:\r
+ if (page_contents < box_there)\r
+ goto done1;\r
+ else\r
+ pi = penalty(p);\r
+ break;\r
+\r
+ case mark_node:\r
+ goto contribute;\r
+ break;\r
+\r
+ case ins_node:\r
+ {\r
+ if (page_contents == 0)\r
+ freeze_page_specs(inserts_only);\r
+\r
+ n = subtype(p);\r
+ r = page_ins_head;\r
+\r
+ while (n >= subtype(link(r)))\r
+ r = link(r);\r
+\r
+ n = n;\r
+\r
+ if (subtype(r) != n)\r
+ {\r
+ q = get_node(page_ins_node_size);\r
+ link(q) = link(r);\r
+ link(r) = q;\r
+ r = q;\r
+ subtype(r) = n;\r
+ type(r) = inserting;\r
+ ensure_vbox(n);\r
+\r
+ if (box(n) == 0)\r
+ height(r) = 0;\r
+ else\r
+ height(r) = height(box(n)) + depth(box(n));\r
+\r
+ best_ins_ptr(r) = 0;\r
+ q = skip(n);\r
+\r
+ if (count(n) == 1000)\r
+ h = height(r);\r
+ else\r
+ h = x_over_n(height(r), 1000) * count(n);\r
+\r
+ page_goal = page_goal - h - width(q);\r
+ page_so_far[2 + stretch_order(q)] = page_so_far[2 + stretch_order(q)] + stretch(q);\r
+ page_shrink = page_shrink + shrink(q);\r
+\r
+ if ((shrink_order(q) != normal) && (shrink(q) != 0))\r
+ {\r
+ print_err("Infinite glue shrinkage inserted from ");\r
+ print_esc("skip");\r
+ print_int(n);\r
+ help3("The correction glue for page breaking with insertions",\r
+ "must have finite shrinkability. But you may proceed,",\r
+ "since the offensive shrinkability has been made finite.");\r
+ error();\r
+ }\r
+ }\r
+\r
+ if (type(r) == split_up)\r
+ insert_penalties = insert_penalties + float_cost(p);\r
+ else\r
+ {\r
+ last_ins_ptr(r) = p;\r
+ delta = page_goal - page_total - page_depth + page_shrink;\r
+\r
+ if (count(n) == 1000)\r
+ h = height(p);\r
+ else\r
+ h = x_over_n(height(p), 1000) * count(n);\r
+\r
+ if (((h <= 0) || (h <= delta)) && (height(p) + height(r) <= dimen(n)))\r
+ {\r
+ page_goal = page_goal - h;\r
+ height(r) = height(r) + height(p);\r
+ }\r
+ else\r
+ {\r
+ if (count(n) <= 0)\r
+ w = max_dimen;\r
+ else\r
+ {\r
+ w = page_goal - page_total - page_depth;\r
+\r
+ if (count(n) != 1000)\r
+ w = x_over_n(w, count(n)) * 1000;\r
+ }\r
+\r
+ if (w > dimen(n) - height(r))\r
+ w = dimen(n) - height(r);\r
+\r
+ q = vert_break(ins_ptr(p), w, depth(p));\r
+ height(r) = height(r) + best_height_plus_depth;\r
+\r
+#ifdef STAT\r
+ if (tracing_pages > 0)\r
+ {\r
+ begin_diagnostic();\r
+ print_nl("% split");\r
+ print_int(n);\r
+ prints(" to");\r
+ print_scaled(w);\r
+ print_char(',');\r
+ print_scaled(best_height_plus_depth);\r
+ prints(" p=");\r
+\r
+ if (q == 0)\r
+ print_int(eject_penalty);\r
+ else if (type(q) == penalty_node)\r
+ print_int(penalty(q));\r
+ else\r
+ print_char('0');\r
+\r
+ end_diagnostic(false);\r
+ }\r
+#endif\r
+ if (count(n) != 1000)\r
+ best_height_plus_depth = x_over_n(best_height_plus_depth, 1000) * count(n);\r
+\r
+ page_goal = page_goal - best_height_plus_depth;\r
+ type(r) = split_up;\r
+ broken_ptr(r) = q;\r
+ broken_ins(r) = p;\r
+\r
+ if (q == 0)\r
+ insert_penalties = insert_penalties + (eject_penalty);\r
+ else if (type(q) == penalty_node)\r
+ insert_penalties = insert_penalties + penalty(q);\r
+ }\r
+ }\r
+ goto contribute;\r
+ }\r
+ break;\r
+\r
+ default:\r
+ {\r
+ confusion("page");\r
+ return;\r
+ }\r
+ break;\r
+ }\r
+\r
+ if (pi < inf_penalty)\r
+ {\r
+ if (page_total < page_goal)\r
+ if ((page_so_far[3] != 0) || (page_so_far[4] != 0) || (page_so_far[5] != 0))\r
+ b = 0;\r
+ else\r
+ b = badness(page_goal - page_total, page_so_far[2]);\r
+ else if (page_total - page_goal > page_shrink)\r
+ b = awful_bad;\r
+ else\r
+ b = badness(page_total - page_goal, page_shrink);\r
+ \r
+ if (b < awful_bad)\r
+ if (pi <= eject_penalty)\r
+ c = pi; \r
+ else if (b < inf_bad)\r
+ c = b + pi + insert_penalties;\r
+ else\r
+ c = deplorable;\r
+ else\r
+ c = b;\r
+\r
+ if (insert_penalties >= 10000)\r
+ c = awful_bad;\r
+\r
+#ifdef STAT\r
+ if (tracing_pages > 0)\r
+ {\r
+ begin_diagnostic();\r
+ print_nl("%");\r
+ prints(" t=");\r
+ print_totals();\r
+ prints(" g=");\r
+ print_scaled(page_goal);\r
+ prints(" b=");\r
+\r
+ if (b == awful_bad)\r
+ print_char('*');\r
+ else\r
+ print_int(b);\r
+\r
+ prints(" p=");\r
+ print_int(pi);\r
+ prints(" c=");\r
+\r
+ if (c == awful_bad)\r
+ print_char('*');\r
+ else\r
+ print_int(c);\r
+\r
+ if (c <= least_page_cost)\r
+ print_char('#');\r
+\r
+ end_diagnostic(false);\r
+ }\r
+#endif\r
+\r
+ if (c <= least_page_cost)\r
+ {\r
+ best_page_break = p;\r
+ best_size = page_goal;\r
+ least_page_cost = c;\r
+ r = link(page_ins_head);\r
+\r
+ while (r != page_ins_head)\r
+ {\r
+ best_ins_ptr(r) = last_ins_ptr(r);\r
+ r = link(r);\r
+ }\r
+ }\r
+\r
+ if ((c == awful_bad) || (pi <= eject_penalty))\r
+ {\r
+ fire_up(p);\r
+\r
+ if (output_active)\r
+ return;\r
+\r
+ goto done;\r
+ }\r
+ }\r
+\r
+ if ((type(p) < glue_node) || (type(p) > kern_node))\r
+ goto contribute;\r
+\r
+update_heights:\r
+ if (type(p) == kern_node)\r
+ q = p;\r
+ else\r
+ {\r
+ q = glue_ptr(p);\r
+ page_so_far[2 + stretch_order(q)] = page_so_far[2 + stretch_order(q)] + stretch(q);\r
+ page_shrink = page_shrink + shrink(q);\r
+\r
+ if ((shrink_order(q) != normal) && (shrink(q) != 0))\r
+ {\r
+ print_err("Infinite glue shrinkage found on current page");\r
+ help4("The page about to be output contains some infinitely",\r
+ "shrinkable glue, e.g., `\\vss' or `\\vskip 0pt minus 1fil'.",\r
+ "Such glue doesn't belong there; but you can safely proceed,",\r
+ "since the offensive shrinkability has been made finite.");\r
+ error();\r
+ r = new_spec(q);\r
+ shrink_order(r) = normal;\r
+ delete_glue_ref(q);\r
+ glue_ptr(p) = r;\r
+ q = r;\r
+ }\r
+ }\r
+\r
+ page_total = page_total + page_depth + width(q);\r
+ page_depth = 0;\r
+\r
+contribute:\r
+ if (page_depth > page_max_depth)\r
+ {\r
+ page_total = page_total + page_depth - page_max_depth;\r
+ page_depth = page_max_depth;\r
+ }\r
+\r
+ link(page_tail) = p;\r
+ page_tail = p;\r
+ link(contrib_head) = link(p);\r
+ link(p) = 0;\r
+ goto done;\r
+\r
+done1:\r
+ link(contrib_head) = link(p);\r
+ link(p) = 0;\r
+ flush_node_list(p);\r
+done:;\r
+ }\r
+ while (!(link(contrib_head) == 0));\r
+\r
+ if (nest_ptr == 0)\r
+ tail = contrib_head;\r
+ else\r
+ nest[0].tail_field = contrib_head;\r
+} \r
+/* sec 1043 */\r
+void app_space (void)\r
+{\r
+ pointer q;\r
+\r
+ if ((space_factor >= 2000) && (xspace_skip != zero_glue))\r
+ q = new_param_glue(xspace_skip_code);\r
+ else\r
+ {\r
+ if (space_skip != zero_glue)\r
+ main_p = space_skip;\r
+ else\r
+ {\r
+ main_p = font_glue[cur_font];\r
+\r
+ if (main_p == 0)\r
+ {\r
+ main_p = new_spec(zero_glue);\r
+ main_k = param_base[cur_font] + space_code;\r
+ width(main_p) = font_info[main_k].cint;\r
+ stretch(main_p) = font_info[main_k + 1].cint;\r
+ shrink(main_p) = font_info[main_k + 2].cint;\r
+ font_glue[cur_font] = main_p;\r
+ }\r
+ }\r
+\r
+ main_p = new_spec(main_p);\r
+\r
+ if (space_factor >= 2000)\r
+ width(main_p) = width(main_p) + extra_space(cur_font);\r
+\r
+ stretch(main_p) = xn_over_d(stretch(main_p), space_factor, 1000);\r
+ shrink(main_p) = xn_over_d(shrink(main_p), 1000, space_factor);\r
+ q = new_glue(main_p);\r
+ glue_ref_count(main_p) = 0;\r
+ }\r
+\r
+ link(tail) = q;\r
+ tail = q;\r
+}\r
+/* sec 1047 */\r
+void insert_dollar_sign (void)\r
+{\r
+ back_input();\r
+ cur_tok = math_shift_token + '$';\r
+ print_err("Missing $ inserted");\r
+ help2("I've inserted a begin-math/end-math symbol since I think",\r
+ "you left one out. Proceed, with fingers crossed.");\r
+ ins_error();\r
+}\r
+/* sec 1049 */\r
+void you_cant (void)\r
+{\r
+ print_err("You can't use `");\r
+ print_cmd_chr(cur_cmd, cur_chr);\r
+ prints("' in ");\r
+ print_mode(mode);\r
+}\r
+/* sec 1050 */\r
+void report_illegal_case (void)\r
+{\r
+ you_cant();\r
+ help4("Sorry, but I'm not programmed to handle this case;",\r
+ "I'll just pretend that you didn't ask for it.",\r
+ "If you're in the wrong mode, you might be able to",\r
+ "return to the right one by typing `I}' or `I$' or `I\\par'.");\r
+ error();\r
+}\r
+/* sec 1051 */\r
+boolean privileged (void)\r
+{\r
+ if (mode > 0)\r
+ return true;\r
+ else\r
+ {\r
+ report_illegal_case();\r
+ return false;\r
+ }\r
+}\r
+/* sec 1054 */\r
+boolean its_all_over (void)\r
+{\r
+ if (privileged())\r
+ {\r
+ if ((page_head == page_tail) && (head == tail) && (dead_cycles == 0))\r
+ {\r
+ return true;\r
+ }\r
+\r
+ back_input();\r
+ tail_append(new_null_box());\r
+ width(tail) = hsize;\r
+ tail_append(new_glue(fill_glue));\r
+ tail_append(new_penalty(-1073741824L));\r
+ build_page();\r
+ }\r
+\r
+ return false;\r
+}\r
+/* sec 1060 */\r
+void append_glue (void)\r
+{\r
+ small_number s;\r
+\r
+ s = cur_chr;\r
+\r
+ switch (s)\r
+ {\r
+ case fil_code:\r
+ cur_val = fil_glue;\r
+ break;\r
+\r
+ case fill_code:\r
+ cur_val = fill_glue;\r
+ break;\r
+\r
+ case ss_code:\r
+ cur_val = ss_glue;\r
+ break;\r
+\r
+ case fil_neg_code:\r
+ cur_val = fil_neg_glue;\r
+ break;\r
+\r
+ case skip_code:\r
+ scan_glue(glue_val);\r
+ break;\r
+\r
+ case mskip_code:\r
+ scan_glue(mu_val);\r
+ break;\r
+ }\r
+\r
+ tail_append(new_glue(cur_val));\r
+\r
+ if (s >= skip_code)\r
+ {\r
+ decr(glue_ref_count(cur_val));\r
+\r
+ if (s > skip_code)\r
+ subtype(tail) = mu_glue;\r
+ }\r
+}\r
+/* sec 1061 */\r
+void append_kern (void)\r
+{ \r
+ quarterword s;\r
+\r
+ s = cur_chr;\r
+\r
+ scan_dimen((s == mu_glue), false, false);\r
+ tail_append(new_kern(cur_val));\r
+ subtype(tail) = s;\r
+}\r
+/* sec 1064 */\r
+void off_save (void)\r
+{\r
+ pointer p;\r
+\r
+ if (cur_group == bottom_level)\r
+ {\r
+ print_err("Extra ");\r
+ print_cmd_chr(cur_cmd, cur_chr);\r
+ help1("Things are pretty mixed up, but I think the worst is over.");\r
+ error();\r
+ }\r
+ else\r
+ {\r
+ back_input();\r
+ p = get_avail();\r
+ link(temp_head) = p;\r
+ print_err("Missing ");\r
+\r
+ switch (cur_group)\r
+ {\r
+ case semi_simple_group:\r
+ {\r
+ info(p) = cs_token_flag + frozen_end_group;\r
+ print_esc("endgroup");\r
+ }\r
+ break;\r
+\r
+ case math_shift_group:\r
+ {\r
+ info(p) = math_shift_token + '$';\r
+ print_char('$');\r
+ }\r
+ break;\r
+\r
+ case math_left_group:\r
+ {\r
+ info(p) = cs_token_flag + frozen_right;\r
+ link(p) = get_avail();\r
+ p = link(p);\r
+ info(p) = other_token + '.';\r
+ print_esc("right.");\r
+ }\r
+ break;\r
+\r
+ default:\r
+ {\r
+ info(p) = right_brace_token + '}';\r
+ print_char('}');\r
+ }\r
+ break;\r
+ }\r
+\r
+ prints(" inserted");\r
+ ins_list(link(temp_head));\r
+ help5("I've inserted something that you may have forgotten.",\r
+ "(See the <inserted text> above.)",\r
+ "With luck, this will get me unwedged. But if you",\r
+ "really didn't forget anything, try typing `2' now; then",\r
+ "my insertion and my current dilemma will both disappear.");\r
+ error();\r
+ }\r
+}\r
+/* sec 1069 */\r
+void extra_right_brace (void)\r
+{\r
+ print_err("Extra }, or forgotten ");\r
+\r
+ switch (cur_group)\r
+ {\r
+ case semi_simple_group:\r
+ print_esc("endgroup");\r
+ break;\r
+\r
+ case math_shift_group:\r
+ print_char('$');\r
+ break;\r
+\r
+ case math_left_group:\r
+ print_esc("right");\r
+ break;\r
+ }\r
+\r
+ help5("I've deleted a group-closing symbol because it seems to be",\r
+ "spurious, as in `$x}$'. But perhaps the } is legitimate and",\r
+ "you forgot something else, as in `\\hbox{$x}'. In such cases",\r
+ "the way to recover is to insert both the forgotten and the",\r
+ "deleted material, e.g., by typing `I$}'.");\r
+ error();\r
+ incr(align_state);\r
+}\r
+/* sec 1070 */\r
+void normal_paragraph (void)\r
+{\r
+ if (looseness != 0)\r
+ eq_word_define(int_base + looseness_code, 0);\r
+\r
+ if (hang_indent != 0)\r
+ eq_word_define(dimen_base + hang_indent_code, 0);\r
+\r
+ if (hang_after != 1)\r
+ eq_word_define(int_base + hang_after_code, 1);\r
+\r
+ if (par_shape_ptr != 0)\r
+ eq_define(par_shape_loc, shape_ref, 0);\r
+}\r
+/* sec 1075 */\r
+void box_end (integer box_context)\r
+{\r
+ pointer p;\r
+\r
+ if (box_context < box_flag)\r
+ {\r
+ if (cur_box != 0)\r
+ {\r
+ shift_amount(cur_box) = box_context;\r
+\r
+ if (abs(mode) == vmode)\r
+ {\r
+ append_to_vlist(cur_box);\r
+\r
+ if (adjust_tail != 0)\r
+ {\r
+ if (adjust_head != adjust_tail)\r
+ {\r
+ link(tail) = link(adjust_head);\r
+ tail = adjust_tail;\r
+ }\r
+\r
+ adjust_tail = 0;\r
+ }\r
+\r
+ if (mode > 0)\r
+ build_page();\r
+ }\r
+ else\r
+ {\r
+ if (abs(mode) == hmode)\r
+ space_factor = 1000;\r
+ else\r
+ {\r
+ p = new_noad();\r
+ math_type(nucleus(p)) = sub_box;\r
+ info(nucleus(p)) = cur_box;\r
+ cur_box = p;\r
+ }\r
+\r
+ link(tail) = cur_box;\r
+ tail = cur_box;\r
+ }\r
+ }\r
+ }\r
+ else if (box_context < ship_out_flag)\r
+ if (box_context < (box_flag + 256))\r
+ eq_define((box_base - box_flag) + box_context, box_ref, cur_box);\r
+ else\r
+ geq_define((box_base - box_flag - 256) + box_context, box_ref, cur_box);\r
+ else if (cur_box != 0)\r
+ if (box_context > ship_out_flag)\r
+ {\r
+ do\r
+ {\r
+ get_x_token();\r
+ }\r
+ while (!((cur_cmd != spacer) && (cur_cmd != relax)));\r
+\r
+ if (((cur_cmd == hskip) && (abs(mode) != vmode)) || ((cur_cmd == vskip) && (abs(mode) == vmode)))\r
+ {\r
+ append_glue();\r
+ subtype(tail) = box_context - (leader_flag - a_leaders);\r
+ leader_ptr(tail) = cur_box;\r
+ }\r
+ else\r
+ {\r
+ print_err("Leaders not followed by proper glue");\r
+ help3("You should say `\\leaders <box or rule><hskip or vskip>'.",\r
+ "I found the <box or rule>, but there's no suitable",\r
+ "<hskip or vskip>, so I'm ignoring these leaders.");\r
+ back_error();\r
+ flush_node_list(cur_box);\r
+ }\r
+ }\r
+ else\r
+ ship_out(cur_box);\r
+}\r
+/* sec 1079 */\r
+void begin_box (integer box_context)\r
+{\r
+ pointer p, q;\r
+ quarterword m;\r
+ halfword k;\r
+ eight_bits n;\r
+\r
+ switch (cur_chr)\r
+ {\r
+ case box_code:\r
+ {\r
+ scan_eight_bit_int();\r
+ cur_box = box(cur_val);\r
+ box(cur_val) = 0;\r
+ }\r
+ break;\r
+\r
+ case copy_code:\r
+ {\r
+ scan_eight_bit_int();\r
+ cur_box = copy_node_list(box(cur_val));\r
+ }\r
+ break;\r
+\r
+ case last_box_code:\r
+ {\r
+ cur_box = 0;\r
+\r
+ if (abs(mode) == mmode)\r
+ {\r
+ you_cant();\r
+ help1("Sorry; this \\lastbox will be void.");\r
+ error();\r
+ }\r
+ else if ((mode == vmode) && (head == cur_list.tail_field))\r
+ {\r
+ you_cant();\r
+ help2("Sorry...I usually can't take things from the current page.",\r
+ "This \\lastbox will therefore be void.");\r
+ error();\r
+ }\r
+ else\r
+ {\r
+ if (!is_char_node(tail))\r
+ if ((type(tail) == hlist_node) || (type(tail) == vlist_node))\r
+ {\r
+ q = head;\r
+\r
+ do\r
+ {\r
+ p = q;\r
+\r
+ if (!is_char_node(q))\r
+ if (type(q) == disc_node)\r
+ {\r
+ for (m = 1; m <= replace_count(q); m++)\r
+ p = link(p);\r
+\r
+ if (p == tail)\r
+ goto done;\r
+ }\r
+\r
+ q = link(p);\r
+ }\r
+ while (!(q == tail));\r
+\r
+ cur_box = tail;\r
+ shift_amount(cur_box) = 0;\r
+ tail = p;\r
+ link(p) = 0;\r
+done:;\r
+ }\r
+ }\r
+ }\r
+ break;\r
+\r
+ case vsplit_code:\r
+ {\r
+ scan_eight_bit_int();\r
+ n = cur_val;\r
+\r
+ if (!scan_keyword("to"))\r
+ {\r
+ print_err("Missing `to' inserted");\r
+ help2("I'm working on `\\vsplit<box number> to <dimen>';",\r
+ "will look for the <dimen> next.");\r
+ error();\r
+ }\r
+\r
+ scan_dimen(false, false, false);\r
+ cur_box = vsplit(n, cur_val);\r
+ }\r
+ break;\r
+\r
+ default:\r
+ {\r
+ k = cur_chr - vtop_code;\r
+ saved(0) = box_context;\r
+\r
+ if (k == hmode)\r
+ if ((box_context < box_flag) && (abs(mode) == vmode))\r
+ scan_spec(adjust_hbox_group, true);\r
+ else\r
+ scan_spec(hbox_group, true);\r
+ else\r
+ {\r
+ if (k == vmode)\r
+ scan_spec(vbox_group, true);\r
+ else\r
+ {\r
+ scan_spec(vtop_group, true);\r
+ k = vmode;\r
+ }\r
+\r
+ normal_paragraph();\r
+ }\r
+\r
+ push_nest();\r
+ mode = - (integer) k;\r
+\r
+ if (k == vmode)\r
+ {\r
+ prev_depth = ignore_depth;\r
+\r
+ if (every_vbox != 0)\r
+ begin_token_list(every_vbox, every_vbox_text);\r
+ }\r
+ else\r
+ {\r
+ space_factor = 1000;\r
+\r
+ if (every_hbox != 0)\r
+ begin_token_list(every_hbox, every_vbox_text);\r
+ }\r
+\r
+ return;\r
+ }\r
+ break;\r
+ }\r
+\r
+ box_end(box_context);\r
+}\r
+/* sec 1084 */\r
+void scan_box_(integer box_context)\r
+{\r
+ do\r
+ {\r
+ get_x_token(); \r
+ }\r
+ while (!((cur_cmd != spacer) && (cur_cmd != relax)));\r
+\r
+ if (cur_cmd == make_box)\r
+ {\r
+ begin_box(box_context);\r
+ }\r
+ else if ((box_context >= leader_flag) && ((cur_cmd == hrule) || (cur_cmd == vrule)))\r
+ {\r
+ cur_box = scan_rule_spec();\r
+ box_end(box_context);\r
+ }\r
+ else\r
+ {\r
+ print_err("A <box> was supposed to be here");\r
+ help3("I was expecting to see \\hbox or \\vbox or \\copy or \\box or",\r
+ "something like that. So you might find something missing in",\r
+ "your output. But keep trying; you can fix this later.");\r
+ back_error();\r
+ }\r
+}\r
+/* sec 1091 */\r
+small_number norm_min (integer h)\r
+{\r
+ if (h <= 0)\r
+ return 1;\r
+ else if (h >= 63)\r
+ return 63;\r
+ else\r
+ return h;\r
+}\r
+/* sec 1091 */\r
+void new_graf (boolean indented)\r
+{\r
+ prev_graf = 0;\r
+\r
+ if ((mode == vmode) || (head != tail))\r
+ tail_append(new_param_glue(par_skip_code));\r
+\r
+ push_nest();\r
+ mode = hmode;\r
+ space_factor = 1000;\r
+ set_cur_lang();\r
+ clang = cur_lang;\r
+ prev_graf = (norm_min(left_hyphen_min) * 64 + norm_min(right_hyphen_min)) * 65536L + cur_lang;\r
+\r
+ if (indented)\r
+ {\r
+ tail = new_null_box();\r
+ link(head) = tail;\r
+ width(tail) = par_indent;\r
+ }\r
+\r
+ if (every_par != 0)\r
+ begin_token_list(every_par, every_par_text);\r
+\r
+ if (nest_ptr == 1)\r
+ build_page();\r
+}\r
+/* sec 1093 */\r
+void indent_in_hmode (void)\r
+{\r
+ pointer p, q;\r
+\r
+ if (cur_chr > 0)\r
+ {\r
+ p = new_null_box();\r
+ width(p) = par_indent;\r
+\r
+ if (abs(mode) == hmode)\r
+ space_factor = 1000;\r
+ else\r
+ {\r
+ q = new_noad();\r
+ math_type(nucleus(q)) = sub_box;\r
+ info(nucleus(q)) = p;\r
+ p = q;\r
+ }\r
+\r
+ tail_append(p);\r
+ }\r
+}\r
+/* sec 1095 */\r
+void head_for_vmode (void)\r
+{\r
+ if (mode < 0)\r
+ {\r
+ if (cur_cmd != hrule)\r
+ off_save();\r
+ else\r
+ {\r
+ print_err("You can't use `");\r
+ print_esc("hrule");\r
+ prints("' here except with leaders");\r
+ help2("To put a horizontal rule in an hbox or an alignment,",\r
+ "you should use \\leaders or \\hrulefill (see The TeXbook).");\r
+ error();\r
+ }\r
+ }\r
+ else\r
+ {\r
+ back_input();\r
+ cur_tok = par_token;\r
+ back_input();\r
+ index = inserted;\r
+ }\r
+}\r
+/* sec 1096 */\r
+void end_graf (void)\r
+{\r
+ if (mode == hmode)\r
+ {\r
+ if (head == tail)\r
+ pop_nest();\r
+ else\r
+ line_break(widow_penalty);\r
+\r
+ normal_paragraph();\r
+ error_count = 0;\r
+ }\r
+}\r
+/* sec 1099 */\r
+void begin_insert_or_adjust (void)\r
+{\r
+ if (cur_cmd == vadjust)\r
+ cur_val = 255;\r
+ else\r
+ {\r
+ scan_eight_bit_int();\r
+\r
+ if (cur_val == 255)\r
+ {\r
+ print_err("You can't ");\r
+ print_esc("insert");\r
+ print_int(255);\r
+ help1("I'm changing to \\insert0; box 255 is special.");\r
+ error();\r
+ cur_val = 0;\r
+ }\r
+ }\r
+\r
+ saved(0) = cur_val;\r
+ incr(save_ptr);\r
+ new_save_level(insert_group);\r
+ scan_left_brace();\r
+ normal_paragraph();\r
+ push_nest();\r
+ mode = -vmode;\r
+ prev_depth = ignore_depth;\r
+}\r
+/* sec 1101 */\r
+void make_mark (void)\r
+{\r
+ pointer p;\r
+\r
+ p = scan_toks(false, true);\r
+ p = get_node(small_node_size);\r
+ type(p) = mark_node;\r
+ subtype(p) = 0;\r
+ mark_ptr(p) = def_ref;\r
+ link(tail) = p;\r
+ tail = p;\r
+}\r
+/* sec 1103 */\r
+void append_penalty (void)\r
+{\r
+ scan_int();\r
+ tail_append(new_penalty(cur_val));\r
+\r
+ if (mode == vmode)\r
+ build_page();\r
+}\r
+/* sec 1105 */\r
+void delete_last (void)\r
+{\r
+ pointer p, q;\r
+ quarterword m;\r
+\r
+ if ((mode == vmode) && (tail == head))\r
+ {\r
+ if ((cur_chr != glue_node) || (last_glue != max_halfword))\r
+ {\r
+ you_cant();\r
+ help2("Sorry...I usually can't take things from the current page.",\r
+ "Try `I\\vskip-\\lastskip' instead.");\r
+\r
+ if (cur_chr == kern_node)\r
+ help_line[0] = "Try `I\\kern-\\last_kern' instead.";\r
+ else if (cur_chr != glue_node)\r
+ help_line[0] = "Perhaps you can make the output routine do it.";\r
+ error();\r
+ }\r
+ }\r
+ else\r
+ {\r
+ if (!is_char_node(tail))\r
+ if (type(tail) == cur_chr)\r
+ {\r
+ q = head;\r
+\r
+ do\r
+ {\r
+ p = q;\r
+\r
+ if (!is_char_node(q))\r
+ if (type(q) == disc_node)\r
+ {\r
+ for (m = 1; m <= replace_count(q); m++)\r
+ p = link(p);\r
+\r
+ if (p == tail)\r
+ return;\r
+ }\r
+\r
+ q = link(p);\r
+ }\r
+ while (!(q == tail));\r
+\r
+ link(p) = 0;\r
+ flush_node_list(tail);\r
+ tail = p;\r
+ }\r
+ }\r
+}\r
+/* sec 1110 */\r
+void unpackage (void)\r
+{\r
+ pointer p;\r
+ char c;\r
+\r
+ c = cur_chr;\r
+ scan_eight_bit_int();\r
+ p = box(cur_val);\r
+\r
+ if (p == 0)\r
+ return;\r
+\r
+ if ((abs(mode) == mmode) || ((abs(mode) == vmode) && (type(p) != vlist_node)) ||\r
+ ((abs(mode) == hmode) && (type(p) != hlist_node)))\r
+ {\r
+ print_err("Incompatible list can't be unboxed");\r
+ help3("Sorry, Pandora. (You sneaky devil.)",\r
+ "I refuse to unbox an \\hbox in vertical mode or vice versa.",\r
+ "And I can't open any boxes in math mode.");\r
+ error();\r
+ return;\r
+ }\r
+\r
+ if (c == copy_code)\r
+ link(tail) = copy_node_list(list_ptr(p));\r
+ else\r
+ {\r
+ link(tail) = list_ptr(p);\r
+ box(cur_val) = 0;\r
+ free_node(p, box_node_size);\r
+ }\r
+\r
+ while (link(tail) != 0)\r
+ tail = link(tail);\r
+}\r
+/* sec 1113 */\r
+void append_italic_correction (void)\r
+{\r
+ pointer p;\r
+ internal_font_number f;\r
+\r
+ if (tail != head)\r
+ {\r
+ if (is_char_node(tail))\r
+ p = tail;\r
+ else if (type(tail) == ligature_node)\r
+ p = tail + 1;\r
+ else\r
+ return;\r
+\r
+ f = font(p);\r
+ tail_append(new_kern(char_italic(f, char_info(f, character(p)))));\r
+ subtype(tail) = explicit;\r
+ }\r
+}\r
+/* sec 1117 */\r
+void append_discretionary (void)\r
+{\r
+ integer c;\r
+\r
+ tail_append(new_disc());\r
+\r
+ if (cur_chr == 1)\r
+ {\r
+ c = hyphen_char[cur_font];\r
+\r
+ if (c >= 0)\r
+ if (c < 256)\r
+ pre_break(tail) = new_character(cur_font, c);\r
+ }\r
+ else\r
+ {\r
+ incr(save_ptr);\r
+ saved(-1) = 0;\r
+ new_save_level(disc_group);\r
+ scan_left_brace();\r
+ push_nest();\r
+ mode = -hmode;\r
+ space_factor = 1000;\r
+ }\r
+}\r
+/* sec 1119 */\r
+void build_discretionary (void)\r
+{\r
+ pointer p, q;\r
+ integer n;\r
+\r
+ unsave();\r
+ q = head;\r
+ p = link(q);\r
+ n = 0;\r
+\r
+ while (p != 0)\r
+ {\r
+ if (!is_char_node(p))\r
+ if (type(p) > rule_node)\r
+ if (type(p) != kern_node)\r
+ if (type(p) != ligature_node)\r
+ {\r
+ print_err("Improper discretionary list");\r
+ help1("Discretionary lists must contain only boxes and kerns.");\r
+ error();\r
+ begin_diagnostic();\r
+ print_nl("The following discretionary sublist has been deleted:");\r
+ show_box(p);\r
+ end_diagnostic(true);\r
+ flush_node_list(p);\r
+ link(q) = 0;\r
+ goto done;\r
+ }\r
+\r
+ q = p;\r
+ p = link(q);\r
+ incr(n);\r
+ }\r
+\r
+done:\r
+ p = link(head);\r
+ pop_nest();\r
+\r
+ switch (saved(-1))\r
+ {\r
+ case 0:\r
+ pre_break(tail) = p;\r
+ break;\r
+\r
+ case 1:\r
+ post_break(tail) = p;\r
+ break;\r
+\r
+ case 2:\r
+ {\r
+ if ((n > 0) && (abs(mode) == mmode))\r
+ {\r
+ print_err("Illegal math ");\r
+ print_esc("discretionary");\r
+ help2("Sorry: The third part of a discretionary break must be",\r
+ "empty, in math formulas. I had to delete your third part.");\r
+ flush_node_list(p);\r
+ n = 0;\r
+ error();\r
+ }\r
+ else\r
+ link(tail) = p;\r
+\r
+ if (n <= max_quarterword)\r
+ replace_count(tail) = n;\r
+ else\r
+ {\r
+ print_err("Discretionary list is too long");\r
+ help2("Wow---I never thought anybody would tweak me here.",\r
+ "You can't seriously need such a huge discretionary list?");\r
+ error();\r
+ }\r
+\r
+ if (n > 0)\r
+ tail = q;\r
+\r
+ decr(save_ptr);\r
+ return;\r
+ }\r
+ break;\r
+ }\r
+\r
+ incr(saved(-1));\r
+ new_save_level(disc_group);\r
+ scan_left_brace();\r
+ push_nest();\r
+ mode = -hmode;\r
+ space_factor = 1000;\r
+}\r
+/* sec 1123 */\r
+void make_accent (void)\r
+{\r
+ real s, t;\r
+ pointer p, q, r;\r
+ internal_font_number f;\r
+ scaled a, h, x, w, delta;\r
+ four_quarters i;\r
+\r
+ scan_char_num();\r
+ f = cur_font;\r
+ p = new_character(f, cur_val);\r
+\r
+ if (p != 0)\r
+ {\r
+ x = x_height(f);\r
+ s = slant(f) / ((double) 65536.0);\r
+ a = char_width(f, char_info(f, character(p)));\r
+ do_assignments();\r
+ q = 0;\r
+ f = cur_font;\r
+\r
+ if ((cur_cmd == letter) || (cur_cmd == other_char) || (cur_cmd == char_given))\r
+ q = new_character(f, cur_chr);\r
+ else if (cur_cmd == char_num)\r
+ {\r
+ scan_char_num();\r
+ q = new_character(f, cur_val);\r
+ }\r
+ else\r
+ back_input();\r
+\r
+ if (q != 0)\r
+ {\r
+ t = slant(f) / ((double) 65536.0);\r
+ i = char_info(f, character(q));\r
+ w = char_width(f, i);\r
+ h = char_height(f, height_depth(i));\r
+\r
+ if (h != x)\r
+ {\r
+ p = hpack(p, 0, 1);\r
+ shift_amount(p) = x - h;\r
+ }\r
+\r
+ delta = round((w - a) / ((double) 2.0) + h * t - x * s);\r
+ r = new_kern(delta);\r
+ subtype(r) = acc_kern;\r
+ link(tail) = r;\r
+ link(r) = p;\r
+ tail = new_kern(- (integer) a - delta);\r
+ subtype(tail) = acc_kern;\r
+ link(p) = tail;\r
+ p = q;\r
+ }\r
+\r
+ link(tail) = p;\r
+ tail = p;\r
+ space_factor = 1000;\r
+ }\r
+}\r
+/* sec 1127 */\r
+void align_error (void)\r
+{\r
+ if (abs(align_state) > 2)\r
+ {\r
+ print_err("Misplaced ");\r
+ print_cmd_chr(cur_cmd, cur_chr);\r
+\r
+ if (cur_tok == tab_token + '&')\r
+ {\r
+ help6("I can't figure out why you would want to use a tab mark",\r
+ "here. If you just want an ampersand, the remedy is",\r
+ "simple: Just type `I\\&' now. But if some right brace",\r
+ "up above has ended a previous alignment prematurely,",\r
+ "you're probably due for more error messages, and you",\r
+ "might try typing `S' now just to see what is salvageable.");\r
+ }\r
+ else\r
+ {\r
+ help5("I can't figure out why you would want to use a tab mark",\r
+ "or \\cr or \\span just now. If something like a right brace",\r
+ "up above has ended a previous alignment prematurely,",\r
+ "you're probably due for more error messages, and you",\r
+ "might try typing `S' now just to see what is salvageable.");\r
+ }\r
+\r
+ error();\r
+ }\r
+ else\r
+ {\r
+ back_input();\r
+\r
+ if (align_state < 0)\r
+ {\r
+ print_err("Missing { inserted");\r
+ incr(align_state);\r
+ cur_tok = left_brace_token + '{';\r
+ }\r
+ else\r
+ {\r
+ print_err("Missing } inserted");\r
+ decr(align_state);\r
+ cur_tok = right_brace_token + '}';\r
+ }\r
+\r
+ help3("I've put in what seems to be necessary to fix",\r
+ "the current column of the current alignment.",\r
+ "Try to go on, since this might almost work.");\r
+ ins_error();\r
+ }\r
+}\r
+/* sec 1129 */\r
+void noalign_error (void)\r
+{\r
+ print_err("Misplaced ");\r
+ print_esc("noalign");\r
+ help2("I expect to see \\noalign only after the \\cr of",\r
+ "an alignment. Proceed, and I'll ignore this case.");\r
+ error();\r
+}\r
+/* sec 1129 */\r
+void omit_error (void)\r
+{\r
+ print_err("Misplaced ");\r
+ print_esc("omit");\r
+ help2("I expect to see \\omit only after tab marks or the \\cr of",\r
+ "an alignment. Proceed, and I'll ignore this case.");\r
+ error();\r
+}\r
+/* sec 1131 */\r
+void do_endv (void)\r
+{\r
+ base_ptr = input_ptr;\r
+ input_stack[base_ptr] = cur_input;\r
+\r
+ while ((input_stack[base_ptr].index_field != v_template) &&\r
+ (input_stack[base_ptr].loc_field == 0) &&\r
+ (input_stack[base_ptr].state_field == token_list))\r
+ decr(base_ptr);\r
+\r
+ if ((input_stack[base_ptr].index_field != v_template) ||\r
+ (input_stack[base_ptr].loc_field != 0) ||\r
+ (input_stack[base_ptr].state_field != token_list))\r
+ fatal_error("(interwoven alignment preambles are not allowed)");\r
+\r
+ if (cur_group == align_group)\r
+ {\r
+ end_graf();\r
+\r
+ if (fin_col())\r
+ fin_row();\r
+ }\r
+ else\r
+ off_save();\r
+}\r
+/* sec 1135 */\r
+void cs_error (void)\r
+{\r
+ print_err("Extra ");\r
+ print_esc("endcsname");\r
+ help1("I'm ignoring this, since I wasn't doing a \\csname."); \r
+ error();\r
+}\r
+/* sec 1136 */\r
+void push_math (group_code c)\r
+{\r
+ push_nest();\r
+ mode = -mmode;\r
+ incompleat_noad = 0;\r
+ new_save_level(c);\r
+}\r
+/* sec 1138 */\r
+void init_math (void)\r
+{\r
+ scaled w;\r
+ scaled l;\r
+ scaled s;\r
+ pointer p;\r
+ pointer q;\r
+ internal_font_number f;\r
+ integer n;\r
+ scaled v;\r
+ scaled d;\r
+\r
+ get_token();\r
+\r
+ if ((cur_cmd == math_shift) && (mode > 0))\r
+ {\r
+ if (head == tail)\r
+ {\r
+ pop_nest();\r
+ w = -max_dimen;\r
+ }\r
+ else\r
+ {\r
+ line_break(display_widow_penalty);\r
+ v = shift_amount(just_box) + 2 * quad(cur_font);\r
+ w = -max_dimen;\r
+ p = list_ptr(just_box);\r
+\r
+ while (p != 0)\r
+ {\r
+reswitch:\r
+ if (is_char_node(p))\r
+ {\r
+ f = font(p);\r
+ d = char_width(f, char_info(f, character(p)));\r
+ goto found;\r
+ }\r
+\r
+ switch (type(p))\r
+ {\r
+ case hlist_node:\r
+ case vlist_node:\r
+ case rule_node:\r
+ {\r
+ d = width(p);\r
+ goto found;\r
+ }\r
+ break;\r
+\r
+ case ligature_node:\r
+ {\r
+ mem[lig_trick] = mem[lig_char(p)];\r
+ link(lig_trick) = link(p);\r
+ p = lig_trick;\r
+ goto reswitch;\r
+ }\r
+ break;\r
+\r
+ case kern_node:\r
+ case math_node:\r
+ d = width(p);\r
+ break;\r
+\r
+ case glue_node:\r
+ {\r
+ q = glue_ptr(p);\r
+ d = width(q);\r
+\r
+ if (glue_sign(just_box) == stretching)\r
+ {\r
+ if ((glue_order(just_box) == stretch_order(q)) && (stretch(q) != 0))\r
+ v = max_dimen;\r
+ }\r
+ else if (glue_sign(just_box) == shrinking)\r
+ {\r
+ if ((glue_order(just_box) == shrink_order(q)) && (shrink(q) != 0))\r
+ v = max_dimen;\r
+ }\r
+\r
+ if (subtype(p) >= a_leaders)\r
+ goto found;\r
+ }\r
+ break;\r
+\r
+ case whatsit_node:\r
+ d = 0;\r
+ break;\r
+\r
+ default:\r
+ d = 0;\r
+ break;\r
+ }\r
+\r
+ if (v < max_dimen)\r
+ v = v + d;\r
+\r
+ goto not_found;\r
+\r
+found:\r
+ if (v < max_dimen)\r
+ {\r
+ v = v + d;\r
+ w = v;\r
+ }\r
+ else\r
+ {\r
+ w = max_dimen;\r
+ goto done;\r
+ }\r
+\r
+not_found:\r
+ p = link(p);\r
+ }\r
+done:;\r
+ }\r
+\r
+ if (par_shape_ptr == 0)\r
+ if ((hang_indent != 0) && (((hang_after >= 0) &&\r
+ (prev_graf + 2 > hang_after)) || (prev_graf + 1 < - (integer) hang_after)))\r
+ {\r
+ l = hsize - abs(hang_indent);\r
+\r
+ if (hang_indent > 0)\r
+ s = hang_indent;\r
+ else\r
+ s = 0;\r
+ }\r
+ else\r
+ {\r
+ l = hsize;\r
+ s = 0;\r
+ }\r
+ else\r
+ {\r
+ n = info(par_shape_ptr);\r
+\r
+ if (prev_graf + 2 >= n)\r
+ p = par_shape_ptr + 2 * n;\r
+ else\r
+ p = par_shape_ptr + 2 * (prev_graf + 2);\r
+\r
+ s = mem[p - 1].cint;\r
+ l = mem[p].cint;\r
+ }\r
+\r
+ push_math(math_shift_group);\r
+ mode = mmode;\r
+ eq_word_define(int_base + cur_fam_code, -1);\r
+ eq_word_define(dimen_base + pre_display_size_code, w);\r
+ eq_word_define(dimen_base + display_width_code, l);\r
+ eq_word_define(dimen_base + display_indent_code, s);\r
+\r
+ if (every_display != 0)\r
+ begin_token_list(every_display, every_display_text);\r
+\r
+ if (nest_ptr == 1)\r
+ {\r
+ build_page();\r
+ }\r
+ }\r
+ else\r
+ {\r
+ back_input();\r
+\r
+ {\r
+ push_math(math_shift_group);\r
+ eq_word_define(int_base + cur_fam_code, -1);\r
+\r
+ if (every_math != 0)\r
+ begin_token_list(every_math, every_math_text);\r
+ }\r
+ }\r
+}\r
+/* sec 1142 */\r
+void start_eq_no (void)\r
+{\r
+ saved(0) = cur_chr;\r
+ incr(save_ptr);\r
+\r
+ {\r
+ push_math(math_shift_group);\r
+ eq_word_define(int_base + cur_fam_code, -1);\r
+\r
+ if (every_math != 0)\r
+ begin_token_list(every_math, every_math_text);\r
+ }\r
+}\r
+/* sec 1151 */\r
+void scan_math (pointer p)\r
+{\r
+ integer c;\r
+\r
+restart:\r
+ do\r
+ {\r
+ get_x_token();\r
+ }\r
+ while (!((cur_cmd != spacer) && (cur_cmd != relax)));\r
+\r
+reswitch:\r
+ switch (cur_cmd)\r
+ {\r
+ case letter:\r
+ case other_char:\r
+ case char_given:\r
+ {\r
+ c = math_code(cur_chr);\r
+\r
+ if (c == 32768L)\r
+ {\r
+ {\r
+ cur_cs = cur_chr + active_base;\r
+ cur_cmd = eq_type(cur_cs);\r
+ cur_chr = equiv(cur_cs);\r
+ x_token();\r
+ back_input();\r
+ }\r
+\r
+ goto restart;\r
+ }\r
+ }\r
+ break;\r
+\r
+ case char_num:\r
+ {\r
+ scan_char_num();\r
+ cur_chr = cur_val;\r
+ cur_cmd = char_given;\r
+ goto reswitch;\r
+ }\r
+ break;\r
+\r
+ case math_char_num:\r
+ {\r
+ scan_fifteen_bit_int();\r
+ c = cur_val;\r
+ }\r
+ break;\r
+\r
+ case math_given:\r
+ c = cur_chr;\r
+ break;\r
+\r
+ case delim_num:\r
+ {\r
+ scan_twenty_seven_bit_int();\r
+ c = cur_val / 4096;\r
+ }\r
+ break;\r
+\r
+ default:\r
+ {\r
+ back_input();\r
+ scan_left_brace();\r
+ saved(0) = p;\r
+ incr(save_ptr);\r
+ push_math(math_group);\r
+ return;\r
+ }\r
+ break;\r
+ }\r
+\r
+ math_type(p) = math_char;\r
+ character(p) = c % 256;\r
+\r
+ if ((c >= var_code) && ((cur_fam >= 0) && (cur_fam < 16)))\r
+ fam(p) = cur_fam;\r
+ else\r
+ fam(p) = (c / 256) % 16;\r
+}\r
+/* sec 1155 */\r
+void set_math_char_(integer c)\r
+{\r
+ pointer p;\r
+\r
+ if (c >= 32768L)\r
+ {\r
+ cur_cs = cur_chr + active_base;\r
+ cur_cmd = eq_type(cur_cs);\r
+ cur_chr = equiv(cur_cs);\r
+ x_token();\r
+ back_input();\r
+ }\r
+ else\r
+ {\r
+ p = new_noad();\r
+ math_type(nucleus(p)) = math_char;\r
+ character(nucleus(p)) = c % 256;\r
+ fam(nucleus(p)) = (c / 256) % 16;\r
+\r
+ if (c >= var_code)\r
+ {\r
+ if (((cur_fam >= 0) && (cur_fam < 16)))\r
+ fam(nucleus(p)) = cur_fam;\r
+\r
+ type(p) = ord_noad;\r
+ }\r
+ else\r
+ type(p) = ord_noad + (c / 4096);\r
+\r
+ link(tail) = p;\r
+ tail = p;\r
+ }\r
+}\r
+/* sec 1159 */\r
+void math_limit_switch (void)\r
+{\r
+ if (head != tail)\r
+ if (type(tail) == op_noad)\r
+ {\r
+ subtype(tail) = cur_chr;\r
+ return;\r
+ }\r
+\r
+ print_err("Limit controls must follow a math operator");\r
+ help1("I'm ignoring this misplaced \\limits or \\nolimits command.");\r
+ error();\r
+}\r
+/* sec 1160 */\r
+void scan_delimiter_(pointer p, boolean r)\r
+{\r
+ if (r)\r
+ scan_twenty_seven_bit_int();\r
+ else\r
+ {\r
+ do\r
+ {\r
+ get_x_token();\r
+ }\r
+ while (!((cur_cmd != spacer) && (cur_cmd != relax)));\r
+\r
+ switch (cur_cmd)\r
+ {\r
+ case letter:\r
+ case other_char:\r
+ cur_val = del_code(cur_chr);\r
+ break;\r
+\r
+ case delim_num:\r
+ scan_twenty_seven_bit_int();\r
+ break;\r
+\r
+ default:\r
+ cur_val = -1;\r
+ break;\r
+ }\r
+ }\r
+\r
+ if (cur_val < 0)\r
+ {\r
+ print_err("Missing delimiter (. inserted)");\r
+ help6("I was expecting to see something like `(' or `\\{' or",\r
+ "`\\}' here. If you typed, e.g., `{' instead of `\\{', you",\r
+ "should probably delete the `{' by typing `1' now, so that",\r
+ "braces don't get unbalanced. Otherwise just proceed.",\r
+ "Acceptable delimiters are characters whose \\delcode is",\r
+ "nonnegative, or you can use `\\delimiter <delimiter code>'.");\r
+ back_error();\r
+ cur_val = 0;\r
+ }\r
+\r
+ small_fam(p) = (cur_val / 1048576L) % 16;\r
+ small_char(p) = (cur_val / 4096) % 256;\r
+ large_fam(p) = (cur_val / 256) % 16;\r
+ large_char(p) = cur_val % 256;\r
+}\r
+/* sec 1163 */\r
+void math_radical (void)\r
+{\r
+ tail_append(get_node(radical_noad_size));\r
+ type(tail) = radical_noad;\r
+ subtype(tail) = normal;\r
+ mem[nucleus(tail)].hh = empty_field;\r
+ mem[subscr(tail)].hh = empty_field;\r
+ mem[supscr(tail)].hh = empty_field;\r
+ scan_delimiter(left_delimiter(tail), true);\r
+ scan_math(nucleus(tail));\r
+}\r
+/* sec 1165 */\r
+void math_ac (void)\r
+{\r
+ if (cur_cmd == accent)\r
+ {\r
+ print_err("Please use ");\r
+ print_esc("mathaccent");\r
+ prints(" for accents in math mode");\r
+ help2("I'm changing \\accent to \\mathaccent here; wish me luck.",\r
+ "(Accents are not the same in formulas as they are in text.)");\r
+ error();\r
+ }\r
+\r
+ tail_append(get_node(accent_noad_size));\r
+ type(tail) = accent_noad;\r
+ subtype(tail) = normal;\r
+ mem[nucleus(tail)].hh = empty_field;\r
+ mem[subscr(tail)].hh = empty_field;\r
+ mem[supscr(tail)].hh = empty_field;\r
+ math_type(accent_chr(tail)) = math_char;\r
+ scan_fifteen_bit_int();\r
+ character(accent_chr(tail)) = cur_val % 256;\r
+\r
+ if ((cur_val >= var_code) && ((cur_fam >= 0) && (cur_fam < 16)))\r
+ fam(accent_chr(tail)) = cur_fam;\r
+ else\r
+ fam(accent_chr(tail)) = (cur_val / 256) % 16;\r
+\r
+ scan_math(nucleus(tail));\r
+}\r
+/* sec 1172 */\r
+void append_choices (void)\r
+{\r
+ tail_append(new_choice());\r
+ incr(save_ptr);\r
+ saved(-1) = 0;\r
+ push_math(math_choice_group);\r
+ scan_left_brace();\r
+}\r
+/* sec 1184 */\r
+pointer fin_mlist (pointer p)\r
+{\r
+ pointer q;\r
+\r
+ if (incompleat_noad != 0)\r
+ {\r
+ math_type(denominator(incompleat_noad)) = sub_mlist;\r
+ info(denominator(incompleat_noad)) = link(head);\r
+\r
+ if (p == 0)\r
+ q = incompleat_noad;\r
+ else\r
+ {\r
+ q = info(numerator(incompleat_noad));\r
+\r
+ if (type(q) != left_noad)\r
+ {\r
+ confusion("right");\r
+ return 0;\r
+ }\r
+\r
+ info(numerator(incompleat_noad)) = link(q);\r
+ link(q) = incompleat_noad;\r
+ link(incompleat_noad) = p;\r
+ }\r
+ }\r
+ else\r
+ {\r
+ link(tail) = p;\r
+ q = link(head);\r
+ }\r
+\r
+ pop_nest();\r
+\r
+ return q;\r
+}\r
+/* sec 1174 */\r
+void build_choices (void)\r
+{\r
+ pointer p;\r
+\r
+ unsave();\r
+ p = fin_mlist(0);\r
+\r
+ switch (saved(-1))\r
+ {\r
+ case 0:\r
+ display_mlist(tail) = p;\r
+ break;\r
+\r
+ case 1:\r
+ text_mlist(tail) = p;\r
+ break;\r
+\r
+ case 2:\r
+ script_mlist(tail) = p;\r
+ break;\r
+\r
+ case 3:\r
+ {\r
+ script_script_mlist(tail) = p;\r
+ decr(save_ptr);\r
+ return;\r
+ }\r
+ break;\r
+ }\r
+\r
+ incr(saved(-1));\r
+ push_math(math_choice_group);\r
+ scan_left_brace();\r
+}\r
+/* sec 1176 */\r
+void sub_sup (void)\r
+{\r
+ /* small_number t; */\r
+ int t;\r
+ pointer p;\r
+\r
+ t = 0;\r
+ p = 0;\r
+\r
+ if (tail != head)\r
+ if (script_allowed(tail))\r
+ {\r
+ p = supscr(tail) + cur_cmd - sup_mark;\r
+ t = math_type(p);\r
+ }\r
+\r
+ if ((p == 0) || (t != 0))\r
+ {\r
+ tail_append(new_noad());\r
+ p = supscr(tail) + cur_cmd - sup_mark;\r
+\r
+ if (t != 0)\r
+ {\r
+ if (cur_cmd == sup_mark)\r
+ {\r
+ print_err("Double superscript");\r
+ help1("I treat `x^1^2' essentially like `x^1{}^2'.");\r
+ }\r
+ else\r
+ {\r
+ print_err("Double subscript");\r
+ help1("I treat `x_1_2' essentially like `x_1{}_2'.");\r
+ }\r
+\r
+ error();\r
+ }\r
+ }\r
+\r
+ scan_math(p);\r
+}\r
+/* sec 1086 */\r
+void package (small_number c)\r
+{\r
+ scaled h;\r
+ pointer p;\r
+ scaled d;\r
+\r
+ d = box_max_depth;\r
+ unsave();\r
+ save_ptr = save_ptr - 3;\r
+\r
+ if (mode == -hmode)\r
+ cur_box = hpack(link(head), saved(2), saved(1));\r
+ else\r
+ {\r
+ cur_box = vpackage(link(head), saved(2), saved(1), d);\r
+\r
+ if (c == vtop_code)\r
+ {\r
+ h = 0;\r
+ p = list_ptr(cur_box);\r
+\r
+ if (p != 0)\r
+ if (type(p) <= rule_node)\r
+ h = height(p);\r
+\r
+ depth(cur_box) = depth(cur_box) - h + height(cur_box);\r
+ height(cur_box) = h;\r
+ }\r
+ }\r
+\r
+ pop_nest();\r
+ box_end(saved(0));\r
+}
\ No newline at end of file