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 /pkg/images/imutil/src/imgets.x | |
download | iraf-osx-40e5a5811c6ffce9b0974e93cdd927cbcf60c157.tar.gz |
Repatch (from linux) of OSX IRAF
Diffstat (limited to 'pkg/images/imutil/src/imgets.x')
-rw-r--r-- | pkg/images/imutil/src/imgets.x | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/pkg/images/imutil/src/imgets.x b/pkg/images/imutil/src/imgets.x new file mode 100644 index 00000000..c05c14ca --- /dev/null +++ b/pkg/images/imutil/src/imgets.x @@ -0,0 +1,53 @@ +# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc. + +include <error.h> +include <imhdr.h> +include <ctype.h> + +# IMGETS -- Get the value of an image header parameter as a character string. +# The value is returned as a CL parameter of type string; the type coercion +# facilities of the CL may be used to convert to a different datatype if +# desired. + +procedure t_imgets() + +pointer sp, im +pointer image, param, value +pointer immap() +int ip, op, stridxs() + +begin + call smark (sp) + call salloc (image, SZ_FNAME, TY_CHAR) + call salloc (param, SZ_LINE, TY_CHAR) + call salloc (value, SZ_LINE, TY_CHAR) + + call clgstr ("image", Memc[image], SZ_FNAME) + call clgstr ("param", Memc[param], SZ_LINE) + + im = immap (Memc[image], READ_ONLY, 0) + + iferr (call imgstr (im, Memc[param], Memc[value], SZ_LINE)) { + call erract (EA_WARN) + call clpstr ("value", "0") + } else { + # Check for special case of string with double quotes. + if (stridxs ("\"", Memc[value]) != 0) { + op = param + for (ip=value; Memc[ip]!=EOS; ip=ip+1) { + if (Memc[ip] == '"') { + Memc[op] = '\\' + op = op + 1 + } + Memc[op] = Memc[ip] + op = op + 1 + } + Memc[op] = EOS + call clpstr ("value", Memc[param]) + } else + call clpstr ("value", Memc[value]) + } + + call imunmap (im) + call sfree (sp) +end |