[Keyboard] Helix add split common option (#7718)
authorMakotoKurauchi <pluis@me.com>
Tue, 10 Mar 2020 08:33:46 +0000 (17:33 +0900)
committerGitHub <noreply@github.com>
Tue, 10 Mar 2020 08:33:46 +0000 (01:33 -0700)
commit2d14d12c7409e8de3f8d465635be115e06ba26f7
tree7e16f8a48b5f1d2fcc400869cc02244c6c2cc167
parent0ba352356deaa741064acc770fa5a8bc57fa8904
[Keyboard] Helix add split common option (#7718)

* is_master, has_usb() move to rev2.[hc]

* Do recent helix/rev2 changes to helix/pico as well.

helix/pico/matrix.c: remove 'is_master'
helix/pico/pico.c: add 'is_master'
helix/pico/pico.h: add 'has_usb()' macro
helix/pico/split_util.c: remove 'setup_handedness()' 'has_usb()', add 'is_helix_master()' etc

* add HELIX=scan option into {rev2/pico}/local_features.mk

Made DEBUG_MATRIX_SCAN_RATE easy to use.

* Changed rules.mk to link "helix/local_drivers/ssd1306.c" only when OLED_ENABLE = yes.

* Added option to use split_common for helix/rev2, helix/pico keyboard.

how to build:
 ### build helix/pico (HelixPico) with helix current codes
  $ make helix/pico:KEY_MAP
  $ make helix/pico/back:KEY_MAP

 ### build helix/rev2 (Helix or Helix beta) with helix current codes
  $ make helix:KEY_MAP
  $ make helix/rev2/back:KEY_MAP
  $ make helix/rev2/under:KEY_MAP
  $ make helix/rev2/oled:KEY_MAP
  $ make helix/rev2/oled/back:KEY_MAP
  $ make helix/rev2/oled/under:KEY_MAP

 ### build helix/pico (HelixPico) with split_common codes
  $ make helix/pico/sc:KEY_MAP
  $ make helix/pico/sc/back:KEY_MAP
  $ make helix/pico/sc/under:KEY_MAP

 ### build helix/rev2 (Helix) with split_common codes
  $ make helix/rev2/sc:KEY_MAP
  $ make helix/rev2/sc/back:KEY_MAP
  $ make helix/rev2/sc/under:KEY_MAP
  $ make helix/rev2/sc/oled:KEY_MAP
  $ make helix/rev2/sc/oledback:KEY_MAP
  $ make helix/rev2/sc/oledunder:KEY_MAP

* add matrix_slave_scan_user() to helix/rev2/rev2.c, helix/pico/pico.h

* Changed 'helix:xulkal' to always use split_common and removed ad hoc code.

Added the following line to 'helix/rev2/keymaps/xulkal/rules.mk':

        SPLIT_KEYBOARD = yes

Removed the following ad hoc code from 'users/xulkal/custom_oled.c':

        #if KEYBOARD_helix_rev2
        extern uint8_t is_master;
        bool is_keyboard_master(void) { return is_master; }
        #endif

* add '#define DIODE_DIRECTION COL2ROW' into helix/{rev2|pico}/config.h

This commit does not change the build result.

* update helix readme

* keyboards/helix/readme.md
* keyboards/helix/pico/keymaps/default/readme.md
* keyboards/helix/rev2/keymaps/default/readme.md

Co-authored-by: mtei <2170248+mtei@users.noreply.github.com>
33 files changed:
keyboards/helix/local_drivers/i2c.c
keyboards/helix/pico/config.h
keyboards/helix/pico/keymaps/default/readme.md
keyboards/helix/pico/local_features.mk
keyboards/helix/pico/matrix.c
keyboards/helix/pico/pico.c
keyboards/helix/pico/pico.h
keyboards/helix/pico/post_config.h [new file with mode: 0644]
keyboards/helix/pico/rules.mk
keyboards/helix/pico/sc/back/rules.mk [new file with mode: 0644]
keyboards/helix/pico/sc/rules.mk [new file with mode: 0644]
keyboards/helix/pico/sc/under/rules.mk [new file with mode: 0644]
keyboards/helix/pico/split_util.c
keyboards/helix/pico/split_util.h
keyboards/helix/readme.md
keyboards/helix/rev2/config.h
keyboards/helix/rev2/keymaps/default/readme.md
keyboards/helix/rev2/keymaps/xulkal/rules.mk
keyboards/helix/rev2/local_features.mk
keyboards/helix/rev2/matrix.c
keyboards/helix/rev2/post_config.h [new file with mode: 0644]
keyboards/helix/rev2/rev2.c
keyboards/helix/rev2/rev2.h
keyboards/helix/rev2/rules.mk
keyboards/helix/rev2/sc/back/rules.mk [new file with mode: 0644]
keyboards/helix/rev2/sc/oled/rules.mk [new file with mode: 0644]
keyboards/helix/rev2/sc/oledback/rules.mk [new file with mode: 0644]
keyboards/helix/rev2/sc/oledunder/rules.mk [new file with mode: 0644]
keyboards/helix/rev2/sc/rules.mk [new file with mode: 0644]
keyboards/helix/rev2/sc/under/rules.mk [new file with mode: 0644]
keyboards/helix/rev2/split_util.c
keyboards/helix/rev2/split_util.h
users/xulkal/custom_oled.c