Modifies process-specific file information.
Operation Notes |
 |
The fnum parameter passes the file number returned by the file system to the calling process at open (FOPEN/HPFOPEN) time. It is the number used to invoke the various file system intrinsics. PID
passes the PID of the process that issued the FOPEN/HPFOPEN call. PID is optional and defaults to the calling process's PID. If there is no active process associated with PID, AIFFILELGET returns an error condition. If there is no process-specific active file associated with fnum, AIFFILELGET returns an error condition.
The PID/file number pairs are obtainable in the following ways:
If no PID is passed, use the file numbers passed by the file system at open time.
Use AIFPROCGET, specifying a PID or PIN and item number 2063 File numbers of open files.
Use AIFFILELGET, specifying the item List of sharers.
Use AIFSYSWIDEGET, specifying the item File opened.
Since the PID/file number pair does not specify a file unique over the lifetime of a process, there is provision for accepting a UFID as a confirmation key. The PID/file number pair selects a particular file on the system which can then be confirmed uniquely by matching its UFID with the UFID passed. If the confirmation fails, the AIFFILELPUT returns an error condition. If no UFID is passed, no such check is carried out.
AIFFILELPUT is designed to make the differences between NM and CM files transparent. Thus, it can determine whether the file is an NM file or not. If it is an NM file, only the NM structures are accessed. However, if it is a CM file, the CM structures (PACB, LACB) must be accessed.
The processes whose files are accessible through AIFFILELPUT are
user processes. Processes of type SYSTEM, UCOP, MAIN, and DETACH are not accessible. If one of these processes is specified, AIFFILELPUT terminates with an error condition.
This procedure can be used to modify the attributes of only the user
files. The files excluded are those with local file numbers zero through
eight and those with file designation other than user. If you attempt to modify the information about one of the excluded files, AIFFILELPUT terminates with an error condition.
Note that this AIF will return an error (-33, "Invalid Fnum PID combination"), if an attempt is made to retrieve information for a remote file.