diff options
Diffstat (limited to 'sys/osb/achtb.gc')
-rw-r--r-- | sys/osb/achtb.gc | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/sys/osb/achtb.gc b/sys/osb/achtb.gc new file mode 100644 index 00000000..dd5f97d2 --- /dev/null +++ b/sys/osb/achtb.gc @@ -0,0 +1,32 @@ +/* Copyright(c) 1986 Association of Universities for Research in Astronomy Inc. + */ + +#define import_spp +#define import_knames +#include <iraf.h> + +/* ACHTB_ -- Unpack an unsigned byte array into an SPP array. + * The loop runs in the reverse direction so that the unpack can be + * performed in place (a and b can be the same array). + */ +void +ACHTB$T ( + XCHAR *a, + $if (datatype == B) + XCHAR *b, + $else + XPIXEL *b, + $endif + XINT *npix +) +{ + register XUBYTE *ip, *first = (XUBYTE *)a; + register XPIXEL *op; + + for (ip = &first[*npix], op = &((XPIXEL *)b)[*npix]; ip > first; ) + $if (datatype == x) + (--op)->r = (float) *--ip; + $else + *--op = *--ip; + $endif +} |