* Branch point for 2020 May 30 Breaking Change * Migrate `ACTION_LAYER_TOGGLE` to `TG()` (#8954) * Migrate `ACTION_MODS_ONESHOT` to `OSM()` (#8957) * Migrate `ACTION_DEFAULT_LAYER_SET` to `DF()` (#8958) * Migrate `ACTION_LAYER_MODS` to `LM()` (#8959) * Migrate `ACTION_MODS_TAP_KEY` to `MT()` (#8968) * Convert V-USB usbdrv to a submodule (#8321) * Unify Tap Hold functions and documentation (#8348) * Changing board names to prevent confusion (#8412) * Move the Keyboardio Model01 to a keyboardio/ subdir (#8499) * Move spaceman keyboards (#8830) * Migrate miscellaneous `fn_actions` entries (#8977) * Migrate `ACTION_MODS_KEY` to chained mod keycodes (#8979) * Organizing my keyboards (plaid, tartan, ergoinu) (#8537) * Refactor Lily58 to use split_common (#6260) * Refactor zinc to use split_common (#7114) * Add a message if bin/qmk doesn't work (#9000) * Fix conflicting types for 'tfp_printf' (#8269) * Fixed RGB_DISABLE_AFTER_TIMEOUT to be seconds based & small internals cleanup (#6480) * Refactor and updates to TKC1800 code (#8472) * Switch to qmk forks for everything (#9019) * audio refactor: replace deprecated PLAY_NOTE_ARRAY (#8484) * Audio enable corrections (2/3) (#8903) * Split HHKB to ANSI and JP layouts and Add VIA support for each (#8582) * Audio enable corrections (Part 4) (#8974) * Fix typo from PR7114 (#9171) * Augment future branch Changelogs (#8978) * Revert "Branch point for 2020 May 30 Breaking Change"
		
			
				
	
	
	
		
			13 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	QMK Breaking Change - 2020 May 30 Changelog
Four times a year QMK runs a process for merging Breaking Changes. A Breaking Change is any change which modifies how QMK behaves in a way that is incompatible or potentially dangerous. We limit these changes to 4 times per year so that users can have confidence that updating their QMK tree will not break their keymaps.
The list of changes follows.
Core Changes
Converting V-USB usbdrv to a submodule
#8321 and qmk_compiler#62.
These PRs move the V-USB driver code out of the qmk_firmware repository and into a submodule pointed at https://github.com/obdev/v-usb. This will make it easier to update the codebase if needed, while applying any potential QMK-specific modifications by forking it to the QMK GitHub organization.
Unify Tap Hold functions and documentation
Updates all of the per key tap-hold functions to pass the keyrecord_t structure, and include documentation changes.
Any remaining versions or code outside of the main repo will need to be converted:
| Old function | New Function | 
|---|---|
| uint16_t get_tapping_term(uint16_t keycode) | uint16_t get_tapping_term(uint16_t keycode, keyrecord_t *record) | 
| bool get_ignore_mod_tap_interrupt(uint16_t keycode) | bool get_ignore_mod_tap_interrupt(uint16_t keycode, keyrecord_t *record) | 
Python Required In The Build Process
This is the last release of QMK that will work without having Python 3.6 (or later) installed. If your environment is not fully setup you will get a warning instructing you to set it up.
After the next breaking change you will not be able to build if bin/qmk hello does not work.
Upgrade from tinyprintf to mpaland/printf
- Provides debug functionality on ChibiOS/ARM that is more compliant than previous integrations.
- Less maintenence, fewer QMK customisations, and allows QMK to sidestep previous compile and runtime issues.
- A make git-submodulemay be required after pulling the latest QMK Firmware code to update to the new dependency.
Fixed RGB_DISABLE_AFTER_TIMEOUT to be seconds based & small internals cleanup
- Changes RGB_DISABLE_AFTER_TIMEOUTto be based on milliseconds instead of ticks.
- Includes a code cleanup, resulting in a savings of 100 bytes, depending on features used.
- Fixed issues with timeouts / suspending at the wrong time not turning off all LEDs in some cases.
The RGB_DISABLE_AFTER_TIMEOUT definition is now deprecated, and has been superseded by RGB_DISABLE_TIMEOUT. To use the new definition, rename RGB_DISABLE_AFTER_TIMEOUT to RGB_DISABLE_TIMEOUT in your config.h file, and multiply the value set by 1200.
Before: #define RGB_DISABLE_AFTER_TIMEOUT 100
After: #define RGB_DISABLE_TIMEOUT 120000
Switch to qmk forks for everything
Fork all QMK submodules to protect against upstream repositories disappearing.
code cleanup regarding deprecated macro PLAY_NOTE_ARRAY by replacing it with PLAY_SONG
Removes the deprecated PLAY_NOTE_ARRAY macro. References to it are replaced with PLAY_SONG, which references the same function.
fixing wrong configuration of AUDIO feature
audio_avr.c does not default to any pin; there has to be a #define XX_AUDIO in config.h at some level for Audio to actually work. Otherwise, the Audio code ends up cluttering the firmware, possibly breaking builds because the maximum allowed firmware size is exceeded.
These changes fix this by disabling Audio on keyboards that have the feature misconfigured, and therefore non-functional.
Also, add a compile-time error to alert the user to a missing pin-configuration (on AVR boards) when AUDIO_ENABLE = yes is set.
Keyboard Refactors
Migrating Lily58 to use split_common
Modifies the default firmware for Lily58 to use the split_common library, instead of including and depending on its own set of libraries for the following functionality:
- SSD1306 display
- i2c for OLED
- Serial Communication
This allows current lily58 firmware to advance with updates to the split_common library, which is shared with many other split keyboards.
To migrate existing Lily58 firmware:
- Remove #define SSD1306OLEDfrom config.h
- Find/Replace each instance of #ifdef SSD1306OLEDwith#ifdef OLED_DRIVER_ENABLE
- The following changes are for compatibility with the OLED driver. If you don't use the OLED driver you may safely delete this section
- Alternatively, if you did not change the OLED code from that in default, you may find it easier to simply copy the relevant section. Otherwise, the changes you need to make are as follows (sample change here)
- Remove the block
#ifdef SSD1306OLED	
  iota_gfx_init(!has_usb());   // turns on the display	
#endif
- Within the block bounded by #ifdef OLED_DRIVER_ENABLEand#endif // OLED_DRIVER_ENABLE, add the following block to ensure that your two OLEDs are rotated correctly across the left and right sides:
oled_rotation_t oled_init_user(oled_rotation_t rotation) {
  if (!is_keyboard_master())
    return OLED_ROTATION_180;  // flips the display 180 degrees if offhand
  return rotation;
}
- Remove the functions matrix_scan_user,matrix_updateandiota_gfx_task_user
- Find/Replace matrix_render_user(struct CharacterMatrix *matrix)withiota_gfx_task_user(void)
- Find/Replace is_masterwithis_keyboard_master()
- For each instance of matrix_write_ln(matrix, display_fn()), rewrite it asoled_write_ln(read_layer_state(), false);
- For each instance of matrix_write(matrix, read_logo());, replace witholed_write(read_logo(), false);
Refactor zinc to use split_common
- Refactor to use split_common and remove split codes under the zinc/revx/
- Add - backlight RGB LED and/or underglow RGB LED option
- Add - continuous RGB animations feature (between L and R halves)
- Fix - keymap files to adapt to changes
- all authors of keymaps confirmed this PR
 
- Update - documents and rules.mk
Refactor of TKC1800 to use common OLED code
Modifies the default firmware for TKC1800 to use the in-built I2C and OLED drivers, instead of including and depending on its own set of libraries for the following functionality:
- SSD1306 display
- i2c for OLED
This allows current TKC1800 firmware to advance with updates to those drivers, which are shared with other keyboards.
To migrate existing TKC1800 firmware:
- Remove #define SSD1306OLEDfrom config.h
- Add the following to avoid debug errors on HID_listen if the screen is not present
void keyboard_pre_init_kb(void) {
  setPinInputHigh(D0);
  setPinInputHigh(D1);
  keyboard_pre_init_user();
}
- Find/Replace each instance of #ifdef SSD1306OLEDwith#ifdef OLED_DRIVER_ENABLE
- The following changes are for compatibility with the OLED driver. If you don't use the OLED driver you may safely delete this section
- Remove the block
#ifdef SSD1306OLED	
  iota_gfx_init(!has_usb());   // turns on the display	
#endif
- Within the block bounded by #ifdef OLED_DRIVER_ENABLEand#endif // OLED_DRIVER_ENABLE, add the following block to ensure that your two OLEDs are rotated correctly across the left and right sides:
oled_rotation_t oled_init_user(oled_rotation_t rotation) {
  if (!is_keyboard_master())
    return OLED_ROTATION_180;  // flips the display 180 degrees if offhand
  return rotation;
}
- Remove the function iota_gfx_task_user
Split HHKB to ANSI and JP layouts and Add VIA support for each
- Splits the HHKB codebase into two separate folders keyboards/hhkb/ansiandkeyboards/hhkb/jp.
- Adds VIA Configurator support for both versions.
Migrating existing HHKB keymaps
- Remove any checks for the HHKB_JPdefinition- All checks for this definition have been removed, and each version uses the source that is appropriate to that version.
 
- Move the directory for your keymap into the appropriate keymapsdirectory- keyboards/hhkb/ansi/keymaps/for ANSI HHKBs
- keyboards/hhkb/jp/keymaps/for HHKB JPs
 
- Compile with the new keyboard names
- This PR changes the compilation instructions for the HHKB Alternate Controller. To compile firmware for this controller moving forward, use:
- make hhkb/ansifor ANSI-layout HHKBs
- make hhkb/jpfor HHKB JP keyboards
 
 
- This PR changes the compilation instructions for the HHKB Alternate Controller. To compile firmware for this controller moving forward, use:
Keyboard Moves
- #8412 by blindassassin111
- #8499 by algernon
- #8830 by Spaceman (formerly known as Rionlion100)
- #8537 by hsgw
Keyboards by Keyboardio, Spaceman, and hsgw move to vendor folders, while PCBs designed by blindassassin111 are renamed.
| Old Name | New Name | 
|---|---|
| 2_milk | spaceman/2_milk | 
| at101_blackheart | at101_bh | 
| ergoinu | dm9records/ergoinu | 
| model01 | keyboardio/model01 | 
| omnikey_blackheart | omnikey_bh | 
| pancake | spaceman/pancake | 
| plaid | dm9records/plaid | 
| tartan | dm9records/tartan | 
| z150_blackheart | z150_bh | 
If you own one of these PCBs, please use the new names to compile your firmware moving forward.
Keycode Migration PRs
#8954, #8957, #8958, #8959, #8968, #8977, and #8979
Authored by fauxpark, these pull requests remove references to deprecated TMK macros that have been superseded by native QMK keycodes.
| Old fn_actionsaction | New QMK keycode | 
|---|---|
| ACTION_DEFAULT_LAYER_SET(layer) | DF(layer) | 
| ACTION_LAYER_MODS(layer, mod) | LM(layer, mod) | 
| ACTION_LAYER_ONESHOT(mod) | OSL(mod) | 
| ACTION_LAYER_TOGGLE(layer) | TG(layer) | 
| ACTION_MODS_ONESHOT(mod) | OSM(mod) | 
| ACTION_MODS_TAP_KEY(mod, kc) | MT(mod, kc) | 
| ACTION_MODS_KEY(mod, kc)e.g. ACTION_MODS_KEY(MOD_LCTL, KC_0) | MOD(kc)e.g. LCTL(KC_0) |