Update Files

This commit is contained in:
2025-01-22 16:18:30 +01:00
parent ed4603cf95
commit a36294b518
16718 changed files with 2960346 additions and 0 deletions

View File

@ -0,0 +1,53 @@
/*
* 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.net;
class Host {
public var host(default, null):String;
public var ip(default, null):Int;
public function new(name:String) {
host = name;
init(resolve(name));
}
public function toString() {
return hostToString(ip);
}
public function reverse() {
return hostReverse(ip);
}
function init(ip:Int) {
this.ip = ip;
}
extern static public function localhost();
extern static function hostReverse(ip:Int);
extern static function hostToString(ip:Int);
extern static function resolve(name:String);
}

View File

@ -0,0 +1,191 @@
/*
* 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.net;
import haxe.io.Error;
import eval.vm.NativeSocket;
private class SocketOutput extends haxe.io.Output {
var socket:NativeSocket;
public function new(socket:NativeSocket) {
this.socket = socket;
}
public override function writeByte(c:Int) {
try {
socket.sendChar(c);
} catch (e:Dynamic) {
if (e == "Blocking")
throw Blocked;
else if (e == "EOF")
throw new haxe.io.Eof();
else
throw Custom(e);
}
}
public override function writeBytes(buf:haxe.io.Bytes, pos:Int, len:Int) {
return try {
socket.send(buf, pos, len);
} catch (e:Dynamic) {
if (e == "Blocking")
throw Blocked;
else
throw Custom(e);
}
}
public override function close() {
super.close();
socket.close();
}
}
private class SocketInput extends haxe.io.Input {
var socket:NativeSocket;
public function new(socket:NativeSocket) {
this.socket = socket;
}
public override function readByte() {
return try {
socket.receiveChar();
} catch (e:Dynamic) {
if (e == "Blocking")
throw Blocked;
else
throw new haxe.io.Eof();
}
}
public override function readBytes(buf:haxe.io.Bytes, pos:Int, len:Int) {
var r;
try {
r = socket.receive(buf, pos, len);
} catch (e:Dynamic) {
if (e == "Blocking")
throw Blocked;
else
throw Custom(e);
}
if (r == 0)
throw new haxe.io.Eof();
return r;
}
public override function close() {
super.close();
socket.close();
}
}
@:coreApi
class Socket {
public var input(default, null):haxe.io.Input;
public var output(default, null):haxe.io.Output;
public var custom:Dynamic;
@:ifFeature("sys.net.Socket.select") var socket:NativeSocket;
public function new() {
init(new NativeSocket());
}
private function init(socket:NativeSocket):Void {
this.socket = socket;
input = new SocketInput(socket);
output = new SocketOutput(socket);
}
public function close():Void {
socket.close();
}
public function read():String {
return input.readAll().toString();
}
public function write(content:String):Void {
output.writeString(content);
}
public function connect(host:Host, port:Int):Void {
socket.connect(host.ip, port);
}
public function listen(connections:Int):Void {
socket.listen(connections);
}
public function shutdown(read:Bool, write:Bool):Void {
socket.shutdown(read, write);
}
public function bind(host:Host, port:Int):Void {
socket.bind(host.ip, port);
}
public function accept():Socket {
var nativeSocket = socket.accept();
var socket:Socket = Type.createEmptyInstance(Socket);
socket.init(nativeSocket);
return socket;
}
@:access(sys.net.Host.init)
public function peer():{host:Host, port:Int} {
var info = socket.peer();
var host:Host = Type.createEmptyInstance(Host);
host.init(info.ip);
return {host: host, port: info.port};
}
@:access(sys.net.Host.init)
public function host():{host:Host, port:Int} {
var info = socket.host();
var host:Host = Type.createEmptyInstance(Host);
host.init(info.ip);
return {host: host, port: info.port};
}
public function setTimeout(timeout:Float):Void {
socket.setTimeout(timeout);
}
public function waitForRead():Void {
select([this], null, null, -1);
}
public function setBlocking(b:Bool):Void {} // TODO: Don't know how to implement this...
public function setFastSend(b:Bool):Void {
socket.setFastSend(b);
}
public static function select(read:Array<Socket>, write:Array<Socket>, others:Array<Socket>,
?timeout:Float):{read:Array<Socket>, write:Array<Socket>, others:Array<Socket>} {
return NativeSocket.select(read, write, others, timeout);
}
}