This is an OSC library for the mbed, created to be compatible with Recotana\'s OSCClass library (http://recotana.com) for the Arduino with Ethernet shield. I have also used parts of the OSC Transceiver(Sender/Receiver) code by xshige. It has many limitations, but it works for simple things (check comments on the mbedOSC.h). It will be evolving. written by: Alvaro Cassinelli, 7.10.2011

Dependencies:   mbed

Committer:
mbedalvaro
Date:
Sat Oct 15 14:15:55 2011 +0000
Revision:
0:f76708a93fb3
First working test of this simple OSC library.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
mbedalvaro 0:f76708a93fb3 1
mbedalvaro 0:f76708a93fb3 2 /*
mbedalvaro 0:f76708a93fb3 3 Copyright (c) 2010 Donatien Garnier (donatiengar [at] gmail [dot] com)
mbedalvaro 0:f76708a93fb3 4
mbedalvaro 0:f76708a93fb3 5 Permission is hereby granted, free of charge, to any person obtaining a copy
mbedalvaro 0:f76708a93fb3 6 of this software and associated documentation files (the "Software"), to deal
mbedalvaro 0:f76708a93fb3 7 in the Software without restriction, including without limitation the rights
mbedalvaro 0:f76708a93fb3 8 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
mbedalvaro 0:f76708a93fb3 9 copies of the Software, and to permit persons to whom the Software is
mbedalvaro 0:f76708a93fb3 10 furnished to do so, subject to the following conditions:
mbedalvaro 0:f76708a93fb3 11
mbedalvaro 0:f76708a93fb3 12 The above copyright notice and this permission notice shall be included in
mbedalvaro 0:f76708a93fb3 13 all copies or substantial portions of the Software.
mbedalvaro 0:f76708a93fb3 14
mbedalvaro 0:f76708a93fb3 15 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
mbedalvaro 0:f76708a93fb3 16 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
mbedalvaro 0:f76708a93fb3 17 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
mbedalvaro 0:f76708a93fb3 18 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
mbedalvaro 0:f76708a93fb3 19 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
mbedalvaro 0:f76708a93fb3 20 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
mbedalvaro 0:f76708a93fb3 21 THE SOFTWARE.
mbedalvaro 0:f76708a93fb3 22 */
mbedalvaro 0:f76708a93fb3 23
mbedalvaro 0:f76708a93fb3 24 #ifndef NETIF_H
mbedalvaro 0:f76708a93fb3 25 #define NETIF_H
mbedalvaro 0:f76708a93fb3 26
mbedalvaro 0:f76708a93fb3 27 #include "core/ipaddr.h"
mbedalvaro 0:f76708a93fb3 28 /*
mbedalvaro 0:f76708a93fb3 29 #include "nettcpsocket.h"
mbedalvaro 0:f76708a93fb3 30 #include "netudpsocket.h"
mbedalvaro 0:f76708a93fb3 31 #include "netdnsrequest.h"
mbedalvaro 0:f76708a93fb3 32 */
mbedalvaro 0:f76708a93fb3 33 class NetTcpSocket;
mbedalvaro 0:f76708a93fb3 34 class NetUdpSocket;
mbedalvaro 0:f76708a93fb3 35 class NetDnsRequest;
mbedalvaro 0:f76708a93fb3 36
mbedalvaro 0:f76708a93fb3 37 #if 0
mbedalvaro 0:f76708a93fb3 38 enum NetifEvent
mbedalvaro 0:f76708a93fb3 39 {
mbedalvaro 0:f76708a93fb3 40 NETIF_CONNECTED, //Connected, can create & use sockets now
mbedalvaro 0:f76708a93fb3 41 NETIF_DNSREPLY,
mbedalvaro 0:f76708a93fb3 42 NETIF_DISCONNECTED
mbedalvaro 0:f76708a93fb3 43 };
mbedalvaro 0:f76708a93fb3 44 #endif
mbedalvaro 0:f76708a93fb3 45
mbedalvaro 0:f76708a93fb3 46 class NetIf
mbedalvaro 0:f76708a93fb3 47 {
mbedalvaro 0:f76708a93fb3 48 public:
mbedalvaro 0:f76708a93fb3 49 NetIf();
mbedalvaro 0:f76708a93fb3 50 virtual ~NetIf();
mbedalvaro 0:f76708a93fb3 51 virtual NetTcpSocket* tcpSocket() = 0; //Create a new tcp socket
mbedalvaro 0:f76708a93fb3 52 virtual NetUdpSocket* udpSocket() = 0; //Create a new udp socket
mbedalvaro 0:f76708a93fb3 53 virtual void poll() = 0;
mbedalvaro 0:f76708a93fb3 54 virtual NetDnsRequest* dnsRequest(const char* hostname) = 0; //Create a new NetDnsRequest object
mbedalvaro 0:f76708a93fb3 55 virtual NetDnsRequest* dnsRequest(Host* pHost) = 0; //Create a new NetDnsRequest object
mbedalvaro 0:f76708a93fb3 56
mbedalvaro 0:f76708a93fb3 57 //!Returns the IP of the interface once it's connected
mbedalvaro 0:f76708a93fb3 58 IpAddr getIp() const;
mbedalvaro 0:f76708a93fb3 59
mbedalvaro 0:f76708a93fb3 60 protected:
mbedalvaro 0:f76708a93fb3 61 IpAddr m_ip;
mbedalvaro 0:f76708a93fb3 62 };
mbedalvaro 0:f76708a93fb3 63
mbedalvaro 0:f76708a93fb3 64 #endif