diff options
author | 2015-10-27 14:52:18 -0400 | |
---|---|---|
committer | 2015-10-27 14:52:18 -0400 | |
commit | d311fd8d1a0af3b767d26b520d399bf0db22f058 (patch) | |
tree | b9de5704143ac205b4e26222f9d7551e9b161924 /tmk_core/protocol/usb_hid/parser.cpp | |
parent | a766918d5c48204375f4c207b30bbbf1389df14f (diff) | |
parent | 6f3141965e88c4ee0ebf7c18a243e4c2d9c5021b (diff) | |
download | qmk_firmware-d311fd8d1a0af3b767d26b520d399bf0db22f058.tar.gz |
Merge pull request #34 from jackhumbert/tmk-master
merging from tmk, new_project script and template
Diffstat (limited to 'tmk_core/protocol/usb_hid/parser.cpp')
-rw-r--r-- | tmk_core/protocol/usb_hid/parser.cpp | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/tmk_core/protocol/usb_hid/parser.cpp b/tmk_core/protocol/usb_hid/parser.cpp new file mode 100644 index 000000000..1a152ff3f --- /dev/null +++ b/tmk_core/protocol/usb_hid/parser.cpp @@ -0,0 +1,33 @@ +#include "parser.h" +#include "usb_hid.h" + +#include "debug.h" + + +report_keyboard_t usb_hid_keyboard_report; +uint16_t usb_hid_time_stamp; + + +void KBDReportParser::Parse(HID *hid, bool is_rpt_id, uint8_t len, uint8_t *buf) +{ + bool is_error = false; + report_keyboard_t *report = (report_keyboard_t *)buf; + + dprintf("KBDReport: %02X %02X", report->mods, report->reserved); + for (uint8_t i = 0; i < KEYBOARD_REPORT_KEYS; i++) { + if (IS_ERROR(report->keys[i])) { + is_error = true; + } + dprintf(" %02X", report->keys[i]); + } + dprint("\r\n"); + + // ignore error and not send report to computer + if (is_error) { + dprint("Error usage! \r\n"); + return; + } + + ::memcpy(&usb_hid_keyboard_report, buf, sizeof(report_keyboard_t)); + usb_hid_time_stamp = millis(); +} |