2007-10-11 Mark Probst <mark.probst@gmail.com>
[mono.git] / mono / metadata / file-io.h
index 2da61091b32f75441f354aeee3ff3687a394a0ed..ba4fc2314938c9b17e0c6ed5246a81ee9dce55a3 100644 (file)
 #include <config.h>
 #include <glib.h>
 
-#include <mono/metadata/object.h>
+#include <mono/metadata/object-internals.h>
 #include <mono/io-layer/io-layer.h>
+#include <mono/utils/mono-compiler.h>
+
+G_BEGIN_DECLS
 
 /* This is a copy of System.IO.FileAccess */
 typedef enum {
        FileAccess_Read=0x01,
        FileAccess_Write=0x02,
-       FileAccess_ReadWrite=FileAccess_Read|FileAccess_Write,
+       FileAccess_ReadWrite=FileAccess_Read|FileAccess_Write
 } MonoFileAccess;
 
 /* This is a copy of System.IO.FileMode */
@@ -31,7 +34,7 @@ typedef enum {
        FileMode_Open=3,
        FileMode_OpenOrCreate=4,
        FileMode_Truncate=5,
-       FileMode_Append=6,
+       FileMode_Append=6
 } MonoFileMode;
 
 /* This is a copy of System.IO.FileShare */
@@ -40,13 +43,26 @@ typedef enum {
        FileShare_Read=0x01,
        FileShare_Write=0x02,
        FileShare_ReadWrite=FileShare_Read|FileShare_Write,
+       FileShare_Delete=0x04
 } MonoFileShare;
 
+/* This is a copy of System.IO.FileOptions */
+typedef enum {
+       FileOptions_None = 0,
+       FileOptions_Temporary = 1,              // Internal.   See note in System.IO.FileOptions
+       FileOptions_Encrypted = 0x4000,
+       FileOptions_DeleteOnClose = 0x4000000,
+       FileOptions_SequentialScan = 0x8000000,
+       FileOptions_RandomAccess = 0x10000000,
+       FileOptions_Asynchronous = 0x40000000,
+       FileOptions_WriteThrough = 0x80000000
+} MonoFileOptions;
+
 /* This is a copy of System.IO.SeekOrigin */
 typedef enum {
        SeekOrigin_Begin=0,
        SeekOrigin_Current=1,
-       SeekOrigin_End=2,
+       SeekOrigin_End=2
 } MonoSeekOrigin;
 
 /* This is a copy of System.IO.MonoIOStat */
@@ -75,7 +91,7 @@ typedef enum {
        FileAttributes_Offline=0x01000,
        FileAttributes_NotContentIndexed=0x02000,
        FileAttributes_Encrypted=0x04000,
-       FileAttributes_MonoExecutable=0x80000000,
+       FileAttributes_MonoExecutable= (int) 0x80000000
 } MonoFileAttributes;
 
 typedef struct _MonoFSAsyncResult {
@@ -98,129 +114,127 @@ typedef struct _MonoFSAsyncResult {
 /* System.IO.MonoIO */
 
 extern MonoBoolean
-ves_icall_System_IO_MonoIO_CreateDirectory (MonoString *path, gint32 *error);
-
-extern MonoBoolean
-ves_icall_System_IO_MonoIO_RemoveDirectory (MonoString *path, gint32 *error);
-
-extern HANDLE 
-ves_icall_System_IO_MonoIO_FindFirstFile (MonoString *path, MonoIOStat *stat,
-                                         gint32 *error);
+ves_icall_System_IO_MonoIO_CreateDirectory (MonoString *path, gint32 *error) MONO_INTERNAL;
 
 extern MonoBoolean
-ves_icall_System_IO_MonoIO_FindNextFile (HANDLE find, MonoIOStat *stat,
-                                        gint32 *error);
+ves_icall_System_IO_MonoIO_RemoveDirectory (MonoString *path, gint32 *error) MONO_INTERNAL;
 
-extern MonoBoolean
-ves_icall_System_IO_MonoIO_FindClose (HANDLE find, gint32 *error);
+MonoArray *
+ves_icall_System_IO_MonoIO_GetFileSystemEntries (MonoString *path,
+                                                MonoString *path_with_pattern,
+                                                gint mask, gint attrs,
+                                                gint32 *error) MONO_INTERNAL;
 
 extern MonoString *
-ves_icall_System_IO_MonoIO_GetCurrentDirectory (gint32 *error);
+ves_icall_System_IO_MonoIO_GetCurrentDirectory (gint32 *error) MONO_INTERNAL;
 
 extern MonoBoolean
 ves_icall_System_IO_MonoIO_SetCurrentDirectory (MonoString *path,
-                                               gint32 *error);
+                                               gint32 *error) MONO_INTERNAL;
 
 extern MonoBoolean
 ves_icall_System_IO_MonoIO_MoveFile (MonoString *path, MonoString *dest,
-                                    gint32 *error);
+                                    gint32 *error) MONO_INTERNAL;
 
 extern MonoBoolean
 ves_icall_System_IO_MonoIO_CopyFile (MonoString *path, MonoString *dest,
-                                    MonoBoolean overwrite, gint32 *error);
+                                    MonoBoolean overwrite, gint32 *error) MONO_INTERNAL;
 
 extern MonoBoolean
