mbedConnectorInterface back port from mbedOS v3 using mbed-client C++ call interface
source/ThreadedResourceObserver.cpp
- Committer:
- ansond
- Date:
- 2016-06-08
- Revision:
- 13:9edad7677211
- Parent:
- 0:1f1f55e73248
- Child:
- 16:dffa38c3340f
File content as of revision 13:9edad7677211:
/** * @file ThreadedResourceObserver.cpp * @brief mbed CoAP DynamicResource Thread-based observer (implementation) * @author Doug Anson/Chris Paola * @version 1.0 * @see * * Copyright (c) 2014 * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include "ThreadedResourceObserver.h" #ifdef CONNECTOR_USING_THREADS // DEBUG //DigitalOut __threaded_led(LED2); #endif // constructor ThreadedResourceObserver::ThreadedResourceObserver(DynamicResource *resource,int sleep_time) : ResourceObserver(resource,sleep_time) #ifdef CONNECTOR_USING_THREADS ,m_observation_thread(&ThreadedResourceObserver::_observation_notifier,this) #endif { this->setObserving(false); // DEBUG std::printf("ThreadedResourceObserver being used for %s (sleep_time=%d)\r\n",resource->getFullName().c_str(),sleep_time); } // destructor ThreadedResourceObserver::~ThreadedResourceObserver() { this->stopObservation(); #ifdef CONNECTOR_USING_THREADS this->m_observation_thread.terminate(); #endif } // notifier void ThreadedResourceObserver::_observation_notifier(void const *instance) { #ifdef CONNECTOR_USING_THREADS ThreadedResourceObserver *me = (ThreadedResourceObserver *)instance; while(true) { Thread::wait(me->getSleepTime()); if (me->isObserving() == true && me->getResource() != NULL && me->getResource()->isConnected() == true) { // // implementsObservation(): This switch denotes whether this threaded resource generates its own observations or relies on the heartbeat (time-based) mechanism. // -- if resource itself doesn't implement it, then we can call notify() with the get() on each heartbeat of the threaded resource (see note below) // -- otherwise, we let the resource itself call observe() as part of its observation implementation // // note: this is independent of whether the resource, when declared, is defined as an observable resource or not. If not, then notify() wont be called // as there will be no observations for this resource regardless of this switch value. // bool do_notify = !(me->getResource()->implementsObservation()); me->getResource()->observe(); //__threaded_led = !__threaded_led; } } #endif } // begin observing... void ThreadedResourceObserver::beginObservation() { this->setObserving(true); } // stop observing... void ThreadedResourceObserver::stopObservation() { this->setObserving(false); }