commit
0d2c846656
@ -0,0 +1,47 @@
|
|||||||
|
# Kaleidoscope-HostPowerManagement
|
||||||
|
|
||||||
|
Support performing custom actions whenever the host suspends, resumes, or is
|
||||||
|
sleeping.
|
||||||
|
|
||||||
|
## Using the plugin
|
||||||
|
|
||||||
|
To use the plugin, one needs to include the header, and activate it. No further
|
||||||
|
configuration is necessary, unless one wants to perform custom actions.
|
||||||
|
|
||||||
|
```c++
|
||||||
|
#include <Kaleidoscope.h>
|
||||||
|
#include <Kaleidoscope-HostPowerManagement.h>
|
||||||
|
|
||||||
|
KALEIDOSCOPE_INIT_PLUGINS(HostPowerManagement);
|
||||||
|
|
||||||
|
void setup () {
|
||||||
|
Kaleidoscope.setup ();
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Plugin methods
|
||||||
|
|
||||||
|
The plugin provides the `HostPowerManagement` object, with no public methods.
|
||||||
|
|
||||||
|
## Overrideable methods
|
||||||
|
|
||||||
|
### `hostPowerManagementEventHandler(event)`
|
||||||
|
|
||||||
|
> The `hostPowerManagementEventHandler` method is the brain of the plugin: this function
|
||||||
|
> tells it what action to perform in response to the various events.
|
||||||
|
>
|
||||||
|
> Currently supported events are:
|
||||||
|
> `kaleidoscope::plugin::HostPowerManagement::Suspend` is fired once when the
|
||||||
|
> host suspends; `kaleidoscope::plugin::HostPowerManagement::Sleep` is fired
|
||||||
|
> every cycle while the host is suspended;
|
||||||
|
> `kaleidoscope::plugin::HostPowerManagement::Resume` is fired once when the
|
||||||
|
> host wakes up.
|
||||||
|
>
|
||||||
|
> The default implementation is empty.
|
||||||
|
|
||||||
|
## Further reading
|
||||||
|
|
||||||
|
Starting from the [example][plugin:example] is the recommended way of getting
|
||||||
|
started with the plugin.
|
||||||
|
|
||||||
|
[plugin:example]: ../../examples/HostPowerManagement/HostPowerManagement.ino
|
@ -0,0 +1,71 @@
|
|||||||
|
/* -*- mode: c++ -*-
|
||||||
|
* Kaleidoscope-HostPowerManagement -- Host power management support plugin.
|
||||||
|
* Copyright (C) 2017, 2018 Gergely Nagy
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <Kaleidoscope.h>
|
||||||
|
#include <Kaleidoscope-LEDControl.h>
|
||||||
|
#include <Kaleidoscope-HostPowerManagement.h>
|
||||||
|
|
||||||
|
// *INDENT-OFF*
|
||||||
|
const Key keymaps[][ROWS][COLS] PROGMEM = {
|
||||||
|
[0] = KEYMAP_STACKED
|
||||||
|
(
|
||||||
|
Key_NoKey, Key_1, Key_2, Key_3, Key_4, Key_5, Key_NoKey,
|
||||||
|
Key_Backtick, Key_Q, Key_W, Key_E, Key_R, Key_T, Key_Tab,
|
||||||
|
Key_PageUp, Key_A, Key_S, Key_D, Key_F, Key_G,
|
||||||
|
Key_PageDown, Key_Z, Key_X, Key_C, Key_V, Key_B, Key_Escape,
|
||||||
|
|
||||||
|
Key_LeftControl, Key_Backspace, Key_LeftGui, Key_LeftShift,
|
||||||
|
Key_NoKey,
|
||||||
|
|
||||||
|
Key_skip, Key_6, Key_7, Key_8, Key_9, Key_0, Key_skip,
|
||||||
|
Key_Enter, Key_Y, Key_U, Key_I, Key_O, Key_P, Key_Equals,
|
||||||
|
Key_H, Key_J, Key_K, Key_L, Key_Semicolon, Key_Quote,
|
||||||
|
Key_skip, Key_N, Key_M, Key_Comma, Key_Period, Key_Slash, Key_Minus,
|
||||||
|
|
||||||
|
Key_RightShift, Key_RightAlt, Key_Spacebar, Key_RightControl,
|
||||||
|
Key_NoKey
|
||||||
|
),
|
||||||
|
};
|
||||||
|
// *INDENT-ON*
|
||||||
|
|
||||||
|
void hostPowerManagementEventHandler(kaleidoscope::plugin::HostPowerManagement::Event event) {
|
||||||
|
switch (event) {
|
||||||
|
case kaleidoscope::plugin::HostPowerManagement::Suspend:
|
||||||
|
LEDControl.paused = true;
|
||||||
|
LEDControl.set_all_leds_to({0, 0, 0});
|
||||||
|
LEDControl.syncLeds();
|
||||||
|
break;
|
||||||
|
case kaleidoscope::plugin::HostPowerManagement::Resume:
|
||||||
|
LEDControl.paused = false;
|
||||||
|
LEDControl.refreshAll();
|
||||||
|
break;
|
||||||
|
case kaleidoscope::plugin::HostPowerManagement::Sleep:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
KALEIDOSCOPE_INIT_PLUGINS(LEDControl,
|
||||||
|
HostPowerManagement);
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
Kaleidoscope.setup();
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
Kaleidoscope.loop();
|
||||||
|
}
|
@ -0,0 +1,21 @@
|
|||||||
|
/* -*- mode: c++ -*-
|
||||||
|
* Kaleidoscope-HostPowerManagement -- Host power management support plugin.
|
||||||
|
* Copyright (C) 2017 Gergely Nagy
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <kaleidoscope/plugin/HostPowerManagement.h>
|
@ -0,0 +1,64 @@
|
|||||||
|
/* -*- mode: c++ -*-
|
||||||
|
* Kaleidoscope-HostPowerManagement -- Host power management support plugin.
|
||||||
|
* Copyright (C) 2017, 2018 Gergely Nagy
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <Kaleidoscope.h>
|
||||||
|
#include <Kaleidoscope-HostPowerManagement.h>
|
||||||
|
#include <Kaleidoscope-LEDControl.h>
|
||||||
|
|
||||||
|
// This is a terrible hack until Arduino#6964 gets implemented.
|
||||||
|
// It makes the `_usbSuspendState` symbol available to us.
|
||||||
|
extern uint8_t _usbSuspendState;
|
||||||
|
|
||||||
|
namespace kaleidoscope {
|
||||||
|
namespace plugin {
|
||||||
|
|
||||||
|
bool HostPowerManagement::was_suspended_ = false;
|
||||||
|
bool HostPowerManagement::initial_suspend_ = true;
|
||||||
|
|
||||||
|
EventHandlerResult HostPowerManagement::beforeEachCycle() {
|
||||||
|
|
||||||
|
#ifdef __AVR__
|
||||||
|
if ((_usbSuspendState & (1 << SUSPI))) {
|
||||||
|
if (!initial_suspend_) {
|
||||||
|
if (!was_suspended_) {
|
||||||
|
was_suspended_ = true;
|
||||||
|
hostPowerManagementEventHandler(Suspend);
|
||||||
|
} else {
|
||||||
|
hostPowerManagementEventHandler(Sleep);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (initial_suspend_)
|
||||||
|
initial_suspend_ = false;
|
||||||
|
if (was_suspended_) {
|
||||||
|
was_suspended_ = false;
|
||||||
|
hostPowerManagementEventHandler(Resume);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return EventHandlerResult::OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
__attribute__((weak)) void hostPowerManagementEventHandler(kaleidoscope::plugin::HostPowerManagement::Event event) {
|
||||||
|
}
|
||||||
|
|
||||||
|
kaleidoscope::plugin::HostPowerManagement HostPowerManagement;
|
@ -0,0 +1,57 @@
|
|||||||
|
/* -*- mode: c++ -*-
|
||||||
|
* Kaleidoscope-HostPowerManagement -- Host power management support plugin.
|
||||||
|
* Copyright (C) 2017, 2018 Gergely Nagy
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <Kaleidoscope.h>
|
||||||
|
|
||||||
|
#define _DEPRECATED_MESSAGE_ENABLEWAKEUP \
|
||||||
|
"The HostPowerManagement.enableWakeup() call is not necessary anymore,\n" \
|
||||||
|
"the firmware supports wakeup by default now. The line can be safely\n" \
|
||||||
|
"removed."
|
||||||
|
|
||||||
|
namespace kaleidoscope {
|
||||||
|
namespace plugin {
|
||||||
|
class HostPowerManagement : public kaleidoscope::Plugin {
|
||||||
|
public:
|
||||||
|
typedef enum {
|
||||||
|
Suspend,
|
||||||
|
Sleep,
|
||||||
|
Resume,
|
||||||
|
} Event;
|
||||||
|
|
||||||
|
HostPowerManagement(void) {}
|
||||||
|
|
||||||
|
void enableWakeup(void) DEPRECATED(ENABLEWAKEUP) {}
|
||||||
|
|
||||||
|
EventHandlerResult beforeEachCycle();
|
||||||
|
|
||||||
|
private:
|
||||||
|
static bool was_suspended_;
|
||||||
|
static bool initial_suspend_;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// Backwards compatibility
|
||||||
|
typedef plugin::HostPowerManagement HostPowerManagement;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void hostPowerManagementEventHandler(kaleidoscope::plugin::HostPowerManagement::Event event);
|
||||||
|
|
||||||
|
extern kaleidoscope::plugin::HostPowerManagement HostPowerManagement;
|
Loading…
Reference in new issue