Browse Source

initial socket support

Johann Borck 11 years ago
parent
commit
6d13aea014

+ 1 - 1
std/haxe/io/BytesData.hx

@@ -35,7 +35,7 @@ package haxe.io;
 #elseif cs
 #elseif cs
 	typedef BytesData = cs.NativeArray<cs.StdTypes.UInt8>;
 	typedef BytesData = cs.NativeArray<cs.StdTypes.UInt8>;
 #elseif python
 #elseif python
-		typedef BytesData = python.lib.Types.ByteArray;
+	typedef BytesData = python.lib.Types.ByteArray;
 #else
 #else
 	typedef BytesData = Array<Int>;
 	typedef BytesData = Array<Int>;
 #end
 #end

+ 64 - 0
std/python/_std/sys/net/Host.hx

@@ -0,0 +1,64 @@
+/*
+ * Copyright (C)2005-2012 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;
+
+/**
+	A given IP host name.
+**/
+class Host {
+
+	/**
+		The actual IP corresponding to the host.
+	**/
+	public var ip(default,null) : Int;
+
+	/**
+		Creates a new Host : the name can be an IP in the form "127.0.0.1" or an host name such as "google.com", in which case
+		the corresponding IP address is resolved using DNS. An exception occur if the host name could not be found.
+	**/
+    var name:String;
+	public function new( name : String ) : Void {
+        this.name = name;
+    }
+
+	/**
+		Returns the IP representation of the host
+	**/
+	public function toString() : String {
+        return name;
+    }
+
+	/**
+		Perform a reverse-DNS query to resolve a host name from an IP.
+	**/
+	public function reverse() : String {
+        return "";
+    }
+
+	/**
+		Returns the local computer host name
+	**/
+	public static function localhost() : String {
+        return "";
+    }
+
+}

+ 267 - 0
std/python/_std/sys/net/Socket.hx

