ccount@ATHENA.MIT.EDU (04/14/90)
Posting-number: Volume 12, Issue 1 Submitted-by: ccount@ATHENA.MIT.EDU Archive-name: starchart2/part01 This patch updates the release 3.2 to version 3.2.1. Many small modifications, and a new IBMPC driver supporting different displays is included. minor bugs have been fixed. The changes were small but widespread, producing this large patch distribution. Separate patch files are provided in this and the following shar files for each subdirectory of the 3.2 distribution, the 'starchart' directory patch is split into four parts which should be reassembled after unsharing. #! /bin/sh # This is a shell archive. Remove anything before this line, then unpack # it by saving it into a file and typing "sh file". To overwrite existing # files, type "sh file -c". You can also feed this as standard input via # unshar, or by typing "sh <file", e.g.. If this archive is complete, you # will see the following message at the end: # "End of archive 1 (of 4)." # Contents: README.3.2.1 data.pch dataconv.pch doc.pch observe.pch # stch_pch.ad # Wrapped by ccount@E40-008-8 on Thu Apr 5 01:17:37 1990 PATH=/bin:/usr/bin:/usr/ucb ; export PATH if test -f 'README.3.2.1' -a "${1}" != "-c" ; then echo shar: Will not clobber existing file \"'README.3.2.1'\" else echo shar: Extracting \"'README.3.2.1'\" \(1328 characters\) sed "s/^X//" >'README.3.2.1' <<'END_OF_FILE' XThis patch updates the release 3.2 to version 3.2.1. Many small Xmodifications, and a new IBMPC driver supporting different displays is Xincluded. minor bugs have been fixed. Note clarification of the Xcopyright statement. X XA #pragma was added to starsupp.c, to support the Macintosh. XOlder compilers may not understand this, and you may need to remove it. X XHere are brief notes on the changes made: X1) minor fix for Atari problems X2) Define NO_BUF_READSTAR to eliminate use of buf_readstar() X3) Fix comet position angle, position angle of bright limb (change in X observe also) X4) fix 16bit int problem in xform X5) add checks on malloc returns X6) improve grids behaviour X7) add C star color class. X8) fix typos in boundaries.star and cnames.star X9) fix constellation name typo in dataconv/sif_to_text.c X10) Add -f error messge to observe X11) improve format of .eph file in observe X12) Add optional STARRC environment variable. X13) Adjust tick positioning in starpost X14) Fix typo with fine_mags in starpost X15) define user dict in starpost X16) Allow multiple -f files in observe X17) Fix problem with magnitude -9.96 to -10 objects in observe:outsif.c X18) Add another method for observe timezone X19) Fix problem with table interpolation in observe X XThanks to all those who reported and expecially those who also fixed Xproblems. END_OF_FILE if test 1328 -ne `wc -c <'README.3.2.1'`; then echo shar: \"'README.3.2.1'\" unpacked with wrong size! fi # end of 'README.3.2.1' fi if test -f 'data.pch' -a "${1}" != "-c" ; then echo shar: Will not clobber existing file \"'data.pch'\" else echo shar: Extracting \"'data.pch'\" \(3137 characters\) sed "s/^X//" >'data.pch' <<'END_OF_FILE' Xdiff -r -c ../../starchart3.2/data/boundaries.star ./boundaries.star X*** ../../starchart3.2/data/boundaries.star Wed Apr 4 18:27:34 1990 X--- ./boundaries.star Wed Apr 4 18:30:31 1990 X*************** X*** 138,143 **** X--- 138,145 ---- X 151230-5530000Vs X 180900-4530000VM X 175900-4530000Vs X+ 175830-3705000VM X+ 175900-4530000Vs X 163400-4545000Vs X 085300-5500000VM X 083000-5500000Vs X*************** X*** 872,874 **** X--- 874,877 ---- X 024230+3720000Vs X 024230+3435000Vs X 025030+3435000Vs X+ 000000+0000999# Version 3.2.1 Xdiff -r -c ../../starchart3.2/data/cnames.star ./cnames.star X*** ../../starchart3.2/data/cnames.star Wed Apr 4 18:27:34 1990 X--- ./cnames.star Wed Apr 4 18:30:32 1990 X*************** X*** 1,11 **** X 120000-8200000I CHAMAELEON X 130000-7400000I MUSCA X! 163000-6900000I TRIANGULUM AUSTALE X 170000-8100000I APUS X 210000-7300000I PAVO X 100000-8500000I OCTANS X 190000-5500000I TELESCOPIUM X! 213000-5800000I INNDUS X 003000-6800000I TUCANA X 020000-8000000I HYDRUS X 053000-8000000I MENSA X--- 1,11 ---- X 120000-8200000I CHAMAELEON X 130000-7400000I MUSCA X! 163000-6900000I TRIANGULUM AUSTRALE X 170000-8100000I APUS X 210000-7300000I PAVO X 100000-8500000I OCTANS X 190000-5500000I TELESCOPIUM X! 213000-5800000I INDUS X 003000-6800000I TUCANA X 020000-8000000I HYDRUS X 053000-8000000I MENSA X*************** X*** 15,27 **** X 161000-5900000I NORMA X 173000-6500000I ARA X 103000-7400000I CARINA X! 105000-5200000I VELLA X 125800-6300000I CRUX X 060000-5400000I PICTOR X 030000-6000000I HOROLOGIUM X 040000-6600000I RETICULUM X 052000-6400000I DORADO X! 200000-4430000I SAGITARIUS X 010000-5600000I PHOENIX X 230000-5400000I GRUS X 175800-4430000I SCORPIUS X--- 15,27 ---- X 161000-5900000I NORMA X 173000-6500000I ARA X 103000-7400000I CARINA X! 105000-5200000I VELA X 125800-6300000I CRUX X 060000-5400000I PICTOR X 030000-6000000I HOROLOGIUM X 040000-6600000I RETICULUM X 052000-6400000I DORADO X! 200000-4430000I SAGITTARIUS X 010000-5600000I PHOENIX X 230000-5400000I GRUS X 175800-4430000I SCORPIUS X*************** X*** 51,57 **** X 212000+0300000I EQUULEUS X 205000+0300000I DELPHINUS X 194500+2000000I VULPECULA X! 021500-5600000I ERADINUS X 171000-2330000I OPHIUCHUS X 185000-1510000I SCUTUM X 194000+1700000I SAGITTA X--- 51,57 ---- X 212000+0300000I EQUULEUS X 205000+0300000I DELPHINUS X 194500+2000000I VULPECULA X! 021500-5600000I ERIDANUS X 171000-2330000I OPHIUCHUS X 185000-1510000I SCUTUM X 194000+1700000I SAGITTA X*************** X*** 87,89 **** X--- 87,90 ---- X 041000+0130000I TAURUS X 033000+3130000I PERSEUS X 060000+2900000I AURIGA X+ 000000+0000999# Version 3.2.1 END_OF_FILE if test 3137 -ne `wc -c <'data.pch'`; then echo shar: \"'data.pch'\" unpacked with wrong size! fi # end of 'data.pch' fi if test -f 'dataconv.pch' -a "${1}" != "-c" ; then echo shar: Will not clobber existing file \"'dataconv.pch'\" else echo shar: Extracting \"'dataconv.pch'\" \(1646 characters\) sed "s/^X//" >'dataconv.pch' <<'END_OF_FILE' Xdiff -r -c ../../starchart3.2/dataconv/sif_to_text.c ./sif_to_text.c X*** ../../starchart3.2/dataconv/sif_to_text.c Wed Apr 4 18:27:41 1990 X--- ./sif_to_text.c Wed Apr 4 18:30:38 1990 X*************** X*** 25,31 **** X * X */ X X! static char rcsid[]="$Header: sif_to_text.c,v 2.6 90/02/19 16:59:29 ccount Exp $"; X X X X--- 25,31 ---- X * X */ X X! static char rcsid[]="$Header: sif_to_text.c,v 2.7 90/04/02 20:05:42 ccount Exp $"; X X X X*************** X*** 319,325 **** X {"PER", "Perseus", "Persei"}, X {"PHE", "Phoenix", "Phoenicis"}, X {"PIC", "Pictor", "Pictoris"}, X! {"PSA", "Piscis Astrinus", "Piscis Austrini"}, X {"PSC", "Pisces", "Piscium"}, X {"PUP", "Puppis", "Puppis"}, X {"PYX", "Pyxis", "Pyxidis"}, X--- 319,325 ---- X {"PER", "Perseus", "Persei"}, X {"PHE", "Phoenix", "Phoenicis"}, X {"PIC", "Pictor", "Pictoris"}, X! {"PSA", "Piscis Austrinus", "Piscis Austrini"}, X {"PSC", "Pisces", "Piscium"}, X {"PUP", "Puppis", "Puppis"}, X {"PYX", "Pyxis", "Pyxidis"}, X*************** X*** 333,339 **** X {"SGR", "Sagittarius", "Sagittarii"}, X {"TAU", "Taurus", "Tauri"}, X {"TEL", "Telescopium", "Telescopii"}, X! {"TRA", "Triangulum Astrale", "Trianguli Astralis"}, X {"TRI", "Triangulum", "Trianguli"}, X {"TUC", "Tucana", "Tucanae"}, X {"UMA", "Ursa Major", "Ursae Majoris"}, X--- 333,339 ---- X {"SGR", "Sagittarius", "Sagittarii"}, X {"TAU", "Taurus", "Tauri"}, X {"TEL", "Telescopium", "Telescopii"}, X! {"TRA", "Triangulum Australe", "Trianguli Australis"}, X {"TRI", "Triangulum", "Trianguli"}, X {"TUC", "Tucana", "Tucanae"}, X {"UMA", "Ursa Major", "Ursae Majoris"}, END_OF_FILE if test 1646 -ne `wc -c <'dataconv.pch'`; then echo shar: \"'dataconv.pch'\" unpacked with wrong size! fi # end of 'dataconv.pch' fi if test -f 'doc.pch' -a "${1}" != "-c" ; then echo shar: Will not clobber existing file \"'doc.pch'\" else echo shar: Extracting \"'doc.pch'\" \(3650 characters\) sed "s/^X//" >'doc.pch' <<'END_OF_FILE' Xdiff -r -c ../../starchart3.2/doc/astro.ms ./astro.ms X*** ../../starchart3.2/doc/astro.ms Wed Apr 4 18:27:48 1990 X--- ./astro.ms Wed Apr 4 18:30:45 1990 X*************** X*** 1760,1766 **** X .PP X Tom Horsley contributed the ibm PC driver. X .PP X! Mike Daly helped with the Macintosh version. X .PP X Joe Wang helped with the X11 version. X .PP X--- 1760,1768 ---- X .PP X Tom Horsley contributed the ibm PC driver. X .PP X! Doug McDonald contributed the ibm PC VGA/SVGA driver. X! .PP X! Mike Daly and Gavin Eadie helped with the Macintosh version. X .PP X Joe Wang helped with the X11 version. X .PP Xdiff -r -c ../../starchart3.2/doc/astro.texinfo ./astro.texinfo X*** ../../starchart3.2/doc/astro.texinfo Wed Apr 4 18:27:49 1990 X--- ./astro.texinfo Wed Apr 4 18:30:45 1990 X*************** X*** 2198,2204 **** X X Tom Horsley contributed the ibm PC driver. X X! Mike Daly helped with the Macintosh version. X X Joe Wang helped with the X11 version. X X--- 2198,2206 ---- X X Tom Horsley contributed the ibm PC driver. X X! Doug McDonald contributed the ibm PC VGA/SVGA driver. X! X! Mike Daly and Gavin Eadie helped with the Macintosh version. X X Joe Wang helped with the X11 version. X Xdiff -r -c ../../starchart3.2/doc/starchart.1 ./starchart.1 X*** ../../starchart3.2/doc/starchart.1 Wed Apr 4 18:27:52 1990 X--- ./starchart.1 Wed Apr 4 18:30:49 1990 X*************** X*** 262,268 **** X X Detailed control of the chart is provided through files containing X variable names and values. A ``.starrc'' file may be used to set X! personal preferences. Additionally, the X .B \-e X argument allows additional files to be read. These files set X parameters which may be overridden by later command line arguments. X--- 262,271 ---- X X Detailed control of the chart is provided through files containing X variable names and values. A ``.starrc'' file may be used to set X! personal preferences. The name of this file was set at compile time, X! and is usually ``.starrc''. It is also possible to use the X! environment variable STARRC to specify this file on some systems. X! Additionally, the X .B \-e X argument allows additional files to be read. These files set X parameters which may be overridden by later command line arguments. X*************** X*** 401,407 **** X .br X Tom Horsley X .br X! Dave Van't Hof X .br X Dave Van't Hof X .br X--- 404,410 ---- X .br X Tom Horsley X .br X! Doug McDonald X .br X Dave Van't Hof X .br X*************** X*** 419,428 **** X .br X and X .br X! Dean Payne <deanp@hplsla.hp.com> X .br X! David Smith <smith@hpldrs.hp.com> X .br X! Tim Pointing <tim@zorac.dciem.dnd.ca> X .br X and others X--- 422,431 ---- X .br X and X .br X! Dean Payne X .br X! David Smith X .br X! Tim Pointing X .br X and others Xdiff -r -c ../../starchart3.2/doc/staribmv.1 ./staribmv.1 X*** ../../starchart3.2/doc/staribmv.1 Wed Apr 4 18:27:53 1990 X--- ./staribmv.1 Wed Apr 4 18:30:49 1990 X*************** X*** 0 **** X--- 1,30 ---- X+ .TH STARCHART LOCAL "15 July 1989" X+ .ad b X+ .SH NAME X+ staribmv \- display astronomical star charts on IBM PC vga or svga display. X+ .SH SYNOPSIS X+ Arguments as in other starchart programs, with the special argument -a: X+ .br X+ .B \-a X+ \fBX X+ | X+ .B \-a X+ \fBD\fIn\fR X+ .br X+ .SH DESCRIPTION X+ See starchart(1) for details on the starchart programs in general. X+ .PP X+ With the X+ .B \-a X+ \fBX X+ option, the names of any non-stellar objects are plotted independent X+ of the normal namelimit. The X+ .B \-a X+ \fBD\fIn\fR X+ option, where n is a number from -5 to 5, changes the size of the X+ plotted stars. X+ .SH BUGS X+ .SH AUTHORS/EDITORS X+ Doug McDonald <mcdonald@aries.scs.uiuc.edu> X+ .br X+ Craig Counterman END_OF_FILE if test 3650 -ne `wc -c <'doc.pch'`; then echo shar: \"'doc.pch'\" unpacked with wrong size! fi # end of 'doc.pch' fi if test -f 'observe.pch' -a "${1}" != "-c" ; then echo shar: Will not clobber existing file \"'observe.pch'\" else echo shar: Extracting \"'observe.pch'\" \(15758 characters\) sed "s/^X//" >'observe.pch' <<'END_OF_FILE' Xdiff -r -c ../../starchart3.2/observe/main.c ./main.c X*** ../../starchart3.2/observe/main.c Wed Apr 4 18:28:00 1990 X--- ./main.c Wed Apr 4 18:30:56 1990 X*************** X*** 28,34 **** X X #ifndef lint X static char rcsid[] = X! "$Header: main.c,v 1.13 90/02/23 18:44:16 ccount Exp $"; X #endif X X X--- 28,34 ---- X X #ifndef lint X static char rcsid[] = X! "$Header: main.c,v 1.14 90/04/02 20:54:32 ccount Exp $"; X #endif X X X*************** X*** 96,105 **** X X int file_input = FALSE; X fformat_t tr_format(); X- char *infile_name = ""; X- FILE *infile; X- fformat_t in_type; X X X X /* objects */ X--- 96,109 ---- X X int file_input = FALSE; X fformat_t tr_format(); X X+ #define MAXFILES 10 X+ struct inf { X+ char *infile_name; X+ FILE *infile; X+ fformat_t in_type; X+ } infiles[MAXFILES]; X+ int num_files = 0; X X X /* objects */ X*************** X*** 198,236 **** X X jd_to_str(start_date, datestr); X X! if (file_input) { X! if ((infile = fopen(infile_name, "r")) == NULL) { X! fprintf(stderr, "%s: could not open file %s for reading\n", X! progname, infile_name); X! exit(1); X! }; X X! /* input data from infile */ X! switch (in_type) { X! case emp: X! case empb: X! case aa: X! case st: X! case iau: X! read_table(infile, in_type); X! nbodies = 1; X! bodies[0].name = obj_name; X! bodies[0].orbit_type = tabulated; X! break; X! case ell_e: X! read_elliptical(infile, bodies, &nbodies, MAXOBJECTS); X! break; X! case par_e: X! read_parabolic(infile, bodies, &nbodies, MAXOBJECTS); X! break; X! case obj: X! read_objects(infile, objects, &nobjects, MAXOBJECTS); X! break; X! default: X! break; X }; X! }; X! X /* open output files */ X strncpy(filename, outfile_root, MAXPATHLEN-5); X #ifndef ATARI_ST X--- 202,243 ---- X X jd_to_str(start_date, datestr); X X! nbodies = 0; X! nobjects = 0; X! for (i = 0; i < num_files; i++) { X! if (file_input) { X! if ((infiles[i].infile = fopen(infiles[i].infile_name, "r")) == NULL) { X! fprintf(stderr, "%s: could not open file %s for reading\n", X! progname, infiles[i].infile_name); X! exit(1); X! }; X X! /* input data from infile */ X! switch (infiles[i].in_type) { X! case emp: X! case empb: X! case aa: X! case st: X! case iau: X! read_table(infiles[i].infile, infiles[i].in_type); X! nbodies++; X! bodies[0].name = obj_name; X! bodies[0].orbit_type = tabulated; X! break; X! case ell_e: X! read_elliptical(infiles[i].infile, bodies, &nbodies, MAXOBJECTS); X! break; X! case par_e: X! read_parabolic(infiles[i].infile, bodies, &nbodies, MAXOBJECTS); X! break; X! case obj: X! read_objects(infiles[i].infile, objects, &nobjects, MAXOBJECTS); X! break; X! default: X! break; X! }; X }; X! } X /* open output files */ X strncpy(filename, outfile_root, MAXPATHLEN-5); X #ifndef ATARI_ST X*************** X*** 588,593 **** X--- 595,614 ---- X return (-tzp.tz_minuteswest/60.0 + tzp.tz_dsttime); X } X */ X+ /* Method 4, on systems (such as VMS) with no knowledge about timezones X+ * use an environment variable named "TIMEZONE". This should be set to X+ * seconds after GMT, like the SYSV definition. X+ */ X+ /* X+ double now_zone() X+ { X+ long timezone; X+ char *chzone; X+ chzone = getenv("TIMEZONE"); X+ timezone = atol(chzone); X+ return(-timezone/3600.0); X+ } X+ */ X /* For ATARI_ST */ X /*double now_zone() X { X*************** X*** 820,835 **** X break; X case 'f': X /* file format */ X! if (((i+2) < argc) && (notarg(argv[i+1])) && (notarg(argv[i+2]))) { X! infile_name = argv[i+1]; X! in_type = tr_format(argv[i+2]); X! if (in_type == no_format) { X fprintf(stderr, "%s: format %s not recognized.\n", progname, X argv[i+2]); X exit(1); X }; X i += 2; X file_input = TRUE; X }; X break; X case 'h': X--- 841,862 ---- X break; X case 'f': X /* file format */ X! if ((((i+2) < argc) && (notarg(argv[i+1])) && (notarg(argv[i+2]))) X! && (num_files < MAXFILES)) { X! infiles[num_files].infile_name = argv[i+1]; X! infiles[num_files].in_type = tr_format(argv[i+2]); X! if (infiles[num_files].in_type == no_format) { X fprintf(stderr, "%s: format %s not recognized.\n", progname, X argv[i+2]); X exit(1); X }; X+ num_files++; X i += 2; X file_input = TRUE; X+ } else { X+ fprintf(stderr, "%s: -f needs filename and file type (format).\n", X+ progname); X+ usage(); X }; X break; X case 'h': Xdiff -r -c ../../starchart3.2/observe/objcalc.c ./objcalc.c X*** ../../starchart3.2/observe/objcalc.c Wed Apr 4 18:28:02 1990 X--- ./objcalc.c Wed Apr 4 18:30:58 1990 X*************** X*** 16,22 **** X X #ifndef lint X static char rcsid[] = X! "$Header: objcalc.c,v 1.9 90/03/06 00:08:40 ccount Exp $"; X #endif X X X--- 16,22 ---- X X #ifndef lint X static char rcsid[] = X! "$Header: objcalc.c,v 1.10 90/04/02 20:55:15 ccount Exp $"; X #endif X X X*************** X*** 52,58 **** X double alpha, delta, alpha2000, delta2000; X char typestr[10]; X X! j = 0; X while (!feof(infile)) { X linep = fgets(in_line, 1000, infile); X if (linep != NULL) { X--- 52,58 ---- X double alpha, delta, alpha2000, delta2000; X char typestr[10]; X X! j = *nobjects_p; X while (!feof(infile)) { X linep = fgets(in_line, 1000, infile); X if (linep != NULL) { Xdiff -r -c ../../starchart3.2/observe/observe.h ./observe.h X*** ../../starchart3.2/observe/observe.h Wed Apr 4 18:28:03 1990 X--- ./observe.h Wed Apr 4 18:30:59 1990 X*************** X*** 14,20 **** X * X */ X /* X! * $Header: observe.h,v 1.7 90/02/19 17:22:04 ccount Exp $ X */ X X X--- 14,20 ---- X * X */ X /* X! * $Header: observe.h,v 1.8 90/04/02 20:55:45 ccount Exp $ X */ X X X*************** X*** 109,114 **** X--- 109,116 ---- X double alpha2000, delta2000; /* position in equinox 2000.0 */ X double beta; /* Phase angle */ X double psi; /* Elongation */ X+ double chi; /* position angle of bright limb, X+ opposite to comet's tail */ X double r, Delta; /* Distance to sun, and earth */ X double mag; /* magnitude */ X orbtype_t orbit_type; /* Orbit type */ Xdiff -r -c ../../starchart3.2/observe/orbcalc.c ./orbcalc.c X*** ../../starchart3.2/observe/orbcalc.c Wed Apr 4 18:28:04 1990 X--- ./orbcalc.c Wed Apr 4 18:31:00 1990 X*************** X*** 16,22 **** X X #ifndef lint X static char rcsid[] = X! "$Header: orbcalc.c,v 1.8 90/02/19 17:20:47 ccount Exp $"; X #endif X X X--- 16,22 ---- X X #ifndef lint X static char rcsid[] = X! "$Header: orbcalc.c,v 1.9 90/04/02 20:56:19 ccount Exp $"; X #endif X X X*************** X*** 67,73 **** X fgets(in_line, 1000, infile); X X X! j = 0; X while ((j < maxbodies) && (!feof(infile))) { X linep = fgets(in_line, 1000, infile); X if (linep != NULL) X--- 67,73 ---- X fgets(in_line, 1000, infile); X X X! j = *nbodies_p; X while ((j < maxbodies) && (!feof(infile))) { X linep = fgets(in_line, 1000, infile); X if (linep != NULL) X*************** X*** 204,209 **** X--- 204,216 ---- X data->psi = acos((R*R + Delta*Delta - r*r)/ (2*R*Delta))*RAD_TO_DEG; X data->beta = acos((r*r + Delta*Delta - R*R)/ (2*r*Delta))*RAD_TO_DEG; X X+ data->chi = /* position angle of bright limb */ X+ DATAN2(DCOS(sun_data.delta2000) * DSIN(sun_data.alpha2000 - alpha2000), X+ DCOS(data->delta2000) * DSIN(sun_data.delta2000) X+ - DSIN(data->delta2000) * DCOS(sun_data.delta2000) X+ * DCOS(sun_data.alpha2000 - data->alpha2000)); X+ if (data->chi < 0.0) data->chi += 360.0; X+ X if (data->body_type == asteroid) { X G = data->G; X H = data->H; X*************** X*** 254,260 **** X fgets(in_line, 1000, infile); X X X! j = 0; X while ((j < maxbodies) && (!feof(infile))) { X linep = fgets(in_line, 1000, infile); X if (linep != NULL) X--- 261,267 ---- X fgets(in_line, 1000, infile); X X X! j = *nbodies_p; X while ((j < maxbodies) && (!feof(infile))) { X linep = fgets(in_line, 1000, infile); X if (linep != NULL) X*************** X*** 380,385 **** X--- 387,399 ---- X X data->psi = acos((R*R + Delta*Delta - r*r)/ (2*R*Delta))*RAD_TO_DEG; X data->beta = acos((r*r + Delta*Delta - R*R)/ (2*r*Delta))*RAD_TO_DEG; X+ X+ data->chi = /* position angle of bright limb */ X+ DATAN2(DCOS(sun_data.delta2000) * DSIN(sun_data.alpha2000 - alpha2000), X+ DCOS(data->delta2000) * DSIN(sun_data.delta2000) X+ - DSIN(data->delta2000) * DCOS(sun_data.delta2000) X+ * DCOS(sun_data.alpha2000 - data->alpha2000)); X+ if (data->chi < 0.0) data->chi += 360.0; X X if (data->body_type == asteroid) { X G = data->G; Xdiff -r -c ../../starchart3.2/observe/outeph.c ./outeph.c X*** ../../starchart3.2/observe/outeph.c Wed Apr 4 18:28:05 1990 X--- ./outeph.c Wed Apr 4 18:31:01 1990 X*************** X*** 16,22 **** X X #ifndef lint X static char rcsid[] = X! "$Header: outeph.c,v 1.11 90/03/06 00:09:35 ccount Exp $"; X #endif X X X--- 16,22 ---- X X #ifndef lint X static char rcsid[] = X! "$Header: outeph.c,v 1.12 90/04/02 20:57:30 ccount Exp $"; X #endif X X X*************** X*** 68,74 **** X X X fprintf(o_eph, X! "name RA2000.0 Dec2000.0 RA epoch Dec epoch rise trans set mag size elong. phase Delta r\n"); X X raformat(sun_data.alpha2000/15.0, rastr1); X raformat(sun_data.alpha/15.0, rastr2); X--- 68,74 ---- X X X fprintf(o_eph, X! " Name RA/2000 Dec/2000 RA/epoch Dec/epoch Rise Trans Set Mag Size Elong Phase Delta r\n"); X X raformat(sun_data.alpha2000/15.0, rastr1); X raformat(sun_data.alpha/15.0, rastr2); X*************** X*** 144,155 **** X }; X X fprintf(o_eph, X! "%-7.7s %s %s %s %s %s %s %s %5.2f %s %s\n", X bodies[i].name, X rastr1, decstr1, X rastr2, decstr2, X risestr, transitstr, setstr, X! bodies[i].mag, Delta_str, r_str); X }; X X for (i = 0; i < nobjects; i++) { X--- 144,155 ---- X }; X X fprintf(o_eph, X! "%-7.7s %s %s %s %s %s %s %s %5.2f %6.1f %s %s\n", X bodies[i].name, X rastr1, decstr1, X rastr2, decstr2, X risestr, transitstr, setstr, X! bodies[i].mag, bodies[i].psi, Delta_str, r_str); X }; X X for (i = 0; i < nobjects; i++) { Xdiff -r -c ../../starchart3.2/observe/outsif.c ./outsif.c X*** ../../starchart3.2/observe/outsif.c Wed Apr 4 18:28:08 1990 X--- ./outsif.c Wed Apr 4 18:31:04 1990 X*************** X*** 16,22 **** X X #ifndef lint X static char rcsid[] = X! "$Header: outsif.c,v 1.13 90/03/06 00:10:00 ccount Exp $"; X #endif X X X--- 16,22 ---- X X #ifndef lint X static char rcsid[] = X! "$Header: outsif.c,v 1.14 90/04/02 20:58:01 ccount Exp $"; X #endif X X X*************** X*** 29,35 **** X #include "observe.h" X #include "date.h" X X- X void write_files(), tosizestr(); X X X--- 29,34 ---- X*************** X*** 48,55 **** X int nobjects; X { X int i; X! char moon_phase[20]; X char *typefield; X X if (one_day) { X /* print all */ X--- 47,55 ---- X int nobjects; X { X int i; X! char moon_phase[20], comet_phase[20]; X char *typefield; X+ char *commentfield; X X if (one_day) { X /* print all */ X*************** X*** 75,85 **** X " ", planets[i].name, ""); X X for (i = 0; i < nbodies; i++) { X if (bodies[i].body_type == asteroid) X typefield = "PA"; X! else if (bodies[i].body_type == comet) X typefield = "PC"; X! else X typefield = "P?"; X X write_files(o_sif, o_star, do_sif, do_star, X--- 75,89 ---- X " ", planets[i].name, ""); X X for (i = 0; i < nbodies; i++) { X+ commentfield = ""; X if (bodies[i].body_type == asteroid) X typefield = "PA"; X! else if (bodies[i].body_type == comet) { X typefield = "PC"; X! /* calculate tail angle */ X! commentfield = comet_phase; X! sprintf(comet_phase, "%6.1f", bodies[i].chi); X! } else X typefield = "P?"; X X write_files(o_sif, o_star, do_sif, do_star, X*************** X*** 86,92 **** X bodies[i].alpha2000/15.0, bodies[i].delta2000, X bodies[i].mag, X typefield, " ", -1.0, X! " ", bodies[i].name, ""); X }; X X for (i = 0; i < nobjects; i++) X--- 90,96 ---- X bodies[i].alpha2000/15.0, bodies[i].delta2000, X bodies[i].mag, X typefield, " ", -1.0, X! " ", bodies[i].name, commentfield); X }; X X for (i = 0; i < nobjects; i++) X*************** X*** 153,159 **** X double jd; X { X static char *namep = ""; X! char *vectfield, *typefield; X char datestr[15]; X char name_date[96]; X X--- 157,164 ---- X double jd; X { X static char *namep = ""; X! char comet_phase[20]; X! char *vectfield, *typefield, *commentfield; X char datestr[15]; X char name_date[96]; X X*************** X*** 164,174 **** X vectfield = "VM"; X }; X X if (body.body_type == asteroid) X typefield = "PA"; X! else if (body.body_type == comet) X typefield = "PC"; X! else X typefield = "P?"; X X jd_to_str(jd, datestr); X--- 169,182 ---- X vectfield = "VM"; X }; X X+ commentfield = ""; X if (body.body_type == asteroid) X typefield = "PA"; X! else if (body.body_type == comet) { X typefield = "PC"; X! commentfield = comet_phase; X! sprintf(comet_phase, "%6.1f", body.chi); X! } else X typefield = "P?"; X X jd_to_str(jd, datestr); X*************** X*** 178,184 **** X body.alpha2000/15.0, body.delta2000, X body.mag, X typefield, " ", -1.0, X! " ", name_date, ""); X write_files(o_sif, o_star, do_sif, do_star, X body.alpha2000/15.0, body.delta2000, X body.mag + 1.0, X--- 186,192 ---- X body.alpha2000/15.0, body.delta2000, X body.mag, X typefield, " ", -1.0, X! " ", name_date, commentfield); X write_files(o_sif, o_star, do_sif, do_star, X body.alpha2000/15.0, body.delta2000, X body.mag + 1.0, X*************** X*** 320,326 **** X } X X if (mag < 0.0) { X! if (mag < -10.0) strcpy(magstr,"-99"); X else { X i = -mag*10 + .5; X sprintf(magstr,"-%02d", i); X--- 328,334 ---- X } X X if (mag < 0.0) { X! if (mag < -9.95) strcpy(magstr,"-99"); X else { X i = -mag*10 + .5; X sprintf(magstr,"-%02d", i); Xdiff -r -c ../../starchart3.2/observe/tablecalc.c ./tablecalc.c X*** ../../starchart3.2/observe/tablecalc.c Wed Apr 4 18:28:13 1990 X--- ./tablecalc.c Wed Apr 4 18:31:10 1990 X*************** X*** 16,22 **** X X #ifndef lint X static char rcsid[] = X! "$Header: tablecalc.c,v 1.8 90/02/19 17:21:52 ccount Exp $"; X #endif X X X--- 16,22 ---- X X #ifndef lint X static char rcsid[] = X! "$Header: tablecalc.c,v 1.9 90/04/04 02:12:31 ccount Exp $"; X #endif X X X*************** X*** 70,79 **** X delta = polint(dates, dec, Nread, jd, &error); X precess(from_equinox, 2000.0, alpha, delta, &alpha2000, &delta2000); X X! body->alpha = alpha; X! body->delta = delta; X! body->alpha2000 = alpha2000; X! body->delta2000 = delta2000; X body->mag = polint(dates, mag, Nread, jd, &error); X body->r = polint(dates, r, Nread, jd, &error); X body->Delta = polint(dates, Delta, Nread, jd, &error); X--- 70,79 ---- X delta = polint(dates, dec, Nread, jd, &error); X precess(from_equinox, 2000.0, alpha, delta, &alpha2000, &delta2000); X X! body->alpha = into_range(alpha); X! body->delta = into_range(delta); X! body->alpha2000 = into_range(alpha2000); X! body->delta2000 = into_range(delta2000); X body->mag = polint(dates, mag, Nread, jd, &error); X body->r = polint(dates, r, Nread, jd, &error); X body->Delta = polint(dates, Delta, Nread, jd, &error); END_OF_FILE if test 15758 -ne `wc -c <'observe.pch'`; then echo shar: \"'observe.pch'\" unpacked with wrong size! fi # end of 'observe.pch' fi if test -f 'stch_pch.ad' -a "${1}" != "-c" ; then echo shar: Will not clobber existing file \"'stch_pch.ad'\" else echo shar: Extracting \"'stch_pch.ad'\" \(21342 characters\) sed "s/^X//" >'stch_pch.ad' <<'END_OF_FILE' X+ X+ cmp first14,0 X+ jne sec14 X+ inc first14 X+ mov ah, 011h X+ mov al, 030h X+ mov bh, 02 X+ push bp X+ int 010h X+ mov ax,es X+ mov es14,ax X+ mov bp14,bp X+ pop bp X+ sec14: X+ X+ xor ax,ax X+ mov al,byte ptr [bp+argbase+8] X+ mul fourt X+ add ax,bp14 X+ mov si,ax X+ mov ax,word ptr [bp+argbase+4] X+ mov dx,ax X+ and dx,7 X+ mov cl,3 X+ sar ax,cl X+ mov [bp+argbase+8],ax X+ mov [bp+argbase+4],dx X+ mov cx,xwidth X+ mov ax,drawseg X+ mov es,ax X+ push ds X+ mov ax,es14 X+ mov ds,ax X+ mov bx,14 X+ X+ X+ commonl: X+ X+ ; symbol, slettr, and llettr the same after this X+ ; compute location of byte to change X+ mov ax,word ptr [bp+argbase+6] ;this is y X+ mov [bp+argbase+6],cx X+ mul word ptr [bp+argbase+6] X+ add ax,[bp+argbase+8] X+ mov di,ax X+ X+ mov dx,3ceh ; change SET/RESET register X+ mov al,00h ; to contain the color to write. X+ out dx,al X+ mov dx,3cfh X+ mov ax,word ptr [bp+argbase+10] X+ out dx,al X+ X+ mov dx,3ceh X+ mov al,08h X+ out dx,al X+ mov dx,3cfh X+ cmp word ptr [bp+argbase+8],0ffffh ;special case:partially off X+ ;left edge of screen X+ je loop2m1 X+ cmp word ptr [bp+argbase+8],cx ;totally off screen horizontally X+ jae commf X+ dec cx X+ cmp word ptr [bp+argbase+8],cx ;Partially off right edge X+ je loop2p1 X+ loop2: X+ X+ xor ax,ax X+ mov ah,ds:[si+0] ;get pattern of current row X+ mov cx,[bp+argbase+4] X+ shr ax,cl X+ out dx,al X+ inc byte ptr es:[di+1] X+ mov al,ah X+ out dx,al X+ inc byte ptr es:[di] X+ add di,[bp+argbase+6] X+ inc si X+ dec bx X+ jg loop2 X+ jmp commf X+ loop2m1: X+ X+ xor ax,ax X+ mov ah,ds:[si+0] X+ mov cx,[bp+argbase+4] X+ shr ax,cl X+ out dx,al X+ inc byte ptr es:[di+1] X+ add di,[bp+argbase+6] X+ inc si X+ dec bx X+ jg loop2m1 X+ jmp commf X+ loop2p1: X+ X+ xor ax,ax X+ mov ah,ds:[si+0] X+ mov cx,[bp+argbase+4] X+ shr ax,cl X+ mov al,ah X+ out dx,al X+ inc byte ptr es:[di] X+ add di,[bp+argbase+6] X+ inc si X+ dec bx X+ jg loop2p1 X+ X+ commf: X+ pop ds X+ pop si X+ pop di X+ pop bp X+ ret X+ X+ pEnd _llettr X+ X+ X+ X+ X+ X+ pBegin _max_lin X+ mov ax,maxline X+ ret X+ pEnd _max_lin X+ X+ ; setmod.asm routine to be called from c to set mode n using X+ ; call setmod(n) : n=3 set to cursor mode, n=16 set to color graphics mode X+ ; 18 for VGA 480x640 color mode X+ ; any number > 61 for 600x800 mode X+ ; this version does not actually call the bios setmode routine - X+ ; you have to do that X+ pBegin _setmod X+ X+ push bp X+ mov bp,sp X+ X+ mov ax, word ptr [bp+argbase+4] X+ mov bx,ax X+ and bx, 127 X+ cmp bx, 60 X+ jl setq7 X+ mov xwidth,100 X+ mov xwidthm,99 X+ mov maxseg,60000 X+ mov maxline,600 X+ mov maxscreen,800 X+ mov mmaxscreen,799 X+ jmp setm1 X+ X+ setq7: X+ mov xwidth,80 X+ mov xwidthm,79 X+ mov maxseg,28000 X+ mov maxline,350 X+ mov maxscreen,640 X+ mov mmaxscreen,639 X+ cmp bx,18 X+ jz qq44 X+ cmp bx,17 X+ jnz setm1 X+ qq44: X+ mov maxseg,38400 X+ mov maxline,480 X+ setm1: X+ pop bp X+ ret X+ X+ X+ pEnd _setmod X+ X+ pBegin _zsetup X+ push dx X+ push ax X+ X+ mov dx,3c4h X+ mov al,02h X+ out dx,al X+ mov dx,3c5h X+ mov al,0fh X+ out dx,al X+ X+ mov dx,3ceh X+ mov al,01h X+ out dx,al X+ mov dx,3cfh X+ mov al,0fh X+ out dx,al X+ pop ax X+ pop dx X+ ret X+ pEnd _zsetup X+ X+ ; ZLINE : SUBROUTINE TO DRAW LINE ON EGA BOARD X+ ;this version has microsoft c calling convention X+ ; zline(ix0,iy0,ix1,iy1,icolor) X+ pBegin _zline X+ push bp X+ mov bp,sp X+ mov cx,word ptr [bp+argbase+6] X+ cmp cx,word ptr [bp+argbase+10] X+ jne nhoriz X+ jmp far ptr __horiz_ X+ nhoriz: X+ sub sp,6 X+ push di X+ push si X+ mov dx,3ceh X+ mov al,00h X+ out dx,al X+ mov dx,3cfh X+ mov ax,word ptr [bp+argbase+12] X+ out dx,al X+ X+ mov dx,word ptr [bp+argbase+10] X+ mov ax,word ptr [bp+argbase+8] X+ mov di,ax X+ mov bx,word ptr [bp+argbase+4] X+ mov ax,di X+ sub ax,bx X+ jge store_x X+ mov bx,di X+ mov di,dx X+ mov dx,cx X+ mov cx,di X+ neg ax X+ store_x: X+ mov word ptr[bp+argbase+6],ax X+ mov word ptr[bp+argbase+4],bx X+ mov word ptr[bp+argbase+8],cx X+ sub dx,cx X+ push xwidth X+ pop word ptr [bp-2] X+ jge store_y X+ neg word ptr [bp-2] X+ neg dx X+ store_y: X+ mov word ptr[bp+argbase+10],dx X+ ;initialize values X+ mov dx,3ceh X+ mov al,08h X+ out dx,al X+ mov ax,drawseg X+ mov es,ax X+ ;calculate address in screen buffer of first point X+ mov ax,word ptr[bp+argbase+4] X+ mov dx,ax X+ and dx,7 X+ mov cl,3 X+ sar ax,cl X+ mov si,ax X+ lea bx,btab X+ add bx,dx X+ mov ax,word ptr[bp+argbase+8] X+ mul xwidth X+ mov dx,ax X+ mov al,[bx] X+ mov bx,dx X+ mov cx,0 X+ ;figure out if slope is greater or less than 1 X+ mov dx,word ptr[bp+argbase+6] X+ cmp dx,word ptr[bp+argbase+10] X+ jl csteep X+ call slant X+ jmp finish X+ csteep: X+ call steep X+ finish: X+ pop si X+ pop di X+ mov sp,bp X+ pop bp X+ ret X+ X+ pEnd _zline X+ slant proc near X+ ;slope<1 X+ cmp si,xwidth ;test for line off screen to right X+ jge quit1 X+ mov di,word ptr[bp+argbase+10] X+ mov dx,word ptr[bp+argbase+6] X+ mov word ptr [bp-4],dx X+ shr dx,1 X+ mov word ptr [bp-6],dx X+ mov dx,3cfh X+ newdot: X+ cmp si,0 ;test for line off screen to left X+ jl q1 X+ out dx,al ;output bit in byte to mask register X+ inc byte ptr es:[bx][si] ;insert byte in buffer ... note that X+ ;the inc instruction doesn't actually do the X+ ;work -- it;s done by the EGA's wierd hardware X+ q1: ror al,1 X+ jnc nc1 X+ inc si X+ cmp si,xwidth X+ je quit1 X+ nc1: add cx,di X+ cmp cx,word ptr [bp-6] X+ jle dcount X+ sub cx,word ptr[bp+argbase+6] X+ add bx,word ptr [bp-2] X+ dcount: dec word ptr [bp-4] X+ jge newdot X+ quit1: ret X+ X+ X+ slant endp X+ steep proc near X+ ;slope>1 see comments in "slant" X+ cmp si,xwidth X+ jge quit2 X+ mov di,word ptr[bp+argbase+6] X+ or di,di X+ je vertical X+ mov dx,word ptr[bp+argbase+10] X+ mov word ptr[bp-4],dx X+ shr dx,1 X+ mov word ptr[bp-6],dx X+ mov dx,3cfh X+ out dx,al X+ newdot2: X+ cmp si,0 X+ jl c3 X+ inc byte ptr es:[bx][si] X+ c3: add bx,word ptr [bp-2] X+ add cx,di X+ cmp cx,word ptr[bp-6] X+ jle dcount2 X+ sub cx,word ptr[bp+argbase+10] X+ ror al,1 X+ out dx,al X+ jnc dcount2 X+ inc si X+ cmp si,xwidth X+ je quit2 X+ dcount2: X+ dec word ptr[bp-4] X+ jge newdot2 X+ quit2: ret X+ vertical: X+ add bx,si X+ cmp si,0 ;special case for vertical lines X+ jl quit2 ;which doesn't need fancy algorithm X+ mov cx,word ptr[bp+argbase+10] X+ mov dx,3cfh X+ out dx,al X+ loopy2: X+ inc byte ptr es:[bx] X+ c3v: X+ add bx,word ptr [bp-2] X+ dec cx X+ jge loopy2 X+ ret X+ X+ X+ steep endp X+ X+ X+ X+ ;this routine resets the system to use ordinary bios or dos screen writes X+ ;it has no parameters and may be called from any language X+ pBegin _curmod X+ push dx X+ push ax X+ X+ mov dx,3ceh X+ mov al,01h X+ out dx,al X+ mov dx,3cfh X+ mov al,00h X+ out dx,al X+ mov dx,3ceh X+ mov al,08h X+ out dx,al X+ mov dx,3cfh X+ mov al,0ffh X+ out dx,al X+ X+ X+ pop ax X+ pop dx X+ ret X+ pEnd _curmod X+ X+ ; zpoint.asm plot point at xt,yt in color zpcol X+ pBegin _zpoint X+ push bp X+ mov bp,sp X+ X+ mov dx,3ceh X+ mov al,00h X+ out dx,al X+ mov dx,3cfh X+ mov al,byte ptr [bp+argbase+8] X+ out dx,al X+ mov ax,drawseg X+ mov es,ax X+ mov cx,word ptr [bp+argbase+4] X+ mov bx,cx X+ and bx,7 X+ sar cx,1 X+ sar cx,1 X+ sar cx,1 X+ or cx,cx X+ jl ptquit X+ cmp cx,xwidthm X+ jg ptquit X+ X+ mov dx,3ceh X+ mov al,08h X+ out dx,al X+ mov dx,3cfh X+ mov al,byte ptr btab[bx] X+ out dx,al X+ X+ mov bx,cx X+ mov ax,word ptr [bp+argbase+6] X+ mul xwidth X+ add bx,ax X+ inc byte ptr es:[bx] X+ X+ ptquit: pop bp X+ ret X+ X+ pEnd _zpoint X+ X+ X+ X+ ;_e_start start up ellipse plotter X+ ; e_start(xleft,xright,y,color) X+ pBegin _e_start X+ push bp X+ mov bp,sp X+ X+ mov dx,3ceh X+ mov al,00h X+ out dx,al X+ mov dx,3cfh X+ mov al,byte ptr [bp+argbase+10] X+ out dx,al X+ mov ax,drawseg X+ mov es,ax X+ X+ mov cx,word ptr [bp+argbase+4] X+ mov bx,cx X+ and bx,7 X+ sar cx,1 X+ sar cx,1 X+ sar cx,1 X+ mov dx,3ceh X+ mov al,08h X+ out dx,al X+ mov dx,3cfh X+ mov al,byte ptr btab[bx] X+ mov leftbit,al X+ X+ out dx,al X+ X+ mov ax,word PTR [bp+argbase+8] X+ mul xwidth X+ mov bx,ax X+ mov ysave,bx X+ mov leftx,cx X+ add bx,cx X+ mov leftbot,bx X+ mov lefttop,bx X+ cmp cx,xwidth X+ jae s1 X+ inc byte ptr es:[bx] X+ X+ s1: mov cx,word ptr [bp+argbase+6] X+ mov bx,cx X+ and bx,7 X+ sar cx,1 X+ sar cx,1 X+ sar cx,1 X+ X+ mov dx,3cfh X+ mov al,byte ptr btab[bx] X+ mov rightbit,al X+ out dx,al X+ mov bx,ysave X+ mov rightx,cx X+ add bx,cx X+ mov rightbot,bx X+ mov righttop,bx X+ cmp cx,xwidth X+ jae s2 X+ inc byte ptr es:[bx] X+ X+ s2: pop bp X+ ret X+ X+ pEnd _e_start X+ X+ X+ pBegin _e_xd X+ mov ax,drawseg X+ mov es,ax X+ rol rightbit,1 X+ mov al,rightbit X+ jae l1 X+ dec rightx X+ dec rightbot X+ dec righttop X+ l1: mov dx,3cfh X+ out dx,al X+ mov bx,xwidth X+ cmp rightx,bx X+ jae s3 X+ mov bx,righttop X+ inc byte ptr es:[bx] X+ mov bx,rightbot X+ inc byte ptr es:[bx] X+ X+ s3: X+ ror leftbit,1 X+ mov al,leftbit X+ jae l2 X+ inc leftx X+ inc lefttop X+ inc leftbot X+ l2: out dx,al X+ mov bx,xwidth X+ cmp leftx,bx X+ jae s4 X+ mov bx,lefttop X+ inc byte ptr es:[bx] X+ mov bx,leftbot X+ inc byte ptr es:[bx] X+ s4: ret X+ pEnd _e_xd X+ X+ pBegin _e_xdyu X+ mov ax,drawseg X+ mov es,ax X+ rol rightbit,1 X+ mov al,rightbit X+ jae l3 X+ dec rightx X+ dec rightbot X+ dec righttop X+ l3: mov dx,3cfh X+ out dx,al X+ mov cx,xwidth X+ add righttop,cx X+ sub rightbot,cx X+ cmp rightx,cx X+ jae s5 X+ mov bx,righttop X+ inc byte ptr es:[bx] X+ mov bx,rightbot X+ inc byte ptr es:[bx] X+ X+ s5: X+ ror leftbit,1 X+ mov al,leftbit X+ jae l4 X+ inc leftx X+ inc lefttop X+ inc leftbot X+ l4: out dx,al X+ add lefttop,cx X+ sub leftbot,cx X+ cmp leftx,cx X+ jae s6 X+ mov bx,lefttop X+ inc byte ptr es:[bx] X+ mov bx,leftbot X+ inc byte ptr es:[bx] X+ X+ X+ s6: ret X+ pEnd _e_xdyu X+ X+ pBegin _e_yu X+ mov ax,drawseg X+ mov es,ax X+ mov al,leftbit X+ mov dx,3cfh X+ out dx,al X+ mov cx,xwidth X+ add lefttop,cx X+ sub leftbot,cx X+ cmp leftx,cx X+ jae s7 X+ mov bx,lefttop X+ inc byte ptr es:[bx] X+ mov bx,leftbot X+ inc byte ptr es:[bx] X+ s7: mov al,rightbit X+ out dx,al X+ add righttop,cx X+ sub rightbot,cx X+ cmp rightx,cx X+ jae s8 X+ mov bx,righttop X+ inc byte ptr es:[bx] X+ mov bx,rightbot X+ inc byte ptr es:[bx] X+ X+ s8: ret X+ pEnd _e_yu X+ X+ pBegin _rectfill X+ ; rectfill(ix0,iy0,ix1,iy1,icol) plots a rectangle in X+ ; color icol. all are integers X+ push bp X+ mov bp,sp X+ mov bx,word PTR [bp+argbase+10] X+ cmp bx,word ptr [bp+argbase+6] X+ jne notflat X+ jmp far ptr __horiz_ X+ notflat: X+ push di X+ push si X+ nop X+ X+ mov dx,3ceh X+ mov al,00h X+ out dx,al X+ mov dx,3cfh X+ mov al,byte ptr [bp+argbase+12] X+ out dx,al X+ mov cx,word PTR [bp+argbase+4] X+ mov dx,word PTR [bp+argbase+6] X+ mov ax,word PTR [bp+argbase+8] X+ X+ cmp ax,cx X+ jge test2 X+ mov si,ax X+ mov ax,cx X+ mov cx,si X+ test2: or ax,ax X+ jge test3 X+ jmp rfinish X+ test3: cmp cx,maxscreen X+ jl test4 X+ jmp rfinish X+ test4: cmp cx,0 X+ jge test5 X+ sub cx,cx X+ test5: cmp ax,maxscreen X+ jl test6 X+ mov ax,mmaxscreen X+ test6: X+ cmp bx,dx X+ jge test7 X+ mov si,bx X+ mov bx,dx X+ mov dx,si X+ test7: or bx,bx X+ jge test8 X+ jmp rfinish X+ test8: cmp dx,maxline X+ jl test9 X+ jmp rfinish X+ test9: cmp dx,0 X+ jge testa X+ sub dx,dx X+ testa: cmp bx,maxline X+ jl testb X+ mov bx,maxline X+ dec bx X+ testb: X+ X+ mov xx0,cx X+ mov yy0,dx X+ mov xx1,ax X+ mov yy1,bx X+ X+ mov ax,cx X+ mov dx,ax X+ and dx,7 X+ mov cl,3 X+ sar ax,cl X+ mov xc10,ax X+ mov xc20,dx X+ mov di,ax X+ mov ax,xx1 X+ mov dx,ax X+ and dx,7 X+ mov cl,3 X+ sar ax,cl X+ mov xc11,ax X+ mov xc21,dx X+ sub ax,di X+ mov del_x,ax X+ mov ax,drawseg X+ mov es,ax X+ mov dx,3ceh X+ mov al,08h X+ out dx,al X+ X+ mov ax,yy0 X+ mul xwidth X+ add ax,xc10 X+ mov lowyb,ax X+ X+ mov ax,yy1 X+ sub ax,yy0 X+ inc ax X+ mov del_y,ax X+ mov bx,xc20 X+ mov dl,left[bx] X+ or del_x,0 X+ jnz leftcol X+ mov bx,xc21 X+ and dl,right[bx] X+ leftcol: X+ mov al,dl X+ mov dx,3cfh X+ out dx,al X+ mov bx,lowyb X+ mov cx,del_y X+ mov ax,xwidth X+ loopd: inc byte ptr es:[bx] X+ add bx,ax X+ loop loopd X+ cmp del_x,1 X+ jl rfinish X+ jz lastcol X+ mov al,255 X+ out dx,al X+ mov bx,del_y X+ mov ax,lowyb X+ inc ax X+ mov si,del_x X+ dec si X+ loope: mov cx,si X+ mov di,ax X+ rep stosb X+ add ax,xwidth X+ dec bx X+ jnz loope X+ X+ lastcol: X+ mov bx,xc21 X+ mov al,right[bx] X+ out dx,al X+ mov bx,lowyb X+ add bx,del_x X+ mov cx,del_y X+ mov ax,xwidth X+ loopf: inc byte ptr es:[bx] X+ add bx,ax X+ loop loopf X+ X+ rfinish: X+ pop si X+ pop di X+ pop bp X+ ret X+ X+ X+ pEnd _rectfill X+ X+ pBegin __horiz_ ;stripped down version of rectfill X+ push di X+ push si X+ X+ mov dx,word PTR [bp+argbase+6] X+ cmp dx,maxline X+ jae rfinish X+ mov dx,3ceh X+ mov al,00h X+ out dx,al X+ mov dx,3cfh X+ mov al,byte ptr [bp+argbase+12] X+ out dx,al X+ mov cx,word PTR [bp+argbase+4] X+ mov bx,word PTR [bp+argbase+8] X+ X+ cmp bx,cx X+ jge test2h X+ mov si,bx X+ mov bx,cx X+ mov cx,si X+ test2h: or bx,bx X+ jge test3h X+ jmp hfinish X+ test3h: cmp cx,maxscreen X+ jl test4h X+ jmp hfinish X+ test4h: cmp cx,0 X+ jge test5h X+ sub cx,cx X+ test5h: cmp bx,maxscreen X+ jl test6h X+ mov bx,mmaxscreen X+ test6h: X+ X+ xor dx,dx X+ mov ax,cx X+ div ate X+ mov xc10,ax X+ mov xc20,dx X+ mov cx,ax X+ xor dx,dx X+ mov ax,bx X+ div ate X+ mov xc11,ax X+ mov xc21,dx X+ sub ax,cx X+ mov cx,ax X+ mov ax,drawseg X+ mov es,ax X+ mov dx,3ceh X+ mov al,08h X+ out dx,al X+ X+ mov ax,word ptr [bp+argbase+6] X+ mov dx,ax X+ mul xwidth X+ add ax,xc10 X+ mov di,ax X+ X+ mov bx,xc20 X+ mov al,left[bx] X+ or cx,cx X+ jnz leftcoh X+ mov bx,xc21 X+ and al,right[bx] X+ leftcoh: X+ mov dx,3cfh X+ out dx,al X+ inc byte ptr es:[di] X+ inc di X+ cmp cx,1 X+ jl hfinish X+ jz lastcoh X+ mov al,255 X+ out dx,al X+ dec cx X+ rep stosb X+ X+ lastcoh: X+ mov bx,xc21 X+ mov al,right[bx] X+ out dx,al X+ inc byte ptr es:[di] X+ X+ hfinish: X+ pop si X+ pop di X+ pop bp X+ ret X+ X+ pEnd __horiz_ X+ X+ endcs _egagraf X+ end X+ X+ X+ END_OF_FILE if test 21342 -ne `wc -c <'stch_pch.ad'`; then echo shar: \"'stch_pch.ad'\" unpacked with wrong size! fi # end of 'stch_pch.ad' fi echo shar: End of archive 1 \(of 4\). cp /dev/null ark1isdone MISSING="" for I in 1 2 3 4 ; do if test ! -f ark${I}isdone ; then MISSING="${MISSING} ${I}" fi done if test "${MISSING}" = "" ; then echo You have unpacked all 4 archives. rm -f ark[1-9]isdone else echo You still need to unpack the following archives: echo " " ${MISSING} fi ## End of shell archive. exit 0