Skip to content

Commit

Permalink
move copyFile to IO module
Browse files Browse the repository at this point in the history
Signed-off-by: Brian Downs <[email protected]>
  • Loading branch information
briandowns committed Oct 20, 2023
1 parent b39076d commit 2751fbc
Show file tree
Hide file tree
Showing 8 changed files with 111 additions and 49 deletions.
10 changes: 10 additions & 0 deletions docs/docs/standard-lib/io.md
Original file line number Diff line number Diff line change
Expand Up @@ -41,3 +41,13 @@ Prints a given list of values to stdout with an appended newline character.
IO.println("Dictu!");
// Dictu!
```

### IO.copyFile(String: src, String: dst) -> Result<Nil>

Copies the contents from the source file to the destination file.

Returns a Result type and on success will unwrap to nil.

```cs
IO.copyFile(src, dst);
```
10 changes: 0 additions & 10 deletions docs/docs/standard-lib/system.md
Original file line number Diff line number Diff line change
Expand Up @@ -280,13 +280,3 @@ Note: This is not available on Windows systems.
System.mkdirTemp().unwrap(); // "VOO16s"
System.mkdirTemp("test_XXXXXX").unwrap(); // "test_0bL2qS"
```

### System.copyFile(String: src, String: dst) -> Result<Nil>

Copies the contents from the source file to the destination file.

Returns a Result type and on success will unwrap to nil.

```cs
System.copyFile(src, dst);
```
3 changes: 2 additions & 1 deletion examples/copyFile.du
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import IO;
import Path;
import System;

Expand Down Expand Up @@ -36,7 +37,7 @@ def cleanup(tmpDir) {
print(file.read());
}

System.copyFile(Path.join(tmpDir, srcFile), Path.join(tmpDir, dstFile)).match(
IO.copyFile(Path.join(tmpDir, srcFile), Path.join(tmpDir, dstFile)).match(
def(result) => result,
def(error) => {
print(error);
Expand Down
57 changes: 57 additions & 0 deletions src/optionals/io.c
Original file line number Diff line number Diff line change
@@ -1,3 +1,11 @@
#include <fcntl.h>
#include <unistd.h>
#if defined(__APPLE__) || defined(__FreeBSD__)
#include <copyfile.h>
#else
#include <sys/sendfile.h>
#endif

#include "io.h"


Expand Down Expand Up @@ -28,6 +36,52 @@ static Value printlnIO(DictuVM *vm, int argCount, Value *args) {
return NIL_VAL;
}

//#ifndef _WIN32
static Value copyFileIO(DictuVM *vm, int argCount, Value *args) {
if (argCount != 2) {
runtimeError(vm, "copyFile() takes 2 arguments (%d given)", argCount);
return EMPTY_VAL;
}

if (!IS_STRING(args[0])) {
runtimeError(vm, "src argument needs to be a string");
return EMPTY_VAL;
}

if (!IS_STRING(args[1])) {
runtimeError(vm, "dst argument needs to be a string");
return EMPTY_VAL;
}

char *src = AS_STRING(args[0])->chars;
char *dst = AS_STRING(args[1])->chars;

int in = 0;
int out = 0;

if ((in = open(src, O_RDONLY)) == -1) {
return newResultError(vm, "failed to open src file");
}
if ((out = creat(dst, 0660)) == -1) {
close(in);
return newResultError(vm, "failed to create/open dst file");
}

#if defined(__APPLE__) || defined(__FreeBSD__)
fcopyfile(in, out, 0, COPYFILE_ALL);
#else
off_t bytes = 0;
struct stat fileinfo = {0};
fstat(in, &fileinfo);
sendfile(out, in, &bytes, fileinfo.st_size);
#endif
close(in);
close(out);

return newResultSuccess(vm, NIL_VAL);
}
//#endif

Value createIOModule(DictuVM *vm) {
ObjString *name = copyString(vm, "IO", 2);
push(vm, OBJ_VAL(name));
Expand All @@ -43,6 +97,9 @@ Value createIOModule(DictuVM *vm) {
*/
defineNative(vm, &module->values, "print", printIO);
defineNative(vm, &module->values, "println", printlnIO);
//#ifndef _WIN32
defineNative(vm, &module->values, "copyFile", copyFileIO);
//#endif

pop(vm);
pop(vm);
Expand Down
38 changes: 0 additions & 38 deletions src/optionals/system.c
Original file line number Diff line number Diff line change
Expand Up @@ -490,43 +490,6 @@ static Value chmodNative(DictuVM *vm, int argCount, Value *args) {
return newResultSuccess(vm, NIL_VAL);
}

static Value copyFileNative(DictuVM *vm, int argCount, Value *args) {
if (argCount != 2) {
runtimeError(vm, "copyFile() takes 2 arguments (%d given).", argCount);
return EMPTY_VAL;
}

if (!IS_STRING(args[0]) || !IS_STRING(args[1])) {
runtimeError(vm, "copyFile() arguments must be strings.");
return EMPTY_VAL;
}

char *srcFile = AS_STRING(args[0])->chars;
char *dstFile = AS_STRING(args[1])->chars;

FILE *sf = fopen(srcFile, "r");
if (sf == NULL) {
return newResultError(vm, "cannot open src file");
}

FILE *df = fopen(dstFile, "w");
if (df == NULL) {
fclose(sf);
return newResultError(vm, "cannot open dst file");
}

int buffer = fgetc(sf);
while (buffer != EOF) {
fputc(buffer, df);
buffer = fgetc(sf);
}

fclose(sf);
fclose(df);

return newResultSuccess(vm, NIL_VAL);
}

void initArgv(DictuVM *vm, Table *table, int argc, char **argv) {
ObjList *list = newList(vm);
push(vm, OBJ_VAL(list));
Expand Down Expand Up @@ -627,7 +590,6 @@ Value createSystemModule(DictuVM *vm) {
defineNative(vm, &module->values, "sleep", sleepNative);
defineNative(vm, &module->values, "exit", exitNative);
defineNative(vm, &module->values, "chmod", chmodNative);
defineNative(vm, &module->values, "copyFile", copyFileNative);

/**
* Define System properties
Expand Down
34 changes: 34 additions & 0 deletions tests/io/copyFile.du
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
/**
* copyFile.du
*
* Testing the IO.copyFile() method
*/
from UnitTest import UnitTest;

import IO;
import System;

class TestIOCopyFile < UnitTest {
const testFile1 = "tests/io/test1";
const testFile2 = "tests/io/test2";

setUp() {
with(this.testFile1, "w") {
this.written = file.write("Dictu!");
}
}

tearDown() {
System.remove(this.testFile1);
System.remove(this.testFile2);
}

testIOCopyFile() {
const res = IO.copyFile(this.testFile1, this.testFile2);
this.assertSuccess(res);
}
}

//if (System.platform != "windows") {
TestIOCopyFile().run();
//}
7 changes: 7 additions & 0 deletions tests/io/import.du
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
/**
* import.du
*
* General import file for the IO module tests
*/

import "copyFile.du";
1 change: 1 addition & 0 deletions tests/runTests.du
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ import "base64/import.du";
import "sqlite/import.du";
import "process/import.du";
import "inspect/import.du";
import "io/import.du";
import "unittest/import.du";

if (isDefined("HTTP")) {
Expand Down

0 comments on commit 2751fbc

Please sign in to comment.