@@ -0,0 +1,267 @@
+/*
+* Copyright (C)2005-2012 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 haxe.io.Bytes;
+import haxe.io.BytesData;
+import python.lib.Types;
+import python.lib.net.Socket in PSocket;
+import python.lib.net.Socket.Select in Select;
+import python.lib.net.Address in PAddress;
+
+private class SocketInput extends haxe.io.Input {
+    
+    var __s : PSocket;
+
+    public function new(s) {
+        __s = s;
+    }
+    
+    public override function readByte() : Int {
+        var r:BytesData;
+        try {
+            r = __s.recv(1,0);
+        } catch( e : BlockingIOError ) {
+                throw Blocked;
+        }
+        if( r.length == 0 )
+            throw new haxe.io.Eof();
+        return python.Syntax.pythonCode("r[0]");
+    }
+
+    public override function readBytes( buf : haxe.io.Bytes, pos : Int, len : Int ) : Int {
+        var r;
+        var data = buf.getData();
+        try {
+            r = __s.recv(len,0);
+            for (i in pos...(pos+r.length)){
+                data.set(i,r[i-pos]);
+            }
+        } catch( e : BlockingIOError ) {
+                throw Blocked;
+        }
+        if( r.length == 0 )
+            throw new haxe.io.Eof();
+        return r.length;
+    }
+
+    public override function close() {
+        super.close();
+        if( __s != null ) __s.close();
+    }
+    
+}
+
+private class SocketOutput extends haxe.io.Output {
+    
+    var __s : PSocket;
+
+    public function new(s) {
+        __s = s;
+    }
+
+    public override function writeByte( c : Int ) {
+        try {
+            __s.send(python.Syntax.pythonCode('bytes([c])'),0);
+        } catch( e : BlockingIOError ) {
+                throw Blocked;
+        }
+    }
+
+    public override function writeBytes( buf : haxe.io.Bytes, pos : Int, len : Int) : Int {
+        return try {
+            var data    = buf.getData();
+            var payload = python.Syntax.pythonCode("data[pos:pos+len]");
+            var r = __s.send(payload,0);
+            return r;
+        } catch( e : BlockingIOError ) {
+                throw Blocked;
+        }
+    }
+
+    public override function close() {
+        super.close();
+        if( __s != null ) __s.close();
+    }
+}
+
+/**
+    A TCP socket class : allow you to both connect to a given server and exchange messages or start your own server and wait for connections.
+**/
+@:coreApi class Socket {
+
+    
+    var __s:PSocket;
+    /**
+        The stream on which you can read available data. By default the stream is blocking until the requested data is available,
+        use [setBlocking(false)] or [setTimeout] to prevent infinite waiting.
+    **/
+    public var input(default,null) : haxe.io.Input;
+
+    /**
+        The stream on which you can send data. Please note that in case the output buffer you will block while writing the data, use [setBlocking(false)] or [setTimeout] to prevent that.
+    **/
+    public var output(default,null) : haxe.io.Output;
+
+    /**
+        A custom value that can be associated with the socket. Can be used to retreive your custom infos after a [select].
+    ***/
+    public var custom : Dynamic;
+
+    /**
+        Creates a new unconnected socket.
+    **/
+    public function new() : Void {
+        //var __s = new PSocket();
+        //input = new SocketInput(__s);
+        //output = new SocketOutput(__s);
+    }
+    
+    function __init() : Void  {
+        __s = new PSocket();
+        input = new SocketInput(__s);
+        output = new SocketOutput(__s);
+    }
+
+    /**
+        Closes the socket : make sure to properly close all your sockets or you will crash when you run out of file descriptors.
+    **/
+    public function close() : Void {
+        __s.close();
+    }
+
+    /**
+        Read the whole data available on the socket.
+    **/
+    public function read() : String {
+        return "";
+    }
+
+    /**
+        Write the whole data to the socket output.
+    **/
+    public function write( content : String ) : Void {
+        
+    }
+
+    /**
+        Connect to the given server host/port. Throw an exception in case we couldn't sucessfully connect.
+    **/
+    public function connect( host : Host, port : Int ) : Void {
+        __init();
+        var host_str = host.toString();
+        __s.connect(python.Syntax.pythonCode("(host_str,port)"));
+    }
+
+    /**
+        Allow the socket to listen for incoming questions. The parameter tells how many pending connections we can have until they get refused. Use [accept()] to accept incoming connections.
+    **/
+    public function listen( connections : Int ) : Void {
+        __s.listen(connections);
+    }
+
+    /**
+        Shutdown the socket, either for reading or writing.
+    **/
+    public function shutdown( read : Bool, write : Bool ) : Void 
+        __s.shutdown( (read && write) ? PSocket.SHUT_RDWR : read ?  PSocket.SHUT_RD : PSocket.SHUT_WR  );
+
+    /**
+        Bind the socket to the given host/port so it can afterwards listen for connections there.
+    **/
+    public function bind( host : Host, port : Int ) : Void {
+        __init();
+        var host_str = host.toString();
+        __s.bind(python.Syntax.pythonCode("(host_str,port)"));
+    }
+
+    /**
+        Accept a new connected client. This will return a connected socket on which you can read/write some data.
+    **/
+    public function accept() : Socket {
+        var tp2:Tup2<PSocket,PAddress> = __s.accept();
+        var s = new Socket();
+        s.__s = tp2._1;
+        s.input = new SocketInput(s.__s);
+        s.output = new SocketOutput(s.__s);
+        return s;
+    }
+
+    /**
+        Return the informations about the other side of a connected socket.
+    **/
+    public function peer() : { host : Host, port : Int } {
+        var pn = __s.getpeername();
+        return { host:new Host( pn._1 ), port:pn._2}
+    }
+
+    /**
+        Return the informations about our side of a connected socket.
+    **/
+    public function host() : { host : Host, port : Int } {
+        var pn = __s.getsockname();
+        return { host:new Host( pn._1 ), port:pn._2};
+    }
+
+    /**
+        Gives a timeout after which blocking socket operations (such as reading and writing) will abort and throw an exception.
+    **/
+    public function setTimeout( timeout : Float ) : Void {
+        __s.settimeout(timeout);
+    }
+
+    /**
+        Block until some data is available for read on the socket.
+    **/
+    public function waitForRead() : Void {
+        
+    }
+
+    /**
+        Change the blocking mode of the socket. A blocking socket is the default behavior. A non-blocking socket will abort blocking operations immediatly by throwing a haxe.io.Error.Blocking value.
+    **/
+    public function setBlocking( b : Bool ) : Void {
+        __s.setblocking(b);
+    }
+
+    /**
+        Allows the socket to immediatly send the data when written to its output : this will cause less ping but might increase the number of packets / data size, especially when doing a lot of small writes.
+    **/
+    public function setFastSend( b : Bool ) : Void {}
+
+    @:keep function fileno():Int return __s.fileno();
+    
+    /**
+        Wait until one of the sockets groups is ready for the given operation :
+        [read] contains sockets on which we want to wait for available data to be read,
+        [write] contains sockets on which we want to wait until we are allowed to write some data to their output buffers,
+        [others] contains sockets on which we want to wait for exceptional conditions.
+        [select] will block until one of the condition is met, in which case it will return the sockets for which the condition was true.
+        In case a [timeout] (in seconds) is specified, select might wait at worse until the timeout expires.
+    **/
+    public static function select(read : Array<Socket>, write : Array<Socket>, others : Array<Socket>, ?timeout : Float) : { read: Array<Socket>,write: Array<Socket>,others: Array<Socket> } {
+        var t3 = Select.select(read,write,others,timeout);
+        return {read:t3._1,write:t3._2,others:t3._3};
+    }
+
+}

