gleam/erlang/file
Working with files on the filesystem.
The functions included in this module are for high-level concepts such as reading and writing.
Types
Reason represents all of the reasons that Erlang surfaces of why a file
system operation could fail. Most of these reasons are POSIX errors, which
come from the operating system and start with E. Others have been added to
represent other issues that may arise.
pub type Reason {
  Eacces
  Eagain
  Ebadf
  Ebadmsg
  Ebusy
  Edeadlk
  Edeadlock
  Edquot
  Eexist
  Efault
  Efbig
  Eftype
  Eintr
  Einval
  Eio
  Eisdir
  Eloop
  Emfile
  Emlink
  Emultihop
  Enametoolong
  Enfile
  Enobufs
  Enodev
  Enolck
  Enolink
  Enoent
  Enomem
  Enospc
  Enosr
  Enostr
  Enosys
  Enotblk
  Enotdir
  Enotsup
  Enxio
  Eopnotsupp
  Eoverflow
  Eperm
  Epipe
  Erange
  Erofs
  Espipe
  Esrch
  Estale
  Etxtbsy
  Exdev
  NotUtf8
}Constructors
- 
          EaccesPermission denied. 
- 
          EagainResource temporarily unavailable. 
- 
          EbadfBad file number 
- 
          EbadmsgBad message. 
- 
          EbusyFile busy. 
- 
          EdeadlkResource deadlock avoided. 
- 
          EdeadlockOn most architectures, same as Edeadlk. On some architectures, it means “File locking deadlock error.”
- 
          EdquotDisk quota exceeded. 
- 
          EexistFile already exists. 
- 
          EfaultBad address in system call argument. 
- 
          EfbigFile too large. 
- 
          EftypeInappropriate file type or format. Usually caused by trying to set the “sticky bit” on a regular file (not a directory). 
- 
          EintrInterrupted system call. 
- 
          EinvalInvalid argument. 
- 
          EioI/O error. 
- 
          EisdirIllegal operation on a directory. 
- 
          EloopToo many levels of symbolic links. 
- 
          EmfileToo many open files. 
- 
          EmlinkToo many links. 
- 
          EmultihopMultihop attempted. 
- 
          EnametoolongFilename too long 
- 
          EnfileFile table overflow 
- 
          EnobufsNo buffer space available. 
- 
          EnodevNo such device. 
- 
          EnolckNo locks available. 
- 
          EnolinkLink has been severed. 
- 
          EnoentNo such file or directory. 
- 
          EnomemNot enough memory. 
- 
          EnospcNo space left on device. 
- 
          EnosrNo STREAM resources. 
- 
          EnostrNot a STREAM. 
- 
          EnosysFunction not implemented. 
- 
          EnotblkBlock device required. 
- 
          EnotdirNot a directory. 
- 
          EnotsupOperation not supported. 
- 
          EnxioNo such device or address. 
- 
          EopnotsuppOperation not supported on socket. 
- 
          EoverflowValue too large to be stored in data type. 
- 
          EpermNot owner. 
- 
          EpipeBroken pipe. 
- 
          ErangeResult too large. 
- 
          ErofsRead-only file system. 
- 
          EspipeInvalid seek. 
- 
          EsrchNo such process. 
- 
          EstaleStale remote file handle. 
- 
          EtxtbsyText file busy. 
- 
          ExdevCross-domain link. 
- 
          NotUtf8File was requested to be read as UTF-8, but is not UTF-8 encoded. 
