openDirStream :: FilePath -> IO DirStream |
openDirStream dir calls opendir to obtain a directory stream for dir.
readDirStream :: DirStream -> IO String |
readDirStream dp calls readdir to obtain the next directory entry (struct dirent) for the open directory stream dp, and returns the d_name member of that structure.
The operation may fail with:
End of file has been reached.
Various other causes.
rewindDirStream :: DirStream -> IO () |
rewindDirStream dp calls rewinddir to reposition the directory stream dp at the beginning of the directory.
closeDirStream :: DirStream -> IO () |
closeDirStream dp calls closedir to close the directory stream dp.
getWorkingDirectory :: IO FilePath |
getWorkingDirectory calls getcwd to obtain the name of the current working directory.
changeWorkingDirectory :: FilePath -> IO () |
changeWorkingDirectory dir calls chdir to change the current working directory to dir.
nullFileMode :: FileMode -- --------- ownerReadMode :: FileMode -- r-------- ownerWriteMode :: FileMode -- -w------- ownerExecuteMode :: FileMode -- --x------ groupReadMode :: FileMode -- ---r----- groupWriteMode :: FileMode -- ----w---- groupExecuteMode :: FileMode -- -----x--- otherReadMode :: FileMode -- ------r-- otherWriteMode :: FileMode -- -------w- otherExecuteMode :: FileMode -- --------x setUserIDMode :: FileMode -- --S------ setGroupIDMode :: FileMode -- -----S--- stdFileMode :: FileMode -- rw-rw-rw- ownerModes :: FileMode -- rwx------ groupModes :: FileMode -- ---rwx--- otherModes :: FileMode -- ------rwx accessModes :: FileMode -- rwxrwxrwx unionFileModes :: FileMode -> FileMode -> FileMode intersectFileModes :: FileMode -> FileMode -> FileMode stdInput :: Fd stdInput = intToFd 0 stdOutput :: Fd stdOutput = intToFd 1 stdError :: Fd stdError = intToFd 2 data OpenFileFlags = OpenFileFlags { append :: Bool, exclusive :: Bool, noctty :: Bool, nonBlock :: Bool, trunc :: Bool } openFd :: FilePath -> OpenMode -> Maybe FileMode -- Just x => O_CREAT, Nothing => must exist -> OpenFileFlags -> IO Fd |
openFd path acc mode (OpenFileFlags app excl noctty nonblock trunc) calls open to obtain a Fd for the file path with access mode acc. If mode is Just m, the O_CREAT flag is set and the file's permissions will be based on m if it does not already exist; otherwise, the O_CREAT flag is not set. The arguments app, excl, noctty, nonblock, and trunc control whether or not the flags O_APPEND, O_EXCL, O_NOCTTY, O_NONBLOCK, and O_TRUNC are set, respectively.
createFile :: FilePath -> FileMode -> IO Fd |
createFile path mode calls creat to obtain a Fd for file path, which will be created with permissions based on mode if it does not already exist.
setFileCreationMask :: FileMode -> IO FileMode |
setFileCreationMask mode calls umask to set the process's file creation mask to mode. The previous file creation mask is returned.
createLink :: FilePath -> FilePath -> IO () |
createLink old new calls link to create a new path, new, linked to an existing file, old.
createDirectory :: FilePath -> FileMode -> IO () |
createDirectory dir mode calls mkdir to create a new directory, dir, with permissions based on mode.
createNamedPipe :: FilePath -> FileMode -> IO () |
createNamedPipe fifo mode calls mkfifo to create a new named pipe, fifo, with permissions based on mode.
removeLink :: FilePath -> IO () |
removeLink path calls unlink to remove the link named path.
removeDirectory :: FilePath -> IO () |
removeDirectory dir calls rmdir to remove the directory named dir.
rename :: FilePath -> FilePath -> IO () |
rename old new calls rename to rename a file or directory from old to new.
fileMode :: FileStatus -> FileMode fileID :: FileStatus -> FileID deviceID :: FileStatus -> DeviceID linkCount :: FileStatus -> LinkCount fileOwner :: FileStatus -> UserID fileGroup :: FileStatus -> GroupID fileSize :: FileStatus -> FileOffset accessTime :: FileStatus -> EpochTime modificationTime :: FileStatus -> EpochTime statusChangeTime :: FileStatus -> EpochTime isDirectory :: FileStatus -> Bool isCharacterDevice :: FileStatus -> Bool isBlockDevice :: FileStatus -> Bool isRegularFile :: FileStatus -> Bool isNamedPipe :: FileStatus -> Bool getFileStatus :: FilePath -> IO FileStatus |
getFileStatus path calls stat to get the FileStatus information for the file path.
getFdStatus :: Fd -> IO FileStatus |
getFdStatus fd calls fstat to get the FileStatus information for the file associated with Fd fd.
queryAccess :: FilePath -> Bool -> Bool -> Bool -> IO Bool |
queryAccess path r w x calls access to test the access permissions for file path. The three arguments, r, w, and x control whether or not access is called with R_OK, W_OK, and X_OK respectively.
queryFile :: FilePath -> IO Bool |
queryFile path calls access with F_OK to test for the existence for file path.
setFileMode :: FilePath -> FileMode -> IO () |
setFileMode path mode calls chmod to set the permission bits associated with file path to mode.
setOwnerAndGroup :: FilePath -> UserID -> GroupID -> IO () |
setOwnerAndGroup path uid gid calls chown to set the UserID and GroupID associated with file path to uid and gid, respectively.
setFileTimes :: FilePath -> EpochTime -> EpochTime -> IO () |
setFileTimes path atime mtime calls utime to set the access and modification times associated with file path to atime and mtime, respectively.
touchFile :: FilePath -> IO () |
touchFile path calls utime to set the access and modification times associated with file path to the current time.
getPathVar :: PathVar -> FilePath -> IO Limit |
getPathVar var path calls pathconf to obtain the dynamic value of the requested configurable file limit or option associated with file or directory path. For defined file limits, getPathVar returns the associated value. For defined file options, the result of getPathVar is undefined, but not failure. The operation may fail with:
The requested file limit or option is undefined.
Various other causes.
getFdVar :: PathVar -> Fd -> IO Limit |
getFdVar var fd calls fpathconf to obtain the dynamic value of the requested configurable file limit or option associated with the file or directory attached to the open channel fd. For defined file limits, getFdVar returns the associated value. For defined file options, the result of getFdVar is undefined, but not failure.
The operation may fail with:
The requested file limit or option is undefined.
Various other causes.