* appdomain.c: Increment version number.
[mono.git] / mono / metadata / file-io.h
index baa438abefbe7f05b5af7d605942f2e2e2fe5360..851e34ff373e6fabea1107971ec667668c6dc7af 100644 (file)
@@ -21,7 +21,7 @@
 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 +31,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 */
@@ -39,14 +39,14 @@ typedef enum {
        FileShare_None=0x0,
        FileShare_Read=0x01,
        FileShare_Write=0x02,
-       FileShare_ReadWrite=FileShare_Read|FileShare_Write,
+       FileShare_ReadWrite=FileShare_Read|FileShare_Write
 } MonoFileShare;
 
 /* 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,9 +75,41 @@ typedef enum {
        FileAttributes_Offline=0x01000,
        FileAttributes_NotContentIndexed=0x02000,
        FileAttributes_Encrypted=0x04000,
-       FileAttributes_MonoExecutable=0x80000000,
+       FileAttributes_MonoExecutable= (int) 0x80000000
 } MonoFileAttributes;
 
+typedef struct _MonoFSAsyncResult {
+       MonoObject obj;
+       MonoObject *state;
+       MonoBoolean completed;
+       MonoBoolean done;
+       MonoException *exc;
+       MonoWaitHandle *wait_handle;
+       MonoDelegate *async_callback;
+       MonoBoolean completed_synch;
+       MonoArray *buffer;
+       gint offset;
+       gint count;
+       gint original_count;
+       gint bytes_read;
+       MonoDelegate *real_cb;
+} MonoFSAsyncResult;
+
+#ifdef PLATFORM_WIN32
+typedef struct _WapiOverlapped WapiOverlapped;
+
+struct _WapiOverlapped
+{
+       guint32 Internal;
+       guint32 InternalHigh;
+       guint32 Offset;
+       guint32 OffsetHigh;
+       gpointer hEvent;
+       gpointer handle1;
+       gpointer handle2;
+};
+#endif
+
 /* System.IO.MonoIO */
 
 extern MonoBoolean
@@ -132,7 +164,7 @@ ves_icall_System_IO_MonoIO_GetFileStat (MonoString *path, MonoIOStat *stat,
 extern HANDLE 
 ves_icall_System_IO_MonoIO_Open (MonoString *filename, gint32 mode,
                                 gint32 access_mode, gint32 share,
-                                gint32 *error);
+                                MonoBoolean async, gint32 *error);
 
 extern MonoBoolean
 ves_icall_System_IO_MonoIO_Close (HANDLE handle, gint32 *error);
@@ -197,4 +229,18 @@ ves_icall_System_IO_MonoIO_get_InvalidPathChars (void);
 extern gint32
 ves_icall_System_IO_MonoIO_GetTempPath (MonoString **mono_name);
 
+extern MonoBoolean
+ves_icall_System_IO_MonoIO_GetSupportsAsync (void);
+
+extern MonoBoolean
+ves_icall_System_IO_MonoIO_BeginRead (HANDLE handle, MonoFSAsyncResult *ares);
+
+extern MonoBoolean
+ves_icall_System_IO_MonoIO_BeginWrite (HANDLE handle, MonoFSAsyncResult *ares);
+
+extern void ves_icall_System_IO_MonoIO_Lock (HANDLE handle, gint64 position,
+                                            gint64 length, gint32 *error);
+extern void ves_icall_System_IO_MonoIO_Unlock (HANDLE handle, gint64 position,
+                                              gint64 length, gint32 *error);
+
 #endif /* _MONO_METADATA_FILEIO_H_ */