home *** CD-ROM | disk | FTP | other *** search
/ minnie.tuhs.org / unixen.tar / unixen / PDP-11 / Trees / V7 / usr / src / libplot / t450.c.a < prev    next >
Unix Archive - Old  |  1979-01-10  |  5.0 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| 90 0d 90 27 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 90 0d 90 27 | 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 90 0d 90 27 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 | 90 0d 90 27 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 90 0d 91 27 |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 90 0d 91 27 |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 90 0d 91 27 |ne.c....|.......'|
|00000200| 29 01 b6 81 00 00 18 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 20 3d 3d 20 30 29 7b | 0a 09 09 09 78 64 3d 30 |p == 0){|....xd=0|
|000003f0| 3b 0a 09 09 09 79 64 3d | 30 3b 0a 09 09 7d 0a 09 |;....yd=|0;...}..|
|00000400| 09 65 6c 73 65 7b 0a 09 | 09 09 78 64 20 3d 2f 6d |.else{..|..xd =/m|
|00000410| 61 78 70 3b 0a 09 09 09 | 79 64 20 3d 2f 6d 61 78 |axp;....|yd =/max|
|00000420| 70 3b 0a 09 09 7d 0a 09 | 09 69 6e 70 6c 6f 74 28 |p;...}..|.inplot(|
|00000430| 29 3b 0a 09 09 66 6f 72 | 20 28 74 74 3d 30 3b 20 |);...for| (tt=0; |
|00000440| 74 74 3c 3d 6d 61 78 70 | 3b 20 74 74 2b 2b 29 7b |tt<=maxp|; tt++){|
|00000450| 0a 09 09 09 6a 3d 20 63 | 78 30 2b 78 64 2a 74 74 |....j= c|x0+xd*tt|
|00000460| 2d 78 6e 6f 77 3b 0a 09 | 09 09 78 6e 6f 77 20 3d |-xnow;..|..xnow =|
|00000470| 2b 20 6a 3b 0a 09 09 09 | 6a 20 3d 20 61 62 76 61 |+ j;....|j = abva|
|00000480| 6c 28 6a 29 3b 0a 09 09 | 09 77 68 69 6c 65 28 6a |l(j);...|.while(j|
|00000490| 2d 2d 20 3e 20 30 29 73 | 70 65 77 28 63 68 78 29 |-- > 0)s|pew(chx)|
|000004a0| 3b 0a 09 09 09 6a 20 3d | 20 63 79 30 2b 79 64 2a |;....j =| cy0+yd*|
|000004b0| 74 74 2d 79 6e 6f 77 3b | 0a 09 09 09 79 6e 6f 77 |tt-ynow;|....ynow|
|000004c0| 20 3d 2b 20 6a 3b 0a 09 | 09 09 6a 20 3d 20 61 62 | =+ j;..|..j = ab|
|000004d0| 76 61 6c 28 6a 29 3b 0a | 09 09 09 77 68 69 6c 65 |val(j);.|...while|
|000004e0| 28 6a 2d 2d 20 3e 20 30 | 29 73 70 65 77 28 63 68 |(j-- > 0|)spew(ch|
|000004f0| 79 29 3b 0a 09 09 09 73 | 70 65 77 20 28 27 2e 27 |y);....s|pew ('.'|
|00000500| 29 3b 0a 09 09 7d 0a 09 | 09 6f 75 74 70 6c 6f 74 |);...}..|.outplot|
|00000510| 28 29 3b 0a 09 09 72 65 | 74 75 72 6e 3b 0a 7d 0a |();...re|turn;.}.|
|00000520| 6c 69 6e 6d 6f 64 2e 63 | 00 00 00 00 00 00 90 0d |linmod.c|........|
|00000530| 91 27 29 01 b6 81 00 00 | 0d 00 6c 69 6e 65 6d 6f |.').....|..linemo|
|00000540| 64 28 29 7b 0a 7d 0a 09 | 6d 6f 76 65 2e 63 00 00 |d(){.}..|move.c..|
|00000550| 00 00 00 00 00 00 90 0d | 91 27 29 01 b6 81 00 00 |........|.').....|
|00000560| 41 00 6d 6f 76 65 28 78 | 69 2c 79 69 29 7b 0a 09 |A.move(x|i,yi){..|
|00000570| 09 6d 6f 76 65 70 28 78 | 63 6f 6e 76 28 78 73 63 |.movep(x|conv(xsc|
|00000580| 28 78 69 29 29 2c 79 63 | 6f 6e 76 28 79 73 63 28 |(xi)),yc|onv(ysc(|
|00000590| 79 69 29 29 29 3b 0a 09 | 09 72 65 74 75 72 6e 3b |yi)));..|.return;|
|000005a0| 0a 7d 0a 20 6f 70 65 6e | 2e 63 00 00 00 00 00 00 |.}. open|.c......|
|000005b0| 00 00 90 0d e5 51 29 01 | b6 81 00 00 1f 04 23 0a |.....Q).|......#.|
|000005c0| 2f 2a 20 67 73 69 20 70 | 6c 6f 74 74 69 6e 67 20 |/* gsi p|lotting |
|000005d0| 6f 75 74 70 75 74 20 72 | 6f 75 74 69 6e 65 73 20 |output r|outines |
|000005e0| 2a 2f 0a 23 20 64 65 66 | 69 6e 65 20 44 4f 57 4e |*/.# def|ine DOWN|
|000005f0| 20 30 31 32 0a 23 20 64 | 65 66 69 6e 65 20 55 50 | 012.# d|efine UP|
|00000600| 20 30 31 33 0a 23 20 64 | 65 66 69 6e 65 20 4c 45 | 013.# d|efine LE|
|00000610| 46 54 20 30 31 30 0a 23 | 20 64 65 66 69 6e 65 20 |FT 010.#| define |
|00000620| 52 49 47 48 54 20 30 34 | 30 0a 23 20 64 65 66 69 |RIGHT 04|0.# defi|
|00000630| 6e 65 20 42 45 4c 20 30 | 30 37 0a 23 20 64 65 66 |ne BEL 0|07.# def|
|00000640| 69 6e 65 20 41 43 4b 20 | 30 30 36 0a 23 64 65 66 |ine ACK |006.#def|
|00000650| 69 6e 65 20 50 4c 4f 54 | 49 4e 20 30 36 33 0a 23 |ine PLOT|IN 063.#|
|00000660| 64 65 66 69 6e 65 20 50 | 4c 4f 54 4f 55 54 20 30 |define P|LOTOUT 0|
|00000670| 36 34 0a 23 20 64 65 66 | 69 6e 65 20 43 52 20 30 |64.# def|ine CR 0|
|00000680| 31 35 0a 23 20 64 65 66 | 69 6e 65 20 46 46 20 30 |15.# def|ine FF 0|
|00000690| 31 34 0a 23 20 64 65 66 | 69 6e 65 20 56 45 52 54 |14.# def|ine VERT|
|000006a0| 52 45 53 50 20 34 38 0a | 23 20 64 65 66 69 6e 65 |RESP 48.|# define|
|000006b0| 20 48 4f 52 5a 52 45 53 | 50 20 36 30 2e 0a 23 20 | HORZRES|P 60..# |
|000006c0| 64 65 66 69 6e 65 20 48 | 4f 52 5a 52 45 53 20 36 |define H|ORZRES 6|
|000006d0| 2e 0a 23 20 64 65 66 69 | 6e 65 20 56 45 52 54 52 |..# defi|ne VERTR|
|000006e0| 45 53 20 38 2e 0a 2f 2a | 20 64 6f 77 6e 20 69 73 |ES 8../*| down is|
|000006f0| 20 6c 69 6e 65 20 66 65 | 65 64 2c 20 75 70 20 69 | line fe|ed, up i|
|00000700| 73 20 72 65 76 65 72 73 | 65 20 6f 79 6e 65 20 66 |s revers|e oyne f|
|00000710| 65 65 64 2c 0a 20 20 20 | 6c 65 66 74 20 69 73 20 |eed,. |left is |
|00000720| 62 77 63 6b 73 70 61 63 | 65 2c 20 72 69 67 68 74 |bwckspac|e, right|
|00000730| 20 69 73 20 73 70 61 63 | 65 2e 20 20 34 38 20 70 | is spac|e. 48 p|
|00000740| 6f 69 6e 74 73 20 70 65 | 72 20 69 6e 63 68 0a 20 |oints pe|r inch. |
|00000750| 20 20 76 65 72 74 69 63 | 61 6c 6c 79 2c 20 36 30 | vertic|ally, 60|
|00000760| 20 68 6f 72 69 7a 6f 6e | 74 61 6c 6c 79 20 2a 2f | horizon|tally */|
|00000770| 0a 0a 69 6e 74 20 78 6e | 6f 77 2c 20 79 6e 6f 77 |..int xn|ow, ynow|
|00000780| 3b 0a 69 6e 74 20 49 54 | 54 59 5b 33 5d 2c 20 50 |;.int IT|TY[3], P|
|00000790| 54 54 59 5b 33 5d 2c 20 | 4f 55 54 46 3b 0a 66 6c |TTY[3], |OUTF;.fl|
|000007a0| 6f 61 74 20 48 45 49 47 | 48 54 20 36 2e 30 2c 20 |oat HEIG|HT 6.0, |
|000007b0| 57 49 44 54 48 20 36 2e | 30 2c 20 4f 46 46 53 45 |WIDTH 6.|0, OFFSE|
|000007c0| 54 20 30 2e 30 3b 0a 69 | 6e 74 20 78 73 63 61 6c |T 0.0;.i|nt xscal|
|000007d0| 65 2c 20 78 6f 66 66 73 | 65 74 2c 20 79 73 63 61 |e, xoffs|et, ysca|
|000007e0| 6c 65 3b 0a 66 6c 6f 61 | 74 20 62 6f 74 78 20 30 |le;.floa|t botx 0|
|000007f0| 2e 2c 20 62 6f 74 79 20 | 30 2e 2c 20 6f 62 6f 74 |., boty |0., obot|
|00000800| 78 20 30 2e 2c 20 6f 62 | 6f 74 79 20 30 2e 3b 0a |x 0., ob|oty 0.;.|
|00000810| 66 6c 6f 61 74 20 73 63 | 61 6c 65 78 20 31 2e 2c |float sc|alex 1.,|
|00000820| 20 73 63 61 6c 65 79 20 | 31 2e 3b 0a 0a 6f 70 65 | scaley |1.;..ope|
|00000830| 6e 70 6c 20 28 29 0a 7b | 0a 09 69 6e 74 20 72 65 |npl ().{|..int re|
|00000840| 73 65 74 28 29 3b 0a 09 | 09 78 6e 6f 77 20 3d 20 |set();..|.xnow = |
|00000850| 79 6e 6f 77 20 3d 20 30 | 3b 0a 09 09 4f 55 54 46 |ynow = 0|;...OUTF|
|00000860| 20 3d 20 31 3b 0a 09 09 | 70 72 69 6e 74 66 28 22 | = 1;...|printf("|
|00000870| 5c 72 22 29 3b 0a 09 09 | 67 74 74 79 28 4f 55 54 |\r");...|gtty(OUT|
|00000880| 46 2c 20 49 54 54 59 29 | 3b 0a 09 09 73 69 67 6e |F, ITTY)|;...sign|
|00000890| 61 6c 20 28 32 2c 20 26 | 72 65 73 65 74 29 3b 0a |al (2, &|reset);.|
|000008a0| 09 09 50 54 54 59 5b 30 | 5d 20 3d 20 49 54 54 59 |..PTTY[0|] = ITTY|
|000008b0| 5b 30 5d 3b 0a 09 09 50 | 54 54 59 5b 31 5d 20 3d |[0];...P|TTY[1] =|
|000008c0| 20 49 54 54 59 5b 31 5d | 3b 0a 09 09 50 54 54 59 | ITTY[1]|;...PTTY|
|000008d0| 5b 32 5d 20 3d 20 49 54 | 54 59 5b 32 5d 20 26 20 |[2] = IT|TY[2] & |
|000008e0| 28 7e 20 30 32 30 29 3b | 20 20 2f 2a 20 64 6f 6e |(~ 020);| /* don|
|000008f0| 27 74 20 6d 61 70 20 6c | 66 20 2a 2f 0a 09 09 50 |'t map l|f */...P|
|00000900| 54 54 59 5b 32 5d 20 3d | 7c 20 30 30 31 3b 20 2f |TTY[2] =|| 001; /|
|00000910| 2a 20 6e 6f 20 64 65 6c | 61 79 73 20 2a 2f 0a 09 |* no del|ays */..|
|00000920| 09 73 74 74 79 28 4f 55 | 54 46 2c 50 54 54 59 29 |.stty(OU|TF,PTTY)|
|00000930| 3b 0a 09 09 2f 2a 20 69 | 6e 69 74 69 61 6c 69 7a |;.../* i|nitializ|
|00000940| 65 20 63 6f 6e 73 74 61 | 6e 74 73 20 2a 2f 0a 09 |e consta|nts */..|
|00000950| 09 78 73 63 61 6c 65 20 | 20 3d 20 34 30 39 36 2e |.xscale | = 4096.|
|00000960| 2f 28 48 4f 52 5a 52 45 | 53 50 20 2a 20 57 49 44 |/(HORZRE|SP * WID|
|00000970| 54 48 29 3b 0a 09 09 79 | 73 63 61 6c 65 20 3d 20 |TH);...y|scale = |
|00000980| 34 30 39 36 20 2f 28 56 | 45 52 54 52 45 53 50 20 |4096 /(V|ERTRESP |
|00000990| 2a 20 48 45 49 47 48 54 | 29 3b 0a 09 09 78 6f 66 |* HEIGHT|);...xof|
|000009a0| 66 73 65 74 20 3d 20 4f | 46 46 53 45 54 20 2a 20 |fset = O|FFSET * |
|000009b0| 48 4f 52 5a 52 45 53 50 | 3b 0a 09 09 72 65 74 75 |HORZRESP|;...retu|
|000009c0| 72 6e 3b 0a 7d 0a 0a 6f | 70 65 6e 76 74 28 29 7b |rn;.}..o|penvt(){|
|000009d0| 0a 6f 70 65 6e 70 6c 28 | 29 3b 0a 7d 0a 73 70 6f |.openpl(|);.}.spo|
|000009e0| 69 6e 74 2e 63 00 00 00 | 00 00 00 00 90 0d 92 27 |int.c...|.......'|
|000009f0| 29 01 b6 81 00 00 37 00 | 70 6f 69 6e 74 28 78 69 |).....7.|point(xi|
|00000a00| 2c 79 69 29 7b 0a 09 09 | 6d 6f 76 65 28 78 69 2c |,yi){...|move(xi,|
|00000a10| 79 69 29 3b 0a 09 09 6c | 61 62 65 6c 28 22 2e 22 |yi);...l|abel("."|
|00000a20| 29 3b 0a 09 09 72 65 74 | 75 72 6e 3b 0a 7d 0a 74 |);...ret|urn;.}.t|
|00000a30| 73 70 61 63 65 2e 63 00 | 00 00 00 00 00 00 90 0d |space.c.|........|
|00000a40| 92 27 29 01 b6 81 00 00 | 94 00 23 20 69 6e 63 6c |.').....|..# incl|
|00000a50| 75 64 65 20 22 63 6f 6e | 2e 68 22 0a 73 70 61 63 |ude "con|.h".spac|
|00000a60| 65 28 78 30 2c 79 30 2c | 78 31 2c 79 31 29 7b 0a |e(x0,y0,|x1,y1){.|
|00000a70| 09 62 6f 74 78 20 3d 20 | 2d 32 30 34 37 2e 3b 0a |.botx = |-2047.;.|
|00000a80| 09 62 6f 74 79 20 3d 20 | 2d 32 30 34 37 2e 3b 0a |.boty = |-2047.;.|
|00000a90| 09 6f 62 6f 74 78 20 3d | 20 78 30 3b 0a 09 6f 62 |.obotx =| x0;..ob|
|00000aa0| 6f 74 79 20 3d 20 79 30 | 3b 0a 09 73 63 61 6c 65 |oty = y0|;..scale|
|00000ab0| 78 20 3d 20 34 30 39 36 | 2e 2f 28 78 31 2d 78 30 |x = 4096|./(x1-x0|
|00000ac0| 29 3b 0a 09 73 63 61 6c | 65 79 20 3d 20 34 30 39 |);..scal|ey = 409|
|00000ad0| 36 2e 2f 28 79 31 2d 79 | 30 29 3b 0a 7d 0a 73 75 |6./(y1-y|0);.}.su|
|00000ae0| 62 72 2e 63 00 00 00 00 | 00 00 00 00 90 0d e5 51 |br.c....|.......Q|
|00000af0| 29 01 b6 81 00 00 de 05 | 23 69 6e 63 6c 75 64 65 |).......|#include|
|00000b00| 20 3c 73 74 64 69 6f 2e | 68 3e 0a 23 69 6e 63 6c | <stdio.|h>.#incl|
|00000b10| 75 64 65 20 22 63 6f 6e | 2e 68 22 0a 61 62 76 61 |ude "con|.h".abva|
|00000b20| 6c 28 71 29 0a 7b 0a 09 | 72 65 74 75 72 6e 20 28 |l(q).{..|return (|
|00000b30| 71 3e 3d 30 20 3f 20 71 | 20 3a 20 2d 71 29 3b 0a |q>=0 ? q| : -q);.|
|00000b40| 7d 0a 0a 78 63 6f 6e 76 | 20 28 78 70 29 0a 7b 0a |}..xconv| (xp).{.|
|00000b50| 09 2f 2a 20 78 20 70 6f | 73 69 74 69 6f 6e 20 69 |./* x po|sition i|
|00000b60| 6e 70 75 74 20 69 73 20 | 2d 32 30 34 37 20 74 6f |nput is |-2047 to|
|00000b70| 20 2b 32 30 34 37 2c 20 | 6f 75 74 70 75 74 20 6d | +2047, |output m|
|00000b80| 75 73 74 20 62 65 20 30 | 20 74 6f 20 50 41 47 53 |ust be 0| to PAGS|
|00000b90| 49 5a 2a 48 4f 52 5a 52 | 45 53 20 2a 2f 0a 09 78 |IZ*HORZR|ES */..x|
|00000ba0| 70 20 3d 2b 20 32 30 34 | 38 3b 0a 09 2f 2a 20 74 |p =+ 204|8;../* t|
|00000bb0| 68 65 20 63 6f 6d 70 75 | 74 61 74 69 6f 6e 20 69 |he compu|tation i|
|00000bc0| 73 20 6e 65 77 78 20 3d | 20 78 70 2a 28 50 41 47 |s newx =| xp*(PAG|
|00000bd0| 53 49 5a 2a 48 4f 52 5a | 52 45 53 29 2f 34 30 39 |SIZ*HORZ|RES)/409|
|00000be0| 36 20 2a 2f 0a 09 72 65 | 74 75 72 6e 20 28 78 6f |6 */..re|turn (xo|
|00000bf0| 66 66 73 65 74 20 2b 20 | 78 70 20 2f 78 73 63 61 |ffset + |xp /xsca|
|00000c00| 6c 65 29 3b 0a 7d 0a 0a | 79 63 6f 6e 76 20 28 79 |le);.}..|yconv (y|
|00000c10| 70 29 0a 7b 0a 09 2f 2a | 20 73 65 65 20 64 65 73 |p).{../*| see des|
|00000c20| 63 72 69 70 74 69 6f 6e | 20 6f 66 20 78 63 6f 6e |cription| of xcon|
|00000c30| 76 20 2a 2f 0a 09 79 70 | 20 3d 2b 20 32 30 34 38 |v */..yp| =+ 2048|
|00000c40| 3b 0a 09 72 65 74 75 72 | 6e 20 28 79 70 20 2f 20 |;..retur|n (yp / |
|00000c50| 79 73 63 61 6c 65 29 3b | 0a 7d 0a 0a 69 6e 70 6c |yscale);|.}..inpl|
|00000c60| 6f 74 28 29 0a 7b 0a 09 | 73 70 65 77 20 28 45 53 |ot().{..|spew (ES|
|00000c70| 43 29 3b 0a 09 73 70 65 | 77 28 50 4c 4f 54 49 4e |C);..spe|w(PLOTIN|
|00000c80| 29 3b 0a 7d 0a 0a 6f 75 | 74 70 6c 6f 74 28 29 0a |);.}..ou|tplot().|
|00000c90| 7b 0a 09 73 70 65 77 28 | 45 53 43 29 3b 0a 09 73 |{..spew(|ESC);..s|
|00000ca0| 70 65 77 28 50 4c 4f 54 | 4f 55 54 29 3b 0a 09 66 |pew(PLOT|OUT);..f|
|00000cb0| 66 6c 75 73 68 28 73 74 | 64 6f 75 74 29 3b 0a 7d |flush(st|dout);.}|
|00000cc0| 0a 0a 73 70 65 77 28 63 | 68 29 0a 7b 0a 09 69 66 |..spew(c|h).{..if|
|00000cd0| 28 63 68 20 3d 3d 20 55 | 50 29 7b 0a 09 09 70 75 |(ch == U|P){...pu|
|00000ce0| 74 63 28 45 53 43 2c 73 | 74 64 6f 75 74 29 3b 0a |tc(ESC,s|tdout);.|
|00000cf0| 09 09 63 68 20 3d 20 44 | 4f 57 4e 3b 0a 09 7d 0a |..ch = D|OWN;..}.|
|00000d00| 09 70 75 74 63 28 63 68 | 2c 20 73 74 64 6f 75 74 |.putc(ch|, stdout|
|00000d10| 29 3b 0a 7d 0a 0a 74 6f | 62 6f 74 6c 65 66 74 20 |);.}..to|botleft |
|00000d20| 28 29 0a 7b 0a 09 6d 6f | 76 65 28 2d 32 30 34 38 |().{..mo|ve(-2048|
|00000d30| 2c 2d 32 30 34 38 29 3b | 0a 7d 0a 72 65 73 65 74 |,-2048);|.}.reset|
|00000d40| 28 29 0a 7b 0a 09 73 69 | 67 6e 61 6c 28 32 2c 31 |().{..si|gnal(2,1|
|00000d50| 29 3b 0a 09 6f 75 74 70 | 6c 6f 74 28 29 3b 0a 09 |);..outp|lot();..|
|00000d60| 73 74 74 79 28 4f 55 54 | 46 2c 49 54 54 59 29 3b |stty(OUT|F,ITTY);|
|00000d70| 0a 09 65 78 69 74 28 29 | 3b 0a 7d 0a 0a 66 6c 6f |..exit()|;.}..flo|
|00000d80| 61 74 0a 64 69 73 74 32 | 20 28 78 31 2c 20 79 31 |at.dist2| (x1, y1|
|00000d90| 2c 20 78 32 2c 20 79 32 | 29 0a 7b 0a 09 66 6c 6f |, x2, y2|).{..flo|
|00000da0| 61 74 20 74 2c 76 3b 0a | 09 74 20 3d 20 78 32 2d |at t,v;.|.t = x2-|
|00000db0| 78 31 3b 0a 09 76 20 3d | 20 79 31 2d 79 32 3b 0a |x1;..v =| y1-y2;.|
|00000dc0| 09 72 65 74 75 72 6e 20 | 28 74 2a 74 2b 76 2a 76 |.return |(t*t+v*v|
|00000dd0| 29 3b 0a 7d 0a 0a 73 77 | 61 70 20 28 70 61 2c 20 |);.}..sw|ap (pa, |
|00000de0| 70 62 29 0a 69 6e 74 20 | 2a 70 61 2c 20 2a 70 62 |pb).int |*pa, *pb|
|00000df0| 3b 0a 7b 0a 09 69 6e 74 | 20 74 3b 0a 09 74 20 3d |;.{..int| t;..t =|
|00000e00| 20 2a 70 61 3b 0a 09 2a | 70 61 20 3d 20 2a 70 62 | *pa;..*|pa = *pb|
|00000e10| 3b 0a 09 2a 70 62 20 3d | 20 74 3b 0a 7d 0a 6d 6f |;..*pb =| t;.}.mo|
|00000e20| 76 65 70 20 28 78 67 2c | 79 67 29 0a 7b 0a 09 69 |vep (xg,|yg).{..i|
|00000e30| 6e 74 20 69 2c 63 68 3b | 0a 09 69 66 28 28 78 67 |nt i,ch;|..if((xg|
|00000e40| 20 3d 3d 20 78 6e 6f 77 | 29 20 26 26 20 28 79 67 | == xnow|) && (yg|
|00000e50| 20 3d 3d 20 79 6e 6f 77 | 29 29 72 65 74 75 72 6e | == ynow|))return|
|00000e60| 3b 0a 09 2f 2a 20 69 66 | 20 77 65 20 6e 65 65 64 |;../* if| we need|
|00000e70| 20 74 6f 20 67 6f 20 74 | 6f 20 6c 65 66 74 20 6d | to go t|o left m|
|00000e80| 61 72 67 69 6e 2c 20 6a | 75 73 74 20 43 52 20 2a |argin, j|ust CR *|
|00000e90| 2f 0a 09 69 66 20 28 78 | 67 20 3c 20 78 6e 6f 77 |/..if (x|g < xnow|
|00000ea0| 2f 32 29 0a 09 7b 0a 09 | 09 73 70 65 77 28 43 52 |/2)..{..|.spew(CR|
|00000eb0| 29 3b 0a 09 09 78 6e 6f | 77 20 3d 20 30 3b 0a 09 |);...xno|w = 0;..|
|00000ec0| 7d 0a 09 69 20 3d 20 28 | 78 67 2d 78 6e 6f 77 29 |}..i = (|xg-xnow)|
|00000ed0| 2f 48 4f 52 5a 52 45 53 | 3b 0a 09 69 66 28 78 6e |/HORZRES|;..if(xn|
|00000ee0| 6f 77 20 3c 20 78 67 29 | 63 68 20 3d 20 52 49 47 |ow < xg)|ch = RIG|
|00000ef0| 48 54 3b 0a 09 65 6c 73 | 65 20 63 68 20 3d 20 4c |HT;..els|e ch = L|
|00000f00| 45 46 54 3b 0a 09 78 6e | 6f 77 20 3d 2b 20 69 2a |EFT;..xn|ow =+ i*|
|00000f10| 48 4f 52 5a 52 45 53 3b | 0a 09 69 20 3d 20 61 62 |HORZRES;|..i = ab|
|00000f20| 76 61 6c 28 69 29 3b 0a | 09 77 68 69 6c 65 28 69 |val(i);.|.while(i|
|00000f30| 2d 2d 29 73 70 65 77 28 | 63 68 29 3b 0a 09 69 20 |--)spew(|ch);..i |
|00000f40| 3d 20 61 62 76 61 6c 28 | 78 67 2d 78 6e 6f 77 29 |= abval(|xg-xnow)|
|00000f50| 3b 0a 09 69 6e 70 6c 6f | 74 28 29 3b 0a 09 77 68 |;..inplo|t();..wh|
|00000f60| 69 6c 65 28 69 2d 2d 29 | 20 73 70 65 77 28 63 68 |ile(i--)| spew(ch|
|00000f70| 29 3b 0a 09 6f 75 74 70 | 6c 6f 74 28 29 3b 0a 09 |);..outp|lot();..|
|00000f80| 69 3d 28 79 67 2d 79 6e | 6f 77 29 2f 56 45 52 54 |i=(yg-yn|ow)/VERT|
|00000f90| 52 45 53 3b 0a 09 69 66 | 28 79 6e 6f 77 20 3c 20 |RES;..if|(ynow < |
|00000fa0| 79 67 29 63 68 20 3d 20 | 55 50 3b 0a 09 65 6c 73 |yg)ch = |UP;..els|
|00000fb0| 65 20 63 68 20 3d 20 44 | 4f 57 4e 3b 0a 09 79 6e |e ch = D|OWN;..yn|
|00000fc0| 6f 77 20 3d 2b 20 69 2a | 56 45 52 54 52 45 53 3b |ow =+ i*|VERTRES;|
|00000fd0| 0a 09 69 20 3d 20 61 62 | 76 61 6c 28 69 29 3b 0a |..i = ab|val(i);.|
|00000fe0| 09 77 68 69 6c 65 28 69 | 2d 2d 29 73 70 65 77 28 |.while(i|--)spew(|
|00000ff0| 63 68 29 3b 0a 09 69 3d | 61 62 76 61 6c 28 79 67 |ch);..i=|abval(yg|
|00001000| 2d 79 6e 6f 77 29 3b 0a | 09 69 6e 70 6c 6f 74 28 |-ynow);.|.inplot(|
|00001010| 29 3b 0a 09 77 68 69 6c | 65 28 69 2d 2d 29 73 70 |);..whil|e(i--)sp|
|00001020| 65 77 28 63 68 29 3b 0a | 09 6f 75 74 70 6c 6f 74 |ew(ch);.|.outplot|
|00001030| 28 29 3b 0a 09 78 6e 6f | 77 20 3d 20 78 67 3b 20 |();..xno|w = xg; |
|00001040| 79 6e 6f 77 20 3d 20 79 | 67 3b 0a 7d 0a 0a 78 73 |ynow = y|g;.}..xs|
|00001050| 63 28 78 69 29 7b 0a 09 | 69 6e 74 20 78 61 3b 0a |c(xi){..|int xa;.|
|00001060| 09 78 61 20 3d 20 28 78 | 69 20 2d 20 6f 62 6f 74 |.xa = (x|i - obot|
|00001070| 78 29 20 2a 20 73 63 61 | 6c 65 78 20 2b 20 62 6f |x) * sca|lex + bo|
|00001080| 74 78 3b 0a 09 72 65 74 | 75 72 6e 28 78 61 29 3b |tx;..ret|urn(xa);|
|00001090| 0a 7d 0a 79 73 63 28 79 | 69 29 7b 0a 09 69 6e 74 |.}.ysc(y|i){..int|
|000010a0| 20 79 61 3b 0a 09 79 61 | 20 3d 20 28 79 69 20 2d | ya;..ya| = (yi -|
|000010b0| 20 6f 62 6f 74 79 29 20 | 2a 73 63 61 6c 65 79 20 | oboty) |*scaley |
|000010c0| 2b 62 6f 74 79 3b 0a 09 | 72 65 74 75 72 6e 28 79 |+boty;..|return(y|
|000010d0| 61 29 3b 0a 7d 0a 63 6f | 6e 2e 68 00 00 00 00 00 |a);.}.co|n.h.....|
|000010e0| 00 00 00 00 90 0d 90 27 | 29 01 b6 81 00 00 7e 02 |.......'|).....~.|
|000010f0| 23 0a 2f 2a 20 67 73 69 | 20 70 6c 6f 74 74 69 6e |#./* gsi| plottin|
|00001100| 67 20 6f 75 74 70 75 74 | 20 72 6f 75 74 69 6e 65 |g output| routine|
|00001110| 73 20 2a 2f 0a 23 20 64 | 65 66 69 6e 65 20 44 4f |s */.# d|efine DO|
|00001120| 57 4e 20 30 31 32 0a 23 | 20 64 65 66 69 6e 65 20 |WN 012.#| define |
|00001130| 55 50 20 30 31 33 0a 23 | 20 64 65 66 69 6e 65 20 |UP 013.#| define |
|00001140| 4c 45 46 54 20 30 31 30 | 0a 23 20 64 65 66 69 6e |LEFT 010|.# defin|
|00001150| 65 20 52 49 47 48 54 20 | 30 34 30 0a 23 20 64 65 |e RIGHT |040.# de|
|00001160| 66 69 6e 65 20 42 45 4c | 20 30 30 37 0a 23 20 64 |fine BEL| 007.# d|
|00001170| 65 66 69 6e 65 20 45 53 | 43 20 30 33 33 0a 23 20 |efine ES|C 033.# |
|00001180| 64 65 66 69 6e 65 20 41 | 43 4b 20 30 30 36 0a 23 |define A|CK 006.#|
|00001190| 64 65 66 69 6e 65 20 50 | 4c 4f 54 49 4e 20 30 36 |define P|LOTIN 06|
|000011a0| 33 0a 23 64 65 66 69 6e | 65 20 50 4c 4f 54 4f 55 |3.#defin|e PLOTOU|
|000011b0| 54 20 30 36 34 0a 23 20 | 64 65 66 69 6e 65 20 43 |T 064.# |define C|
|000011c0| 52 20 30 31 35 0a 23 20 | 64 65 66 69 6e 65 20 46 |R 015.# |define F|
|000011d0| 46 20 30 31 34 0a 23 20 | 64 65 66 69 6e 65 20 56 |F 014.# |define V|
|000011e0| 45 52 54 52 45 53 50 20 | 34 38 0a 23 20 64 65 66 |ERTRESP |48.# def|
|000011f0| 69 6e 65 20 48 4f 52 5a | 52 45 53 50 20 36 30 2e |ine HORZ|RESP 60.|
|00001200| 0a 23 20 64 65 66 69 6e | 65 20 56 45 52 54 52 45 |.# defin|e VERTRE|
|00001210| 53 20 38 2e 0a 23 20 64 | 65 66 69 6e 65 20 48 4f |S 8..# d|efine HO|
|00001220| 52 5a 52 45 53 20 36 2e | 0a 2f 2a 20 64 6f 77 6e |RZRES 6.|./* down|
|00001230| 20 69 73 20 6c 69 6e 65 | 20 66 65 65 64 2c 20 75 | is line| feed, u|
|00001240| 70 20 69 73 20 72 65 76 | 65 72 73 65 20 6c 69 6e |p is rev|erse lin|
|00001250| 65 20 66 65 65 64 2c 0a | 20 20 20 6c 65 66 74 20 |e feed,.| left |
|00001260| 69 73 20 62 61 63 6b 73 | 70 61 63 65 2c 20 72 69 |is backs|pace, ri|
|00001270| 67 68 74 20 69 73 20 73 | 70 61 63 65 2e 20 20 34 |ght is s|pace. 4|
|00001280| 38 20 70 6f 69 6e 74 73 | 20 70 65 72 20 69 6e 63 |8 points| per inc|
|00001290| 68 0a 20 20 20 76 65 72 | 74 69 63 61 6c 6c 79 2c |h. ver|tically,|
|000012a0| 20 36 30 20 68 6f 72 69 | 7a 6f 6e 74 61 6c 6c 79 | 60 hori|zontally|
|000012b0| 20 2a 2f 0a 0a 65 78 74 | 65 72 6e 20 69 6e 74 20 | */..ext|ern int |
|000012c0| 78 6e 6f 77 2c 20 79 6e | 6f 77 3b 0a 65 78 74 65 |xnow, yn|ow;.exte|
|000012d0| 72 6e 20 69 6e 74 20 49 | 54 54 59 5b 33 5d 2c 20 |rn int I|TTY[3], |
|000012e0| 50 54 54 59 5b 33 5d 2c | 20 4f 55 54 46 3b 0a 65 |PTTY[3],| OUTF;.e|
|000012f0| 78 74 65 72 6e 20 66 6c | 6f 61 74 20 48 45 49 47 |xtern fl|oat HEIG|
|00001300| 48 54 2c 20 57 49 44 54 | 48 2c 20 4f 46 46 53 45 |HT, WIDT|H, OFFSE|
|00001310| 54 3b 0a 65 78 74 65 72 | 6e 20 69 6e 74 20 78 73 |T;.exter|n int xs|
|00001320| 63 61 6c 65 2c 20 78 6f | 66 66 73 65 74 2c 20 79 |cale, xo|ffset, y|
|00001330| 73 63 61 6c 65 3b 0a 65 | 78 74 65 72 6e 20 66 6c |scale;.e|xtern fl|
|00001340| 6f 61 74 20 62 6f 74 78 | 2c 20 62 6f 74 79 2c 20 |oat botx|, boty, |
|00001350| 6f 62 6f 74 78 2c 20 6f | 62 6f 74 79 2c 20 73 63 |obotx, o|boty, sc|
|00001360| 61 6c 65 78 2c 73 63 61 | 6c 65 79 3b 0a 0a 62 6f |alex,sca|ley;..bo|
|00001370| 78 2e 63 00 00 00 00 00 | 00 00 00 00 cf 0f d5 1b |x.c.....|........|
|00001380| 09 01 b6 81 00 00 72 00 | 62 6f 78 28 78 30 2c 20 |......r.|box(x0, |
|00001390| 79 30 2c 20 78 31 2c 20 | 79 31 29 0a 7b 0a 09 6d |y0, x1, |y1).{..m|
|000013a0| 6f 76 65 28 78 30 2c 20 | 79 30 29 3b 0a 09 63 6f |ove(x0, |y0);..co|
|000013b0| 6e 74 28 78 30 2c 20 79 | 31 29 3b 0a 09 63 6f 6e |nt(x0, y|1);..con|
|000013c0| 74 28 78 31 2c 20 79 31 | 29 3b 0a 09 63 6f 6e 74 |t(x1, y1|);..cont|
|000013d0| 28 78 31 2c 20 79 30 29 | 3b 0a 09 63 6f 6e 74 28 |(x1, y0)|;..cont(|
|000013e0| 78 30 2c 20 79 30 29 3b | 0a 09 6d 6f 76 65 28 78 |x0, y0);|..move(x|
|000013f0| 31 2c 20 79 31 29 3b 0a | 7d 0a |1, y1);.|}. |
+--------+-------------------------+-------------------------+--------+--------+