cec: simplified AddLog() method
[deb_libcec.git] / src / lib / implementations / ANCommandHandler.cpp
CommitLineData
e9de9629
LOK
1/*
2 * This file is part of the libCEC(R) library.
3 *
4 * libCEC(R) is Copyright (C) 2011 Pulse-Eight Limited. All rights reserved.
5 * libCEC(R) is an original work, containing original code.
6 *
7 * libCEC(R) is a trademark of Pulse-Eight Limited.
8 *
9 * This program is dual-licensed; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
22 *
23 *
24 * Alternatively, you can license this library under a commercial license,
25 * please contact Pulse-Eight Licensing for more information.
26 *
27 * For more information contact:
28 * Pulse-Eight Licensing <license@pulse-eight.com>
29 * http://www.pulse-eight.com/
30 * http://www.pulse-eight.net/
31 */
32
33#include "ANCommandHandler.h"
eafa9d46 34#include "../devices/CECBusDevice.h"
387b6f6f 35#include "../CECProcessor.h"
5477a250 36#include "../LibCEC.h"
e9de9629
LOK
37
38using namespace CEC;
39
40CANCommandHandler::CANCommandHandler(CCECBusDevice *busDevice) :
41 CCECCommandHandler(busDevice)
42{
ff684fef 43 m_vendorId = CEC_VENDOR_SAMSUNG;
0c2a43e0 44 m_bOPTSendDeckStatusUpdateOnActiveSource = false;
e9de9629
LOK
45}
46
47bool CANCommandHandler::HandleVendorRemoteButtonDown(const cec_command &command)
48{
5f316715 49 if (m_processor->IsStarted() && command.parameters.size > 0)
e9de9629 50 {
95ba7a09
LOK
51 cec_keypress key;
52 key.duration = CEC_BUTTON_TIMEOUT;
53 key.keycode = CEC_USER_CONTROL_CODE_UNKNOWN;
e9de9629 54
e9de9629
LOK
55 switch (command.parameters[0])
56 {
57 case CEC_AN_USER_CONTROL_CODE_RETURN:
95ba7a09 58 key.keycode = CEC_USER_CONTROL_CODE_EXIT;
e9de9629
LOK
59 break;
60 default:
61 break;
62 }
63
95ba7a09 64 if (key.keycode != CEC_USER_CONTROL_CODE_UNKNOWN)
e9de9629 65 {
5477a250 66 CLibCEC::AddLog(CEC_LOG_DEBUG, "key pressed: %1x", key.keycode);
95ba7a09 67 m_busDevice->GetProcessor()->AddKey(key);
e9de9629
LOK
68 }
69 }
70
71 return true;
72}
73
74bool CANCommandHandler::HandleCommand(const cec_command &command)
75{
387b6f6f 76 bool bHandled(false);
f8513317 77 if (m_busDevice->MyLogicalAddressContains(command.destination))
e9de9629
LOK
78 {
79 switch(command.opcode)
80 {
81 case CEC_OPCODE_VENDOR_REMOTE_BUTTON_DOWN:
387b6f6f 82 bHandled = true;
e9de9629
LOK
83 HandleVendorRemoteButtonDown(command);
84 break;
85 case CEC_OPCODE_VENDOR_REMOTE_BUTTON_UP:
387b6f6f 86 bHandled = true;
e9de9629
LOK
87 HandleUserControlRelease(command);
88 break;
89 default:
e9de9629
LOK
90 break;
91 }
92 }
93
94 if (!bHandled)
95 bHandled = CCECCommandHandler::HandleCommand(command);
96
97 return bHandled;
98}