aboutsummaryrefslogtreecommitdiff
path: root/tmk_core/common/action_macro.c
diff options
context:
space:
mode:
Diffstat (limited to 'tmk_core/common/action_macro.c')
-rw-r--r--tmk_core/common/action_macro.c83
1 files changed, 83 insertions, 0 deletions
diff --git a/tmk_core/common/action_macro.c b/tmk_core/common/action_macro.c
new file mode 100644
index 000000000..ba93fc8b2
--- /dev/null
+++ b/tmk_core/common/action_macro.c
@@ -0,0 +1,83 @@
1/*
2Copyright 2013 Jun Wako <wakojun@gmail.com>
3
4This program is free software: you can redistribute it and/or modify
5it under the terms of the GNU General Public License as published by
6the Free Software Foundation, either version 2 of the License, or
7(at your option) any later version.
8
9This program is distributed in the hope that it will be useful,
10but WITHOUT ANY WARRANTY; without even the implied warranty of
11MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12GNU General Public License for more details.
13
14You should have received a copy of the GNU General Public License
15along with this program. If not, see <http://www.gnu.org/licenses/>.
16*/
17#include "action.h"
18#include "action_util.h"
19#include "action_macro.h"
20#include "wait.h"
21
22#ifdef DEBUG_ACTION
23#include "debug.h"
24#else
25#include "nodebug.h"
26#endif
27
28
29#ifndef NO_ACTION_MACRO
30
31#define MACRO_READ() (macro = MACRO_GET(macro_p++))
32void action_macro_play(const macro_t *macro_p)
33{
34 macro_t macro = END;
35 uint8_t interval = 0;
36
37 if (!macro_p) return;
38 while (true) {
39 switch (MACRO_READ()) {
40 case KEY_DOWN:
41 MACRO_READ();
42 dprintf("KEY_DOWN(%02X)\n", macro);
43 if (IS_MOD(macro)) {
44 add_weak_mods(MOD_BIT(macro));
45 } else {
46 register_code(macro);
47 }
48 break;
49 case KEY_UP:
50 MACRO_READ();
51 dprintf("KEY_UP(%02X)\n", macro);
52 if (IS_MOD(macro)) {
53 del_weak_mods(MOD_BIT(macro));
54 } else {
55 unregister_code(macro);
56 }
57 break;
58 case WAIT:
59 MACRO_READ();
60 dprintf("WAIT(%u)\n", macro);
61 { uint8_t ms = macro; while (ms--) wait_ms(1); }
62 break;
63 case INTERVAL:
64 interval = MACRO_READ();
65 dprintf("INTERVAL(%u)\n", interval);
66 break;
67 case 0x04 ... 0x73:
68 dprintf("DOWN(%02X)\n", macro);
69 register_code(macro);
70 break;
71 case 0x84 ... 0xF3:
72 dprintf("UP(%02X)\n", macro);
73 unregister_code(macro&0x7F);
74 break;
75 case END:
76 default:
77 return;
78 }
79 // interval
80 { uint8_t ms = interval; while (ms--) wait_ms(1); }
81 }
82}
83#endif