Fork of NetServicesMin with some warnings removed

Dependencies:   lwip-sys lwip

Fork of NetServicesMin by Hendrik Lipka

Committer:
uci1
Date:
Sat Nov 24 20:20:45 2012 +0000
Revision:
4:c8b2f969c8dd
Parent:
0:8b387bed54c2
Remove debugging printouts

Who changed what in which revision?

UserRevisionLine numberNew contents of line
hlipka 0:8b387bed54c2 1
hlipka 0:8b387bed54c2 2 /*
hlipka 0:8b387bed54c2 3 Copyright (c) 2010 Donatien Garnier (donatiengar [at] gmail [dot] com)
hlipka 0:8b387bed54c2 4
hlipka 0:8b387bed54c2 5 Permission is hereby granted, free of charge, to any person obtaining a copy
hlipka 0:8b387bed54c2 6 of this software and associated documentation files (the "Software"), to deal
hlipka 0:8b387bed54c2 7 in the Software without restriction, including without limitation the rights
hlipka 0:8b387bed54c2 8 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
hlipka 0:8b387bed54c2 9 copies of the Software, and to permit persons to whom the Software is
hlipka 0:8b387bed54c2 10 furnished to do so, subject to the following conditions:
hlipka 0:8b387bed54c2 11
hlipka 0:8b387bed54c2 12 The above copyright notice and this permission notice shall be included in
hlipka 0:8b387bed54c2 13 all copies or substantial portions of the Software.
hlipka 0:8b387bed54c2 14
hlipka 0:8b387bed54c2 15 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
hlipka 0:8b387bed54c2 16 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
hlipka 0:8b387bed54c2 17 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
hlipka 0:8b387bed54c2 18 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
hlipka 0:8b387bed54c2 19 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
hlipka 0:8b387bed54c2 20 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
hlipka 0:8b387bed54c2 21 THE SOFTWARE.
hlipka 0:8b387bed54c2 22 */
hlipka 0:8b387bed54c2 23
hlipka 0:8b387bed54c2 24 #include "netservice.h"
hlipka 0:8b387bed54c2 25 #include "net.h"
hlipka 0:8b387bed54c2 26
hlipka 0:8b387bed54c2 27 //#define __DEBUG
hlipka 0:8b387bed54c2 28 #include "dbg/dbg.h"
hlipka 0:8b387bed54c2 29
hlipka 0:8b387bed54c2 30 NetService::NetService(bool owned /*= true*/) : m_closed(false), m_removed(false), m_owned(owned)
hlipka 0:8b387bed54c2 31 {
hlipka 0:8b387bed54c2 32 NetService::lpServices().push_back(this);
hlipka 0:8b387bed54c2 33 DBG("\r\n[ + %p ] %d\r\n", (void*)this, lpServices().size());
hlipka 0:8b387bed54c2 34 }
hlipka 0:8b387bed54c2 35
hlipka 0:8b387bed54c2 36 NetService::~NetService()
hlipka 0:8b387bed54c2 37 {
hlipka 0:8b387bed54c2 38 // DBG("\r\nService removed\r\n");
hlipka 0:8b387bed54c2 39 // DBG("\r\nNow %d services running\r\n", lpServices().size()-1);
hlipka 0:8b387bed54c2 40 DBG("\r\n[ - %p ] %d\r\n", (void*)this, lpServices().size()-1);
hlipka 0:8b387bed54c2 41 if((!m_owned) || (!m_removed)) //Destructor was not called by servicesPoll()
hlipka 0:8b387bed54c2 42 {
hlipka 0:8b387bed54c2 43 if(m_owned)
hlipka 0:8b387bed54c2 44 DBG("\r\nWARN!!!Service removed in dtor!!!\r\n");
hlipka 0:8b387bed54c2 45 NetService::lpServices().remove(this);
hlipka 0:8b387bed54c2 46 }
hlipka 0:8b387bed54c2 47 }
hlipka 0:8b387bed54c2 48
hlipka 0:8b387bed54c2 49 void NetService::poll()
hlipka 0:8b387bed54c2 50 {
hlipka 0:8b387bed54c2 51
hlipka 0:8b387bed54c2 52 }
hlipka 0:8b387bed54c2 53
hlipka 0:8b387bed54c2 54 void NetService::servicesPoll() //Poll all registered services & destroy closed ones
hlipka 0:8b387bed54c2 55 {
hlipka 0:8b387bed54c2 56 list<NetService*>::iterator it;
hlipka 0:8b387bed54c2 57 DBG("\r\nServices polling over %d services\r\n", lpServices().size());
hlipka 0:8b387bed54c2 58 for( it = lpServices().begin(); it != lpServices().end(); )
hlipka 0:8b387bed54c2 59 {
hlipka 0:8b387bed54c2 60 if( (*it)->m_owned && (*it)->m_closed )
hlipka 0:8b387bed54c2 61 {
hlipka 0:8b387bed54c2 62 DBG("\r\nService %p is flagged as closed\r\n", (*it));
hlipka 0:8b387bed54c2 63 (*it)->m_removed = true;
hlipka 0:8b387bed54c2 64 delete (*it);
hlipka 0:8b387bed54c2 65 it = lpServices().erase(it);
hlipka 0:8b387bed54c2 66 }
hlipka 0:8b387bed54c2 67 else
hlipka 0:8b387bed54c2 68 {
hlipka 0:8b387bed54c2 69 //DBG("Service %p polling start\n", (*it));
hlipka 0:8b387bed54c2 70 (*it)->poll();
hlipka 0:8b387bed54c2 71 //DBG("Service %p polling end\n", (*it));
hlipka 0:8b387bed54c2 72 it++;
hlipka 0:8b387bed54c2 73 }
hlipka 0:8b387bed54c2 74 }
hlipka 0:8b387bed54c2 75
hlipka 0:8b387bed54c2 76 }
hlipka 0:8b387bed54c2 77
hlipka 0:8b387bed54c2 78 void NetService::close()
hlipka 0:8b387bed54c2 79 {
hlipka 0:8b387bed54c2 80 DBG("\r\nService %p to be closed (owned = %d)\r\n", this, m_owned);
hlipka 0:8b387bed54c2 81 m_closed = true;
hlipka 0:8b387bed54c2 82 }
hlipka 0:8b387bed54c2 83
hlipka 0:8b387bed54c2 84 list<NetService*>& NetService::lpServices()
hlipka 0:8b387bed54c2 85 {
hlipka 0:8b387bed54c2 86 static list<NetService*>* pInst = new list<NetService*>(); //Called only once
hlipka 0:8b387bed54c2 87 return *pInst;
hlipka 0:8b387bed54c2 88 }