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);
 }