Skip to content

Commit

Permalink
Remove the legacy keyboard.debug_enabled flag and document the debu…
Browse files Browse the repository at this point in the history
…g utility proper
  • Loading branch information
xs5871 committed Nov 19, 2024
1 parent bad0f50 commit 9c73df7
Show file tree
Hide file tree
Showing 14 changed files with 29 additions and 30 deletions.
1 change: 0 additions & 1 deletion boards/atreus62/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,6 @@
keyboard.modules = [layers, encoder, macros]

keyboard.tap_time = 250
keyboard.debug_enabled = False


# custom keys
Expand Down
2 changes: 0 additions & 2 deletions boards/crowboard/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,5 @@
# ((KC.VOLD, KC.VOLU),(KC.VOLD, KC.VOLU),), # Layer 4
# ]

# keyboard.debug_enabled = True

if __name__ == '__main__':
keyboard.go()
1 change: 0 additions & 1 deletion boards/fingerpunch/ffkb/nice_nano/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@

keyboard = kb.KMKKeyboard()
keyboard.modules = [combos, dyn_seq, layers, sticky_keys]
keyboard.debug_enabled = False

# Convenience variables for the Keymap
_______ = KC.TRNS
Expand Down
1 change: 0 additions & 1 deletion boards/fingerpunch/ffkb/other_pro_micro/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@

keyboard = KMKKeyboard()
keyboard.tap_time = 150
keyboard.debug_enabled = False

# Cleaner key names
_______ = KC.TRNS
Expand Down
1 change: 0 additions & 1 deletion boards/keebio/iris/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@

keyboard = KMKKeyboard()

keyboard.debug_enabled = False
keyboard.tap_time = 750

_______ = KC.TRNS
Expand Down
1 change: 0 additions & 1 deletion boards/kyria/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@
from kmk.modules.split import Split, SplitType

keyboard = KMKKeyboard()
keyboard.debug_enabled = True

keyboard.modules.append(Layers())
keyboard.modules.append(HoldTap())
Expand Down
1 change: 0 additions & 1 deletion boards/splitkb/aurora/lily58/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@
from kmk.modules.split import Split

keyboard = KMKKeyboard()
# keyboard.debug_enabled = True

# Adding modules
# Using drive names (LILY58L, LILY58R) to recognize sides; use split_side arg if you're not doing it
Expand Down
4 changes: 0 additions & 4 deletions docs/en/config_and_keymap.md
Original file line number Diff line number Diff line change
Expand Up @@ -82,10 +82,6 @@ keyboard.keymap = [[KC.A, KC.B]]

You can further define a bunch of other stuff:

- `keyboard.debug_enabled` which will spew a ton of debugging information to the serial
console. This is very rarely needed, but can provide very valuable information
if you need to open an issue.

- `keyboard.tap_time` which defines how long `KC.TT` and `KC.LT` will wait before
considering a key "held" (see `layers.md`).

24 changes: 22 additions & 2 deletions docs/en/debugging.md
Original file line number Diff line number Diff line change
@@ -1,13 +1,33 @@
# Debugging

KMK's debug output is written to CircuitPython's serial console -- the one that's
used for the REPL -- and is automatically enabled if it detects a connection to
that console.
It can also be enabled manually, though that shouldn't be necessary in
general:
general.

## KMK's Debug Utility

KMK has a convenient debug utility that adds a timestamp in milliseconds since boot and a message origin to distinguish subsystems to debug statements.

```python
keyboard.debug_enabled = True
from kmk.utils import Debug

# Create a debug source with the current file as message origin
debug = Debug(__name__)

# For completeness: Force enable/disable debug output. This is handled
# automatically -- you will most likely never have to use this:
# debug.enabled = True/False

# KMK idiomatic debug with guard clause
var = 'concatenate'
if debug.enabled:
debug('Arguments ', var, '!')
```

## Connecting to the Serial Console

Follow for example Adafruit's beginners guide on [how to connect to the serial console](https://learn.adafruit.com/welcome-to-circuitpython/kattni-connecting-to-the-serial-console).
For Linux users, we recommend [picocom](https://github.com/npat-efault/picocom)
or [screen](https://www.gnu.org/software/screen/manual/screen.html)
1 change: 0 additions & 1 deletion docs/en/encoder.md
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,6 @@ keyboard.diode_orientation = DiodeOrientation.COLUMNS
encoder_handler.pins = ((board.GP17, board.GP15, board.GP14, False),)

keyboard.tap_time = 250
keyboard.debug_enabled = False


# Filler keys
Expand Down
6 changes: 1 addition & 5 deletions docs/en/extension_stringy_keymaps.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,14 +22,10 @@ keyboard.keymap = [[ 'A' , 'B', 'RESET' ]]

stringyKeymaps = StringyKeymaps()

# Enabling debug will show each replacement or failure.
# This is recommended during the initial development of a keyboard.
# stringyKeymaps.debug_enable = True

keyboard.extensions.append(stringyKeymaps)
```

It should be noted that these are **not** ASCII. The string is **not** what
will be sent to the computer. The examples above have no functional difference.

When utilizing argumented keys, such as `KC.MO(layer)`, it's not possible to use a string like `'MO(layer)'` instead employ the standard notation of e.g. `KC.MO(1)` in your keymap.
When utilizing argumented keys, such as `KC.MO(layer)`, it's not possible to use a string like `'MO(layer)'` instead employ the standard notation of e.g. `KC.MO(1)` in your keymap.
2 changes: 1 addition & 1 deletion docs/en/keycodes.md
Original file line number Diff line number Diff line change
Expand Up @@ -162,7 +162,7 @@
|-------------------------|------------------------------------------------------------------------|
| `KC.RESET` | Restarts the keyboard |
| `KC.RELOAD`, `KC.RLD` | Reloads the keyboard software, preserving any serial connections |
| `KC.DEBUG` | Toggle `debug_enabled`, which enables log spew to serial console |
| `KC.DEBUG` | Toggle `debug.enabled`, which enables log spew to serial console |
| `KC.ANY` | Any key between `A` and `/` |
| `KC.GESC` | Escape when tapped, <code>&#96;</code> when pressed with Shift or GUI |
| `KC.BKDL` | Backspace when tapped, Delete when pressed with GUI |
Expand Down
8 changes: 0 additions & 8 deletions kmk/kmk_keyboard.py
Original file line number Diff line number Diff line change
Expand Up @@ -185,14 +185,6 @@ def _process_resume_buffer(self):

self._resume_buffer_x = buffer

@property
def debug_enabled(self) -> bool:
return debug.enabled

@debug_enabled.setter
def debug_enabled(self, enabled: bool):
debug.enabled = enabled

def pre_process_key(
self,
key: Key,
Expand Down
6 changes: 5 additions & 1 deletion tests/keyboard_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,9 @@
from kmk.kmk_keyboard import KMKKeyboard
from kmk.scanners import DiodeOrientation
from kmk.scanners.digitalio import MatrixScanner
from kmk.utils import Debug

debug = Debug(__name__)


class DigitalInOut(Mock):
Expand Down Expand Up @@ -39,7 +42,8 @@ def __init__(
self.debug_enabled = debug_enabled

self.keyboard = KMKKeyboard()
self.keyboard.debug_enabled = keyboard_debug_enabled
if keyboard_debug_enabled:
debug.enabled = True

self.keyboard.modules = modules
self.keyboard.extensions = extensions
Expand Down

0 comments on commit 9c73df7

Please sign in to comment.