Committer:
zoot661
Date:
Tue May 29 09:49:18 2012 +0000
Revision:
0:f993b6d8b1d8

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
zoot661 0:f993b6d8b1d8 1
zoot661 0:f993b6d8b1d8 2 /*
zoot661 0:f993b6d8b1d8 3 Copyright (c) 2010 Donatien Garnier (donatiengar [at] gmail [dot] com)
zoot661 0:f993b6d8b1d8 4
zoot661 0:f993b6d8b1d8 5 Permission is hereby granted, free of charge, to any person obtaining a copy
zoot661 0:f993b6d8b1d8 6 of this software and associated documentation files (the "Software"), to deal
zoot661 0:f993b6d8b1d8 7 in the Software without restriction, including without limitation the rights
zoot661 0:f993b6d8b1d8 8 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
zoot661 0:f993b6d8b1d8 9 copies of the Software, and to permit persons to whom the Software is
zoot661 0:f993b6d8b1d8 10 furnished to do so, subject to the following conditions:
zoot661 0:f993b6d8b1d8 11
zoot661 0:f993b6d8b1d8 12 The above copyright notice and this permission notice shall be included in
zoot661 0:f993b6d8b1d8 13 all copies or substantial portions of the Software.
zoot661 0:f993b6d8b1d8 14
zoot661 0:f993b6d8b1d8 15 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
zoot661 0:f993b6d8b1d8 16 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
zoot661 0:f993b6d8b1d8 17 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
zoot661 0:f993b6d8b1d8 18 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
zoot661 0:f993b6d8b1d8 19 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
zoot661 0:f993b6d8b1d8 20 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
zoot661 0:f993b6d8b1d8 21 THE SOFTWARE.
zoot661 0:f993b6d8b1d8 22 */
zoot661 0:f993b6d8b1d8 23
zoot661 0:f993b6d8b1d8 24 #ifndef NETUDPSOCKET_H
zoot661 0:f993b6d8b1d8 25 #define NETUDPSOCKET_H
zoot661 0:f993b6d8b1d8 26
zoot661 0:f993b6d8b1d8 27 #include "net.h"
zoot661 0:f993b6d8b1d8 28 #include "host.h"
zoot661 0:f993b6d8b1d8 29
zoot661 0:f993b6d8b1d8 30 #include <queue>
zoot661 0:f993b6d8b1d8 31 using std::queue;
zoot661 0:f993b6d8b1d8 32
zoot661 0:f993b6d8b1d8 33 //Implements a Berkeley-like socket if
zoot661 0:f993b6d8b1d8 34 //Can be interfaced either to lwip or a Telit module
zoot661 0:f993b6d8b1d8 35
zoot661 0:f993b6d8b1d8 36 enum NetUdpSocketErr
zoot661 0:f993b6d8b1d8 37 {
zoot661 0:f993b6d8b1d8 38 __NETUDPSOCKET_MIN = -0xFFFF,
zoot661 0:f993b6d8b1d8 39 NETUDPSOCKET_SETUP, //NetUdpSocket not properly configured
zoot661 0:f993b6d8b1d8 40 NETUDPSOCKET_IF, //If has problems
zoot661 0:f993b6d8b1d8 41 NETUDPSOCKET_MEM, //Not enough mem
zoot661 0:f993b6d8b1d8 42 NETUDPSOCKET_INUSE, //If/Port is in use
zoot661 0:f993b6d8b1d8 43 //...
zoot661 0:f993b6d8b1d8 44 NETUDPSOCKET_OK = 0
zoot661 0:f993b6d8b1d8 45 };
zoot661 0:f993b6d8b1d8 46
zoot661 0:f993b6d8b1d8 47 enum NetUdpSocketEvent //Only one lonely event here... but who knows, maybe some day there'll be another one!
zoot661 0:f993b6d8b1d8 48 {
zoot661 0:f993b6d8b1d8 49 NETUDPSOCKET_READABLE, //Data in buf
zoot661 0:f993b6d8b1d8 50 };
zoot661 0:f993b6d8b1d8 51
zoot661 0:f993b6d8b1d8 52
zoot661 0:f993b6d8b1d8 53 class NetUdpSocket
zoot661 0:f993b6d8b1d8 54 {
zoot661 0:f993b6d8b1d8 55 public:
zoot661 0:f993b6d8b1d8 56 NetUdpSocket();
zoot661 0:f993b6d8b1d8 57 virtual ~NetUdpSocket(); //close()
zoot661 0:f993b6d8b1d8 58
zoot661 0:f993b6d8b1d8 59 virtual NetUdpSocketErr bind(const Host& me) = 0;
zoot661 0:f993b6d8b1d8 60
zoot661 0:f993b6d8b1d8 61 virtual int /*if < 0 : NetUdpSocketErr*/ sendto(const char* buf, int len, Host* pHost) = 0;
zoot661 0:f993b6d8b1d8 62 virtual int /*if < 0 : NetUdpSocketErr*/ recvfrom(char* buf, int len, Host* pHost) = 0;
zoot661 0:f993b6d8b1d8 63
zoot661 0:f993b6d8b1d8 64 /* TODO NTH : printf / scanf helpers that call send/recv */
zoot661 0:f993b6d8b1d8 65
zoot661 0:f993b6d8b1d8 66 virtual NetUdpSocketErr close() = 0;
zoot661 0:f993b6d8b1d8 67
zoot661 0:f993b6d8b1d8 68 virtual NetUdpSocketErr poll() = 0;
zoot661 0:f993b6d8b1d8 69
zoot661 0:f993b6d8b1d8 70 class CDummy;
zoot661 0:f993b6d8b1d8 71 //Callbacks
zoot661 0:f993b6d8b1d8 72 template<class T>
zoot661 0:f993b6d8b1d8 73 //Linker bug : Must be defined here :(
zoot661 0:f993b6d8b1d8 74 void setOnEvent( T* pItem, void (T::*pMethod)(NetUdpSocketEvent) )
zoot661 0:f993b6d8b1d8 75 {
zoot661 0:f993b6d8b1d8 76 m_pCbItem = (CDummy*) pItem;
zoot661 0:f993b6d8b1d8 77 m_pCbMeth = (void (CDummy::*)(NetUdpSocketEvent)) pMethod;
zoot661 0:f993b6d8b1d8 78 }
zoot661 0:f993b6d8b1d8 79
zoot661 0:f993b6d8b1d8 80 void resetOnEvent(); //Disable callback
zoot661 0:f993b6d8b1d8 81
zoot661 0:f993b6d8b1d8 82 protected:
zoot661 0:f993b6d8b1d8 83 void queueEvent(NetUdpSocketEvent e);
zoot661 0:f993b6d8b1d8 84 void discardEvents();
zoot661 0:f993b6d8b1d8 85 void flushEvents(); //to be called during polling
zoot661 0:f993b6d8b1d8 86
zoot661 0:f993b6d8b1d8 87 Host m_host;
zoot661 0:f993b6d8b1d8 88 Host m_client;
zoot661 0:f993b6d8b1d8 89
zoot661 0:f993b6d8b1d8 90 friend class Net;
zoot661 0:f993b6d8b1d8 91 int m_refs;
zoot661 0:f993b6d8b1d8 92
zoot661 0:f993b6d8b1d8 93 bool m_closed;
zoot661 0:f993b6d8b1d8 94 bool m_removed;
zoot661 0:f993b6d8b1d8 95
zoot661 0:f993b6d8b1d8 96 private:
zoot661 0:f993b6d8b1d8 97 //We do not want to execute user code in interrupt routines, so we queue events until the server is polled
zoot661 0:f993b6d8b1d8 98 //If we port this to a multithreaded OS, we could avoid this (however some functions here are not thread-safe, so beware ;) )
zoot661 0:f993b6d8b1d8 99 void onEvent(NetUdpSocketEvent e); //To be called on poll
zoot661 0:f993b6d8b1d8 100 CDummy* m_pCbItem;
zoot661 0:f993b6d8b1d8 101 void (CDummy::*m_pCbMeth)(NetUdpSocketEvent);
zoot661 0:f993b6d8b1d8 102 queue<NetUdpSocketEvent> m_events;
zoot661 0:f993b6d8b1d8 103
zoot661 0:f993b6d8b1d8 104 };
zoot661 0:f993b6d8b1d8 105
zoot661 0:f993b6d8b1d8 106 #endif