diff options
Diffstat (limited to 'Utility/FileMode.hs')
-rwxr-xr-x[-rw-r--r--] | Utility/FileMode.hs | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/Utility/FileMode.hs b/Utility/FileMode.hs index b6bb579b5..cf9ec45a2 100644..100755 --- a/Utility/FileMode.hs +++ b/Utility/FileMode.hs @@ -5,6 +5,8 @@ - Licensed under the GNU GPL version 3 or higher. -} +{-# LANGUAGE CPP #-} + module Utility.FileMode where import Common @@ -17,6 +19,7 @@ import Foreign (complement) {- Applies a conversion function to a file's mode. -} modifyFileMode :: FilePath -> (FileMode -> FileMode) -> IO () modifyFileMode f convert = void $ modifyFileMode' f convert +#if 0 modifyFileMode' :: FilePath -> (FileMode -> FileMode) -> IO FileMode modifyFileMode' f convert = do s <- getFileStatus f @@ -25,6 +28,9 @@ modifyFileMode' f convert = do when (new /= old) $ setFileMode f new return old +#else +modifyFileMode' = error "modifyFileMode' TODO" +#endif {- Adds the specified FileModes to the input mode, leaving the rest - unchanged. -} @@ -33,7 +39,11 @@ addModes ms m = combineModes (m:ms) {- Removes the specified FileModes from the input mode. -} removeModes :: [FileMode] -> FileMode -> FileMode +#if 0 removeModes ms m = m `intersectFileModes` complement (combineModes ms) +#else +removeModes = error "removeModes TODO" +#endif {- Runs an action after changing a file's mode, then restores the old mode. -} withModifiedFileMode :: FilePath -> (FileMode -> FileMode) -> IO a -> IO a @@ -44,43 +54,78 @@ withModifiedFileMode file convert a = bracket setup cleanup go go _ = a writeModes :: [FileMode] +#if 0 writeModes = [ownerWriteMode, groupWriteMode, otherWriteMode] +#else +writeModes = [] +#endif readModes :: [FileMode] +#if 0 readModes = [ownerReadMode, groupReadMode, otherReadMode] +#else +readModes = [] +#endif executeModes :: [FileMode] +#if 0 executeModes = [ownerExecuteMode, groupExecuteMode, otherExecuteMode] +#else +executeModes = [] +#endif {- Removes the write bits from a file. -} preventWrite :: FilePath -> IO () +#if 0 preventWrite f = modifyFileMode f $ removeModes writeModes +#else +preventWrite _ = return () +#endif {- Turns a file's owner write bit back on. -} allowWrite :: FilePath -> IO () +#if 0 allowWrite f = modifyFileMode f $ addModes [ownerWriteMode] +#else +allowWrite _ = return () +#endif {- Allows owner and group to read and write to a file. -} groupWriteRead :: FilePath -> IO () +#if 0 groupWriteRead f = modifyFileMode f $ addModes [ ownerWriteMode, groupWriteMode , ownerReadMode, groupReadMode ] +#else +groupWriteRead _ = return () +#endif +#if 0 checkMode :: FileMode -> FileMode -> Bool checkMode checkfor mode = checkfor `intersectFileModes` mode == checkfor +#endif {- Checks if a file mode indicates it's a symlink. -} isSymLink :: FileMode -> Bool +#if 0 isSymLink = checkMode symbolicLinkMode +#else +isSymLink _ = False +#endif {- Checks if a file has any executable bits set. -} isExecutable :: FileMode -> Bool +#if 0 isExecutable mode = combineModes executeModes `intersectFileModes` mode /= 0 +#else +isExecutable _ = False +#endif {- Runs an action without that pesky umask influencing it, unless the - passed FileMode is the standard one. -} noUmask :: FileMode -> IO a -> IO a +#if 0 noUmask mode a | mode == stdFileMode = a | otherwise = bracket setup cleanup go @@ -88,17 +133,28 @@ noUmask mode a setup = setFileCreationMask nullFileMode cleanup = setFileCreationMask go _ = a +#else +noUmask _ a = a +#endif combineModes :: [FileMode] -> FileMode +#if 0 combineModes [] = undefined combineModes [m] = m combineModes (m:ms) = foldl unionFileModes m ms +#else +combineModes _ = error "combineModes TODO" +#endif stickyMode :: FileMode stickyMode = 512 isSticky :: FileMode -> Bool +#if 0 isSticky = checkMode stickyMode +#else +isSticky _ = False +#endif setSticky :: FilePath -> IO () setSticky f = modifyFileMode f $ addModes [stickyMode] @@ -110,6 +166,7 @@ setSticky f = modifyFileMode f $ addModes [stickyMode] - as writeFile. -} writeFileProtected :: FilePath -> String -> IO () +#if 0 writeFileProtected file content = do h <- openFile file WriteMode void $ tryIO $ @@ -117,3 +174,6 @@ writeFileProtected file content = do removeModes [groupReadMode, otherReadMode] hPutStr h content hClose h +#else +writeFileProtected = writeFile +#endif |