From fa080de7afc95aa1c19a6e6fc0e0708ced2eadc4 Mon Sep 17 00:00:00 2001 From: Joseph Hunkeler Date: Wed, 8 Jul 2015 20:46:52 -0400 Subject: Initial commit --- sys/etc/gen/nmireadi.x | 50 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 sys/etc/gen/nmireadi.x (limited to 'sys/etc/gen/nmireadi.x') diff --git a/sys/etc/gen/nmireadi.x b/sys/etc/gen/nmireadi.x new file mode 100644 index 00000000..c07d5914 --- /dev/null +++ b/sys/etc/gen/nmireadi.x @@ -0,0 +1,50 @@ +# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc. + +include + +# NMI_READ -- Read a block of data stored externally in NMI format. +# Data is returned in the format of the local host machine. + +int procedure nmi_readi (fd, spp, maxelem) + +int fd #I input file +int spp[ARB] #O receives data +int maxelem # max number of data elements to be read + +pointer sp, bp +int pksize, nchars, nelem +int nmipksize(), nminelem(), read() +errchk read() + +long note() + +begin + pksize = nmipksize (maxelem, NMI_INT) + nelem = EOF + + if (pksize > maxelem * SZ_INT) { + # 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, nminelem (nchars, NMI_INT)) + call nmiupki (Memc[bp], spp, nelem, TY_INT) + } + + call sfree (sp) + + } else { + # Read data into user buffer and unpack in place. + + nchars = read (fd, spp, pksize) + if (nchars != EOF) { + nelem = min (maxelem, nminelem (nchars, NMI_INT)) + call nmiupki (spp, spp, nelem, TY_INT) + } + } + + return (nelem) +end -- cgit