for EthernetInterface library compatibility.\\ ** Unoffical fix. may be a problem. **

Dependents:   SNIC-httpclient-example SNIC-ntpclient-example

Fork of SNICInterface by muRata

Committer:
kishino
Date:
Thu Mar 13 03:38:25 2014 +0000
Revision:
4:99cc93fe7d88
Child:
14:54378c96d285
Commit stub of socket  class

Who changed what in which revision?

UserRevisionLine numberNew contents of line
kishino 4:99cc93fe7d88 1 /* Copyright (C) 2012 mbed.org, MIT License
kishino 4:99cc93fe7d88 2 *
kishino 4:99cc93fe7d88 3 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
kishino 4:99cc93fe7d88 4 * and associated documentation files (the "Software"), to deal in the Software without restriction,
kishino 4:99cc93fe7d88 5 * including without limitation the rights to use, copy, modify, merge, publish, distribute,
kishino 4:99cc93fe7d88 6 * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
kishino 4:99cc93fe7d88 7 * furnished to do so, subject to the following conditions:
kishino 4:99cc93fe7d88 8 *
kishino 4:99cc93fe7d88 9 * The above copyright notice and this permission notice shall be included in all copies or
kishino 4:99cc93fe7d88 10 * substantial portions of the Software.
kishino 4:99cc93fe7d88 11 *
kishino 4:99cc93fe7d88 12 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
kishino 4:99cc93fe7d88 13 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
kishino 4:99cc93fe7d88 14 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
kishino 4:99cc93fe7d88 15 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
kishino 4:99cc93fe7d88 16 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
kishino 4:99cc93fe7d88 17 */
kishino 4:99cc93fe7d88 18
kishino 4:99cc93fe7d88 19 #ifndef UDPSOCKET_H
kishino 4:99cc93fe7d88 20 #define UDPSOCKET_H
kishino 4:99cc93fe7d88 21
kishino 4:99cc93fe7d88 22 #include "Socket.h"
kishino 4:99cc93fe7d88 23 #include "Endpoint.h"
kishino 4:99cc93fe7d88 24
kishino 4:99cc93fe7d88 25 namespace murata_wifi
kishino 4:99cc93fe7d88 26 {
kishino 4:99cc93fe7d88 27
kishino 4:99cc93fe7d88 28 /**
kishino 4:99cc93fe7d88 29 UDP Socket
kishino 4:99cc93fe7d88 30 */
kishino 4:99cc93fe7d88 31 class UDPSocket : public Socket {
kishino 4:99cc93fe7d88 32
kishino 4:99cc93fe7d88 33 public:
kishino 4:99cc93fe7d88 34 /** Instantiate an UDP Socket.
kishino 4:99cc93fe7d88 35 */
kishino 4:99cc93fe7d88 36 UDPSocket();
kishino 4:99cc93fe7d88 37
kishino 4:99cc93fe7d88 38 /** Init the UDP Client Socket without binding it to any specific port
kishino 4:99cc93fe7d88 39 \return 0 on success, -1 on failure.
kishino 4:99cc93fe7d88 40 */
kishino 4:99cc93fe7d88 41 int init(void);
kishino 4:99cc93fe7d88 42
kishino 4:99cc93fe7d88 43 /** Bind a UDP Server Socket to a specific port
kishino 4:99cc93fe7d88 44 \param port The port to listen for incoming connections on
kishino 4:99cc93fe7d88 45 \return 0 on success, -1 on failure.
kishino 4:99cc93fe7d88 46 */
kishino 4:99cc93fe7d88 47 int bind(int port);
kishino 4:99cc93fe7d88 48
kishino 4:99cc93fe7d88 49 /** Send a packet to a remote endpoint
kishino 4:99cc93fe7d88 50 \param remote The remote endpoint
kishino 4:99cc93fe7d88 51 \param packet The packet to be sent
kishino 4:99cc93fe7d88 52 \param length The length of the packet to be sent
kishino 4:99cc93fe7d88 53 \return the number of written bytes on success (>=0) or -1 on failure
kishino 4:99cc93fe7d88 54 */
kishino 4:99cc93fe7d88 55 int sendTo(Endpoint &remote, char *packet, int length);
kishino 4:99cc93fe7d88 56
kishino 4:99cc93fe7d88 57 /** Receive a packet from a remote endpoint
kishino 4:99cc93fe7d88 58 \param remote The remote endpoint
kishino 4:99cc93fe7d88 59 \param buffer The buffer for storing the incoming packet data. If a packet
kishino 4:99cc93fe7d88 60 is too long to fit in the supplied buffer, excess bytes are discarded
kishino 4:99cc93fe7d88 61 \param length The length of the buffer
kishino 4:99cc93fe7d88 62 \return the number of received bytes on success (>=0) or -1 on failure
kishino 4:99cc93fe7d88 63 */
kishino 4:99cc93fe7d88 64 int receiveFrom(Endpoint &remote, char *buffer, int length);
kishino 4:99cc93fe7d88 65 };
kishino 4:99cc93fe7d88 66 }
kishino 4:99cc93fe7d88 67
kishino 4:99cc93fe7d88 68 #endif