tg.c 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. /* tg.c: process included text blocks */
  2. # include "t.h"
  3. int
  4. gettext(char *sp, int ilin, int icol, char *fn, char *sz)
  5. {
  6. /* get a section of text */
  7. char line[4096];
  8. int oname, startline;
  9. char *vs;
  10. startline = iline;
  11. if (texname == 0)
  12. error("Too many text block diversions");
  13. if (textflg == 0) {
  14. Bprint(&tabout, ".nr %d \\n(.lu\n", SL); /* remember old line length */
  15. textflg = 1;
  16. }
  17. Bprint(&tabout, ".eo\n");
  18. Bprint(&tabout, ".am %s\n", reg(icol, CRIGHT));
  19. Bprint(&tabout, ".br\n");
  20. Bprint(&tabout, ".di %c+\n", texname);
  21. rstofill();
  22. if (fn && *fn)
  23. Bprint(&tabout, ".nr %d \\n(.f\n.ft %s\n", S1, fn);
  24. Bprint(&tabout, ".ft \\n(.f\n"); /* protect font */
  25. vs = vsize[icol][stynum[ilin]];
  26. if ((sz && *sz) || (vs && *vs)) {
  27. Bprint(&tabout, ".nr %d \\n(.v\n", S9);
  28. if (vs == 0 || *vs == 0)
  29. vs = "\\n(.s+2";
  30. if (sz && *sz)
  31. Bprint(&tabout, ".ps %s\n", sz);
  32. Bprint(&tabout, ".vs %s\n", vs);
  33. Bprint(&tabout, ".if \\n(%du>\\n(.vu .sp \\n(%du-\\n(.vu\n", S9, S9);
  34. }
  35. if (cll[icol][0])
  36. Bprint(&tabout, ".ll %sn\n", cll[icol]);
  37. else
  38. Bprint(&tabout, ".ll \\n(%du*%du/%du\n", SL, ctspan(ilin, icol), ncol + 1);
  39. Bprint(&tabout, ".if \\n(.l<\\n(%2s .ll \\n(%2su\n", reg(icol, CRIGHT),
  40. reg(icol, CRIGHT));
  41. if (ctype(ilin, icol) == 'a')
  42. Bprint(&tabout, ".ll -2n\n");
  43. Bprint(&tabout, ".in 0\n");
  44. for (;;) {
  45. if (gets1(line, sizeof(line)) == nil) {
  46. iline = startline;
  47. error("missing closing T}");
  48. }
  49. if (line[0] == 'T' && line[1] == '}' && line[2] == tab)
  50. break;
  51. if (match("T}", line))
  52. break;
  53. Bprint(&tabout, "%s\n", line);
  54. }
  55. if (fn && *fn)
  56. Bprint(&tabout, ".ft \\n(%d\n", S1);
  57. if (sz && *sz)
  58. Bprint(&tabout, ".br\n.ps\n.vs\n");
  59. Bprint(&tabout, ".br\n");
  60. Bprint(&tabout, ".di\n");
  61. Bprint(&tabout, ".nr %c| \\n(dn\n", texname);
  62. Bprint(&tabout, ".nr %c- \\n(dl\n", texname);
  63. Bprint(&tabout, "..\n");
  64. Bprint(&tabout, ".ec \\\n");
  65. /* copy remainder of line */
  66. if (line[2])
  67. tcopy (sp, line + 3);
  68. else
  69. *sp = 0;
  70. oname = texname;
  71. texname = texstr[++texct];
  72. return(oname);
  73. }
  74. void
  75. untext(void)
  76. {
  77. rstofill();
  78. Bprint(&tabout, ".nf\n");
  79. Bprint(&tabout, ".ll \\n(%du\n", SL);
  80. }