Merge pull request #878 from sethbc/add_sethbc_gh60_keymap
	
		
	
				
					
				
			add sethbc keymap for gh60 and update macro expansionpull/892/head
						commit
						3b990c08dc
					
				@ -0,0 +1,3 @@
 | 
				
			||||
ifndef QUANTUM_DIR
 | 
				
			||||
	include ../../../../Makefile
 | 
				
			||||
endif
 | 
				
			||||
@ -0,0 +1,76 @@
 | 
				
			||||
#include "gh60.h"
 | 
				
			||||
#include "action_layer.h"
 | 
				
			||||
 | 
				
			||||
#define MODS_CTRL_MASK  (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT))
 | 
				
			||||
 | 
				
			||||
 | 
				
			||||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
 | 
				
			||||
    /* 0: qwerty */
 | 
				
			||||
  KEYMAP_HHKB(
 | 
				
			||||
	      F(0),KC_1,KC_2,KC_3,KC_4,KC_5,KC_6,KC_7,KC_8,KC_9,KC_0,KC_MINS,KC_EQL,KC_BSLS,KC_GRV,\
 | 
				
			||||
        KC_TAB,KC_Q,KC_W,KC_E,KC_R,KC_T,KC_Y,KC_U,KC_I,KC_O,KC_P,KC_LBRC,KC_RBRC,KC_BSPC,\
 | 
				
			||||
        KC_LCTL,KC_A,KC_S,KC_D,KC_F,KC_G,KC_H,KC_J,KC_K,KC_L,KC_SCLN,KC_QUOT,KC_ENT,\
 | 
				
			||||
        KC_LSFT,KC_Z,KC_X,KC_C,KC_V,KC_B,KC_N,KC_M,KC_COMM,KC_DOT,KC_SLSH,KC_RSFT,F(1),\
 | 
				
			||||
        KC_LCTL,KC_LALT,KC_LGUI,      KC_SPC,            KC_RGUI,KC_RALT,KC_APP,KC_RCTL),
 | 
				
			||||
    /* 1: fn */
 | 
				
			||||
	KEYMAP_HHKB(
 | 
				
			||||
        KC_GRV,KC_F1,KC_F2,KC_F3,KC_F4,KC_F5,KC_F6,KC_F7,KC_F8,KC_F9,KC_F10,KC_F11,KC_F12,KC_TRNS,KC_TRNS,\
 | 
				
			||||
        KC_CAPS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_UP,KC_TRNS,KC_TRNS,\
 | 
				
			||||
        KC_TRNS,KC_VOLD,KC_VOLU,KC_MUTE,KC_TRNS,KC_TRNS,KC_PAST,KC_PSLS,KC_HOME,KC_PGUP,KC_LEFT,KC_RIGHT,KC_PENT,\
 | 
				
			||||
        KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_PPLS,KC_PMNS,KC_END,KC_PGDN,KC_DOWN,KC_TRNS,KC_TRNS,\
 | 
				
			||||
        KC_TRNS,KC_TRNS,KC_TRNS,      KC_TRNS,           KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS),
 | 
				
			||||
};
 | 
				
			||||
 | 
				
			||||
enum function_id {
 | 
				
			||||
    SHIFT_ESC,
 | 
				
			||||
};
 | 
				
			||||
 | 
				
			||||
const uint16_t PROGMEM fn_actions[] = {
 | 
				
			||||
    [0] = ACTION_FUNCTION(SHIFT_ESC),
 | 
				
			||||
    [1] = ACTION_LAYER_MOMENTARY(1),  // to Fn overlay
 | 
				
			||||
};
 | 
				
			||||
 | 
				
			||||
const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
 | 
				
			||||
{
 | 
				
			||||
  // MACRODOWN only works in this function
 | 
				
			||||
      switch(id) {
 | 
				
			||||
        case 0:
 | 
				
			||||
          if (record->event.pressed) {
 | 
				
			||||
            register_code(KC_RSFT);
 | 
				
			||||
          } else {
 | 
				
			||||
            unregister_code(KC_RSFT);
 | 
				
			||||
          }
 | 
				
			||||
        break;
 | 
				
			||||
      }
 | 
				
			||||
    return MACRO_NONE;
 | 
				
			||||
};
 | 
				
			||||
 | 
				
			||||
void matrix_scan_user(void) {
 | 
				
			||||
 | 
				
			||||
}
 | 
				
			||||
 | 
				
			||||
void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) {
 | 
				
			||||
  static uint8_t shift_esc_shift_mask;
 | 
				
			||||
  switch (id) {
 | 
				
			||||
    case SHIFT_ESC:
 | 
				
			||||
      shift_esc_shift_mask = get_mods()&MODS_CTRL_MASK;
 | 
				
			||||
      if (record->event.pressed) {
 | 
				
			||||
        if (shift_esc_shift_mask) {
 | 
				
			||||
          add_key(KC_GRV);
 | 
				
			||||
          send_keyboard_report();
 | 
				
			||||
        } else {
 | 
				
			||||
          add_key(KC_ESC);
 | 
				
			||||
          send_keyboard_report();
 | 
				
			||||
        }
 | 
				
			||||
      } else {
 | 
				
			||||
        if (shift_esc_shift_mask) {
 | 
				
			||||
          del_key(KC_GRV);
 | 
				
			||||
          send_keyboard_report();
 | 
				
			||||
        } else {
 | 
				
			||||
          del_key(KC_ESC);
 | 
				
			||||
          send_keyboard_report();
 | 
				
			||||
        }
 | 
				
			||||
      }
 | 
				
			||||
      break;
 | 
				
			||||
  }
 | 
				
			||||
}
 | 
				
			||||
					Loading…
					
					
				
		Reference in new issue