Add File.delete to CLI platform

This commit is contained in:
Richard Feldman 2022-09-12 10:03:35 -04:00
parent d5cc75907f
commit 81d11e4edd
No known key found for this signature in database
GPG key ID: F1F21AA5B1D9E43B
3 changed files with 43 additions and 10 deletions

View file

@ -11,6 +11,7 @@ hosted Effect
stdinLine, stdinLine,
sendRequest, sendRequest,
fileReadBytes, fileReadBytes,
fileDelete,
fileWriteUtf8, fileWriteUtf8,
fileWriteBytes, fileWriteBytes,
] ]
@ -23,6 +24,7 @@ stdinLine : Effect Str
fileWriteBytes : List U8, List U8 -> Effect (Result {} InternalFile.WriteErr) fileWriteBytes : List U8, List U8 -> Effect (Result {} InternalFile.WriteErr)
fileWriteUtf8 : List U8, Str -> Effect (Result {} InternalFile.WriteErr) fileWriteUtf8 : List U8, Str -> Effect (Result {} InternalFile.WriteErr)
fileDelete : List U8 -> Effect (Result {} InternalFile.WriteErr)
fileReadBytes : List U8 -> Effect (Result (List U8) InternalFile.ReadErr) fileReadBytes : List U8 -> Effect (Result (List U8) InternalFile.ReadErr)
sendRequest : Box Request -> Effect Response sendRequest : Box Request -> Effect Response

View file

@ -1,6 +1,6 @@
interface File interface File
exposes [ReadErr, WriteErr, write, writeUtf8, writeBytes, readUtf8, readBytes] exposes [ReadErr, WriteErr, write, writeUtf8, writeBytes, readUtf8, readBytes, delete]
imports [Effect, Task.{ Task }, InternalTask, InternalFile, Path.{ Path }, InternalPath] imports [Task.{ Task }, InternalTask, InternalFile, Path.{ Path }, InternalPath, Effect.{ Effect }]
ReadErr : InternalFile.ReadErr ReadErr : InternalFile.ReadErr
@ -41,10 +41,7 @@ write = \path, val, fmt ->
## To format data before writing it to a file, you can use [File.write] instead. ## To format data before writing it to a file, you can use [File.write] instead.
writeBytes : Path, List U8 -> Task {} [FileWriteErr Path WriteErr]* [Write [File]*]* writeBytes : Path, List U8 -> Task {} [FileWriteErr Path WriteErr]* [Write [File]*]*
writeBytes = \path, bytes -> writeBytes = \path, bytes ->
InternalPath.toBytes path toWriteTask path \pathBytes -> Effect.fileWriteBytes pathBytes bytes
|> Effect.fileWriteBytes bytes
|> InternalTask.fromEffect
|> Task.mapFail \err -> FileWriteErr path err
## Write a [Str] to a file, encoded as [UTF-8](https://en.wikipedia.org/wiki/UTF-8). ## Write a [Str] to a file, encoded as [UTF-8](https://en.wikipedia.org/wiki/UTF-8).
## ##
@ -56,10 +53,27 @@ writeBytes = \path, bytes ->
## To write unformatted bytes to a file, you can use [File.writeBytes] instead. ## To write unformatted bytes to a file, you can use [File.writeBytes] instead.
writeUtf8 : Path, Str -> Task {} [FileWriteErr Path WriteErr]* [Write [File]*]* writeUtf8 : Path, Str -> Task {} [FileWriteErr Path WriteErr]* [Write [File]*]*
writeUtf8 = \path, str -> writeUtf8 = \path, str ->
InternalPath.toBytes path toWriteTask path \bytes -> Effect.fileWriteUtf8 bytes str
|> Effect.fileWriteUtf8 str
|> InternalTask.fromEffect ## Delete a file from the filesystem.
|> Task.mapFail \err -> FileWriteErr path err ##
## # Deletes the file named
## File.delete (Path.fromStr "myfile.dat") [1, 2, 3]
##
## Note that this does not securely erase the file's contents from disk; instead, the operating
## system marks the space it was occupying as safe to write over in the future. Also, the operating
## system may not immediately mark the space as free; for example, on Windows it will wait until
## the last file handle to it is closed, and on UNIX, it will not remove it until the last
## [hard link](https://en.wikipedia.org/wiki/Hard_link) to it has been deleted.
##
## This performs a [`DeleteFile`](https://docs.microsoft.com/en-us/windows/win32/api/winbase/nf-winbase-deletefile)
## on Windows and [`unlink`](https://en.wikipedia.org/wiki/Unlink_(Unix)) on UNIX systems.
##
## On Windows, this will fail when attempting to delete a readonly file; the file's
## readonly permission must be disabled before it can be successfully deleted.
delete : Path -> Task {} [FileWriteErr Path WriteErr]* [Write [File]*]*
delete = \path ->
toWriteTask path \bytes -> Effect.fileDelete bytes
## Read all the bytes in a file. ## Read all the bytes in a file.
## ##
@ -119,3 +133,10 @@ readUtf8 = \path ->
# Err decodingErr -> Err (FileReadDecodeErr decodingErr) # Err decodingErr -> Err (FileReadDecodeErr decodingErr)
# Err readErr -> Err (FileReadErr readErr) # Err readErr -> Err (FileReadErr readErr)
# InternalTask.fromEffect effect # InternalTask.fromEffect effect
toWriteTask : Path, (List U8 -> Effect (Result ok err)) -> Task ok [FileWriteErr Path err]* [Write [File]*]*
toWriteTask = \path, toEffect ->
InternalPath.toBytes path
|> toEffect
|> InternalTask.fromEffect
|> Task.mapFail \err -> FileWriteErr path err

View file

@ -217,6 +217,16 @@ pub extern "C" fn roc_fx_fileReadBytes(path: &RocList<u8>) -> RocResult<RocList<
RocResult::ok(RocList::empty()) RocResult::ok(RocList::empty())
} }
#[no_mangle]
pub extern "C" fn roc_fx_fileDelete(roc_path: &RocList<u8>) -> RocResult<(), ReadErr> {
match std::fs::remove_file(path_from_roc_path(roc_path)) {
Ok(()) => RocResult::ok(()),
Err(_) => {
todo!("Report a file write error");
}
}
}
#[no_mangle] #[no_mangle]
pub extern "C" fn roc_fx_sendRequest(roc_request: &glue::Request) -> glue::Response { pub extern "C" fn roc_fx_sendRequest(roc_request: &glue::Request) -> glue::Response {
let mut builder = reqwest::blocking::ClientBuilder::new(); let mut builder = reqwest::blocking::ClientBuilder::new();