Functions
pub external fn delete(String) -> Result(Nil, Reason)Delete the given file.
Returns a Result with Nil if the operation was successful or a Reason otherwise.
Examples
> delete("file.txt")
Ok(Nil)
> delete("does_not_exist.txt")
Error(Enoent)
pub external fn delete_directory(
  path: String,
) -> Result(Nil, Reason)Deletes a directory.
The directory must be empty before it can be deleted. Returns a nil Success or Reason if the operation failed.
Examples
> delete_directory("foo")
Ok(Nil)
> delete_directory("does_not_exist/")
Error(Enoent)pub external fn is_directory(path: String) -> BoolReturns true if path refers to a directory, otherwise false.
Examples
> is_directory("/tmp")
True
> is_directory("resume.pdf")
Falsepub external fn is_file(path: String) -> BoolReturns true if path refers to a file, otherwise false.
Examples
> is_file("resume.pdf")
True
> is_file("/tmp")
True
> is_file("/does_not_exist")
Falsepub external fn list_directory(
  path: String,
) -> Result(List(String), Reason)Lists all files in a directory, except files with raw filenames.
Returns a Result containing the list of filenames in the directory, or Reason if the operation failed.
Examples
> list_directory("/tmp")
Ok(["FB01293B-8597-4359-80D5-130140A0C0DE","AlTest2.out"])
> list_directory("resume.docx")
Error(Enotdir)pub external fn make_directory(
  path: String,
) -> Result(Nil, Reason)Tries to create a directory. Missing parent directories are not created.
Returns a Result of nil if the directory is created or Reason if the operation failed.
Examples
> make_directory("/tmp/foo")
Ok(Nil)
> make_directory("relative_directory")
Ok(Nil)
> make_directory("/tmp/missing_intermediate_directory/foo")
Error(Enoent)pub fn read(from path: String) -> Result(String, Reason)Read the contents of the given file as a String
Assumes the file is UTF-8 encoded. Returns a Result containing the file’s
contents as a String if the operation was successful, or Reason if the file
operation failed. If the file is not UTF-8 encoded, the NotUTF8 variant
will be returned.
Examples
> read("example.txt")
Ok("Hello, World!")
> read(from: "example.txt")
Ok("Hello, World!")
> read("does_not_exist.txt")
Error(Enoent)
> read("cat.gif")
Error(NotUTF8)
pub fn read_bits(from path: String) -> Result(BitString, Reason)Read the contents of the given file as a BitString
Returns a Result containing the file’s contents as a BitString if the operation was successful, or Reason if the operation failed.
Examples
> read_bits("example.txt")
Ok(<<"Hello, World!">>)
> read_bits(from: "cat.gif")
Ok(<<71,73,70,56,57,97,1,0,1,0,0,0,0,59>>)
> read_bits("does_not_exist.txt")
Error(Enoent)
pub external fn recursive_delete(
  path: String,
) -> Result(Nil, Reason)Deletes a file or directory recursively.
Returns a nil Success or Reason if the operation failed.
Examples
> recursive_delete("foo")
Ok(Nil)
> recursive_delete("/bar")
Ok(Nil)
> recursive_delete("does_not_exist/")
Error(Enoent)pub fn write(contents contents: String, to path: String) -> Result(
  Nil,
  Reason,
)Write the given String contents to a file of the given name.
Returns a Result with Nil if the operation was successful or a Reason otherwise.
Examples
> write("Hello, World!", "file.txt")
Ok(Nil)
> write(to: "file.txt", contents: "Hello, World!")
Ok(Nil)
> write("Hello, World!", "does_not_exist/file.txt")
Error(Enoent)
pub fn write_bits(contents contents: BitString, to path: String) -> Result(
  Nil,
  Reason,
)Write the given BitString contents to a file of the given name.
Returns a Result with Nil if the operation was successful or a Reason otherwise.
Examples
> write_bits(<<71,73,70,56,57,97,1,0,1,0,0,0,0,59>>, "cat.gif")
Ok(Nil)
> write_bits(to: "cat.gif", contents: <<71,73,70,56,57,97,1,0,1,0,0,0,0,59>>)
Ok(Nil)
> write_bits(<<71,73,70,56,57,97,1,0,1,0,0,0,0,59>>, "does_not_exist/cat.gif")
Error(Enoent)