From 40e5a5811c6ffce9b0974e93cdd927cbcf60c157 Mon Sep 17 00:00:00 2001 From: Joe Hunkeler Date: Tue, 11 Aug 2015 16:51:37 -0400 Subject: Repatch (from linux) of OSX IRAF --- sys/etc/nmireadc.x | 50 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 sys/etc/nmireadc.x (limited to 'sys/etc/nmireadc.x') diff --git a/sys/etc/nmireadc.x b/sys/etc/nmireadc.x new file mode 100644 index 00000000..be65b9dd --- /dev/null +++ b/sys/etc/nmireadc.x @@ -0,0 +1,50 @@ +# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc. + +include + +# NMIREADC -- Read a block of character data stored externally in NMI format. +# Data is returned in the native machine character format. + +int procedure nmi_readc (fd, spp, maxchars) + +int fd # input file +int spp[ARB] # receives data +int maxchars # max number of chars to be read + +pointer sp, bp +int pksize, nchars +int nmipksize(), nminelem(), read() +errchk read() + +long note() + +begin + pksize = nmipksize (maxchars, NMI_BYTE) + nchars = max (maxchars, pksize) + + if (nchars > maxchars) { + # Read data into local buffer and unpack into user buffer. + + call smark (sp) + call salloc (bp, nchars, TY_CHAR) + + nchars = read (fd, Memc[bp], pksize) + if (nchars != EOF) { + nchars = min (maxchars, nminelem (nchars, NMI_BYTE)) + call nmiupk8 (Memc[bp], spp, nchars, TY_CHAR) + } + + call sfree (sp) + + } else { + # Read data into user buffer and unpack in place. + + nchars = read (fd, spp, pksize) + if (nchars != EOF) { + nchars = min (maxchars, nminelem (nchars, NMI_BYTE)) + call nmiupk8 (spp, spp, nchars, TY_CHAR) + } + } + + return (nchars) +end -- cgit