home *** CD-ROM | disk | FTP | other *** search
/ minnie.tuhs.org / unixen.tar / unixen / PDP-11 / Trees / V7 / usr / src / libplot / t300.c.a < prev    next >
Unix Archive - Old  |  1979-01-10  |  4.9 KB

open in: MacOS 8.1     |     Win98     |     DOS

view JSON data     |     view as text


This file was processed as: Unix Archive - Old (archive/unixArchiveOld).
This format is not currently supported by dexvert.

ConfidenceProgramDetectionMatch TypeSupport
1% dexvert Unix Archive - Old (archive/unixArchiveOld) magic Unsupported
1% dexvert System V 64-bit library (executable/systemV64BitLibrary) ext Unsupported
1% dexvert COFF Library (other/coffLibrary) ext Unsupported
100% file old 16-bit-int little-endian archive default
99% file Microsoft x.out archive default (weak)
98% file data default



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 65 ff 61 72 63 2e 63 00 | 00 00 00 00 00 00 00 00 |e.arc.c.|........|
|00000010| 8e 0d 96 f4 29 01 b6 81 | 00 00 09 00 61 72 63 28 |....)...|....arc(|
|00000020| 29 7b 0a 7d 0a 00 63 69 | 72 63 6c 65 2e 63 00 00 |){.}..ci|rcle.c..|
|00000030| 00 00 00 00 8e 0d 96 f4 | 29 01 b6 81 00 00 0c 00 |........|).......|
|00000040| 63 69 72 63 6c 65 28 29 | 7b 0a 7d 0a 63 6c 6f 73 |circle()|{.}.clos|
|00000050| 65 2e 63 00 00 00 00 00 | 00 00 8f 0d b6 0a 29 01 |e.c.....|......).|
|00000060| b6 81 00 00 54 00 23 69 | 6e 63 6c 75 64 65 20 3c |....T.#i|nclude <|
|00000070| 73 74 64 69 6f 2e 68 3e | 0a 63 6c 6f 73 65 76 74 |stdio.h>|.closevt|
|00000080| 28 29 7b 0a 09 63 6c 6f | 73 65 70 6c 28 29 3b 0a |(){..clo|sepl();.|
|00000090| 7d 0a 63 6c 6f 73 65 70 | 6c 28 29 7b 0a 09 66 66 |}.closep|l(){..ff|
|000000a0| 6c 75 73 68 28 73 74 64 | 6f 75 74 29 3b 0a 09 72 |lush(std|out);..r|
|000000b0| 65 73 65 74 28 29 3b 0a | 7d 0a 64 6f 74 2e 63 00 |eset();.|}.dot.c.|
|000000c0| 00 00 00 00 00 00 00 00 | 8e 0d 96 f4 29 01 b6 81 |........|....)...|
|000000d0| 00 00 09 00 64 6f 74 28 | 29 7b 0a 7d 0a 3c 65 72 |....dot(|){.}.<er|
|000000e0| 61 73 65 2e 63 00 00 00 | 00 00 00 00 8e 0d 97 f4 |ase.c...|........|
|000000f0| 29 01 b6 81 00 00 66 00 | 23 69 6e 63 6c 75 64 65 |).....f.|#include|
|00000100| 20 22 63 6f 6e 2e 68 22 | 0a 65 72 61 73 65 28 29 | "con.h"|.erase()|
|00000110| 7b 0a 09 69 6e 74 20 69 | 3b 0a 09 09 66 6f 72 28 |{..int i|;...for(|
|00000120| 69 3d 30 3b 20 69 3c 31 | 31 2a 28 56 45 52 54 52 |i=0; i<1|1*(VERTR|
|00000130| 45 53 50 2f 56 45 52 54 | 52 45 53 29 3b 20 69 2b |ESP/VERT|RES); i+|
|00000140| 2b 29 0a 09 09 09 73 70 | 65 77 28 44 4f 57 4e 29 |+)....sp|ew(DOWN)|
|00000150| 3b 0a 09 09 72 65 74 75 | 72 6e 3b 0a 7d 0a 6c 61 |;...retu|rn;.}.la|
|00000160| 62 65 6c 2e 63 00 00 00 | 00 00 00 00 8e 0d 97 f4 |bel.c...|........|
|00000170| 29 01 b6 81 00 00 76 00 | 23 69 6e 63 6c 75 64 65 |).....v.|#include|
|00000180| 20 22 63 6f 6e 2e 68 22 | 0a 6c 61 62 65 6c 28 73 | "con.h"|.label(s|
|00000190| 29 0a 63 68 61 72 20 2a | 73 3b 0a 7b 0a 09 69 6e |).char *|s;.{..in|
|000001a0| 74 20 69 2c 63 3b 0a 09 | 09 77 68 69 6c 65 28 28 |t i,c;..|.while((|
|000001b0| 63 20 3d 20 2a 73 2b 2b | 29 20 21 3d 20 27 5c 30 |c = *s++|) != '\0|
|000001c0| 27 29 7b 0a 09 09 09 78 | 6e 6f 77 20 3d 2b 20 36 |'){....x|now =+ 6|
|000001d0| 3b 0a 09 09 09 73 70 65 | 77 28 63 29 3b 0a 09 09 |;....spe|w(c);...|
|000001e0| 7d 0a 09 09 72 65 74 75 | 72 6e 3b 0a 7d 0a 6c 69 |}...retu|rn;.}.li|
|000001f0| 6e 65 2e 63 00 00 00 00 | 00 00 00 00 8e 0d 97 f4 |ne.c....|........|
|00000200| 29 01 b6 81 00 00 16 03 | 23 69 6e 63 6c 75 64 65 |).......|#include|
|00000210| 20 22 63 6f 6e 2e 68 22 | 0a 6c 69 6e 65 28 78 30 | "con.h"|.line(x0|
|00000220| 2c 79 30 2c 78 31 2c 79 | 31 29 7b 0a 09 69 6c 69 |,y0,x1,y|1){..ili|
|00000230| 6e 65 28 78 63 6f 6e 76 | 28 78 73 63 28 78 30 29 |ne(xconv|(xsc(x0)|
|00000240| 29 2c 79 63 6f 6e 76 28 | 79 73 63 28 79 30 29 29 |),yconv(|ysc(y0))|
|00000250| 2c 78 63 6f 6e 76 28 78 | 73 63 28 78 31 29 29 2c |,xconv(x|sc(x1)),|
|00000260| 79 63 6f 6e 76 28 79 73 | 63 28 79 31 29 29 29 3b |yconv(ys|c(y1)));|
|00000270| 0a 09 09 72 65 74 75 72 | 6e 3b 0a 7d 0a 63 6f 6e |...retur|n;.}.con|
|00000280| 74 28 78 30 2c 79 30 29 | 7b 0a 09 69 6c 69 6e 65 |t(x0,y0)|{..iline|
|00000290| 28 78 6e 6f 77 2c 79 6e | 6f 77 2c 78 63 6f 6e 76 |(xnow,yn|ow,xconv|
|000002a0| 28 78 73 63 28 78 30 29 | 29 2c 79 63 6f 6e 76 28 |(xsc(x0)|),yconv(|
|000002b0| 79 73 63 28 79 30 29 29 | 29 3b 0a 09 72 65 74 75 |ysc(y0))|);..retu|
|000002c0| 72 6e 3b 0a 7d 0a 69 6c | 69 6e 65 28 63 78 30 2c |rn;.}.il|ine(cx0,|
|000002d0| 63 79 30 2c 63 78 31 2c | 63 79 31 29 7b 0a 09 69 |cy0,cx1,|cy1){..i|
|000002e0| 6e 74 20 6d 61 78 70 2c | 74 74 2c 6a 2c 6e 70 3b |nt maxp,|tt,j,np;|
|000002f0| 0a 09 63 68 61 72 20 63 | 68 78 2c 63 68 79 3b 0a |..char c|hx,chy;.|
|00000300| 09 66 6c 6f 61 74 20 78 | 64 2c 79 64 3b 0a 09 66 |.float x|d,yd;..f|
|00000310| 6c 6f 61 74 20 64 69 73 | 74 32 28 29 2c 73 71 72 |loat dis|t2(),sqr|
|00000320| 74 28 29 3b 0a 09 09 6d | 6f 76 65 70 28 63 78 30 |t();...m|ovep(cx0|
|00000330| 2c 63 79 30 29 3b 0a 09 | 09 6d 61 78 70 20 3d 20 |,cy0);..|.maxp = |
|00000340| 73 71 72 74 28 64 69 73 | 74 32 28 63 78 30 2c 63 |sqrt(dis|t2(cx0,c|
|00000350| 79 30 2c 63 78 31 2c 63 | 79 31 29 29 2f 32 2e 3b |y0,cx1,c|y1))/2.;|
|00000360| 0a 09 09 78 64 20 3d 20 | 63 78 31 2d 63 78 30 3b |...xd = |cx1-cx0;|
|00000370| 0a 09 09 79 64 20 3d 20 | 63 79 31 2d 63 79 30 3b |...yd = |cy1-cy0;|
|00000380| 0a 09 09 69 66 28 78 64 | 20 3e 3d 20 30 29 63 68 |...if(xd| >= 0)ch|
|00000390| 78 20 3d 20 52 49 47 48 | 54 3b 0a 09 09 65 6c 73 |x = RIGH|T;...els|
|000003a0| 65 20 63 68 78 20 3d 20 | 4c 45 46 54 3b 0a 09 09 |e chx = |LEFT;...|
|000003b0| 69 66 28 79 64 20 3e 3d | 20 30 29 63 68 79 20 3d |if(yd >=| 0)chy =|
|000003c0| 20 55 50 3b 0a 09 09 65 | 6c 73 65 20 63 68 79 20 | UP;...e|lse chy |
|000003d0| 3d 20 44 4f 57 4e 3b 0a | 09 09 69 66 28 6d 61 78 |= DOWN;.|..if(max|
|000003e0| 70 3d 3d 30 29 7b 0a 09 | 09 09 78 64 3d 30 3b 0a |p==0){..|..xd=0;.|
|000003f0| 09 09 09 79 64 3d 30 3b | 0a 09 09 7d 0a 09 09 65 |...yd=0;|...}...e|
|00000400| 6c 73 65 7b 0a 09 09 09 | 78 64 20 3d 2f 6d 61 78 |lse{....|xd =/max|
|00000410| 70 3b 0a 09 09 09 79 64 | 20 3d 2f 6d 61 78 70 3b |p;....yd| =/maxp;|
|00000420| 0a 09 09 7d 0a 09 09 69 | 6e 70 6c 6f 74 28 29 3b |...}...i|nplot();|
|00000430| 0a 09 09 66 6f 72 20 28 | 74 74 3d 30 3b 20 74 74 |...for (|tt=0; tt|
|00000440| 3c 3d 6d 61 78 70 3b 20 | 74 74 2b 2b 29 7b 0a 09 |<=maxp; |tt++){..|
|00000450| 09 09 6a 3d 20 63 78 30 | 2b 78 64 2a 74 74 2d 78 |..j= cx0|+xd*tt-x|
|00000460| 6e 6f 77 3b 0a 09 09 09 | 78 6e 6f 77 20 3d 2b 20 |now;....|xnow =+ |
|00000470| 6a 3b 0a 09 09 09 6a 20 | 3d 20 61 62 76 61 6c 28 |j;....j |= abval(|
|00000480| 6a 29 3b 0a 09 09 09 77 | 68 69 6c 65 28 6a 2d 2d |j);....w|hile(j--|
|00000490| 20 3e 20 30 29 73 70 65 | 77 28 63 68 78 29 3b 0a | > 0)spe|w(chx);.|
|000004a0| 09 09 09 6a 20 3d 20 63 | 79 30 2b 79 64 2a 74 74 |...j = c|y0+yd*tt|
|000004b0| 2d 79 6e 6f 77 3b 0a 09 | 09 09 79 6e 6f 77 20 3d |-ynow;..|..ynow =|
|000004c0| 2b 20 6a 3b 0a 09 09 09 | 6a 20 3d 20 61 62 76 61 |+ j;....|j = abva|
|000004d0| 6c 28 6a 29 3b 0a 09 09 | 09 77 68 69 6c 65 28 6a |l(j);...|.while(j|
|000004e0| 2d 2d 20 3e 20 30 29 73 | 70 65 77 28 63 68 79 29 |-- > 0)s|pew(chy)|
|000004f0| 3b 0a 09 09 09 73 70 65 | 77 20 28 27 2e 27 29 3b |;....spe|w ('.');|
|00000500| 0a 09 09 7d 0a 09 09 6f | 75 74 70 6c 6f 74 28 29 |...}...o|utplot()|
|00000510| 3b 0a 09 09 72 65 74 75 | 72 6e 3b 0a 7d 0a 6c 69 |;...retu|rn;.}.li|
|00000520| 6e 6d 6f 64 2e 63 00 00 | 00 00 00 00 8e 0d 97 f4 |nmod.c..|........|
|00000530| 29 01 b6 81 00 00 0d 00 | 6c 69 6e 65 6d 6f 64 28 |).......|linemod(|
|00000540| 29 7b 0a 7d 0a 09 6d 6f | 76 65 2e 63 00 00 00 00 |){.}..mo|ve.c....|
|00000550| 00 00 00 00 8e 0d 97 f4 | 29 01 b6 81 00 00 41 00 |........|).....A.|
|00000560| 6d 6f 76 65 28 78 69 2c | 79 69 29 7b 0a 09 09 6d |move(xi,|yi){...m|
|00000570| 6f 76 65 70 28 78 63 6f | 6e 76 28 78 73 63 28 78 |ovep(xco|nv(xsc(x|
|00000580| 69 29 29 2c 79 63 6f 6e | 76 28 79 73 63 28 79 69 |i)),ycon|v(ysc(yi|
|00000590| 29 29 29 3b 0a 09 09 72 | 65 74 75 72 6e 3b 0a 7d |)));...r|eturn;.}|
|000005a0| 0a 74 6f 70 65 6e 2e 63 | 00 00 00 00 00 00 00 00 |.topen.c|........|
|000005b0| 8e 0d 89 f6 29 01 b6 81 | 00 00 e5 03 23 0a 2f 2a |....)...|....#./*|
|000005c0| 20 67 73 69 20 70 6c 6f | 74 74 69 6e 67 20 6f 75 | gsi plo|tting ou|
|000005d0| 74 70 75 74 20 72 6f 75 | 74 69 6e 65 73 20 2a 2f |tput rou|tines */|
|000005e0| 0a 23 20 64 65 66 69 6e | 65 20 44 4f 57 4e 20 30 |.# defin|e DOWN 0|
|000005f0| 31 32 0a 23 20 64 65 66 | 69 6e 65 20 55 50 20 30 |12.# def|ine UP 0|
|00000600| 31 33 0a 23 20 64 65 66 | 69 6e 65 20 4c 45 46 54 |13.# def|ine LEFT|
|00000610| 20 30 31 30 0a 23 20 64 | 65 66 69 6e 65 20 52 49 | 010.# d|efine RI|
|00000620| 47 48 54 20 30 34 30 0a | 23 20 64 65 66 69 6e 65 |GHT 040.|# define|
|00000630| 20 42 45 4c 20 30 30 37 | 0a 23 20 64 65 66 69 6e | BEL 007|.# defin|
|00000640| 65 20 41 43 4b 20 30 30 | 36 0a 23 20 64 65 66 69 |e ACK 00|6.# defi|
|00000650| 6e 65 20 43 52 20 30 31 | 35 0a 23 20 64 65 66 69 |ne CR 01|5.# defi|
|00000660| 6e 65 20 46 46 20 30 31 | 34 0a 23 20 64 65 66 69 |ne FF 01|4.# defi|
|00000670| 6e 65 20 56 45 52 54 52 | 45 53 50 20 34 38 0a 23 |ne VERTR|ESP 48.#|
|00000680| 20 64 65 66 69 6e 65 20 | 48 4f 52 5a 52 45 53 50 | define |HORZRESP|
|00000690| 20 36 30 2e 0a 23 20 64 | 65 66 69 6e 65 20 48 4f | 60..# d|efine HO|
|000006a0| 52 5a 52 45 53 20 36 2e | 0a 23 20 64 65 66 69 6e |RZRES 6.|.# defin|
|000006b0| 65 20 56 45 52 54 52 45 | 53 20 38 2e 0a 2f 2a 20 |e VERTRE|S 8../* |
|000006c0| 64 6f 77 6e 20 69 73 20 | 6c 69 6e 65 20 66 65 65 |down is |line fee|
|000006d0| 64 2c 20 75 70 20 69 73 | 20 72 65 76 65 72 73 65 |d, up is| reverse|
|000006e0| 20 6f 79 6e 65 20 66 65 | 65 64 2c 0a 20 20 20 6c | oyne fe|ed,. l|
|000006f0| 65 66 74 20 69 73 20 62 | 77 63 6b 73 70 61 63 65 |eft is b|wckspace|
|00000700| 2c 20 72 69 67 68 74 20 | 69 73 20 73 70 61 63 65 |, right |is space|
|00000710| 2e 20 20 34 38 20 70 6f | 69 6e 74 73 20 70 65 72 |. 48 po|ints per|
|00000720| 20 69 6e 63 68 0a 20 20 | 20 76 65 72 74 69 63 61 | inch. | vertica|
|00000730| 6c 6c 79 2c 20 36 30 20 | 68 6f 72 69 7a 6f 6e 74 |lly, 60 |horizont|
|00000740| 61 6c 6c 79 20 2a 2f 0a | 0a 69 6e 74 20 78 6e 6f |ally */.|.int xno|
|00000750| 77 2c 20 79 6e 6f 77 3b | 0a 69 6e 74 20 49 54 54 |w, ynow;|.int ITT|
|00000760| 59 5b 33 5d 2c 20 50 54 | 54 59 5b 33 5d 2c 20 4f |Y[3], PT|TY[3], O|
|00000770| 55 54 46 3b 0a 66 6c 6f | 61 74 20 48 45 49 47 48 |UTF;.flo|at HEIGH|
|00000780| 54 20 36 2e 30 2c 20 57 | 49 44 54 48 20 36 2e 30 |T 6.0, W|IDTH 6.0|
|00000790| 2c 20 4f 46 46 53 45 54 | 20 30 2e 30 3b 0a 69 6e |, OFFSET| 0.0;.in|
|000007a0| 74 20 78 73 63 61 6c 65 | 2c 20 78 6f 66 66 73 65 |t xscale|, xoffse|
|000007b0| 74 2c 20 79 73 63 61 6c | 65 3b 0a 66 6c 6f 61 74 |t, yscal|e;.float|
|000007c0| 20 62 6f 74 78 20 30 2e | 2c 20 62 6f 74 79 20 30 | botx 0.|, boty 0|
|000007d0| 2e 2c 20 6f 62 6f 74 78 | 20 30 2e 2c 20 6f 62 6f |., obotx| 0., obo|
|000007e0| 74 79 20 30 2e 3b 0a 66 | 6c 6f 61 74 20 73 63 61 |ty 0.;.f|loat sca|
|000007f0| 6c 65 78 20 31 2e 2c 20 | 73 63 61 6c 65 79 20 31 |lex 1., |scaley 1|
|00000800| 2e 3b 0a 0a 6f 70 65 6e | 70 6c 20 28 29 0a 7b 0a |.;..open|pl ().{.|
|00000810| 09 69 6e 74 20 72 65 73 | 65 74 28 29 3b 0a 09 09 |.int res|et();...|
|00000820| 78 6e 6f 77 20 3d 20 79 | 6e 6f 77 20 3d 20 30 3b |xnow = y|now = 0;|
|00000830| 0a 09 09 4f 55 54 46 20 | 3d 20 31 3b 0a 09 09 70 |...OUTF |= 1;...p|
|00000840| 72 69 6e 74 66 28 22 5c | 72 22 29 3b 0a 09 09 67 |rintf("\|r");...g|
|00000850| 74 74 79 28 4f 55 54 46 | 2c 20 49 54 54 59 29 3b |tty(OUTF|, ITTY);|
|00000860| 0a 09 09 73 69 67 6e 61 | 6c 20 28 32 2c 20 26 72 |...signa|l (2, &r|
|00000870| 65 73 65 74 29 3b 0a 09 | 09 50 54 54 59 5b 30 5d |eset);..|.PTTY[0]|
|00000880| 20 3d 20 49 54 54 59 5b | 30 5d 3b 0a 09 09 50 54 | = ITTY[|0];...PT|
|00000890| 54 59 5b 31 5d 20 3d 20 | 49 54 54 59 5b 31 5d 3b |TY[1] = |ITTY[1];|
|000008a0| 0a 09 09 50 54 54 59 5b | 32 5d 20 3d 20 49 54 54 |...PTTY[|2] = ITT|
|000008b0| 59 5b 32 5d 20 26 20 28 | 7e 20 30 32 30 29 3b 20 |Y[2] & (|~ 020); |
|000008c0| 20 2f 2a 20 64 6f 6e 27 | 74 20 6d 61 70 20 6c 66 | /* don'|t map lf|
|000008d0| 20 2a 2f 0a 09 09 50 54 | 54 59 5b 32 5d 20 3d 7c | */...PT|TY[2] =||
|000008e0| 20 30 30 31 3b 20 2f 2a | 20 6e 6f 20 64 65 6c 61 | 001; /*| no dela|
|000008f0| 79 73 20 2a 2f 0a 09 09 | 2f 2a 20 69 6e 69 74 69 |ys */...|/* initi|
|00000900| 61 6c 69 7a 65 20 63 6f | 6e 73 74 61 6e 74 73 20 |alize co|nstants |
|00000910| 2a 2f 0a 09 09 78 73 63 | 61 6c 65 20 20 3d 20 34 |*/...xsc|ale = 4|
|00000920| 30 39 36 2e 2f 28 48 4f | 52 5a 52 45 53 50 20 2a |096./(HO|RZRESP *|
|00000930| 20 57 49 44 54 48 29 3b | 0a 09 09 79 73 63 61 6c | WIDTH);|...yscal|
|00000940| 65 20 3d 20 34 30 39 36 | 20 2f 28 56 45 52 54 52 |e = 4096| /(VERTR|
|00000950| 45 53 50 20 2a 20 48 45 | 49 47 48 54 29 3b 0a 09 |ESP * HE|IGHT);..|
|00000960| 09 78 6f 66 66 73 65 74 | 20 3d 20 4f 46 46 53 45 |.xoffset| = OFFSE|
|00000970| 54 20 2a 20 48 4f 52 5a | 52 45 53 50 3b 0a 09 09 |T * HORZ|RESP;...|
|00000980| 72 65 74 75 72 6e 3b 0a | 7d 0a 0a 6f 70 65 6e 76 |return;.|}..openv|
|00000990| 74 28 29 7b 0a 6f 70 65 | 6e 70 6c 28 29 3b 0a 7d |t(){.ope|npl();.}|
|000009a0| 0a 20 70 6f 69 6e 74 2e | 63 00 00 00 00 00 00 00 |. point.|c.......|
|000009b0| 8e 0d 97 f4 29 01 b6 81 | 00 00 37 00 70 6f 69 6e |....)...|..7.poin|
|000009c0| 74 28 78 69 2c 79 69 29 | 7b 0a 09 09 6d 6f 76 65 |t(xi,yi)|{...move|
|000009d0| 28 78 69 2c 79 69 29 3b | 0a 09 09 6c 61 62 65 6c |(xi,yi);|...label|
|000009e0| 28 22 2e 22 29 3b 0a 09 | 09 72 65 74 75 72 6e 3b |(".");..|.return;|
|000009f0| 0a 7d 0a 20 73 70 61 63 | 65 2e 63 00 00 00 00 00 |.}. spac|e.c.....|
|00000a00| 00 00 8e 0d 98 f4 29 01 | b6 81 00 00 ba 00 23 20 |......).|......# |
|00000a10| 69 6e 63 6c 75 64 65 20 | 22 63 6f 6e 2e 68 22 0a |include |"con.h".|
|00000a20| 66 6c 6f 61 74 20 64 65 | 6c 74 78 20 34 30 39 35 |float de|ltx 4095|
|00000a30| 2e 3b 0a 66 6c 6f 61 74 | 20 64 65 6c 74 79 20 34 |.;.float| delty 4|
|00000a40| 30 39 35 2e 3b 0a 73 70 | 61 63 65 28 78 30 2c 79 |095.;.sp|ace(x0,y|
|00000a50| 30 2c 78 31 2c 79 31 29 | 7b 0a 09 62 6f 74 78 20 |0,x1,y1)|{..botx |
|00000a60| 3d 20 2d 32 30 34 37 2e | 3b 0a 09 62 6f 74 79 20 |= -2047.|;..boty |
|00000a70| 3d 20 2d 32 30 34 37 2e | 3b 0a 09 6f 62 6f 74 78 |= -2047.|;..obotx|
|00000a80| 20 3d 20 78 30 3b 0a 09 | 6f 62 6f 74 79 20 3d 20 | = x0;..|oboty = |
|00000a90| 79 30 3b 0a 09 73 63 61 | 6c 65 78 20 3d 20 64 65 |y0;..sca|lex = de|
|00000aa0| 6c 74 78 2f 28 78 31 2d | 78 30 29 3b 0a 09 73 63 |ltx/(x1-|x0);..sc|
|00000ab0| 61 6c 65 79 20 3d 20 64 | 65 6c 74 79 2f 28 79 31 |aley = d|elty/(y1|
|00000ac0| 2d 79 30 29 3b 0a 7d 0a | 73 75 62 72 2e 63 00 00 |-y0);.}.|subr.c..|
|00000ad0| 00 00 00 00 00 00 8e 0d | ae f7 29 01 b6 81 00 00 |........|..).....|
|00000ae0| bf 05 23 69 6e 63 6c 75 | 64 65 20 3c 73 74 64 69 |..#inclu|de <stdi|
|00000af0| 6f 2e 68 3e 0a 23 69 6e | 63 6c 75 64 65 20 22 63 |o.h>.#in|clude "c|
|00000b00| 6f 6e 2e 68 22 0a 61 62 | 76 61 6c 28 71 29 0a 7b |on.h".ab|val(q).{|
|00000b10| 0a 09 72 65 74 75 72 6e | 20 28 71 3e 3d 30 20 3f |..return| (q>=0 ?|
|00000b20| 20 71 20 3a 20 2d 71 29 | 3b 0a 7d 0a 0a 78 63 6f | q : -q)|;.}..xco|
|00000b30| 6e 76 20 28 78 70 29 0a | 7b 0a 09 2f 2a 20 78 20 |nv (xp).|{../* x |
|00000b40| 70 6f 73 69 74 69 6f 6e | 20 69 6e 70 75 74 20 69 |position| input i|
|00000b50| 73 20 2d 32 30 34 37 20 | 74 6f 20 2b 32 30 34 37 |s -2047 |to +2047|
|00000b60| 2c 20 6f 75 74 70 75 74 | 20 6d 75 73 74 20 62 65 |, output| must be|
|00000b70| 20 30 20 74 6f 20 50 41 | 47 53 49 5a 2a 48 4f 52 | 0 to PA|GSIZ*HOR|
|00000b80| 5a 52 45 53 20 2a 2f 0a | 09 78 70 20 3d 2b 20 32 |ZRES */.|.xp =+ 2|
|00000b90| 30 34 38 3b 0a 09 2f 2a | 20 74 68 65 20 63 6f 6d |048;../*| the com|
|00000ba0| 70 75 74 61 74 69 6f 6e | 20 69 73 20 6e 65 77 78 |putation| is newx|
|00000bb0| 20 3d 20 78 70 2a 28 50 | 41 47 53 49 5a 2a 48 4f | = xp*(P|AGSIZ*HO|
|00000bc0| 52 5a 52 45 53 29 2f 34 | 30 39 36 20 2a 2f 0a 09 |RZRES)/4|096 */..|
|00000bd0| 72 65 74 75 72 6e 20 28 | 78 6f 66 66 73 65 74 20 |return (|xoffset |
|00000be0| 2b 20 78 70 20 2f 78 73 | 63 61 6c 65 29 3b 0a 7d |+ xp /xs|cale);.}|
|00000bf0| 0a 0a 79 63 6f 6e 76 20 | 28 79 70 29 0a 7b 0a 09 |..yconv |(yp).{..|
|00000c00| 2f 2a 20 73 65 65 20 64 | 65 73 63 72 69 70 74 69 |/* see d|escripti|
|00000c10| 6f 6e 20 6f 66 20 78 63 | 6f 6e 76 20 2a 2f 0a 09 |on of xc|onv */..|
|00000c20| 79 70 20 3d 2b 20 32 30 | 34 38 3b 0a 09 72 65 74 |yp =+ 20|48;..ret|
|00000c30| 75 72 6e 20 28 79 70 20 | 2f 20 79 73 63 61 6c 65 |urn (yp |/ yscale|
|00000c40| 29 3b 0a 7d 0a 0a 69 6e | 70 6c 6f 74 28 29 0a 7b |);.}..in|plot().{|
|00000c50| 0a 09 73 74 74 79 28 4f | 55 54 46 2c 20 50 54 54 |..stty(O|UTF, PTT|
|00000c60| 59 29 3b 0a 09 73 70 65 | 77 20 28 41 43 4b 29 3b |Y);..spe|w (ACK);|
|00000c70| 0a 7d 0a 0a 6f 75 74 70 | 6c 6f 74 28 29 0a 7b 0a |.}..outp|lot().{.|
|00000c80| 09 73 70 65 77 28 45 53 | 43 29 3b 0a 09 73 70 65 |.spew(ES|C);..spe|
|00000c90| 77 28 41 43 4b 29 3b 0a | 09 66 66 6c 75 73 68 28 |w(ACK);.|.fflush(|
|00000ca0| 73 74 64 6f 75 74 29 3b | 0a 09 73 74 74 79 20 28 |stdout);|..stty (|
|00000cb0| 4f 55 54 46 2c 20 49 54 | 54 59 29 3b 0a 7d 0a 0a |OUTF, IT|TY);.}..|
|00000cc0| 73 70 65 77 28 63 68 29 | 0a 7b 0a 09 69 66 28 63 |spew(ch)|.{..if(c|
|00000cd0| 68 20 3d 3d 20 55 50 29 | 70 75 74 63 28 45 53 43 |h == UP)|putc(ESC|
|00000ce0| 2c 73 74 64 6f 75 74 29 | 3b 0a 09 70 75 74 63 28 |,stdout)|;..putc(|
|00000cf0| 63 68 2c 20 73 74 64 6f | 75 74 29 3b 0a 7d 0a 0a |ch, stdo|ut);.}..|
|00000d00| 74 6f 62 6f 74 6c 65 66 | 74 20 28 29 0a 7b 0a 09 |tobotlef|t ().{..|
|00000d10| 6d 6f 76 65 28 2d 32 30 | 34 38 2c 2d 32 30 34 38 |move(-20|48,-2048|
|00000d20| 29 3b 0a 7d 0a 72 65 73 | 65 74 28 29 0a 7b 0a 09 |);.}.res|et().{..|
|00000d30| 6f 75 74 70 6c 6f 74 28 | 29 3b 0a 09 65 78 69 74 |outplot(|);..exit|
|00000d40| 28 29 3b 0a 7d 0a 0a 66 | 6c 6f 61 74 0a 64 69 73 |();.}..f|loat.dis|
|00000d50| 74 32 20 28 78 31 2c 20 | 79 31 2c 20 78 32 2c 20 |t2 (x1, |y1, x2, |
|00000d60| 79 32 29 0a 7b 0a 09 66 | 6c 6f 61 74 20 74 2c 76 |y2).{..f|loat t,v|
|00000d70| 3b 0a 09 74 20 3d 20 78 | 32 2d 78 31 3b 0a 09 76 |;..t = x|2-x1;..v|
|00000d80| 20 3d 20 79 31 2d 79 32 | 3b 0a 09 72 65 74 75 72 | = y1-y2|;..retur|
|00000d90| 6e 20 28 74 2a 74 2b 76 | 2a 76 29 3b 0a 7d 0a 0a |n (t*t+v|*v);.}..|
|00000da0| 73 77 61 70 20 28 70 61 | 2c 20 70 62 29 0a 69 6e |swap (pa|, pb).in|
|00000db0| 74 20 2a 70 61 2c 20 2a | 70 62 3b 0a 7b 0a 09 69 |t *pa, *|pb;.{..i|
|00000dc0| 6e 74 20 74 3b 0a 09 74 | 20 3d 20 2a 70 61 3b 0a |nt t;..t| = *pa;.|
|00000dd0| 09 2a 70 61 20 3d 20 2a | 70 62 3b 0a 09 2a 70 62 |.*pa = *|pb;..*pb|
|00000de0| 20 3d 20 74 3b 0a 7d 0a | 6d 6f 76 65 70 20 28 78 | = t;.}.|movep (x|
|00000df0| 67 2c 20 79 67 29 0a 7b | 0a 09 69 6e 74 20 69 2c |g, yg).{|..int i,|
|00000e00| 63 68 3b 0a 09 69 66 28 | 28 78 67 20 3d 3d 20 78 |ch;..if(|(xg == x|
|00000e10| 6e 6f 77 29 20 26 26 20 | 28 79 67 20 3d 3d 20 79 |now) && |(yg == y|
|00000e20| 6e 6f 77 29 29 72 65 74 | 75 72 6e 3b 0a 09 2f 2a |now))ret|urn;../*|
|00000e30| 20 69 66 20 77 65 20 6e | 65 65 64 20 74 6f 20 67 | if we n|eed to g|
|00000e40| 6f 20 74 6f 20 6c 65 66 | 74 20 6d 61 72 67 69 6e |o to lef|t margin|
|00000e50| 2c 20 6a 75 73 74 20 43 | 52 20 2a 2f 0a 09 69 66 |, just C|R */..if|
|00000e60| 20 28 78 67 20 3c 20 78 | 6e 6f 77 2f 32 29 0a 09 | (xg < x|now/2)..|
|00000e70| 7b 0a 09 09 73 70 65 77 | 28 43 52 29 3b 0a 09 09 |{...spew|(CR);...|
|00000e80| 78 6e 6f 77 20 3d 20 30 | 3b 0a 09 7d 0a 09 69 20 |xnow = 0|;..}..i |
|00000e90| 3d 20 28 78 67 2d 78 6e | 6f 77 29 2f 48 4f 52 5a |= (xg-xn|ow)/HORZ|
|00000ea0| 52 45 53 3b 0a 09 69 66 | 28 78 6e 6f 77 20 3c 20 |RES;..if|(xnow < |
|00000eb0| 78 67 29 63 68 20 3d 20 | 52 49 47 48 54 3b 0a 09 |xg)ch = |RIGHT;..|
|00000ec0| 65 6c 73 65 20 63 68 20 | 3d 20 4c 45 46 54 3b 0a |else ch |= LEFT;.|
|00000ed0| 09 78 6e 6f 77 20 3d 2b | 20 69 2a 48 4f 52 5a 52 |.xnow =+| i*HORZR|
|00000ee0| 45 53 3b 0a 09 69 20 3d | 20 61 62 76 61 6c 28 69 |ES;..i =| abval(i|
|00000ef0| 29 3b 0a 09 77 68 69 6c | 65 28 69 2d 2d 29 73 70 |);..whil|e(i--)sp|
|00000f00| 65 77 28 63 68 29 3b 0a | 09 69 20 3d 20 61 62 76 |ew(ch);.|.i = abv|
|00000f10| 61 6c 28 78 67 2d 78 6e | 6f 77 29 3b 0a 09 69 6e |al(xg-xn|ow);..in|
|00000f20| 70 6c 6f 74 28 29 3b 0a | 09 77 68 69 6c 65 28 69 |plot();.|.while(i|
|00000f30| 2d 2d 29 20 73 70 65 77 | 28 63 68 29 3b 0a 09 6f |--) spew|(ch);..o|
|00000f40| 75 74 70 6c 6f 74 28 29 | 3b 0a 09 69 3d 28 79 67 |utplot()|;..i=(yg|
|00000f50| 2d 79 6e 6f 77 29 2f 56 | 45 52 54 52 45 53 3b 0a |-ynow)/V|ERTRES;.|
|00000f60| 09 69 66 28 79 6e 6f 77 | 20 3c 20 79 67 29 63 68 |.if(ynow| < yg)ch|
|00000f70| 20 3d 20 55 50 3b 0a 09 | 65 6c 73 65 20 63 68 20 | = UP;..|else ch |
|00000f80| 3d 20 44 4f 57 4e 3b 0a | 09 79 6e 6f 77 20 3d 2b |= DOWN;.|.ynow =+|
|00000f90| 20 69 2a 56 45 52 54 52 | 45 53 3b 0a 09 69 20 3d | i*VERTR|ES;..i =|
|00000fa0| 20 61 62 76 61 6c 28 69 | 29 3b 0a 09 77 68 69 6c | abval(i|);..whil|
|00000fb0| 65 28 69 2d 2d 29 73 70 | 65 77 28 63 68 29 3b 0a |e(i--)sp|ew(ch);.|
|00000fc0| 09 69 3d 61 62 76 61 6c | 28 79 67 2d 79 6e 6f 77 |.i=abval|(yg-ynow|
|00000fd0| 29 3b 0a 09 69 6e 70 6c | 6f 74 28 29 3b 0a 09 77 |);..inpl|ot();..w|
|00000fe0| 68 69 6c 65 28 69 2d 2d | 29 73 70 65 77 28 63 68 |hile(i--|)spew(ch|
|00000ff0| 29 3b 0a 09 6f 75 74 70 | 6c 6f 74 28 29 3b 0a 09 |);..outp|lot();..|
|00001000| 78 6e 6f 77 20 3d 20 78 | 67 3b 20 79 6e 6f 77 20 |xnow = x|g; ynow |
|00001010| 3d 20 79 67 3b 0a 7d 0a | 0a 78 73 63 28 78 69 29 |= yg;.}.|.xsc(xi)|
|00001020| 7b 0a 09 69 6e 74 20 78 | 61 3b 0a 09 78 61 20 3d |{..int x|a;..xa =|
|00001030| 20 28 78 69 20 2d 20 6f | 62 6f 74 78 29 20 2a 20 | (xi - o|botx) * |
|00001040| 73 63 61 6c 65 78 20 2b | 20 62 6f 74 78 3b 0a 09 |scalex +| botx;..|
|00001050| 72 65 74 75 72 6e 28 78 | 61 29 3b 0a 7d 0a 79 73 |return(x|a);.}.ys|
|00001060| 63 28 79 69 29 7b 0a 09 | 69 6e 74 20 79 61 3b 0a |c(yi){..|int ya;.|
|00001070| 09 79 61 20 3d 20 28 79 | 69 20 2d 20 6f 62 6f 74 |.ya = (y|i - obot|
|00001080| 79 29 20 2a 73 63 61 6c | 65 79 20 2b 62 6f 74 79 |y) *scal|ey +boty|
|00001090| 3b 0a 09 72 65 74 75 72 | 6e 28 79 61 29 3b 0a 7d |;..retur|n(ya);.}|
|000010a0| 0a 45 63 6f 6e 2e 68 00 | 00 00 00 00 00 00 00 00 |.Econ.h.|........|
|000010b0| 8e 0d 98 f4 29 01 b6 81 | 00 00 57 02 23 0a 2f 2a |....)...|..W.#./*|
|000010c0| 20 67 73 69 20 70 6c 6f | 74 74 69 6e 67 20 6f 75 | gsi plo|tting ou|
|000010d0| 74 70 75 74 20 72 6f 75 | 74 69 6e 65 73 20 2a 2f |tput rou|tines */|
|000010e0| 0a 23 20 64 65 66 69 6e | 65 20 44 4f 57 4e 20 30 |.# defin|e DOWN 0|
|000010f0| 31 32 0a 23 20 64 65 66 | 69 6e 65 20 55 50 20 30 |12.# def|ine UP 0|
|00001100| 31 33 0a 23 20 64 65 66 | 69 6e 65 20 4c 45 46 54 |13.# def|ine LEFT|
|00001110| 20 30 31 30 0a 23 20 64 | 65 66 69 6e 65 20 52 49 | 010.# d|efine RI|
|00001120| 47 48 54 20 30 34 30 0a | 23 20 64 65 66 69 6e 65 |GHT 040.|# define|
|00001130| 20 42 45 4c 20 30 30 37 | 0a 23 20 64 65 66 69 6e | BEL 007|.# defin|
|00001140| 65 20 45 53 43 20 30 33 | 33 0a 23 20 64 65 66 69 |e ESC 03|3.# defi|
|00001150| 6e 65 20 41 43 4b 20 30 | 30 36 0a 23 20 64 65 66 |ne ACK 0|06.# def|
|00001160| 69 6e 65 20 43 52 20 30 | 31 35 0a 23 20 64 65 66 |ine CR 0|15.# def|
|00001170| 69 6e 65 20 46 46 20 30 | 31 34 0a 23 20 64 65 66 |ine FF 0|14.# def|
|00001180| 69 6e 65 20 56 45 52 54 | 52 45 53 50 20 34 38 0a |ine VERT|RESP 48.|
|00001190| 23 20 64 65 66 69 6e 65 | 20 48 4f 52 5a 52 45 53 |# define| HORZRES|
|000011a0| 50 20 36 30 2e 0a 23 20 | 64 65 66 69 6e 65 20 56 |P 60..# |define V|
|000011b0| 45 52 54 52 45 53 20 38 | 2e 0a 23 20 64 65 66 69 |ERTRES 8|..# defi|
|000011c0| 6e 65 20 48 4f 52 5a 52 | 45 53 20 36 2e 0a 2f 2a |ne HORZR|ES 6../*|
|000011d0| 20 64 6f 77 6e 20 69 73 | 20 6c 69 6e 65 20 66 65 | down is| line fe|
|000011e0| 65 64 2c 20 75 70 20 69 | 73 20 72 65 76 65 72 73 |ed, up i|s revers|
|000011f0| 65 20 6c 69 6e 65 20 66 | 65 65 64 2c 0a 20 20 20 |e line f|eed,. |
|00001200| 6c 65 66 74 20 69 73 20 | 62 61 63 6b 73 70 61 63 |left is |backspac|
|00001210| 65 2c 20 72 69 67 68 74 | 20 69 73 20 73 70 61 63 |e, right| is spac|
|00001220| 65 2e 20 20 34 38 20 70 | 6f 69 6e 74 73 20 70 65 |e. 48 p|oints pe|
|00001230| 72 20 69 6e 63 68 0a 20 | 20 20 76 65 72 74 69 63 |r inch. | vertic|
|00001240| 61 6c 6c 79 2c 20 36 30 | 20 68 6f 72 69 7a 6f 6e |ally, 60| horizon|
|00001250| 74 61 6c 6c 79 20 2a 2f | 0a 0a 65 78 74 65 72 6e |tally */|..extern|
|00001260| 20 69 6e 74 20 78 6e 6f | 77 2c 20 79 6e 6f 77 3b | int xno|w, ynow;|
|00001270| 0a 65 78 74 65 72 6e 20 | 69 6e 74 20 49 54 54 59 |.extern |int ITTY|
|00001280| 5b 33 5d 2c 20 50 54 54 | 59 5b 33 5d 2c 20 4f 55 |[3], PTT|Y[3], OU|
|00001290| 54 46 3b 0a 65 78 74 65 | 72 6e 20 66 6c 6f 61 74 |TF;.exte|rn float|
|000012a0| 20 48 45 49 47 48 54 2c | 20 57 49 44 54 48 2c 20 | HEIGHT,| WIDTH, |
|000012b0| 4f 46 46 53 45 54 3b 0a | 65 78 74 65 72 6e 20 69 |OFFSET;.|extern i|
|000012c0| 6e 74 20 78 73 63 61 6c | 65 2c 20 78 6f 66 66 73 |nt xscal|e, xoffs|
|000012d0| 65 74 2c 20 79 73 63 61 | 6c 65 3b 0a 65 78 74 65 |et, ysca|le;.exte|
|000012e0| 72 6e 20 66 6c 6f 61 74 | 20 62 6f 74 78 2c 20 62 |rn float| botx, b|
|000012f0| 6f 74 79 2c 20 6f 62 6f | 74 78 2c 20 6f 62 6f 74 |oty, obo|tx, obot|
|00001300| 79 2c 20 73 63 61 6c 65 | 78 2c 73 63 61 6c 65 79 |y, scale|x,scaley|
|00001310| 3b 0a 0a 30 62 6f 78 2e | 63 00 00 00 00 00 00 00 |;..0box.|c.......|
|00001320| 00 00 cf 0f d5 1b 09 01 | b6 81 00 00 72 00 62 6f |........|....r.bo|
|00001330| 78 28 78 30 2c 20 79 30 | 2c 20 78 31 2c 20 79 31 |x(x0, y0|, x1, y1|
|00001340| 29 0a 7b 0a 09 6d 6f 76 | 65 28 78 30 2c 20 79 30 |).{..mov|e(x0, y0|
|00001350| 29 3b 0a 09 63 6f 6e 74 | 28 78 30 2c 20 79 31 29 |);..cont|(x0, y1)|
|00001360| 3b 0a 09 63 6f 6e 74 28 | 78 31 2c 20 79 31 29 3b |;..cont(|x1, y1);|
|00001370| 0a 09 63 6f 6e 74 28 78 | 31 2c 20 79 30 29 3b 0a |..cont(x|1, y0);.|
|00001380| 09 63 6f 6e 74 28 78 30 | 2c 20 79 30 29 3b 0a 09 |.cont(x0|, y0);..|
|00001390| 6d 6f 76 65 28 78 31 2c | 20 79 31 29 3b 0a 7d 0a |move(x1,| y1);.}.|
+--------+-------------------------+-------------------------+--------+--------+