/*
-** Copyright (C) University of Virginia, Massachusetts Institue of Technology 1994-2001.
+** Copyright (C) University of Virginia, Massachusetts Institue of Technology 1994-2003.
** See ../LICENSE for license information.
**
*/
typedef enum { FILE_NORMAL, FILE_LSLTEMP, FILE_NODELETE,
FILE_HEADER, FILE_XH, FILE_MACROS, FILE_METASTATE } fileType;
-/*@private@*/ typedef struct
+/*:private:*/ typedef struct
{
bool ftemp BOOLBITS;
bool fsystem BOOLBITS;
bool fspecial BOOLBITS;
- cstring fname;
+ /*@only@*/ cstring fname;
cstring basename;
fileType ftype;
fileId fder;
int nopen;
int nopenspace;
- /*@reldef@*/ /*@only@*/ foentry *openelements;
+ /*@reldef@*/ /*@only@*/ foentry *openelements; /* evans 2002-07-12: removed reldef */
} *fileTable ;
/*@constant null fileTable fileTable_undefined; @*/
extern fileId fileTable_addLibraryFile (fileTable p_ft, cstring p_name)
/*@modifies p_ft@*/ ;
-# ifndef NOLCL
extern fileId fileTable_addLCLFile (fileTable p_ft, cstring p_name)
/*@modifies p_ft@*/ ;
extern fileId fileTable_addltemp (fileTable p_ft);
-# endif
-
extern /*@notnull@*/ /*@only@*/ fileTable fileTable_create (void) /*@*/ ;
extern fileId fileTable_lookup (fileTable p_ft, cstring p_s) /*@*/ ;
extern fileId fileTable_addCTempFile (fileTable p_ft, fileId p_fid)
extern fileId fileTable_addFileOnly (fileTable p_ft, /*@only@*/ cstring p_name)
/*@modifies p_ft@*/ ;
-# ifndef NOLCL
extern fileId fileTable_addImportFile (fileTable p_ft, cstring p_name)
/*@modifies p_ft@*/ ;
-# endif
extern fileId fileTable_addMacrosFile (fileTable p_ft)
/*@modifies p_ft@*/ ;
extern /*@observer@*/ cstring fileTable_fileNameBase (fileId p_fid) /*@*/ ;
extern /*@observer@*/ cstring fileTable_rootFileName (fileId p_fid) /*@*/ ;
+extern /*@null@*/ /*@open@*/ /*@dependent@*/ FILE *fileTable_createFile (fileTable p_ft, cstring p_fname)
+ /*@modifies p_ft, fileSystem@*/ ;
+
+extern /*@null@*/ /*@open@*/ /*@dependent@*/ FILE *fileTable_createMacrosFile (fileTable p_ft, cstring p_fname)
+ /*@modifies p_ft, fileSystem@*/ ;
+
# define fileTable_fileName(fid) (fileTable_getName(context_fileTable(), fid))
# define fileTable_fileNameBase(fid) (fileTable_getNameBase(context_fileTable(), fid))
# define fileTable_rootFileName(fid) (fileTable_getRootName(context_fileTable(), fid))
# define fileId_baseEqual(t1,t2) \
(fileId_equal (t1, t2) || fileTable_sameBase (context_fileTable (), t1, t2))
+extern /*@null@*/ /*@open@*/ /*@dependent@*/ FILE *
+fileTable_openReadFile (fileTable p_ft, cstring p_fname)
+ /*@modifies p_ft@*/ ;
+
+extern /*@null@*/ /*@open@*/ /*@dependent@*/ FILE *
+fileTable_openWriteFile (fileTable p_ft, cstring p_fname)
+ /*@modifies p_ft@*/ ;
extern /*@null@*/ /*@open@*/ /*@dependent@*/ FILE *
-fileTable_openFile (fileTable p_ft, cstring p_fname, /*@observer@*/ char *p_mode)
+fileTable_openWriteUpdateFile (fileTable p_ft, cstring p_fname)
/*@modifies p_ft@*/ ;
extern bool fileTable_closeFile (fileTable p_ft, FILE *p_f)