-#pragma once
/*
* This file is part of the libCEC(R) library.
*
*/
#include "ANCommandHandler.h"
-#include "CECBusDevice.h"
-#include "CECProcessor.h"
-#include "util/StdString.h"
+#include "../devices/CECBusDevice.h"
+#include "../CECProcessor.h"
+#include "../util/StdString.h"
using namespace CEC;
{
if (command.parameters.size > 0)
{
- m_busDevice->GetProcessor()->AddKey();
+ cec_keypress key;
+ key.duration = CEC_BUTTON_TIMEOUT;
+ key.keycode = CEC_USER_CONTROL_CODE_UNKNOWN;
- uint8_t iButton = 0;
switch (command.parameters[0])
{
case CEC_AN_USER_CONTROL_CODE_RETURN:
- iButton = CEC_USER_CONTROL_CODE_PREVIOUS_CHANNEL;
+ key.keycode = CEC_USER_CONTROL_CODE_EXIT;
break;
default:
break;
}
- if (iButton > 0 && iButton <= CEC_USER_CONTROL_CODE_MAX)
+ if (key.keycode != CEC_USER_CONTROL_CODE_UNKNOWN)
{
CStdString strLog;
- strLog.Format("key pressed: %1x", iButton);
+ strLog.Format("key pressed: %1x", key.keycode);
m_busDevice->AddLog(CEC_LOG_DEBUG, strLog);
- m_busDevice->GetProcessor()->SetCurrentButton((cec_user_control_code) command.parameters[0]);
+ m_busDevice->GetProcessor()->AddKey(key);
}
}
bool CANCommandHandler::HandleCommand(const cec_command &command)
{
- bool bHandled(true);
- if (command.destination == m_busDevice->GetMyLogicalAddress())
+ bool bHandled(false);
+ if (m_busDevice->MyLogicalAddressContains(command.destination))
{
switch(command.opcode)
{
case CEC_OPCODE_VENDOR_REMOTE_BUTTON_DOWN:
+ bHandled = true;
HandleVendorRemoteButtonDown(command);
break;
case CEC_OPCODE_VENDOR_REMOTE_BUTTON_UP:
+ bHandled = true;
HandleUserControlRelease(command);
break;
default:
- bHandled = false;
- break;
- }
- }
- else if (command.destination == CECDEVICE_BROADCAST)
- {
- switch(command.opcode)
- {
- // TODO
- default:
- bHandled = false;
break;
}
}