-ves_icall_System_IO_MonoIO_DeleteFile (MonoString *path, gint32 *error);
+ves_icall_System_IO_MonoIO_DeleteFile (MonoString *path, gint32 *error) MONO_INTERNAL;
 
 extern gint32 
-ves_icall_System_IO_MonoIO_GetFileAttributes (MonoString *path, gint32 *error);
+ves_icall_System_IO_MonoIO_GetFileAttributes (MonoString *path, gint32 *error) MONO_INTERNAL;
 
 extern MonoBoolean
 ves_icall_System_IO_MonoIO_SetFileAttributes (MonoString *path, gint32 attrs,
-                                             gint32 *error);
+                                             gint32 *error) MONO_INTERNAL;
 
 extern gint32
-ves_icall_System_IO_MonoIO_GetFileType (HANDLE handle, gint32 *error);
+ves_icall_System_IO_MonoIO_GetFileType (HANDLE handle, gint32 *error) MONO_INTERNAL;
 
 extern MonoBoolean
 ves_icall_System_IO_MonoIO_GetFileStat (MonoString *path, MonoIOStat *stat,
-                                       gint32 *error);
+                                       gint32 *error) MONO_INTERNAL;
 
 extern HANDLE 
 ves_icall_System_IO_MonoIO_Open (MonoString *filename, gint32 mode,
-                                gint32 access_mode, gint32 share,
-                                MonoBoolean async, gint32 *error);
+                                gint32 access_mode, gint32 share, gint32 options,
+                                gint32 *error) MONO_INTERNAL;
 
 extern MonoBoolean
-ves_icall_System_IO_MonoIO_Close (HANDLE handle, gint32 *error);
+ves_icall_System_IO_MonoIO_Close (HANDLE handle, gint32 *error) MONO_INTERNAL;
 
 extern gint32 
 ves_icall_System_IO_MonoIO_Read (HANDLE handle, MonoArray *dest,
                                 gint32 dest_offset, gint32 count,
-                                gint32 *error);
+                                gint32 *error) MONO_INTERNAL;
 
 extern gint32 
 ves_icall_System_IO_MonoIO_Write (HANDLE handle, MonoArray *src,
                                  gint32 src_offset, gint32 count,
-                                 gint32 *error);
+                                 gint32 *error) MONO_INTERNAL;
 
 extern gint64 
 ves_icall_System_IO_MonoIO_Seek (HANDLE handle, gint64 offset, gint32 origin,
-                                gint32 *error);
+                                gint32 *error) MONO_INTERNAL;
 
 extern MonoBoolean
-ves_icall_System_IO_MonoIO_Flush (HANDLE handle, gint32 *error);
+ves_icall_System_IO_MonoIO_Flush (HANDLE handle, gint32 *error) MONO_INTERNAL;
 
 extern gint64 
