branch update for HEAD-2003021201
[reactos.git] / lib / crtdll / io / chmod.c
index be48dbf..0f54898 100644 (file)
@@ -1,31 +1,33 @@
 #include <windows.h>
-#include <crtdll/io.h>
+#include <msvcrt/io.h>
+
+#define NDEBUG
+#include <msvcrt/msvcrtdbg.h>
+
 #define mode_t int
 
-int
-_chmod(const char *filename, mode_t mode)
+
+int _chmod(const char* filename, mode_t mode)
 {
-        DWORD FileAttributes = 0;
-        
-        FileAttributes = GetFileAttributes(filename);
-        if ( FileAttributes == -1 )
-               return -1;
-               
-        if ( mode == 0 )
-               return -1;
-        
-        
-        if ( (mode & _S_IREAD) == _S_IREAD && (mode & _S_IWRITE) != _S_IWRITE)
-                FileAttributes &= FILE_ATTRIBUTE_READONLY;       
-        else if ( ((mode & _S_IREAD) != _S_IREAD) && ((mode & _S_IWRITE) == _S_IWRITE) )
-                FileAttributes &= FILE_ATTRIBUTE_NORMAL;
-        else
-               FileAttributes &= FILE_ATTRIBUTE_NORMAL;
-                
-
-
-        if ( SetFileAttributes(filename,FileAttributes) == FALSE )
-                return -1;
-
-        return 1;
+    DWORD FileAttributes = 0;
+    DPRINT("_chmod('%s', %x)\n", filename, mode);
+
+    FileAttributes = GetFileAttributesA(filename);
+    if ( FileAttributes == -1 )
+        return -1;
+
+    if ( mode == 0 )
+        return -1;
+
+    if ((mode & _S_IREAD) == _S_IREAD && (mode & _S_IWRITE) != _S_IWRITE)
+        FileAttributes &= FILE_ATTRIBUTE_READONLY;
+    else if (((mode & _S_IREAD) != _S_IREAD) && ((mode & _S_IWRITE) == _S_IWRITE))
+        FileAttributes &= FILE_ATTRIBUTE_NORMAL;
+    else
+        FileAttributes &= FILE_ATTRIBUTE_NORMAL;
+
+    if (SetFileAttributesA(filename, FileAttributes) == FALSE)
+        return -1;
+
+    return 1;
 }