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
|
# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc.
include "fxf.h"
# FXF_ACCESS -- Test the accessibility or existence of an existing image, or
# the legality of the name of a new image. Returns status = YES or NO.
procedure fxf_access (kernel, root, extn, acmode, status)
int kernel #I IKI kernel
char root[ARB] #I root filename
char extn[ARB] #I extension (SET on output if none specified)
int acmode #I access mode (0 to test only existence)
int status #O status code
int i
pointer sp, fname, kextn
int access(), iki_validextn(), iki_getextn(), btoi()
begin
call smark (sp)
call salloc (fname, SZ_PATHNAME, TY_CHAR)
call salloc (kextn, FITS_LENEXTN, TY_CHAR)
# If new image, test only the legality of the given extension.
# This is used to select a kernel given the imagefile extension.
if (acmode == NEW_IMAGE || acmode == NEW_COPY) {
status = btoi (iki_validextn (kernel, extn) > 0)
call sfree (sp)
return
}
status = NO
# If no extension was given, look for a file with the default
# extension, and return the actual extension if an image with the
# default extension is found.
if (extn[1] == EOS) {
do i = 1, ARB {
if (iki_getextn (kernel, i, Memc[kextn], FITS_LENEXTN) <= 0)
break
call iki_mkfname (root, Memc[kextn], Memc[fname], SZ_PATHNAME)
if (access (Memc[fname], acmode, 0) == YES) {
call strcpy (Memc[kextn], extn, FITS_LENEXTN)
status = YES
break
}
}
} else if (iki_validextn (kernel, extn) == kernel) {
call iki_mkfname (root, extn, Memc[fname], SZ_PATHNAME)
if (access (Memc[fname], acmode, 0) == YES)
status = YES
}
call sfree (sp)
end
|