| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 
 | /*
 * Copyright (C)2005-2019 Haxe Foundation
 *
 * Permission is hereby granted, free of charge, to any person obtaining a
 * copy of this software and associated documentation files (the "Software"),
 * to deal in the Software without restriction, including without limitation
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 * and/or sell copies of the Software, and to permit persons to whom the
 * Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 * DEALINGS IN THE SOFTWARE.
 */
package sys.io;
import haxe.SysTools;
import lua.Lua;
import lua.Io;
import lua.Os;
import lua.FileHandle;
import lua.Boot;
@:coreApi
class File {
	public static function getContent(path:String):String {
		var f = Io.open(path, "r");
		if (f == null)
			throw 'Invalid path : $path';
		var s = f.read("*all");
		f.close();
		return s;
	}
	public static function append(path:String, binary:Bool = true):FileOutput {
		return @:privateAccess new FileOutput(Io.open(path, "a"));
	}
	public static function update(path:String, binary:Bool = true):FileOutput {
		if (!FileSystem.exists(path)) {
			write(path).close();
		}
		return @:privateAccess new FileOutput(Io.open(path, binary ? "r+b" : "r+"));
	}
	public static function copy(srcPath:String, dstPath:String):Void {
		var result = switch (Sys.systemName()) {
			case "Windows": Os.execute('copy ${SysTools.quoteWinArg(srcPath, true)} ${SysTools.quoteWinArg(dstPath, true)}');
			default: Os.execute('cp ${SysTools.quoteUnixArg(srcPath)} ${SysTools.quoteUnixArg(dstPath)}');
		};
		if (#if (lua_ver >= 5.2) !result.success #elseif (lua_ver < 5.2) result != 0 #else ((result : Dynamic) != true && (result : Dynamic) != 0) #end
		) {
			throw 'Failed to copy $srcPath to $dstPath';
		}
	}
	public static function getBytes(path:String):haxe.io.Bytes {
		var finput = read(path, true);
		var res = finput.readAll();
		finput.close();
		return res;
	}
	public static function read(path:String, binary:Bool = true):FileInput {
		var fh = Io.open(path, binary ? 'rb' : 'r');
		if (fh == null)
			throw 'Invalid path : $path';
		return @:privateAccess new FileInput(fh);
	}
	public static function write(path:String, binary:Bool = true):FileOutput {
		var fh = Io.open(path, binary ? 'wb' : 'w');
		if (fh == null)
			throw 'Invalid path : $path';
		return @:privateAccess new FileOutput(fh);
	}
	public static function saveBytes(path:String, bytes:haxe.io.Bytes):Void {
		var f = write(path, true);
		f.writeBytes(bytes, 0, bytes.length);
		f.close();
	}
	public static function saveContent(path:String, content:String):Void {
		var f = write(path, true);
		f.writeString(content);
		f.close();
	}
}
 |