diff options
author | Joe Hunkeler <jhunkeler@gmail.com> | 2015-08-11 16:51:37 -0400 |
---|---|---|
committer | Joe Hunkeler <jhunkeler@gmail.com> | 2015-08-11 16:51:37 -0400 |
commit | 40e5a5811c6ffce9b0974e93cdd927cbcf60c157 (patch) | |
tree | 4464880c571602d54f6ae114729bf62a89518057 /sys/etc/gen/miireadd.x | |
download | iraf-osx-40e5a5811c6ffce9b0974e93cdd927cbcf60c157.tar.gz |
Repatch (from linux) of OSX IRAF
Diffstat (limited to 'sys/etc/gen/miireadd.x')
-rw-r--r-- | sys/etc/gen/miireadd.x | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/sys/etc/gen/miireadd.x b/sys/etc/gen/miireadd.x new file mode 100644 index 00000000..de15b8c1 --- /dev/null +++ b/sys/etc/gen/miireadd.x @@ -0,0 +1,50 @@ +# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc. + +include <mii.h> + +# MIIREAD -- Read a block of data stored externally in MII format. +# Data is returned in the format of the local host machine. + +int procedure mii_readd (fd, spp, maxelem) + +int fd #I input file +double spp[ARB] #O receives data +int maxelem # max number of data elements to be read + +pointer sp, bp +int pksize, nchars, nelem +int miipksize(), miinelem(), read() +errchk read() + +long note() + +begin + pksize = miipksize (maxelem, MII_DOUBLE) + nelem = EOF + + if (pksize > maxelem * SZ_DOUBLE) { + # Read data into local buffer and unpack into user buffer. + + call smark (sp) + call salloc (bp, pksize, TY_CHAR) + + nchars = read (fd, Memc[bp], pksize) + if (nchars != EOF) { + nelem = min (maxelem, miinelem (nchars, MII_DOUBLE)) + call miiupkd (Memc[bp], spp, nelem, TY_DOUBLE) + } + + call sfree (sp) + + } else { + # Read data into user buffer and unpack in place. + + nchars = read (fd, spp, pksize) + if (nchars != EOF) { + nelem = min (maxelem, miinelem (nchars, MII_DOUBLE)) + call miiupkd (spp, spp, nelem, TY_DOUBLE) + } + } + + return (nelem) +end |