+ 7 - 1
std/python/lib/Types.hx

@@ -34,7 +34,13 @@ extern class ByteArray implements ArrayAccess<Int> {
 	public inline function get(i:Int):Int {
 	public inline function get(i:Int):Int {
 		return python.Syntax.arrayAccess(this, i);
 		return python.Syntax.arrayAccess(this, i);
 	}
 	}
-
+	
+	public inline function set(i:Int,v:Int):Void {
+        this.__setitem__(i,v);
+    }
+    
+    public function __setitem__(i:Int,v:Int):Void;
+    
 	public function decode(encoding:String="utf-8", errors:String="strict"):String;
 	public function decode(encoding:String="utf-8", errors:String="strict"):String;
 }
 }
 
 

+ 4 - 0
std/python/lib/net/Address.hx

@@ -0,0 +1,4 @@
+
+package python.lib.net;
+
+typedef Address = python.lib.Types.Tup2<String,Int>;

+ 401 - 0
std/python/lib/net/Socket.hx

@@ -0,0 +1,401 @@
+/*
+ * Copyright (C)2005-2012 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 python.lib.net;
+
+import haxe.io.BytesData;
+import python.lib.Types;
+
+/**
+    A TCP socket class : allow you to both connect to a given server and exchange messages or start your own server and wait for connections.
+**/
+
+typedef Selectable = {
+    function fileno():Int;
+}
+
+@:native("select")
+extern class Select {
+    
+    static function __init__ ():Void
+    {
+        Syntax.importModule("select");
+    }
+    
+    static function select<T>(reads:Array<T>,writes:Array<T>,xs:Array<T>,timeout:Float):Tup3<Array<T>,Array<T>,Array<T>>;
+    
+}
+
+extern class Socket {
+    
+    static function __init__ ():Void
+    {
+        Syntax.importFromAs("socket", "socket", "python.lib.net.Socket");
+    }
+    
+    static var AF_APPLETALK:Int;
+    static var AF_ASH:Int;
+    static var AF_ATMPVC:Int;
+    static var AF_ATMSVC:Int;
+    static var AF_AX25:Int;
+    static var AF_BLUETOOTH:Int;
+    static var AF_BRIDGE:Int;
+    static var AF_CAN:Int;
+    static var AF_ECONET:Int;
+    static var AF_INET:Int;
+    static var AF_INET6:Int;
+    static var AF_IPX:Int;
+    static var AF_IRDA:Int;
+    static var AF_KEY:Int;
+    static var AF_LLC:Int;
+    static var AF_NETBEUI:Int;
+    static var AF_NETLINK:Int;
+    static var AF_NETROM:Int;
+    static var AF_PACKET:Int;
+    static var AF_PPPOX:Int;
+    static var AF_RDS:Int;
+    static var AF_ROSE:Int;
+    static var AF_ROUTE:Int;
+    static var AF_SECURITY:Int;
+    static var AF_SNA:Int;
+    static var AF_TIPC:Int;
+    static var AF_UNIX:Int;
+    static var AF_UNSPEC:Int;
+    static var AF_WANPIPE:Int;
+    static var AF_X25:Int;
+    static var AI_ADDRCONFIG:Int;
+    static var AI_ALL:Int;
+    static var AI_CANONNAME:Int;
+    static var AI_NUMERICHOST:Int;
+    static var AI_NUMERICSERV:Int;
+    static var AI_PASSIVE:Int;
+    static var AI_V4MAPPED:Int;
+    static var BDADDR_ANY:Int;
+    static var BDADDR_LOCAL:Int;
+    static var BTPROTO_HCI:Int;
+    static var BTPROTO_L2CAP:Int;
+    static var BTPROTO_RFCOMM:Int;
+    static var BTPROTO_SCO:Int;
+    static var CAN_EFF_FLAG:Int;
+    static var CAN_EFF_MASK:Int;
+    static var CAN_ERR_FLAG:Int;
+    static var CAN_ERR_MASK:Int;
+    static var CAN_RAW:Int;
+    static var CAN_RAW_ERR_FILTER:Int;
+    static var CAN_RAW_FILTER:Int;
+    static var CAN_RAW_LOOPBACK:Int;
+    static var CAN_RAW_RECV_OWN_MSGS:Int;
+    static var CAN_RTR_FLAG:Int;
+    static var CAN_SFF_MASK:Int;
+    static var CAPI:Int;
+    static var CMSG_LEN:Int;
+    static var CMSG_SPACE:Int;
+    static var EAGAIN:Int;
+    static var EAI_ADDRFAMILY:Int;
+    static var EAI_AGAIN:Int;
+    static var EAI_BADFLAGS:Int;
+    static var EAI_FAIL:Int;
+    static var EAI_FAMILY:Int;
+    static var EAI_MEMORY:Int;
+    static var EAI_NODATA:Int;
+    static var EAI_NONAME:Int;
+    static var EAI_OVERFLOW:Int;
+    static var EAI_SERVICE:Int;
+    static var EAI_SOCKTYPE:Int;
+    static var EAI_SYSTEM:Int;
+    static var EBADF:Int;
+    static var EWOULDBLOCK:Int;
+    static var HCI_DATA_DIR:Int;
+    static var HCI_FILTER:Int;
+    static var HCI_TIME_STAMP:Int;
+    static var INADDR_ALLHOSTS_GROUP:Int;
+    static var INADDR_ANY:Int;
+    static var INADDR_BROADCAST:Int;
+    static var INADDR_LOOPBACK:Int;
+    static var INADDR_MAX_LOCAL_GROUP:Int;
+    static var INADDR_NONE:Int;
+    static var INADDR_UNSPEC_GROUP:Int;
+    static var IPPORT_RESERVED:Int;
+    static var IPPORT_USERRESERVED:Int;
+    static var IPPROTO_AH:Int;
+    static var IPPROTO_DSTOPTS:Int;
+    static var IPPROTO_EGP:Int;
+    static var IPPROTO_ESP:Int;
+    static var IPPROTO_FRAGMENT:Int;
+    static var IPPROTO_GRE:Int;
+    static var IPPROTO_HOPOPTS:Int;
+    static var IPPROTO_ICMP:Int;
+    static var IPPROTO_ICMPV6:Int;
+    static var IPPROTO_IDP:Int;
+    static var IPPROTO_IGMP:Int;
+    static var IPPROTO_IP:Int;
+    static var IPPROTO_IPIP:Int;
+    static var IPPROTO_IPV6:Int;
+    static var IPPROTO_NONE:Int;
+    static var IPPROTO_PIM:Int;
+    static var IPPROTO_PUP:Int;
+    static var IPPROTO_RAW:Int;
+    static var IPPROTO_ROUTING:Int;
+    static var IPPROTO_RSVP:Int;
+    static var IPPROTO_SCTP:Int;
+    static var IPPROTO_TCP:Int;
+    static var IPPROTO_TP:Int;
+    static var IPPROTO_UDP:Int;
+    static var IPV6_CHECKSUM:Int;
+    static var IPV6_DSTOPTS:Int;
+    static var IPV6_HOPLIMIT:Int;
+    static var IPV6_HOPOPTS:Int;
+    static var IPV6_JOIN_GROUP:Int;
+    static var IPV6_LEAVE_GROUP:Int;
+    static var IPV6_MULTICAST_HOPS:Int;
+    static var IPV6_MULTICAST_IF:Int;
+    static var IPV6_MULTICAST_LOOP:Int;
+    static var IPV6_NEXTHOP:Int;
+    static var IPV6_PKTINFO:Int;
+    static var IPV6_RECVDSTOPTS:Int;
+    static var IPV6_RECVHOPLIMIT:Int;
+    static var IPV6_RECVHOPOPTS:Int;
+    static var IPV6_RECVPKTINFO:Int;
+    static var IPV6_RECVRTHDR:Int;
+    static var IPV6_RECVTCLASS:Int;
+    static var IPV6_RTHDR:Int;
+    static var IPV6_RTHDRDSTOPTS:Int;
+    static var IPV6_RTHDR_TYPE_0:Int;
+    static var IPV6_TCLASS:Int;
+    static var IPV6_UNICAST_HOPS:Int;
+    static var IPV6_V6ONLY:Int;
+    static var IP_ADD_MEMBERSHIP:Int;
+    static var IP_DEFAULT_MULTICAST_LOOP:Int;
+    static var IP_DEFAULT_MULTICAST_TTL:Int;
+    static var IP_DROP_MEMBERSHIP:Int;
+    static var IP_HDRINCL:Int;
+    static var IP_MAX_MEMBERSHIPS:Int;
+    static var IP_MULTICAST_IF:Int;
+    static var IP_MULTICAST_LOOP:Int;
+    static var IP_MULTICAST_TTL:Int;
+    static var IP_OPTIONS:Int;
+    static var IP_RECVOPTS:Int;
+    static var IP_RECVRETOPTS:Int;
+    static var IP_RETOPTS:Int;
+    static var IP_TOS:Int;
+    static var IP_TRANSPARENT:Int;
+    static var IP_TTL:Int;
+    static var MSG_CMSG_CLOEXEC:Int;
+    static var MSG_CONFIRM:Int;
+    static var MSG_CTRUNC:Int;
+    static var MSG_DONTROUTE:Int;
+    static var MSG_DONTWAIT:Int;
+    static var MSG_EOR:Int;
+    static var MSG_ERRQUEUE:Int;
+    static var MSG_MORE:Int;
+    static var MSG_NOSIGNAL:Int;
+    static var MSG_OOB:Int;
+    static var MSG_PEEK:Int;
+    static var MSG_TRUNC:Int;
+    static var MSG_WAITALL:Int;
+    static var NETLINK_DNRTMSG:Int;
+    static var NETLINK_FIREWALL:Int;
+    static var NETLINK_IP6_FW:Int;
+    static var NETLINK_NFLOG:Int;
+    static var NETLINK_ROUTE:Int;
+    static var NETLINK_USERSOCK:Int;
+    static var NETLINK_XFRM:Int;
+    static var NI_DGRAM:Int;
+    static var NI_MAXHOST:Int;
+    static var NI_MAXSERV:Int;
+    static var NI_NAMEREQD:Int;
+    static var NI_NOFQDN:Int;
+    static var NI_NUMERICHOST:Int;
+    static var NI_NUMERICSERV:Int;
+    static var PACKET_BROADCAST:Int;
+    static var PACKET_FASTROUTE:Int;
+    static var PACKET_HOST:Int;
+    static var PACKET_LOOPBACK:Int;
+    static var PACKET_MULTICAST:Int;
+    static var PACKET_OTHERHOST:Int;
+    static var PACKET_OUTGOING:Int;
+    static var PF_CAN:Int;
+    static var PF_PACKET:Int;
+    static var PF_RDS:Int;
+    static var SCM_CREDENTIALS:Int;
+    static var SCM_RIGHTS:Int;
+    static var SHUT_RD:Int;
+    static var SHUT_RDWR:Int;
+    static var SHUT_WR:Int;
+    static var SOCK_CLOEXEC:Int;
+    static var SOCK_DGRAM:Int;
+    static var SOCK_NONBLOCK:Int;
+    static var SOCK_RAW:Int;
+    static var SOCK_RDM:Int;
+    static var SOCK_SEQPACKET:Int;
+    static var SOCK_STREAM:Int;
+    static var SOL_CAN_BASE:Int;
+    static var SOL_CAN_RAW:Int;
+    static var SOL_HCI:Int;
+    static var SOL_IP:Int;
+    static var SOL_SOCKET:Int;
+    static var SOL_TCP:Int;
+    static var SOL_TIPC:Int;
+    static var SOL_UDP:Int;
+    static var SOMAXCONN:Int;
+    static var SO_ACCEPTCONN:Int;
+    static var SO_BINDTODEVICE:Int;
+    static var SO_BROADCAST:Int;
+    static var SO_DEBUG:Int;
+    static var SO_DONTROUTE:Int;
+    static var SO_ERROR:Int;
+    static var SO_KEEPALIVE:Int;
+    static var SO_LINGER:Int;
+    static var SO_OOBINLINE:Int;
+    static var SO_PASSCRED:Int;
+    static var SO_PEERCRED:Int;
+    static var SO_RCVBUF:Int;
+    static var SO_RCVLOWAT:Int;
+    static var SO_RCVTIMEO:Int;
+    static var SO_REUSEADDR:Int;
+    static var SO_REUSEPORT:Int;
+    static var SO_SNDBUF:Int;
+    static var SO_SNDLOWAT:Int;
+    static var SO_SNDTIMEO:Int;
+    static var SO_TYPE:Int;
+    static var TCP_CORK:Int;
+    static var TCP_DEFER_ACCEPT:Int;
+    static var TCP_INFO:Int;
+    static var TCP_KEEPCNT:Int;
+    static var TCP_KEEPIDLE:Int;
+    static var TCP_KEEPINTVL:Int;
+    static var TCP_LINGER2:Int;
+    static var TCP_MAXSEG:Int;
+    static var TCP_NODELAY:Int;
+    static var TCP_QUICKACK:Int;
+    static var TCP_SYNCNT:Int;
+    static var TCP_WINDOW_CLAMP:Int;
+    static var TIPC_ADDR_ID:Int;
+    static var TIPC_ADDR_NAME:Int;
+    static var TIPC_ADDR_NAMESEQ:Int;
+    static var TIPC_CFG_SRV:Int;
+    static var TIPC_CLUSTER_SCOPE:Int;
+    static var TIPC_CONN_TIMEOUT:Int;
+    static var TIPC_CRITICAL_IMPORTANCE:Int;
+    static var TIPC_DEST_DROPPABLE:Int;
+    static var TIPC_HIGH_IMPORTANCE:Int;
+    static var TIPC_IMPORTANCE:Int;
+    static var TIPC_LOW_IMPORTANCE:Int;
+    static var TIPC_MEDIUM_IMPORTANCE:Int;
+    static var TIPC_NODE_SCOPE:Int;
+    static var TIPC_PUBLISHED:Int;
+    static var TIPC_SRC_DROPPABLE:Int;
+    static var TIPC_SUBSCR_TIMEOUT:Int;
+    static var TIPC_SUB_CANCEL:Int;
+    static var TIPC_SUB_PORTS:Int;
+    static var TIPC_SUB_SERVICE:Int;
+    static var TIPC_TOP_SRV:Int;
+    static var TIPC_WAIT_FOREVER:Int;
+    static var TIPC_WITHDRAWN:Int;
+    static var TIPC_ZONE_SCOPE:Int;
+    static var _GLOBAL_DEFAULT_TIMEOUT:Int;
+    
+    function send(d:BytesData,flags:Int):Int;
+    function recv(n:Int,flags:Int):BytesData;
+    
+    
+    
+    /**
+        Creates a new unconnected socket.
+    **/
+    function new() : Void;
+
+    /**
+        Closes the socket : make sure to properly close all your sockets or you will crash when you run out of file descriptors.
+    **/
+    function close() : Void;
+
+    /**
+        Connect to the given server host/port. Throw an exception in case we couldn't sucessfully connect.
+    **/
+    function connect( addr : python.lib.net.Address ) : Void;
+
+    //function create_connection() : 
+    
+    /**
+        Allow the socket to listen for incoming questions. The parameter tells how many pending connections we can have until they get refused. Use [accept()] to accept incoming connections.
+    **/
+    function listen( connections : Int ) : Void;
+
+    /**
+        Shutdown the socket, either for reading or writing.
+    **/
+    function shutdown( how :Int ) : Void;
+
+    /**
+        Bind the socket to the given host/port so it can afterwards listen for connections there.
+    **/
+    function bind( address : python.lib.net.Address ) : Void;
+
+    /**
+        Accept a new connected client. This will return a connected socket on which you can read/write some data.
+    **/
+    function accept() : Tup2<Socket,Address>;
+
+    /**
+        Return the informations about the other side of a connected socket.
+    **/
+    function getpeername() : python.lib.net.Address;
+
+    /**
+        Return the informations about our side of a connected socket.
+    **/
+    function getsockname() : python.lib.net.Address;
+
+    /**
+        Gives a timeout after which blocking socket operations (such as reading and writing) will abort and throw an exception.
+    **/
+    function settimeout( timeout : Float ) : Void;
+
+    /**
+        Block until some data is available for read on the socket.
+    **/
+    function waitForRead() : Void;
+
+    /**
+        Change the blocking mode of the socket. A blocking socket is the default behavior. A non-blocking socket will abort blocking operations immediatly by throwing a haxe.io.Error.Blocking value.
+    **/
+    function setblocking( b : Bool ) : Void;
+
+    /**
+        
+    **/
+    function setsockopt( family:Int, option:Int, value : Bool ) : Void;
+
+    
+    function fileno():Int;
+    
+    /**
+        Wait until one of the sockets groups is ready for the given operation :
+        [read] contains sockets on which we want to wait for available data to be read,
+        [write] contains sockets on which we want to wait until we are allowed to write some data to their output buffers,
+        [others] contains sockets on which we want to wait for exceptional conditions.
+        [select] will block until one of the condition is met, in which case it will return the sockets for which the condition was true.
+        In case a [timeout] (in seconds) is specified, select might wait at worse until the timeout expires.
+    **/
+    //static function select(read : Array<Socket>, write : Array<Socket>, others : Array<Socket>, ?timeout : Float) : { read: Array<Socket>,write: Array<Socket>,others: Array<Socket> };
+
+}