Implements subprojects and updates projects for this (#459)
* non-working commit * working * subprojects implemented for planck * pass a subproject variable through to c * consolidates clueboard revisions * thanks for letting me know about conflicts.. * turn off audio for yang's * corrects starting paths for subprojects * messing around with travis * semicolon * travis script * travis script * script for travis * correct directory (probably), amend files to commit * remove origin before adding * git pull, correct syntax * git checkout * git pull origin branch * where are we? * where are we? * merging * force things to happen * adds commit message, adds add * rebase, no commit message * rebase branch * idk! * try just pull * fetch - merge * specify repo branch * checkout * goddammit * merge? idk * pls * after all * don't split up keyboards * syntax * adds quick for all-keyboards * trying out new script * script update * lowercase * all keyboards * stop replacing compiled.hex automatically * adds if statement * skip automated build branches * forces push to automated build branch * throw an add in there * upstream? * adds AUTOGEN * ignore all .hex files again * testing out new repo * global ident * generate script, keyboard_keymap.hex * skip generation for now, print pandoc info, submodule update * try trusty * and sudo * try generate * updates subprojects to keyboards * no idea * updates to keyboards * cleans up clueboard stuff * setup to use local readme * updates cluepad, planck experimental * remove extra led.c [ci skip] * disable power up for now * config files updates * makefile updates * .h file updates, config tuning * disable audio for yang
This commit is contained in:
		
							parent
							
								
									755b17f8fc
								
							
						
					
					
						commit
						215c2119af
					
				
					 44 changed files with 480 additions and 475 deletions
				
			
		
							
								
								
									
										50
									
								
								.travis.yml
									
										
									
									
									
								
							
							
						
						
									
										50
									
								
								.travis.yml
									
										
									
									
									
								
							| 
						 | 
					@ -1,39 +1,21 @@
 | 
				
			||||||
os:
 | 
					os: linux
 | 
				
			||||||
  - linux
 | 
					dist: trusty
 | 
				
			||||||
 | 
					sudo: required
 | 
				
			||||||
language:
 | 
					language: c
 | 
				
			||||||
  - c
 | 
					compiler: avr-gcc
 | 
				
			||||||
 | 
					branches:
 | 
				
			||||||
compiler:
 | 
					  except:
 | 
				
			||||||
  - avr-gcc
 | 
					    - /^.*-automated-build$/
 | 
				
			||||||
 | 
					 | 
				
			||||||
env:
 | 
					env:
 | 
				
			||||||
  - KEYBOARD=alps64
 | 
					  global:
 | 
				
			||||||
  - KEYBOARD=arrow_pad
 | 
					  - secure: vBTSL34BDPxDilKUuTXqU4CJ26Pv5hogD2nghatkxSQkI1/jbdnLj/DQdPUrMJFDIY6TK3AltsBx72MaMsLQ1JO/Ou24IeHINHXzUC1FlS9yQa48cpxnhX5kzXNyGs3oa0qaFbvnr7RgYRWtmD52n4bIZuSuW+xpBv05x2OCizdT2ZonH33nATaHGFasxROm4qYZ241VfzcUv766V6RVHgL4x9V08warugs+RENVkfzxxwhk3NmkrISabze0gSVJLHBPHxroZC6EUcf/ocobcuDrCwFqtEt90i7pNIAFUE7gZsN2uE75LmpzAWin21G7lLPcPL2k4FJVd8an1HiP2WmscJU6U89fOfMb2viObnKcCzebozBCmKGtHEuXZo9FcReOx49AnQSpmESJGs+q2dL/FApkTjQiyT4J6O5dJpoww0/r57Wx0cmmqjETKBb5rSgXM51Etk3wO09mvcPHsEwrT7qH8r9XWdyCDoEn7FCLX3/LYnf/D4SmZ633YPl5gv3v9XEwxR5+04akjgnvWDSNIaDbWBdxHNb7l4pMc+WR1bwCyMyA7KXj0RrftEGOrm9ZRLe6BkbT4cycA+j77nbPOMcyZChliV9pPQos+4TOJoTzcK2L8yWVoY409aDNVuAjdP6Yum0R2maBGl/etLmIMpJC35C5/lZ+dUNjJAM=
 | 
				
			||||||
  - KEYBOARD=atomic
 | 
					 | 
				
			||||||
  - KEYBOARD=atreus
 | 
					 | 
				
			||||||
  - KEYBOARD=bantam44
 | 
					 | 
				
			||||||
  - KEYBOARD=clueboard1
 | 
					 | 
				
			||||||
  - KEYBOARD=clueboard2
 | 
					 | 
				
			||||||
  - KEYBOARD=cluepad
 | 
					 | 
				
			||||||
  - KEYBOARD=ergodox_ez
 | 
					 | 
				
			||||||
  - KEYBOARD=gh60
 | 
					 | 
				
			||||||
  - KEYBOARD=hhkb
 | 
					 | 
				
			||||||
  - KEYBOARD=jd45
 | 
					 | 
				
			||||||
  - KEYBOARD=kc60
 | 
					 | 
				
			||||||
  - KEYBOARD=phantom
 | 
					 | 
				
			||||||
  - KEYBOARD=planck
 | 
					 | 
				
			||||||
  - KEYBOARD=preonic
 | 
					 | 
				
			||||||
  - KEYBOARD=retro_refit
 | 
					 | 
				
			||||||
  - KEYBOARD=satan
 | 
					 | 
				
			||||||
  - KEYBOARD=sixkeyboard
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
script:
 | 
					script:
 | 
				
			||||||
  - cd keyboards/$KEYBOARD && make all-keymaps
 | 
					- make all-keyboards quick AUTOGEN=true
 | 
				
			||||||
 | 
					 | 
				
			||||||
addons:
 | 
					addons:
 | 
				
			||||||
  apt:
 | 
					  apt:
 | 
				
			||||||
    packages:
 | 
					    packages:
 | 
				
			||||||
      - avr-libc
 | 
					    - avr-libc
 | 
				
			||||||
      - gcc-avr
 | 
					    - gcc-avr
 | 
				
			||||||
      - dfu-programmer
 | 
					    - dfu-programmer
 | 
				
			||||||
 | 
					    - pandoc
 | 
				
			||||||
 | 
					after_success: bash util/travis_compiled_push.sh
 | 
				
			||||||
							
								
								
									
										68
									
								
								Makefile
									
										
									
									
									
								
							
							
						
						
									
										68
									
								
								Makefile
									
										
									
									
									
								
							| 
						 | 
					@ -10,19 +10,32 @@ abs_tmk_root := $(patsubst %/,%,$(dir $(mkfile_path)))
 | 
				
			||||||
ifneq (,$(findstring /keyboards/,$(starting_makefile)))
 | 
					ifneq (,$(findstring /keyboards/,$(starting_makefile)))
 | 
				
			||||||
	possible_keyboard:=$(patsubst %/,%,$(dir $(patsubst $(abs_tmk_root)/keyboards/%,%,$(starting_makefile))))
 | 
						possible_keyboard:=$(patsubst %/,%,$(dir $(patsubst $(abs_tmk_root)/keyboards/%,%,$(starting_makefile))))
 | 
				
			||||||
	ifneq (,$(findstring /keymaps/,$(possible_keyboard)))
 | 
						ifneq (,$(findstring /keymaps/,$(possible_keyboard)))
 | 
				
			||||||
		KEYBOARD_DIR:=$(firstword $(subst /keymaps/, ,$(possible_keyboard)))
 | 
					 | 
				
			||||||
		KEYMAP_DIR:=$(lastword $(subst /keymaps/, ,$(possible_keyboard)))
 | 
							KEYMAP_DIR:=$(lastword $(subst /keymaps/, ,$(possible_keyboard)))
 | 
				
			||||||
		tmk_root = ../../../..
 | 
							KEYBOARD_DIR:=$(firstword $(subst /keymaps/, ,$(possible_keyboard)))
 | 
				
			||||||
 | 
							ifneq (,$(findstring /,$(KEYBOARD_DIR)))
 | 
				
			||||||
 | 
								# SUBPROJECT_DIR:=$(lastword $(subst /, ,$(KEYBOARD_DIR)))
 | 
				
			||||||
 | 
								# KEYBOARD_DIR:=$(firstword $(subst /, ,$(KEYBOARD_DIR)))
 | 
				
			||||||
 | 
								tmk_root = ../../..
 | 
				
			||||||
 | 
							else
 | 
				
			||||||
 | 
								tmk_root = ../../../..
 | 
				
			||||||
 | 
							endif
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		KEYBOARD_DIR:=$(possible_keyboard)
 | 
					 | 
				
			||||||
		KEYMAP_DIR:=default
 | 
							KEYMAP_DIR:=default
 | 
				
			||||||
		tmk_root = ../..
 | 
							KEYBOARD_DIR:=$(possible_keyboard)
 | 
				
			||||||
 | 
							ifneq (,$(findstring /,$(KEYBOARD_DIR)))
 | 
				
			||||||
 | 
								# SUBPROJECT_DIR:=$(lastword $(subst /, ,$(KEYBOARD_DIR)))
 | 
				
			||||||
 | 
								# KEYBOARD_DIR:=$(firstword $(subst /, ,$(KEYBOARD_DIR)))
 | 
				
			||||||
 | 
								tmk_root = ../../..
 | 
				
			||||||
 | 
							else
 | 
				
			||||||
 | 
								tmk_root = ../..
 | 
				
			||||||
 | 
							endif
 | 
				
			||||||
	endif
 | 
						endif
 | 
				
			||||||
else
 | 
					else
 | 
				
			||||||
	tmk_root = .
 | 
						tmk_root = .
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
# $(info $(KEYBOARD_DIR))
 | 
					# $(info $(KEYBOARD_DIR))
 | 
				
			||||||
# $(info $(KEYMAP_DIR))
 | 
					# $(info $(KEYMAP_DIR))
 | 
				
			||||||
 | 
					# $(info $(SUBPROJECT_DIR))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Directory common source filess exist
 | 
					# Directory common source filess exist
 | 
				
			||||||
TOP_DIR = $(tmk_root)
 | 
					TOP_DIR = $(tmk_root)
 | 
				
			||||||
| 
						 | 
					@ -32,6 +45,7 @@ TMK_PATH = $(TOP_DIR)/$(TMK_DIR)
 | 
				
			||||||
QUANTUM_DIR = quantum
 | 
					QUANTUM_DIR = quantum
 | 
				
			||||||
QUANTUM_PATH = $(TOP_DIR)/$(QUANTUM_DIR)
 | 
					QUANTUM_PATH = $(TOP_DIR)/$(QUANTUM_DIR)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifdef keyboard
 | 
					ifdef keyboard
 | 
				
			||||||
	KEYBOARD ?= $(keyboard)
 | 
						KEYBOARD ?= $(keyboard)
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
| 
						 | 
					@ -41,7 +55,16 @@ endif
 | 
				
			||||||
ifndef KEYBOARD
 | 
					ifndef KEYBOARD
 | 
				
			||||||
	KEYBOARD=planck
 | 
						KEYBOARD=planck
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# converts things to keyboards/subproject
 | 
				
			||||||
 | 
					ifneq (,$(findstring /,$(KEYBOARD)))
 | 
				
			||||||
 | 
						TEMP:=$(KEYBOARD)
 | 
				
			||||||
 | 
						KEYBOARD:=$(firstword $(subst /, ,$(TEMP)))
 | 
				
			||||||
 | 
						SUBPROJECT:=$(lastword $(subst /, ,$(TEMP)))
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
KEYBOARD_PATH = $(TOP_DIR)/keyboards/$(KEYBOARD)
 | 
					KEYBOARD_PATH = $(TOP_DIR)/keyboards/$(KEYBOARD)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifneq ("$(wildcard $(KEYBOARD_PATH)/$(KEYBOARD).c)","")
 | 
					ifneq ("$(wildcard $(KEYBOARD_PATH)/$(KEYBOARD).c)","")
 | 
				
			||||||
	KEYBOARD_FILE = keyboards/$(KEYBOARD)/$(KEYBOARD).c
 | 
						KEYBOARD_FILE = keyboards/$(KEYBOARD)/$(KEYBOARD).c
 | 
				
			||||||
	ifndef ARCH
 | 
						ifndef ARCH
 | 
				
			||||||
| 
						 | 
					@ -51,6 +74,28 @@ else
 | 
				
			||||||
$(error "$(KEYBOARD_PATH)/$(KEYBOARD).c" does not exist)
 | 
					$(error "$(KEYBOARD_PATH)/$(KEYBOARD).c" does not exist)
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifdef sub
 | 
				
			||||||
 | 
						SUBPROJECT=$(sub)
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					ifdef subproject
 | 
				
			||||||
 | 
						SUBPROJECT=$(subproject)
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifdef SUBPROJECT_DEFAULT
 | 
				
			||||||
 | 
						SUBPROJECT?=$(SUBPROJECT_DEFAULT)
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifdef SUBPROJECT
 | 
				
			||||||
 | 
						SUBPROJECT_PATH = $(TOP_DIR)/keyboards/$(KEYBOARD)/$(SUBPROJECT)
 | 
				
			||||||
 | 
						ifneq ("$(wildcard $(SUBPROJECT_PATH)/$(SUBPROJECT).c)","")
 | 
				
			||||||
 | 
							OPT_DEFS += -DSUBPROJECT_$(SUBPROJECT)
 | 
				
			||||||
 | 
							SUBPROJECT_FILE = keyboards/$(KEYBOARD)/$(SUBPROJECT)/$(SUBPROJECT).c
 | 
				
			||||||
 | 
							-include $(SUBPROJECT_PATH)/Makefile
 | 
				
			||||||
 | 
						else 
 | 
				
			||||||
 | 
					$(error "$(SUBPROJECT_PATH)/$(SUBPROJECT).c" does not exist)
 | 
				
			||||||
 | 
						endif
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifdef keymap
 | 
					ifdef keymap
 | 
				
			||||||
	KEYMAP ?= $(keymap)
 | 
						KEYMAP ?= $(keymap)
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
| 
						 | 
					@ -68,7 +113,13 @@ else
 | 
				
			||||||
$(error "$(KEYMAP_PATH)/keymap.c" does not exist)
 | 
					$(error "$(KEYMAP_PATH)/keymap.c" does not exist)
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
TARGET ?= $(KEYBOARD)_$(KEYMAP)
 | 
					ifdef SUBPROJECT
 | 
				
			||||||
 | 
						TARGET ?= $(KEYBOARD)_$(SUBPROJECT)_$(KEYMAP)
 | 
				
			||||||
 | 
					else
 | 
				
			||||||
 | 
						TARGET ?= $(KEYBOARD)_$(KEYMAP)
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifneq ("$(wildcard $(KEYMAP_PATH)/config.h)","")
 | 
					ifneq ("$(wildcard $(KEYMAP_PATH)/config.h)","")
 | 
				
			||||||
	CONFIG_H = $(KEYMAP_PATH)/config.h
 | 
						CONFIG_H = $(KEYMAP_PATH)/config.h
 | 
				
			||||||
| 
						 | 
					@ -83,6 +134,10 @@ SRC += $(KEYBOARD_FILE) \
 | 
				
			||||||
	$(QUANTUM_DIR)/keymap.c \
 | 
						$(QUANTUM_DIR)/keymap.c \
 | 
				
			||||||
	$(QUANTUM_DIR)/keycode_config.c
 | 
						$(QUANTUM_DIR)/keycode_config.c
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifdef SUBPROJECT
 | 
				
			||||||
 | 
						SRC += $(SUBPROJECT_FILE)
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifndef CUSTOM_MATRIX
 | 
					ifndef CUSTOM_MATRIX
 | 
				
			||||||
	SRC += $(QUANTUM_DIR)/matrix.c
 | 
						SRC += $(QUANTUM_DIR)/matrix.c
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
| 
						 | 
					@ -104,6 +159,9 @@ endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Search Path
 | 
					# Search Path
 | 
				
			||||||
VPATH += $(KEYMAP_PATH)
 | 
					VPATH += $(KEYMAP_PATH)
 | 
				
			||||||
 | 
					ifdef SUBPROJECT
 | 
				
			||||||
 | 
						VPATH += $(SUBPROJECT_PATH)
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
VPATH += $(KEYBOARD_PATH)
 | 
					VPATH += $(KEYBOARD_PATH)
 | 
				
			||||||
VPATH += $(TOP_DIR)
 | 
					VPATH += $(TOP_DIR)
 | 
				
			||||||
VPATH += $(TMK_PATH)
 | 
					VPATH += $(TMK_PATH)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,4 +1,5 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SUBPROJECT_DEFAULT = rev2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# MCU name
 | 
					# MCU name
 | 
				
			||||||
MCU = atmega32u4
 | 
					MCU = atmega32u4
 | 
				
			||||||
| 
						 | 
					@ -1,4 +1,9 @@
 | 
				
			||||||
#include "clueboard1.h"
 | 
					#include "clueboard.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void led_init_ports() {
 | 
				
			||||||
 | 
					    // * Set our LED pins as output
 | 
				
			||||||
 | 
					    DDRB |= (1<<4);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void led_set_kb(uint8_t usb_led) {
 | 
					void led_set_kb(uint8_t usb_led) {
 | 
				
			||||||
    DDRF |= (1<<0);
 | 
					    DDRF |= (1<<0);
 | 
				
			||||||
							
								
								
									
										13
									
								
								keyboards/clueboard/clueboard.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								keyboards/clueboard/clueboard.h
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,13 @@
 | 
				
			||||||
 | 
					#ifndef CLUEBOARD_H
 | 
				
			||||||
 | 
					#define CLUEBOARD_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SUBPROJECT_rev1
 | 
				
			||||||
 | 
					    #include "rev1.h"
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef SUBPROJECT_rev2
 | 
				
			||||||
 | 
					    #include "rev2.h"
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "quantum.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
| 
						 | 
					@ -22,29 +22,10 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* USB Device descriptor parameter */
 | 
					/* USB Device descriptor parameter */
 | 
				
			||||||
#define VENDOR_ID       0xC1ED
 | 
					#define VENDOR_ID       0xC1ED
 | 
				
			||||||
#define PRODUCT_ID      0x2301
 | 
					 | 
				
			||||||
#define DEVICE_VER      0x0003
 | 
					 | 
				
			||||||
#define MANUFACTURER    Clueboard
 | 
					#define MANUFACTURER    Clueboard
 | 
				
			||||||
#define PRODUCT         Clueboard
 | 
					#define PRODUCT         Clueboard
 | 
				
			||||||
#define DESCRIPTION     QMK keyboard firmware for Clueboard
 | 
					#define DESCRIPTION     QMK keyboard firmware for Clueboard
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* key matrix size */
 | 
					 | 
				
			||||||
#define MATRIX_ROWS 5
 | 
					 | 
				
			||||||
#define MATRIX_COLS 16
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// ROWS: Top to bottom, COLS: Left to right
 | 
					 | 
				
			||||||
/* Column pin configuration
 | 
					 | 
				
			||||||
* col: 0  1  2  3  4  5  6  7  8  9  10 11 12 13 14 15
 | 
					 | 
				
			||||||
* pin: B3 F1 F4 F5 F6 C7 C6 B6 B5 B4 D7 D6 D4 F7 B0 B1
 | 
					 | 
				
			||||||
*/
 | 
					 | 
				
			||||||
#define MATRIX_COL_PINS { B3, F1, F4, F5, F6, C7, C6, B6, B5, B4, D7, D6, D4, F7, B0, B1 }
 | 
					 | 
				
			||||||
/* Row pin configuration
 | 
					 | 
				
			||||||
* row: 0  1  2  3  4
 | 
					 | 
				
			||||||
* pin: D1 D0 D2 D5 D3
 | 
					 | 
				
			||||||
*/
 | 
					 | 
				
			||||||
#define MATRIX_ROW_PINS { D1, D0, D2, D5, D3 }
 | 
					 | 
				
			||||||
#define UNUSED_PINS
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* COL2ROW or ROW2COL */
 | 
					/* COL2ROW or ROW2COL */
 | 
				
			||||||
#define DIODE_DIRECTION COL2ROW
 | 
					#define DIODE_DIRECTION COL2ROW
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -64,16 +45,6 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
    keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) \
 | 
					    keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) \
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Underlight configuration
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
 #define ws2812_PORTREG PORTB
 | 
					 | 
				
			||||||
 #define ws2812_DDRREG DDRB
 | 
					 | 
				
			||||||
 #define ws2812_pin 2
 | 
					 | 
				
			||||||
 #define RGBLED_NUM 14     // Number of LEDs
 | 
					 | 
				
			||||||
 #define RGBLIGHT_HUE_STEP 10
 | 
					 | 
				
			||||||
 #define RGBLIGHT_SAT_STEP 17
 | 
					 | 
				
			||||||
 #define RGBLIGHT_VAL_STEP 17
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Feature disable options
 | 
					 * Feature disable options
 | 
				
			||||||
 *  These options are also useful to firmware size reduction.
 | 
					 *  These options are also useful to firmware size reduction.
 | 
				
			||||||
| 
						 | 
					@ -92,4 +63,12 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
//#define NO_ACTION_MACRO
 | 
					//#define NO_ACTION_MACRO
 | 
				
			||||||
//#define NO_ACTION_FUNCTION
 | 
					//#define NO_ACTION_FUNCTION
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SUBPROJECT_rev1
 | 
				
			||||||
 | 
					    #include "rev1/config.h"
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef SUBPROJECT_rev2
 | 
				
			||||||
 | 
					    #include "rev2/config.h"
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
| 
						 | 
					@ -1,4 +1,4 @@
 | 
				
			||||||
#include "clueboard2.h"
 | 
					#include "clueboard.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Used for SHIFT_ESC
 | 
					// Used for SHIFT_ESC
 | 
				
			||||||
#define MODS_CTRL_MASK  (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT))
 | 
					#define MODS_CTRL_MASK  (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT))
 | 
				
			||||||
| 
						 | 
					@ -138,6 +138,7 @@ void action_function(keyrecord_t *record, uint8_t id, uint8_t opt) {
 | 
				
			||||||
      if (record->event.pressed) {
 | 
					      if (record->event.pressed) {
 | 
				
			||||||
        rgblight_toggle();
 | 
					        rgblight_toggle();
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      break;
 | 
					      break;
 | 
				
			||||||
    case RGBLED_INCREASE_HUE:
 | 
					    case RGBLED_INCREASE_HUE:
 | 
				
			||||||
      if (record->event.pressed) {
 | 
					      if (record->event.pressed) {
 | 
				
			||||||
							
								
								
									
										49
									
								
								keyboards/clueboard/keymaps/max/Makefile
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								keyboards/clueboard/keymaps/max/Makefile
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,49 @@
 | 
				
			||||||
 | 
					#----------------------------------------------------------------------------
 | 
				
			||||||
 | 
					# On command line:
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# make all = Make software.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# make clean = Clean out built project files.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# make coff = Convert ELF to AVR COFF.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# make extcoff = Convert ELF to AVR Extended COFF.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# make program = Download the hex file to the device.
 | 
				
			||||||
 | 
					#                Please customize your programmer settings(PROGRAM_CMD)
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# make teensy = Download the hex file to the device, using teensy_loader_cli.
 | 
				
			||||||
 | 
					#               (must have teensy_loader_cli installed).
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# make dfu = Download the hex file to the device, using dfu-programmer (must
 | 
				
			||||||
 | 
					#            have dfu-programmer installed).
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# make flip = Download the hex file to the device, using Atmel FLIP (must
 | 
				
			||||||
 | 
					#             have Atmel FLIP installed).
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# make dfu-ee = Download the eeprom file to the device, using dfu-programmer
 | 
				
			||||||
 | 
					#               (must have dfu-programmer installed).
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# make flip-ee = Download the eeprom file to the device, using Atmel FLIP
 | 
				
			||||||
 | 
					#                (must have Atmel FLIP installed).
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# make debug = Start either simulavr or avarice as specified for debugging,
 | 
				
			||||||
 | 
					#              with avr-gdb or avr-insight as the front end for debugging.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# make filename.s = Just compile filename.c into the assembler code only.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# make filename.i = Create a preprocessed source file for use in submitting
 | 
				
			||||||
 | 
					#                   bug reports to the GCC project.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# To rebuild project do "make clean" then "make all".
 | 
				
			||||||
 | 
					#----------------------------------------------------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Build Options
 | 
				
			||||||
 | 
					#   change to "no" to disable the options, or define them in the makefile.mk in 
 | 
				
			||||||
 | 
					#   the appropriate keymap folder that will get included automatically
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					RGBLIGHT_ENABLE = yes        # Enable WS2812 RGB underlight.  Do not enable this with audio at the same time.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifndef QUANTUM_DIR
 | 
				
			||||||
 | 
						include ../../../../Makefile
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
| 
						 | 
					@ -1,4 +1,4 @@
 | 
				
			||||||
#include "clueboard2.h"
 | 
					#include "clueboard.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Used for SHIFT_ESC
 | 
					// Used for SHIFT_ESC
 | 
				
			||||||
#define MODS_CTRL_MASK  (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT))
 | 
					#define MODS_CTRL_MASK  (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT))
 | 
				
			||||||
| 
						 | 
					@ -1,4 +1,4 @@
 | 
				
			||||||
#include "clueboard2.h"
 | 
					#include "clueboard.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Used for SHIFT_ESC
 | 
					// Used for SHIFT_ESC
 | 
				
			||||||
#define MODS_CTRL_MASK  (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT))
 | 
					#define MODS_CTRL_MASK  (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT))
 | 
				
			||||||
							
								
								
									
										5
									
								
								keyboards/clueboard/rev1/Makefile
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								keyboards/clueboard/rev1/Makefile
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,5 @@
 | 
				
			||||||
 | 
					BACKLIGHT_ENABLE = no
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifndef QUANTUM_DIR
 | 
				
			||||||
 | 
						include ../../../Makefile
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
							
								
								
									
										37
									
								
								keyboards/clueboard/rev1/config.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								keyboards/clueboard/rev1/config.h
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,37 @@
 | 
				
			||||||
 | 
					#ifndef REV2_CONFIG_H
 | 
				
			||||||
 | 
					#define REV2_CONFIG_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "../config.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define PRODUCT_ID      0x2301
 | 
				
			||||||
 | 
					#define DEVICE_VER      0x0003
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* key matrix size */
 | 
				
			||||||
 | 
					#define MATRIX_ROWS 5
 | 
				
			||||||
 | 
					#define MATRIX_COLS 16
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// ROWS: Top to bottom, COLS: Left to right
 | 
				
			||||||
 | 
					/* Column pin configuration
 | 
				
			||||||
 | 
					* col: 0  1  2  3  4  5  6  7  8  9  10 11 12 13 14 15
 | 
				
			||||||
 | 
					* pin: B3 F1 F4 F5 F6 C7 C6 B6 B5 B4 D7 D6 D4 F7 B0 B1
 | 
				
			||||||
 | 
					*/
 | 
				
			||||||
 | 
					#define MATRIX_COL_PINS { B3, F1, F4, F5, F6, C7, C6, B6, B5, B4, D7, D6, D4, F7, B0, B1 }
 | 
				
			||||||
 | 
					/* Row pin configuration
 | 
				
			||||||
 | 
					* row: 0  1  2  3  4
 | 
				
			||||||
 | 
					* pin: D1 D0 D2 D5 D3
 | 
				
			||||||
 | 
					*/
 | 
				
			||||||
 | 
					#define MATRIX_ROW_PINS { D1, D0, D2, D5, D3 }
 | 
				
			||||||
 | 
					#define UNUSED_PINS
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Underlight configuration
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define ws2812_PORTREG PORTB
 | 
				
			||||||
 | 
					#define ws2812_DDRREG DDRB
 | 
				
			||||||
 | 
					#define ws2812_pin 2
 | 
				
			||||||
 | 
					#define RGBLED_NUM 14     // Number of LEDs
 | 
				
			||||||
 | 
					#define RGBLIGHT_HUE_STEP 10
 | 
				
			||||||
 | 
					#define RGBLIGHT_SAT_STEP 17
 | 
				
			||||||
 | 
					#define RGBLIGHT_VAL_STEP 17
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										1
									
								
								keyboards/clueboard/rev1/rev1.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								keyboards/clueboard/rev1/rev1.c
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					#include "rev1.h"
 | 
				
			||||||
| 
						 | 
					@ -1,8 +1,7 @@
 | 
				
			||||||
#ifndef CLUEBOARD1_H
 | 
					#ifndef REV1_H
 | 
				
			||||||
#define CLUEBOARD1_H
 | 
					#define REV1_H
 | 
				
			||||||
 | 
					 | 
				
			||||||
#include "quantum.h"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "../clueboard.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Clueboard matrix layout
 | 
					/* Clueboard matrix layout
 | 
				
			||||||
 * ,-----------------------------------------------------------.  ,---.
 | 
					 * ,-----------------------------------------------------------.  ,---.
 | 
				
			||||||
| 
						 | 
					@ -30,6 +29,7 @@
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
// The first section contains all of the arguements
 | 
					// The first section contains all of the arguements
 | 
				
			||||||
// The second converts the arguments into a two-dimensional array
 | 
					// The second converts the arguments into a two-dimensional array
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define KEYMAP( \
 | 
					#define KEYMAP( \
 | 
				
			||||||
    k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0A, k0B, k0C, k0D, k0E, k0F, \
 | 
					    k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0A, k0B, k0C, k0D, k0E, k0F, \
 | 
				
			||||||
    k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1A, k1B, k1C, k1D,      k1F, \
 | 
					    k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1A, k1B, k1C, k1D,      k1F, \
 | 
				
			||||||
							
								
								
									
										5
									
								
								keyboards/clueboard/rev2/Makefile
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								keyboards/clueboard/rev2/Makefile
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,5 @@
 | 
				
			||||||
 | 
					BACKLIGHT_ENABLE = yes
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifndef QUANTUM_DIR
 | 
				
			||||||
 | 
						include ../../../Makefile
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
							
								
								
									
										40
									
								
								keyboards/clueboard/rev2/config.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								keyboards/clueboard/rev2/config.h
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,40 @@
 | 
				
			||||||
 | 
					#ifndef REV2_CONFIG_H
 | 
				
			||||||
 | 
					#define REV2_CONFIG_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "../config.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define PRODUCT_ID      0x2320
 | 
				
			||||||
 | 
					#define DEVICE_VER      0x0001
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* key matrix size */
 | 
				
			||||||
 | 
					#define MATRIX_ROWS 10
 | 
				
			||||||
 | 
					#define MATRIX_COLS 8
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// ROWS: Top to bottom, COLS: Left to right
 | 
				
			||||||
 | 
					/* Row pin configuration
 | 
				
			||||||
 | 
					* row: 0  1  2  3  4  5  6  7  8  9
 | 
				
			||||||
 | 
					* pin: B2 C7 C6 B6 B5 B0 B3 D5 D3 D2
 | 
				
			||||||
 | 
					*/
 | 
				
			||||||
 | 
					#define MATRIX_ROW_PINS { B2, C7, C6, B6, B5, B0, B3, D5, D3, D2 }
 | 
				
			||||||
 | 
					/* Column pin configuration
 | 
				
			||||||
 | 
					 * col: 0  1  2  3  4  5  6  7
 | 
				
			||||||
 | 
					 * pin: F0 F1 F4 F5 F6 F7 E6 B1
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define MATRIX_COL_PINS { F0, F1, F4, F5, F6, F7, E6, B1 }
 | 
				
			||||||
 | 
					#define UNUSED_PINS
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 /* Backlight configuration
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define BACKLIGHT_LEVELS 1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Underlight configuration
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define ws2812_PORTREG PORTD
 | 
				
			||||||
 | 
					#define ws2812_DDRREG DDRD
 | 
				
			||||||
 | 
					#define ws2812_pin 7
 | 
				
			||||||
 | 
					#define RGBLED_NUM 14     // Number of LEDs
 | 
				
			||||||
 | 
					#define RGBLIGHT_HUE_STEP 10
 | 
				
			||||||
 | 
					#define RGBLIGHT_SAT_STEP 17
 | 
				
			||||||
 | 
					#define RGBLIGHT_VAL_STEP 17
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										47
									
								
								keyboards/clueboard/rev2/rev2.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								keyboards/clueboard/rev2/rev2.c
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,47 @@
 | 
				
			||||||
 | 
					#include "rev2.h"
 | 
				
			||||||
 | 
					#include <avr/io.h>
 | 
				
			||||||
 | 
					#include "backlight.h"
 | 
				
			||||||
 | 
					#include "print.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void matrix_init_kb(void) {
 | 
				
			||||||
 | 
						// put your keyboard start-up code here
 | 
				
			||||||
 | 
						// runs once when the firmware starts up
 | 
				
			||||||
 | 
						matrix_init_user();
 | 
				
			||||||
 | 
						led_init_ports();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // JTAG disable for PORT F. write JTD bit twice within four cycles.
 | 
				
			||||||
 | 
					    MCUCR |= (1<<JTD);
 | 
				
			||||||
 | 
					    MCUCR |= (1<<JTD);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void matrix_scan_kb(void) {
 | 
				
			||||||
 | 
					    matrix_scan_user();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void backlight_init_ports(void) {
 | 
				
			||||||
 | 
					    print("init_backlight_pin()\n");
 | 
				
			||||||
 | 
					    // Set our LED pins as output
 | 
				
			||||||
 | 
					    DDRD |= (1<<6); // Esc
 | 
				
			||||||
 | 
					    DDRB |= (1<<7); // Page Up
 | 
				
			||||||
 | 
					    DDRD |= (1<<4); // Arrows
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Set our LED pins low
 | 
				
			||||||
 | 
					    PORTD &= ~(1<<6); // Esc
 | 
				
			||||||
 | 
					    PORTB &= ~(1<<7); // Page Up
 | 
				
			||||||
 | 
					    PORTD &= ~(1<<4); // Arrows
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void backlight_set(uint8_t level) {
 | 
				
			||||||
 | 
					    if ( level == 0 ) {
 | 
				
			||||||
 | 
					        // Turn off light
 | 
				
			||||||
 | 
					        PORTD |= (1<<6); // Esc
 | 
				
			||||||
 | 
					        PORTB |= (1<<7); // Page Up
 | 
				
			||||||
 | 
					        PORTD |= (1<<4); // Arrows
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        // Turn on light
 | 
				
			||||||
 | 
					        PORTD &= ~(1<<6); // Esc
 | 
				
			||||||
 | 
					        PORTB &= ~(1<<7); // Page Up
 | 
				
			||||||
 | 
					        PORTD &= ~(1<<4); // Arrows
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -1,8 +1,7 @@
 | 
				
			||||||
#ifndef CLUEBOARD2_H
 | 
					#ifndef REV2_H
 | 
				
			||||||
#define CLUEBOARD2_H
 | 
					#define REV2_H
 | 
				
			||||||
 | 
					 | 
				
			||||||
#include "quantum.h"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "../clueboard.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Clueboard matrix layout
 | 
					/* Clueboard matrix layout
 | 
				
			||||||
 * ,-----------------------------------------------------------.  ,---.
 | 
					 * ,-----------------------------------------------------------.  ,---.
 | 
				
			||||||
| 
						 | 
					@ -30,6 +29,7 @@
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
// The first section contains all of the arguments
 | 
					// The first section contains all of the arguments
 | 
				
			||||||
// The second converts the arguments into a two-dimensional array
 | 
					// The second converts the arguments into a two-dimensional array
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define KEYMAP( \
 | 
					#define KEYMAP( \
 | 
				
			||||||
    k00, k01, k02, k03, k04, k05, k06, k07, k50, k51, k52, k53, k54, k55, k56, k57, \
 | 
					    k00, k01, k02, k03, k04, k05, k06, k07, k50, k51, k52, k53, k54, k55, k56, k57, \
 | 
				
			||||||
    k10, k11, k12, k13, k14, k15, k16, k17, k60, k61, k62, k63, k64, k65,      k67, \
 | 
					    k10, k11, k12, k13, k14, k15, k16, k17, k60, k61, k62, k63, k64, k65,      k67, \
 | 
				
			||||||
| 
						 | 
					@ -1,184 +0,0 @@
 | 
				
			||||||
#include "clueboard1.h"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef RGBLIGHT_ENABLE
 | 
					 | 
				
			||||||
#include "rgblight.h"
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// Used for SHIFT_ESC
 | 
					 | 
				
			||||||
#define MODS_CTRL_MASK  (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT))
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// Each layer gets a name for readability, which is then used in the keymap matrix below.
 | 
					 | 
				
			||||||
// The underscores don't mean anything - you can have a layer called STUFF or any other name.
 | 
					 | 
				
			||||||
// Layer names don't all need to be of the same length, obviously, and you can also skip them
 | 
					 | 
				
			||||||
// entirely and just use numbers.
 | 
					 | 
				
			||||||
#define _BL 0
 | 
					 | 
				
			||||||
#define _FL 1
 | 
					 | 
				
			||||||
#define _RS 2
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
 | 
					 | 
				
			||||||
  /* Keymap _BL: (Base Layer) Default Layer
 | 
					 | 
				
			||||||
   * ,--------------------------------------------------------------------------.  ,----.
 | 
					 | 
				
			||||||
   * |Esc~|   1|   2|   3|   4|   5|   6|   7|   8|   9|   0|   -|   =|   \|  BS|  |PGUP|
 | 
					 | 
				
			||||||
   * |--------------------------------------------------------------------------|  |----|
 | 
					 | 
				
			||||||
   * |   Tab|   Q|   W|   E|   R|   T|   Y|   U|   I|   O|   P|   [|   ]|      \|  |PGDN|
 | 
					 | 
				
			||||||
   * |--------------------------------------------------------------------------|  `----'
 | 
					 | 
				
			||||||
   * |Capslck|   A|   S|   D|   F|   G|   H|   J|   K|   L|   ;|   '|   # |  Ent|
 | 
					 | 
				
			||||||
   * |-----------------------------------------------------------------------------.
 | 
					 | 
				
			||||||
   * |Shift|  BS|   Z|   X|   C|   V|   B|   N|   M|   ,|   .|   /|   BS|Shift|  UP|
 | 
					 | 
				
			||||||
   * |------------------------------------------------------------------------|----|----.
 | 
					 | 
				
			||||||
   * | Ctrl|  Gui|  Alt| MHen|    Space|    Space|  Hen|  Alt| Ctrl|  _FL|LEFT|DOWN|RGHT|
 | 
					 | 
				
			||||||
   * `----------------------------------------------------------------------------------'
 | 
					 | 
				
			||||||
   */
 | 
					 | 
				
			||||||
[_BL] = KEYMAP(
 | 
					 | 
				
			||||||
  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_GRV,  KC_BSPC,          KC_PGUP, \
 | 
					 | 
				
			||||||
  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_BSLS,                   KC_PGDN, \
 | 
					 | 
				
			||||||
  KC_CAPS, KC_A,    KC_S,   KC_D,   KC_F,   KC_G,   KC_H,   KC_J,   KC_K,   KC_L,    KC_SCLN,  KC_QUOT,  KC_NUHS,  KC_ENT,                             \
 | 
					 | 
				
			||||||
  KC_LSFT, KC_NUBS, KC_Z,   KC_X,   KC_C,   KC_V,   KC_B,   KC_N,   KC_M,   KC_COMM, KC_DOT,   KC_SLSH,  KC_RO,    KC_RSFT,          KC_UP,            \
 | 
					 | 
				
			||||||
  KC_LCTL, KC_LGUI, KC_LALT, KC_MHEN,          KC_SPC,KC_SPC,                        KC_HENK,  KC_RALT,  KC_RCTL,  MO(_FL), KC_LEFT, KC_DOWN, KC_RGHT),
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  /* Keymap _FL: Function Layer
 | 
					 | 
				
			||||||
   * ,--------------------------------------------------------------------------.  ,----.
 | 
					 | 
				
			||||||
   * |   `|  F1|  F2|  F3|  F4|  F5|  F6|  F7|  F8|  F9| F10| F11| F12|    | Del|  |BLIN|
 | 
					 | 
				
			||||||
   * |--------------------------------------------------------------------------|  |----|
 | 
					 | 
				
			||||||
   * |      |    |    |    |    |    |    |    |PScr|SLck|Paus|    |    |       |  |BLDE|
 | 
					 | 
				
			||||||
   * |--------------------------------------------------------------------------|  `----'
 | 
					 | 
				
			||||||
   * |       |    | _RS|    |    |    |    |    |    |    |    |    |     |     |
 | 
					 | 
				
			||||||
   * |-----------------------------------------------------------------------------.
 | 
					 | 
				
			||||||
   * |     |    |    |    |    |    |    |    |    |    |    |    |     |     |PGUP|
 | 
					 | 
				
			||||||
   * |------------------------------------------------------------------------|----|----.
 | 
					 | 
				
			||||||
   * |     |     |     |     |         |         |     |     |     |  _FL|HOME|PGDN| END|
 | 
					 | 
				
			||||||
   * `----------------------------------------------------------------------------------'
 | 
					 | 
				
			||||||
   */
 | 
					 | 
				
			||||||
[_FL] = KEYMAP(
 | 
					 | 
				
			||||||
  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_DEL,           BL_STEP, \
 | 
					 | 
				
			||||||
  KC_TRNS, KC_TRNS, KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_PSCR,KC_SLCK, KC_PAUS,  KC_TRNS,  KC_TRNS,  KC_TRNS,                   KC_TRNS, \
 | 
					 | 
				
			||||||
  KC_TRNS, KC_TRNS, MO(_RS),KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS,                           \
 | 
					 | 
				
			||||||
  KC_TRNS, KC_TRNS, KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS,          KC_PGUP,         \
 | 
					 | 
				
			||||||
  KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,        KC_TRNS,KC_TRNS,                        KC_TRNS,  KC_TRNS,  KC_TRNS,  MO(_FL), KC_HOME, KC_PGDN, KC_END),
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  /* Keymap _RS: Reset layer
 | 
					 | 
				
			||||||
   * ,--------------------------------------------------------------------------.  ,----.
 | 
					 | 
				
			||||||
   * |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |    |
 | 
					 | 
				
			||||||
   * |--------------------------------------------------------------------------|  |----|
 | 
					 | 
				
			||||||
   * |      |    |    |    |RESET|   |    |    |    |    |    |    |    |       |  |    |
 | 
					 | 
				
			||||||
   * |--------------------------------------------------------------------------|  `----'
 | 
					 | 
				
			||||||
   * |       |    | _RS|    |    |    |    |    |    |    |    |    |     |     |
 | 
					 | 
				
			||||||
   * |-----------------------------------------------------------------------------.
 | 
					 | 
				
			||||||
   * |     |    |    |    |    |    |    |    |    |    |    |    |     |     |    |
 | 
					 | 
				
			||||||
   * |------------------------------------------------------------------------|----|----.
 | 
					 | 
				
			||||||
   * |     |     |     |     |         |         |     |     |     |  _FL|    |    |    |
 | 
					 | 
				
			||||||
   * `----------------------------------------------------------------------------------'
 | 
					 | 
				
			||||||
   */
 | 
					 | 
				
			||||||
[_RS] = KEYMAP(
 | 
					 | 
				
			||||||
  #ifdef RGBLIGHT_ENABLE
 | 
					 | 
				
			||||||
  KC_TRNS, KC_TRNS, KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS, F(1),             F(7), \
 | 
					 | 
				
			||||||
  KC_TRNS, KC_TRNS, KC_TRNS,KC_TRNS,RESET,  KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS,                   F(8), \
 | 
					 | 
				
			||||||
  KC_TRNS, KC_TRNS, MO(_RS),KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS,                         \
 | 
					 | 
				
			||||||
  MO(_FL), KC_TRNS, KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, KC_TRNS,  KC_TRNS,  KC_TRNS,  MO(_FL),          F(5),          \
 | 
					 | 
				
			||||||
  KC_TRNS, KC_TRNS, KC_TRNS,KC_TRNS,        F(2),   F(2),                            KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS, F(4),    F(6),    F(3)),
 | 
					 | 
				
			||||||
  #else
 | 
					 | 
				
			||||||
  KC_TRNS, KC_TRNS, KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS, KC_TRNS,          KC_TRNS, \
 | 
					 | 
				
			||||||
  KC_TRNS, KC_TRNS, KC_TRNS,KC_TRNS,RESET,  KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS,                   KC_TRNS, \
 | 
					 | 
				
			||||||
  KC_TRNS, KC_TRNS, MO(_RS),KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS,                            \
 | 
					 | 
				
			||||||
  KC_TRNS, KC_TRNS, KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS, KC_TRNS,  KC_TRNS,  KC_TRNS,  KC_TRNS,          KC_TRNS,          \
 | 
					 | 
				
			||||||
  KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,        KC_TRNS,KC_TRNS,                        KC_TRNS,  KC_TRNS,  KC_TRNS,  MO(_FL), KC_TRNS, KC_TRNS, KC_TRNS),
 | 
					 | 
				
			||||||
  #endif
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
enum function_id {
 | 
					 | 
				
			||||||
    SHIFT_ESC,
 | 
					 | 
				
			||||||
    #ifdef RGBLIGHT_ENABLE
 | 
					 | 
				
			||||||
    RGBLED_TOGGLE,
 | 
					 | 
				
			||||||
    RGBLED_STEP_MODE,
 | 
					 | 
				
			||||||
    RGBLED_INCREASE_HUE,
 | 
					 | 
				
			||||||
    RGBLED_DECREASE_HUE,
 | 
					 | 
				
			||||||
    RGBLED_INCREASE_SAT,
 | 
					 | 
				
			||||||
    RGBLED_DECREASE_SAT,
 | 
					 | 
				
			||||||
    RGBLED_INCREASE_VAL,
 | 
					 | 
				
			||||||
    RGBLED_DECREASE_VAL
 | 
					 | 
				
			||||||
    #endif
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
const uint16_t PROGMEM fn_actions[] = {
 | 
					 | 
				
			||||||
  [0]  = ACTION_FUNCTION(SHIFT_ESC),
 | 
					 | 
				
			||||||
  #ifdef RGBLIGHT_ENABLE
 | 
					 | 
				
			||||||
  [1]  = ACTION_FUNCTION(RGBLED_TOGGLE),
 | 
					 | 
				
			||||||
  [2]  = ACTION_FUNCTION(RGBLED_STEP_MODE),
 | 
					 | 
				
			||||||
  [3]  = ACTION_FUNCTION(RGBLED_INCREASE_HUE),
 | 
					 | 
				
			||||||
  [4]  = ACTION_FUNCTION(RGBLED_DECREASE_HUE),
 | 
					 | 
				
			||||||
  [5]  = ACTION_FUNCTION(RGBLED_INCREASE_SAT),
 | 
					 | 
				
			||||||
  [6]  = ACTION_FUNCTION(RGBLED_DECREASE_SAT),
 | 
					 | 
				
			||||||
  [7]  = ACTION_FUNCTION(RGBLED_INCREASE_VAL),
 | 
					 | 
				
			||||||
  [8]  = ACTION_FUNCTION(RGBLED_DECREASE_VAL),
 | 
					 | 
				
			||||||
  #endif
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
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;
 | 
					 | 
				
			||||||
    //led operations
 | 
					 | 
				
			||||||
    #ifdef RGBLIGHT_ENABLE
 | 
					 | 
				
			||||||
    case RGBLED_TOGGLE:
 | 
					 | 
				
			||||||
      if (record->event.pressed) {
 | 
					 | 
				
			||||||
        rgblight_toggle();
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      break;
 | 
					 | 
				
			||||||
    case RGBLED_INCREASE_HUE:
 | 
					 | 
				
			||||||
      if (record->event.pressed) {
 | 
					 | 
				
			||||||
        rgblight_increase_hue();
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      break;
 | 
					 | 
				
			||||||
    case RGBLED_DECREASE_HUE:
 | 
					 | 
				
			||||||
      if (record->event.pressed) {
 | 
					 | 
				
			||||||
        rgblight_decrease_hue();
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      break;
 | 
					 | 
				
			||||||
    case RGBLED_INCREASE_SAT:
 | 
					 | 
				
			||||||
      if (record->event.pressed) {
 | 
					 | 
				
			||||||
        rgblight_increase_sat();
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      break;
 | 
					 | 
				
			||||||
    case RGBLED_DECREASE_SAT:
 | 
					 | 
				
			||||||
      if (record->event.pressed) {
 | 
					 | 
				
			||||||
        rgblight_decrease_sat();
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      break;
 | 
					 | 
				
			||||||
    case RGBLED_INCREASE_VAL:
 | 
					 | 
				
			||||||
      if (record->event.pressed) {
 | 
					 | 
				
			||||||
        rgblight_increase_val();
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      break;
 | 
					 | 
				
			||||||
    case RGBLED_DECREASE_VAL:
 | 
					 | 
				
			||||||
      if (record->event.pressed) {
 | 
					 | 
				
			||||||
        rgblight_decrease_val();
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      break;
 | 
					 | 
				
			||||||
    case RGBLED_STEP_MODE:
 | 
					 | 
				
			||||||
      if (record->event.pressed) {
 | 
					 | 
				
			||||||
        rgblight_step();
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      break;
 | 
					 | 
				
			||||||
    #endif
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
| 
						 | 
					@ -1,99 +0,0 @@
 | 
				
			||||||
/*
 | 
					 | 
				
			||||||
Copyright 2012 Jun Wako <wakojun@gmail.com>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
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 2 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/>.
 | 
					 | 
				
			||||||
*/
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifndef CONFIG_H
 | 
					 | 
				
			||||||
#define CONFIG_H
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#include "config_common.h"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* USB Device descriptor parameter */
 | 
					 | 
				
			||||||
#define VENDOR_ID       0xC1ED
 | 
					 | 
				
			||||||
#define PRODUCT_ID      0x2320
 | 
					 | 
				
			||||||
#define DEVICE_VER      0x0001
 | 
					 | 
				
			||||||
#define MANUFACTURER    Clueboard
 | 
					 | 
				
			||||||
#define PRODUCT         Clueboard with RGB Underlighting
 | 
					 | 
				
			||||||
#define DESCRIPTION     QMK keyboard firmware for Clueboard
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* key matrix size */
 | 
					 | 
				
			||||||
#define MATRIX_ROWS 10
 | 
					 | 
				
			||||||
#define MATRIX_COLS 8
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// ROWS: Top to bottom, COLS: Left to right
 | 
					 | 
				
			||||||
/* Row pin configuration
 | 
					 | 
				
			||||||
* row: 0  1  2  3  4  5  6  7  8  9
 | 
					 | 
				
			||||||
* pin: B2 C7 C6 B6 B5 B0 B3 D5 D3 D2
 | 
					 | 
				
			||||||
*/
 | 
					 | 
				
			||||||
#define MATRIX_ROW_PINS { B2, C7, C6, B6, B5, B0, B3, D5, D3, D2 }
 | 
					 | 
				
			||||||
/* Column pin configuration
 | 
					 | 
				
			||||||
 * col: 0  1  2  3  4  5  6  7
 | 
					 | 
				
			||||||
 * pin: F0 F1 F4 F5 F6 F7 E6 B1
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
#define MATRIX_COL_PINS { F0, F1, F4, F5, F6, F7, E6, B1 }
 | 
					 | 
				
			||||||
#define UNUSED_PINS
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* COL2ROW or ROW2COL */
 | 
					 | 
				
			||||||
#define DIODE_DIRECTION COL2ROW
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* define if matrix has ghost */
 | 
					 | 
				
			||||||
//#define MATRIX_HAS_GHOST
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* Set 0 if debouncing isn't needed */
 | 
					 | 
				
			||||||
#define DEBOUNCING_DELAY 5
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */
 | 
					 | 
				
			||||||
#define LOCKING_SUPPORT_ENABLE
 | 
					 | 
				
			||||||
/* Locking resynchronize hack */
 | 
					 | 
				
			||||||
#define LOCKING_RESYNC_ENABLE
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* key combination for command */
 | 
					 | 
				
			||||||
#define IS_COMMAND() ( \
 | 
					 | 
				
			||||||
    keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) \
 | 
					 | 
				
			||||||
)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* Backlight configuration
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
#define BACKLIGHT_LEVELS 1
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* Underlight configuration
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
 #define ws2812_PORTREG PORTD
 | 
					 | 
				
			||||||
 #define ws2812_DDRREG DDRD
 | 
					 | 
				
			||||||
 #define ws2812_pin 7
 | 
					 | 
				
			||||||
 #define RGBLED_NUM 14     // Number of LEDs
 | 
					 | 
				
			||||||
 #define RGBLIGHT_HUE_STEP 10
 | 
					 | 
				
			||||||
 #define RGBLIGHT_SAT_STEP 17
 | 
					 | 
				
			||||||
 #define RGBLIGHT_VAL_STEP 17
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/*
 | 
					 | 
				
			||||||
 * Feature disable options
 | 
					 | 
				
			||||||
 *  These options are also useful to firmware size reduction.
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* disable debug print */
 | 
					 | 
				
			||||||
//#define NO_DEBUG
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* disable print */
 | 
					 | 
				
			||||||
//#define NO_PRINT
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/* disable action features */
 | 
					 | 
				
			||||||
//#define NO_ACTION_LAYER
 | 
					 | 
				
			||||||
//#define NO_ACTION_TAPPING
 | 
					 | 
				
			||||||
//#define NO_ACTION_ONESHOT
 | 
					 | 
				
			||||||
//#define NO_ACTION_MACRO
 | 
					 | 
				
			||||||
//#define NO_ACTION_FUNCTION
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
| 
						 | 
					@ -1,11 +0,0 @@
 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Build Options
 | 
					 | 
				
			||||||
#   change to "no" to disable the options, or define them in the Makefile in 
 | 
					 | 
				
			||||||
#   the appropriate keymap folder that will get included automatically
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
RGBLIGHT_ENABLE = yes        # Enable WS2812 RGB underlight.  Do not enable this with audio at the same time.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
ifndef QUANTUM_DIR
 | 
					 | 
				
			||||||
	include ../../../../Makefile
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
| 
						 | 
					@ -1,8 +1,4 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
# # project specific files
 | 
					 | 
				
			||||||
SRC = backlight.c
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# MCU name
 | 
					# MCU name
 | 
				
			||||||
#MCU = at90usb1287
 | 
					#MCU = at90usb1287
 | 
				
			||||||
MCU = atmega32u4
 | 
					MCU = atmega32u4
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,54 +0,0 @@
 | 
				
			||||||
#include <avr/io.h>
 | 
					 | 
				
			||||||
#include "backlight.h"
 | 
					 | 
				
			||||||
#include "led.h"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#include "print.h"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int pwm_level;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
void led_set_kb(uint8_t usb_led)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
    print("led_set\n");
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
void init_backlight_pin(void)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
    // Set C7 to output
 | 
					 | 
				
			||||||
    DDRC |= (1<<7);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    // Initialize the timer
 | 
					 | 
				
			||||||
    TC4H = 0x03;
 | 
					 | 
				
			||||||
    OCR4C = 0xFF;
 | 
					 | 
				
			||||||
    TCCR4A = 0b10000010;
 | 
					 | 
				
			||||||
    TCCR4B = 0b00000001;
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
void backlight_set(uint8_t level)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
    // Determine the PWM level
 | 
					 | 
				
			||||||
    switch (level)
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        case 0:
 | 
					 | 
				
			||||||
            // 33%
 | 
					 | 
				
			||||||
            pwm_level = 0x54;
 | 
					 | 
				
			||||||
            break;
 | 
					 | 
				
			||||||
        case 1:
 | 
					 | 
				
			||||||
            // 66%
 | 
					 | 
				
			||||||
            pwm_level = 0xA8;
 | 
					 | 
				
			||||||
            break;
 | 
					 | 
				
			||||||
        case 2:
 | 
					 | 
				
			||||||
            // 100%
 | 
					 | 
				
			||||||
            pwm_level = 0xFF;
 | 
					 | 
				
			||||||
            break;
 | 
					 | 
				
			||||||
        case 3:
 | 
					 | 
				
			||||||
            // 0%
 | 
					 | 
				
			||||||
            pwm_level = 0x00;
 | 
					 | 
				
			||||||
            break;
 | 
					 | 
				
			||||||
        default:
 | 
					 | 
				
			||||||
            xprintf("Unknown level: %d\n", level);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    // Write the PWM level to the timer
 | 
					 | 
				
			||||||
    TC4H = pwm_level >> 8;
 | 
					 | 
				
			||||||
    OCR4A = 0xFF & pwm_level;
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
| 
						 | 
					@ -1,15 +1,60 @@
 | 
				
			||||||
#include "cluepad.h"
 | 
					#include "cluepad.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int pwm_level;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void matrix_init_kb(void) {
 | 
					void matrix_init_kb(void) {
 | 
				
			||||||
    // put your keyboard start-up code here
 | 
					    // put your keyboard start-up code here
 | 
				
			||||||
    // runs once when the firmware starts up
 | 
					    // runs once when the firmware starts up
 | 
				
			||||||
    matrix_init_user();
 | 
					    matrix_init_user();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    #ifdef BACKLIGHT_ENABLE
 | 
					 | 
				
			||||||
        init_backlight_pin();
 | 
					 | 
				
			||||||
    #endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    // JTAG disable for PORT F. write JTD bit twice within four cycles.
 | 
					    // JTAG disable for PORT F. write JTD bit twice within four cycles.
 | 
				
			||||||
    MCUCR |= (1<<JTD);
 | 
					    MCUCR |= (1<<JTD);
 | 
				
			||||||
    MCUCR |= (1<<JTD);
 | 
					    MCUCR |= (1<<JTD);
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void led_set_kb(uint8_t usb_led)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    print("led_set\n");
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void backlight_init_ports(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    // Set C7 to output
 | 
				
			||||||
 | 
					    DDRC |= (1<<7);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Initialize the timer
 | 
				
			||||||
 | 
					    TC4H = 0x03;
 | 
				
			||||||
 | 
					    OCR4C = 0xFF;
 | 
				
			||||||
 | 
					    TCCR4A = 0b10000010;
 | 
				
			||||||
 | 
					    TCCR4B = 0b00000001;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void backlight_set(uint8_t level)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    // Determine the PWM level
 | 
				
			||||||
 | 
					    switch (level)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        case 0:
 | 
				
			||||||
 | 
					            // 33%
 | 
				
			||||||
 | 
					            pwm_level = 0x54;
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
 | 
					        case 1:
 | 
				
			||||||
 | 
					            // 66%
 | 
				
			||||||
 | 
					            pwm_level = 0xA8;
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
 | 
					        case 2:
 | 
				
			||||||
 | 
					            // 100%
 | 
				
			||||||
 | 
					            pwm_level = 0xFF;
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
 | 
					        case 3:
 | 
				
			||||||
 | 
					            // 0%
 | 
				
			||||||
 | 
					            pwm_level = 0x00;
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
 | 
					        default:
 | 
				
			||||||
 | 
					            xprintf("Unknown level: %d\n", level);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Write the PWM level to the timer
 | 
				
			||||||
 | 
					    TC4H = pwm_level >> 8;
 | 
				
			||||||
 | 
					    OCR4A = 0xFF & pwm_level;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,9 +1,7 @@
 | 
				
			||||||
#ifndef CLUEPAD_H
 | 
					#ifndef CLUEPAD_H
 | 
				
			||||||
#define CLUEPAD_H
 | 
					#define CLUEPAD_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include "matrix.h"
 | 
					#include "quantum.h"
 | 
				
			||||||
#include "keymap.h"
 | 
					 | 
				
			||||||
#include <stddef.h>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Cluepad matrix layout
 | 
					/* Cluepad matrix layout
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,4 +1,5 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SUBPROJECT_DEFAULT = rev4
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# MCU name
 | 
					# MCU name
 | 
				
			||||||
#MCU = at90usb1287
 | 
					#MCU = at90usb1287
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -23,7 +23,6 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
/* USB Device descriptor parameter */
 | 
					/* USB Device descriptor parameter */
 | 
				
			||||||
#define VENDOR_ID       0xFEED
 | 
					#define VENDOR_ID       0xFEED
 | 
				
			||||||
#define PRODUCT_ID      0x6060
 | 
					#define PRODUCT_ID      0x6060
 | 
				
			||||||
#define DEVICE_VER      0x0001
 | 
					 | 
				
			||||||
#define MANUFACTURER    Ortholinear Keyboards
 | 
					#define MANUFACTURER    Ortholinear Keyboards
 | 
				
			||||||
#define PRODUCT         The Planck Keyboard
 | 
					#define PRODUCT         The Planck Keyboard
 | 
				
			||||||
#define DESCRIPTION     A compact ortholinear keyboard
 | 
					#define DESCRIPTION     A compact ortholinear keyboard
 | 
				
			||||||
| 
						 | 
					@ -79,4 +78,11 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
//#define NO_ACTION_MACRO
 | 
					//#define NO_ACTION_MACRO
 | 
				
			||||||
//#define NO_ACTION_FUNCTION
 | 
					//#define NO_ACTION_FUNCTION
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SUBPROJECT_rev3
 | 
				
			||||||
 | 
					    #include "rev3/config.h"
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef SUBPROJECT_rev4
 | 
				
			||||||
 | 
					    #include "rev4/config.h"
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -4,5 +4,6 @@
 | 
				
			||||||
#include "../../config.h"
 | 
					#include "../../config.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define LEADER_TIMEOUT 300
 | 
					#define LEADER_TIMEOUT 300
 | 
				
			||||||
 | 
					#define BACKLIGHT_BREATHING
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -3,6 +3,7 @@
 | 
				
			||||||
#   the appropriate keymap folder that will get included automatically
 | 
					#   the appropriate keymap folder that will get included automatically
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
RGBLIGHT_ENABLE = yes        # Enable WS2812 RGB underlight.  Do not enable this with audio at the same time.
 | 
					RGBLIGHT_ENABLE = yes        # Enable WS2812 RGB underlight.  Do not enable this with audio at the same time.
 | 
				
			||||||
 | 
					AUDIO_ENABLE = no
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifndef QUANTUM_DIR
 | 
					ifndef QUANTUM_DIR
 | 
				
			||||||
	include ../../../../Makefile
 | 
						include ../../../../Makefile
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,6 +1,13 @@
 | 
				
			||||||
#ifndef PLANCK_H
 | 
					#ifndef PLANCK_H
 | 
				
			||||||
#define PLANCK_H
 | 
					#define PLANCK_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SUBPROJECT_rev3
 | 
				
			||||||
 | 
					    #include "rev3.h"
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef SUBPROJECT_rev4
 | 
				
			||||||
 | 
					    #include "rev4.h"
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include "quantum.h"
 | 
					#include "quantum.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define PLANCK_MIT( \
 | 
					#define PLANCK_MIT( \
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										5
									
								
								keyboards/planck/rev3/Makefile
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								keyboards/planck/rev3/Makefile
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,5 @@
 | 
				
			||||||
 | 
					AUDIO_ENABLE = no           # Audio output on port C6
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifndef QUANTUM_DIR
 | 
				
			||||||
 | 
						include ../../../Makefile
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
							
								
								
									
										8
									
								
								keyboards/planck/rev3/config.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								keyboards/planck/rev3/config.h
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,8 @@
 | 
				
			||||||
 | 
					#ifndef REV3_CONFIG_H
 | 
				
			||||||
 | 
					#define REV3_CONFIG_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "../config.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define DEVICE_VER 0x0003
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										1
									
								
								keyboards/planck/rev3/rev3.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								keyboards/planck/rev3/rev3.c
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					#include "rev3.h"
 | 
				
			||||||
							
								
								
									
										6
									
								
								keyboards/planck/rev3/rev3.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								keyboards/planck/rev3/rev3.h
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,6 @@
 | 
				
			||||||
 | 
					#ifndef REV3_H
 | 
				
			||||||
 | 
					#define REV3_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "../planck.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										5
									
								
								keyboards/planck/rev4/Makefile
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								keyboards/planck/rev4/Makefile
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,5 @@
 | 
				
			||||||
 | 
					AUDIO_ENABLE = yes           # Audio output on port C6
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifndef QUANTUM_DIR
 | 
				
			||||||
 | 
						include ../../../Makefile
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
							
								
								
									
										8
									
								
								keyboards/planck/rev4/config.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								keyboards/planck/rev4/config.h
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,8 @@
 | 
				
			||||||
 | 
					#ifndef REV4_CONFIG_H
 | 
				
			||||||
 | 
					#define REV4_CONFIG_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "../config.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define DEVICE_VER 0x0004
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
							
								
								
									
										1
									
								
								keyboards/planck/rev4/rev4.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								keyboards/planck/rev4/rev4.c
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					#include "rev4.h"
 | 
				
			||||||
							
								
								
									
										6
									
								
								keyboards/planck/rev4/rev4.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								keyboards/planck/rev4/rev4.h
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,6 @@
 | 
				
			||||||
 | 
					#ifndef REV4_H
 | 
				
			||||||
 | 
					#define REV4_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "../planck.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
| 
						 | 
					@ -23,8 +23,7 @@ Made in Taiwan using advanced robotic manufacturing, the ErgoDox EZ is a fully-a
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Designed and built in Felton, CA, Clueboards keyboard emphasize quality and locally sourced components, available on [clueboard.co](http://clueboard.co)
 | 
					Designed and built in Felton, CA, Clueboards keyboard emphasize quality and locally sourced components, available on [clueboard.co](http://clueboard.co)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* [Clueboard rev.1](/keyboards/clueboard1/) - The old Clueboard.
 | 
					* [Clueboard](/keyboards/clueboard/) - The 66% custom keyboard.
 | 
				
			||||||
* [Clueboard rev.2](/keyboards/clueboard2/) - New and improved! The Clueboard, revision 2.
 | 
					 | 
				
			||||||
* [Cluepad](/keyboards/cluepad/) - A mechanical numpad with QMK superpowers.
 | 
					* [Cluepad](/keyboards/cluepad/) - A mechanical numpad with QMK superpowers.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,3 +1,6 @@
 | 
				
			||||||
 | 
					#ifndef AUDIO_H
 | 
				
			||||||
 | 
					#define AUDIO_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <stdint.h>
 | 
					#include <stdint.h>
 | 
				
			||||||
#include <stdbool.h>
 | 
					#include <stdbool.h>
 | 
				
			||||||
#include <avr/io.h>
 | 
					#include <avr/io.h>
 | 
				
			||||||
| 
						 | 
					@ -7,9 +10,6 @@
 | 
				
			||||||
#include "voices.h"
 | 
					#include "voices.h"
 | 
				
			||||||
#include "quantum.h"
 | 
					#include "quantum.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef AUDIO_H
 | 
					 | 
				
			||||||
#define AUDIO_H
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// Largely untested PWM audio mode (doesn't sound as good)
 | 
					// Largely untested PWM audio mode (doesn't sound as good)
 | 
				
			||||||
// #define PWM_AUDIO
 | 
					// #define PWM_AUDIO
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -86,29 +86,29 @@ uint8_t matrix_cols(void) {
 | 
				
			||||||
    return MATRIX_COLS;
 | 
					    return MATRIX_COLS;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void matrix_power_up(void) {
 | 
					// void matrix_power_up(void) {
 | 
				
			||||||
#if DIODE_DIRECTION == COL2ROW
 | 
					// #if DIODE_DIRECTION == COL2ROW
 | 
				
			||||||
    for (int8_t r = MATRIX_ROWS - 1; r >= 0; --r) {
 | 
					//     for (int8_t r = MATRIX_ROWS - 1; r >= 0; --r) {
 | 
				
			||||||
        /* DDRxn */
 | 
					//         /* DDRxn */
 | 
				
			||||||
        _SFR_IO8((row_pins[r] >> 4) + 1) |= _BV(row_pins[r] & 0xF);
 | 
					//         _SFR_IO8((row_pins[r] >> 4) + 1) |= _BV(row_pins[r] & 0xF);
 | 
				
			||||||
        toggle_row(r);
 | 
					//         toggle_row(r);
 | 
				
			||||||
    }
 | 
					//     }
 | 
				
			||||||
    for (int8_t c = MATRIX_COLS - 1; c >= 0; --c) {
 | 
					//     for (int8_t c = MATRIX_COLS - 1; c >= 0; --c) {
 | 
				
			||||||
        /* PORTxn */
 | 
					//         /* PORTxn */
 | 
				
			||||||
        _SFR_IO8((col_pins[c] >> 4) + 2) |= _BV(col_pins[c] & 0xF);
 | 
					//         _SFR_IO8((col_pins[c] >> 4) + 2) |= _BV(col_pins[c] & 0xF);
 | 
				
			||||||
    }
 | 
					//     }
 | 
				
			||||||
#else
 | 
					// #else
 | 
				
			||||||
    for (int8_t c = MATRIX_COLS - 1; c >= 0; --c) {
 | 
					//     for (int8_t c = MATRIX_COLS - 1; c >= 0; --c) {
 | 
				
			||||||
        /* DDRxn */
 | 
					//         /* DDRxn */
 | 
				
			||||||
        _SFR_IO8((col_pins[c] >> 4) + 1) |= _BV(col_pins[c] & 0xF);
 | 
					//         _SFR_IO8((col_pins[c] >> 4) + 1) |= _BV(col_pins[c] & 0xF);
 | 
				
			||||||
        toggle_col(c);
 | 
					//         toggle_col(c);
 | 
				
			||||||
    }
 | 
					//     }
 | 
				
			||||||
    for (int8_t r = MATRIX_ROWS - 1; r >= 0; --r) {
 | 
					//     for (int8_t r = MATRIX_ROWS - 1; r >= 0; --r) {
 | 
				
			||||||
        /* PORTxn */
 | 
					//         /* PORTxn */
 | 
				
			||||||
        _SFR_IO8((row_pins[r] >> 4) + 2) |= _BV(row_pins[r] & 0xF);
 | 
					//         _SFR_IO8((row_pins[r] >> 4) + 2) |= _BV(row_pins[r] & 0xF);
 | 
				
			||||||
    }
 | 
					//     }
 | 
				
			||||||
#endif
 | 
					// #endif
 | 
				
			||||||
}
 | 
					// }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void matrix_init(void) {
 | 
					void matrix_init(void) {
 | 
				
			||||||
    /* frees PORTF by setting the JTD bit twice within four cycles */
 | 
					    /* frees PORTF by setting the JTD bit twice within four cycles */
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -14,8 +14,7 @@ For an easy-to-read version of this document and the repository, check out [http
 | 
				
			||||||
* [Preonic](/keyboards/preonic/)
 | 
					* [Preonic](/keyboards/preonic/)
 | 
				
			||||||
* [Atomic](/keyboards/atomic/)
 | 
					* [Atomic](/keyboards/atomic/)
 | 
				
			||||||
* [ErgoDox EZ](/keyboards/ergodox_ez/)
 | 
					* [ErgoDox EZ](/keyboards/ergodox_ez/)
 | 
				
			||||||
* [Clueboard rev.1](/keyboards/clueboard1/)
 | 
					* [Clueboard](/keyboards/clueboard/)
 | 
				
			||||||
* [Clueboard rev.2](/keyboards/clueboard2/)
 | 
					 | 
				
			||||||
* [Cluepad](/keyboards/cluepad/)
 | 
					* [Cluepad](/keyboards/cluepad/)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
The project also includes community support for [lots of other keyboards](/keyboards/).
 | 
					The project also includes community support for [lots of other keyboards](/keyboards/).
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -51,6 +51,13 @@ ifeq ($(COLOR),true)
 | 
				
			||||||
	BOLD=\033[1m
 | 
						BOLD=\033[1m
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifdef quick
 | 
				
			||||||
 | 
						QUICK = $(quick)
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					QUICK ?= false
 | 
				
			||||||
 | 
					AUTOGEN ?= false
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifneq ($(shell awk --version 2>/dev/null),)
 | 
					ifneq ($(shell awk --version 2>/dev/null),)
 | 
				
			||||||
	AWK=awk
 | 
						AWK=awk
 | 
				
			||||||
else
 | 
					else
 | 
				
			||||||
| 
						 | 
					@ -524,7 +531,12 @@ extcoff: $(BUILD_DIR)/$(TARGET).elf
 | 
				
			||||||
	@$(SILENT) || printf "$(MSG_FLASH) $@" | $(AWK_CMD)
 | 
						@$(SILENT) || printf "$(MSG_FLASH) $@" | $(AWK_CMD)
 | 
				
			||||||
	$(eval CMD=$(OBJCOPY) -O $(FORMAT) -R .eeprom -R .fuse -R .lock -R .signature $< $@)
 | 
						$(eval CMD=$(OBJCOPY) -O $(FORMAT) -R .eeprom -R .fuse -R .lock -R .signature $< $@)
 | 
				
			||||||
	@$(BUILD_CMD)
 | 
						@$(BUILD_CMD)
 | 
				
			||||||
	@$(COPY) $@ $(TARGET).hex
 | 
						@if $(AUTOGEN); then \
 | 
				
			||||||
 | 
							$(SILENT) || printf "Copying $(TARGET).hex to keymaps/$(KEYMAP)/$(KEYBOARD)_$(KEYMAP).hex\n"; \
 | 
				
			||||||
 | 
							$(COPY) $@ $(KEYMAP_PATH)/$(KEYBOARD)_$(KEYMAP).hex; \
 | 
				
			||||||
 | 
						else \
 | 
				
			||||||
 | 
							$(COPY) $@ $(TARGET).hex; \
 | 
				
			||||||
 | 
						fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
%.eep: %.elf
 | 
					%.eep: %.elf
 | 
				
			||||||
	@$(SILENT) || printf "$(MSG_EEPROM) $@" | $(AWK_CMD)
 | 
						@$(SILENT) || printf "$(MSG_EEPROM) $@" | $(AWK_CMD)
 | 
				
			||||||
| 
						 | 
					@ -570,7 +582,7 @@ $(OBJDIR)/%.o : %.c
 | 
				
			||||||
$(OBJDIR)/%.o : %.cpp
 | 
					$(OBJDIR)/%.o : %.cpp
 | 
				
			||||||
	@mkdir -p $(@D)
 | 
						@mkdir -p $(@D)
 | 
				
			||||||
	@$(SILENT) || printf "$(MSG_COMPILING_CPP) $<" | $(AWK_CMD)
 | 
						@$(SILENT) || printf "$(MSG_COMPILING_CPP) $<" | $(AWK_CMD)
 | 
				
			||||||
	$(CC) -c $(ALL_CPPFLAGS) $< -o $@
 | 
						$(eval CMD=$(CC) -c $(ALL_CPPFLAGS) $< -o $@)
 | 
				
			||||||
	@$(BUILD_CMD)
 | 
						@$(BUILD_CMD)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Compile: create assembler files from C source files.
 | 
					# Compile: create assembler files from C source files.
 | 
				
			||||||
| 
						 | 
					@ -600,9 +612,11 @@ $(OBJDIR)/%.o : %.S
 | 
				
			||||||
clean: begin clean_list end
 | 
					clean: begin clean_list end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
clean_list :
 | 
					clean_list :
 | 
				
			||||||
	$(REMOVE) -r $(TOP_DIR)/$(BUILD_DIR)
 | 
						@$(REMOVE) -r $(BUILD_DIR)
 | 
				
			||||||
	$(REMOVE) -r $(KEYBOARD_PATH)/$(BUILD_DIR)
 | 
						@$(REMOVE) -r $(TOP_DIR)/$(BUILD_DIR)
 | 
				
			||||||
	$(REMOVE) -r $(KEYMAP_PATH)/$(BUILD_DIR)
 | 
						@$(REMOVE) -r $(KEYBOARD_PATH)/$(BUILD_DIR)
 | 
				
			||||||
 | 
						@if $$SUBPROJECT; then $(REMOVE) -r $(SUBPROJECT_PATH)/$(BUILD_DIR); fi
 | 
				
			||||||
 | 
						@$(REMOVE) -r $(KEYMAP_PATH)/$(BUILD_DIR)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
show_path:
 | 
					show_path:
 | 
				
			||||||
	@echo VPATH=$(VPATH)
 | 
						@echo VPATH=$(VPATH)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										23
									
								
								util/travis_compiled_push.sh
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								util/travis_compiled_push.sh
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,23 @@
 | 
				
			||||||
 | 
					#!/bin/bash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					set -o errexit -o nounset
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					rev=$(git rev-parse --short HEAD)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					git config --global user.name "Travis CI"
 | 
				
			||||||
 | 
					git config --global user.email "jack.humb+travis.ci@gmail.com"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					find . -name ".build" | xargs rm -rf
 | 
				
			||||||
 | 
					cd ..
 | 
				
			||||||
 | 
					git clone https://$GH_TOKEN@github.com/jackhumbert/qmk.fm.git
 | 
				
			||||||
 | 
					cd qmk.fm
 | 
				
			||||||
 | 
					git submodule update --init --recursive
 | 
				
			||||||
 | 
					rm -rf keyboard
 | 
				
			||||||
 | 
					rm -rf keyboards
 | 
				
			||||||
 | 
					cp -r ../qmk_firmware/keyboards .
 | 
				
			||||||
 | 
					cp ../qmk_firmware/readme.md qmk_readme.md
 | 
				
			||||||
 | 
					./generate.sh
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					git add -A
 | 
				
			||||||
 | 
					git commit -m "generated from qmk_firmware/$TRAVIS_BRANCH@${rev}" 
 | 
				
			||||||
 | 
					git push
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue