diff options
Diffstat (limited to 'src/components/media_manager/src/streamer_listener.cc')
-rw-r--r-- | src/components/media_manager/src/streamer_listener.cc | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/src/components/media_manager/src/streamer_listener.cc b/src/components/media_manager/src/streamer_listener.cc new file mode 100644 index 0000000000..17306f486a --- /dev/null +++ b/src/components/media_manager/src/streamer_listener.cc @@ -0,0 +1,80 @@ +/* + Copyright (c) 2013, Ford Motor Company + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + + Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following + disclaimer in the documentation and/or other materials provided with the + distribution. + + Neither the name of the Ford Motor Company nor the names of its contributors + may be used to endorse or promote products derived from this software + without specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE + LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. + */ + +#include "media_manager/streamer_listener.h" +#include "media_manager/media_manager_impl.h" +#include "utils/logger.h" + +namespace media_manager { + +CREATE_LOGGERPTR_GLOBAL(logger_, "StreamerListener") + +StreamerListener::StreamerListener() + : current_application_(0) { +} + +StreamerListener::~StreamerListener() { + OnActivityEnded(current_application_); +} + +void StreamerListener::OnDataReceived( + int32_t application_key, + const DataForListener& data) { + MediaManagerImpl::instance()->FramesProcessed(application_key, data); +} + +void StreamerListener::OnErrorReceived( + int32_t application_key, + const DataForListener& data) { + LOG4CXX_ERROR(logger_, "StreamerListener::OnErrorReceived"); +} + +void StreamerListener::OnActivityStarted(int32_t application_key) { + LOG4CXX_INFO(logger_, "StreamerListener::OnActivityStarted"); + if (current_application_ == application_key) { + LOG4CXX_WARN(logger_, "Already performing activity for " + << application_key); + return; + } + current_application_ = application_key; +} + +void StreamerListener::OnActivityEnded(int32_t application_key) { + LOG4CXX_INFO(logger_, "StreamerListener::OnActivityEnded"); + if (current_application_ != application_key) { + LOG4CXX_WARN(logger_, "Already not performing activity for " + << application_key); + return; + } + current_application_ = 0; +} +} // namespace media_manager |