aboutsummaryrefslogtreecommitdiff
path: root/sys/imio/imunmap.x
blob: dd2290b1a780eea3694c127864afeb0bb46923e9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc.

include	<syserr.h>
include	<imhdr.h>
include	<imio.h>

# IMUNMAP -- Unmap a image.  Flush the output buffer, append the bad pixel
# list, update the image header.  Close all files and return buffer space.

procedure imunmap (im)

pointer	im

int	acmode
errchk	imflush, close, imerr, iki_updhdr

begin
	acmode = IM_ACMODE(im)

	# Note that if no pixel i/o occurred, the pixel storage file will
	# never have been opened or created.

	if (IM_PFD(im) != NULL)
	    call imflush (im)

	# Update the image header, if necessary (count of bad pixels,
	# minimum and maximum pixel values, etc.).

	if (IM_UPDATE(im) == YES) {
	    if (acmode == READ_ONLY)
		call imerr (IM_NAME(im), SYS_IMUPIMHDR)

	    # Restore those fields of the image header that may have been
	    # modified to map a section (if accessing an existing image).

	    switch (acmode) {
	    case NEW_COPY, NEW_IMAGE:
		;			# Cannot access section of new image
	    default:
		IM_NDIM(im) = IM_NPHYSDIM(im)
		IM_MTIME(im) = IM_SVMTIME(im)
		call amovl (IM_SVLEN(im,1), IM_LEN(im,1), IM_NDIM(im))
	    }

	    # Update the image header or mask storage file.
	    call iki_updhdr (im)
	}

	# Physically close the image.
	call iki_close (im)

	# If the image is a mask image and the PL_CLOSEPL flag is set, close
	# the associated mask.

	if (IM_PL(im) != NULL && and(IM_PLFLAGS(im),PL_CLOSEPL) != 0)
	    call pl_close (IM_PL(im))

	# Free all buffer space allocated by IMIO.
	call imrmbufs (im)
	call mfree (im, TY_STRUCT)
end