Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
TCPSocket.h
00001 00002 /* 00003 Copyright (c) 2010 Donatien Garnier (donatiengar [at] gmail [dot] com) 00004 00005 Permission is hereby granted, free of charge, to any person obtaining a copy 00006 of this software and associated documentation files (the "Software"), to deal 00007 in the Software without restriction, including without limitation the rights 00008 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 00009 copies of the Software, and to permit persons to whom the Software is 00010 furnished to do so, subject to the following conditions: 00011 00012 The above copyright notice and this permission notice shall be included in 00013 all copies or substantial portions of the Software. 00014 00015 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 00016 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 00017 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 00018 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 00019 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 00020 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 00021 THE SOFTWARE. 00022 */ 00023 00024 /** \file 00025 TCP Socket header file 00026 */ 00027 00028 #ifndef TCPSOCKET_H 00029 #define TCPSOCKET_H 00030 00031 #include "core/net.h" 00032 #include "core/host.h" 00033 //Essentially it is a safe interface to NetTcpSocket 00034 00035 ///TCP Socket error codes 00036 enum TCPSocketErr 00037 { 00038 __TCPSOCKET_MIN = -0xFFFF, 00039 TCPSOCKET_SETUP, ///<TCPSocket not properly configured 00040 TCPSOCKET_TIMEOUT, ///<Connection timed out 00041 TCPSOCKET_IF, ///<Interface has problems, does not exist or is not initialized 00042 TCPSOCKET_MEM, ///<Not enough mem 00043 TCPSOCKET_INUSE, ///<Interface / Port is in use 00044 TCPSOCKET_EMPTY, ///<Connections queue is empty 00045 TCPSOCKET_RST, ///<Connection was reset by remote host 00046 //... 00047 TCPSOCKET_OK = 0 ///<Success 00048 }; 00049 00050 ///TCP Socket Events 00051 enum TCPSocketEvent 00052 { 00053 TCPSOCKET_CONNECTED, ///<Connected to host 00054 TCPSOCKET_ACCEPT, ///<Client is connected, must call accept() to get a new Socket 00055 TCPSOCKET_READABLE, ///<Data in buf 00056 TCPSOCKET_WRITEABLE, ///<Can write data to buf 00057 TCPSOCKET_CONTIMEOUT, ///<Connection timed out 00058 TCPSOCKET_CONRST, ///<Connection was reset by remote host 00059 TCPSOCKET_CONABRT, ///<Connection was aborted 00060 TCPSOCKET_ERROR, ///<Unknown error 00061 TCPSOCKET_DISCONNECTED ///<Disconnected 00062 }; 00063 00064 class NetTcpSocket; 00065 enum NetTcpSocketEvent; 00066 00067 ///This is a simple TCP Socket class 00068 /** 00069 This class exposes an API to deal with TCP Sockets 00070 */ 00071 class TCPSocket 00072 { 00073 public: 00074 ///Creates a new socket 00075 TCPSocket(); 00076 protected: 00077 TCPSocket(NetTcpSocket* pNetTcpSocket); 00078 public: 00079 ///Closes if needed and destroys the socket 00080 ~TCPSocket(); //close() 00081 00082 ///Binds the socket to (local) host 00083 TCPSocketErr bind(const Host& me); 00084 00085 ///Starts listening 00086 TCPSocketErr listen(); 00087 00088 ///Connects socket to host 00089 TCPSocketErr connect(const Host& host); 00090 00091 ///Accepts connection from client and gets connected socket 00092 TCPSocketErr accept(Host* pClient, TCPSocket** ppNewTcpSocket); 00093 00094 ///Sends data 00095 /* 00096 @return a negative error code or the number of bytes transmitted 00097 */ 00098 int /*if < 0 : TCPSocketErr*/ send(const char* buf, int len); 00099 00100 ///Receives data 00101 /* 00102 @return a negative error code or the number of bytes received 00103 */ 00104 int /*if < 0 : TCPSocketErr*/ recv(char* buf, int len); 00105 00106 /* TODO NTH : printf / scanf helpers that call send/recv */ 00107 00108 ///Closes socket 00109 TCPSocketErr close(); 00110 00111 //Callbacks 00112 ///Setups callback 00113 /** 00114 @param pMethod : callback function 00115 */ 00116 void setOnEvent( void (*pMethod)(TCPSocketEvent) ); 00117 00118 class CDummy; 00119 ///Setups callback 00120 /** 00121 @param pItem : instance of class on which to execute the callback method 00122 @param pMethod : callback method 00123 */ 00124 template<class T> 00125 void setOnEvent( T* pItem, void (T::*pMethod)(TCPSocketEvent) ) 00126 { 00127 m_pCbItem = (CDummy*) pItem; 00128 m_pCbMeth = (void (CDummy::*)(TCPSocketEvent)) pMethod; 00129 } 00130 00131 ///Disables callback 00132 void resetOnEvent(); 00133 00134 protected: 00135 void onNetTcpSocketEvent(NetTcpSocketEvent e); 00136 TCPSocketErr checkInst(); 00137 00138 private: 00139 NetTcpSocket* m_pNetTcpSocket; 00140 00141 CDummy* m_pCbItem; 00142 void (CDummy::*m_pCbMeth)(TCPSocketEvent); 00143 00144 void (*m_pCb)(TCPSocketEvent); 00145 00146 }; 00147 00148 #endif
Generated on Tue Jul 12 2022 15:41:49 by
 1.7.2
 1.7.2