-ves_icall_System_IO_MonoIO_GetLength (HANDLE handle, gint32 *error);
+ves_icall_System_IO_MonoIO_GetLength (HANDLE handle, gint32 *error) MONO_INTERNAL;
 
 extern MonoBoolean
 ves_icall_System_IO_MonoIO_SetLength (HANDLE handle, gint64 length,
-                                     gint32 *error);
+                                     gint32 *error) MONO_INTERNAL;
 
 extern MonoBoolean
 ves_icall_System_IO_MonoIO_SetFileTime (HANDLE handle, gint64 creation_time,
                                        gint64 last_access_time,
-                                       gint64 last_write_time, gint32 *error);
+                                       gint64 last_write_time, gint32 *error) MONO_INTERNAL;
 
 extern HANDLE 
-ves_icall_System_IO_MonoIO_get_ConsoleOutput (void);
+ves_icall_System_IO_MonoIO_get_ConsoleOutput (void) MONO_INTERNAL;
 
 extern HANDLE 
-ves_icall_System_IO_MonoIO_get_ConsoleInput (void);
+ves_icall_System_IO_MonoIO_get_ConsoleInput (void) MONO_INTERNAL;
 
 extern HANDLE 
-ves_icall_System_IO_MonoIO_get_ConsoleError (void);
+ves_icall_System_IO_MonoIO_get_ConsoleError (void) MONO_INTERNAL;
 
 extern MonoBoolean
 ves_icall_System_IO_MonoIO_CreatePipe (HANDLE *read_handle,
-                                      HANDLE *write_handle);
+                                      HANDLE *write_handle) MONO_INTERNAL;
 
 extern gunichar2 
-ves_icall_System_IO_MonoIO_get_VolumeSeparatorChar (void);
+ves_icall_System_IO_MonoIO_get_VolumeSeparatorChar (void) MONO_INTERNAL;
 
 extern gunichar2 
-ves_icall_System_IO_MonoIO_get_DirectorySeparatorChar (void);
+ves_icall_System_IO_MonoIO_get_DirectorySeparatorChar (void) MONO_INTERNAL;
 
 extern gunichar2 
-ves_icall_System_IO_MonoIO_get_AltDirectorySeparatorChar (void);
+ves_icall_System_IO_MonoIO_get_AltDirectorySeparatorChar (void) MONO_INTERNAL;
 
 extern gunichar2 
-ves_icall_System_IO_MonoIO_get_PathSeparator (void);
+ves_icall_System_IO_MonoIO_get_PathSeparator (void) MONO_INTERNAL;
 
 extern MonoArray *
-ves_icall_System_IO_MonoIO_get_InvalidPathChars (void);
+ves_icall_System_IO_MonoIO_get_InvalidPathChars (void) MONO_INTERNAL;
 
 extern gint32
-ves_icall_System_IO_MonoIO_GetTempPath (MonoString **mono_name);
+ves_icall_System_IO_MonoIO_GetTempPath (MonoString **mono_name) MONO_INTERNAL;
 
-extern MonoBoolean
-ves_icall_System_IO_MonoIO_GetSupportsAsync (void);
+extern void ves_icall_System_IO_MonoIO_Lock (HANDLE handle, gint64 position,
+                                            gint64 length, gint32 *error) MONO_INTERNAL;
+extern void ves_icall_System_IO_MonoIO_Unlock (HANDLE handle, gint64 position,
+                                              gint64 length, gint32 *error) MONO_INTERNAL;
 
 extern MonoBoolean
-ves_icall_System_IO_MonoIO_BeginRead (HANDLE handle, MonoFSAsyncResult *ares);
+ves_icall_System_IO_MonoIO_ReplaceFile (MonoString *sourceFileName, MonoString *destinationFileName,
+                                       MonoString *destinationBackupFileName, MonoBoolean ignoreMetadataErrors,
+                                       gint32 *error) MONO_INTERNAL;
 
-extern MonoBoolean
-ves_icall_System_IO_MonoIO_BeginWrite (HANDLE handle, MonoFSAsyncResult *ares);
+G_END_DECLS
 
 #endif /* _MONO_METADATA_FILEIO_H_ */