~ruther/qmk_firmware

215c2119af5281072d5a6efb0308408793cadd08 — Jack Humbert 9 years ago 755b17f
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
43 files changed, 453 insertions(+), 448 deletions(-)

M .travis.yml
M Makefile
R keyboards/{clueboard1 => clueboard}/Makefile
R keyboards/{clueboard1/clueboard1 => clueboard/clueboard}.c
A keyboards/clueboard/clueboard.h
R keyboards/{clueboard1 => clueboard}/config.h
R keyboards/{clueboard2 => clueboard}/keymaps/default/keymap.c
A keyboards/clueboard/keymaps/max/Makefile
R keyboards/{clueboard2 => clueboard}/keymaps/max/keymap.c
R keyboards/{clueboard2 => clueboard}/keymaps/skully/keymap.c
A keyboards/clueboard/rev1/Makefile
A keyboards/clueboard/rev1/config.h
A keyboards/clueboard/rev1/rev1.c
R keyboards/{clueboard1/clueboard1 => clueboard/rev1/rev1}.h
A keyboards/clueboard/rev2/Makefile
R keyboards/{clueboard2 => clueboard/rev2}/config.h
A keyboards/clueboard/rev2/rev2.c
R keyboards/{clueboard2/clueboard2 => clueboard/rev2/rev2}.h
D keyboards/clueboard1/keymaps/default/keymap.c
D keyboards/clueboard2/keymaps/max/Makefile
M keyboards/cluepad/Makefile
D keyboards/cluepad/backlight.c
M keyboards/cluepad/cluepad.c
M keyboards/cluepad/cluepad.h
M keyboards/planck/Makefile
M keyboards/planck/config.h
M keyboards/planck/keymaps/experimental/config.h
M keyboards/planck/keymaps/yang/Makefile
M keyboards/planck/planck.h
A keyboards/planck/rev3/Makefile
A keyboards/planck/rev3/config.h
A keyboards/planck/rev3/rev3.c
A keyboards/planck/rev3/rev3.h
A keyboards/planck/rev4/Makefile
A keyboards/planck/rev4/config.h
A keyboards/planck/rev4/rev4.c
A keyboards/planck/rev4/rev4.h
M keyboards/readme.md
M quantum/audio/audio.h
M quantum/matrix.c
M readme.md
M tmk_core/rules.mk
A util/travis_compiled_push.sh
M .travis.yml => .travis.yml +16 -34
@@ 1,39 1,21 @@
os:
  - linux

language:
  - c

compiler:
  - avr-gcc

os: linux
dist: trusty
sudo: required
language: c
compiler: avr-gcc
branches:
  except:
    - /^.*-automated-build$/
env:
  - KEYBOARD=alps64
  - KEYBOARD=arrow_pad
  - 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

  global:
  - secure: vBTSL34BDPxDilKUuTXqU4CJ26Pv5hogD2nghatkxSQkI1/jbdnLj/DQdPUrMJFDIY6TK3AltsBx72MaMsLQ1JO/Ou24IeHINHXzUC1FlS9yQa48cpxnhX5kzXNyGs3oa0qaFbvnr7RgYRWtmD52n4bIZuSuW+xpBv05x2OCizdT2ZonH33nATaHGFasxROm4qYZ241VfzcUv766V6RVHgL4x9V08warugs+RENVkfzxxwhk3NmkrISabze0gSVJLHBPHxroZC6EUcf/ocobcuDrCwFqtEt90i7pNIAFUE7gZsN2uE75LmpzAWin21G7lLPcPL2k4FJVd8an1HiP2WmscJU6U89fOfMb2viObnKcCzebozBCmKGtHEuXZo9FcReOx49AnQSpmESJGs+q2dL/FApkTjQiyT4J6O5dJpoww0/r57Wx0cmmqjETKBb5rSgXM51Etk3wO09mvcPHsEwrT7qH8r9XWdyCDoEn7FCLX3/LYnf/D4SmZ633YPl5gv3v9XEwxR5+04akjgnvWDSNIaDbWBdxHNb7l4pMc+WR1bwCyMyA7KXj0RrftEGOrm9ZRLe6BkbT4cycA+j77nbPOMcyZChliV9pPQos+4TOJoTzcK2L8yWVoY409aDNVuAjdP6Yum0R2maBGl/etLmIMpJC35C5/lZ+dUNjJAM=
script:
  - cd keyboards/$KEYBOARD && make all-keymaps

- make all-keyboards quick AUTOGEN=true
addons:
  apt:
    packages:
      - avr-libc
      - gcc-avr
      - dfu-programmer
    - avr-libc
    - gcc-avr
    - dfu-programmer
    - pandoc
after_success: bash util/travis_compiled_push.sh
\ No newline at end of file

M Makefile => Makefile +63 -5
@@ 10,19 10,32 @@ abs_tmk_root := $(patsubst %/,%,$(dir $(mkfile_path)))
ifneq (,$(findstring /keyboards/,$(starting_makefile)))
	possible_keyboard:=$(patsubst %/,%,$(dir $(patsubst $(abs_tmk_root)/keyboards/%,%,$(starting_makefile))))
	ifneq (,$(findstring /keymaps/,$(possible_keyboard)))
		KEYBOARD_DIR:=$(firstword $(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
		KEYBOARD_DIR:=$(possible_keyboard)
		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
else
	tmk_root = .
endif
# $(info $(KEYBOARD_DIR))
# $(info $(KEYMAP_DIR))
# $(info $(SUBPROJECT_DIR))

# Directory common source filess exist
TOP_DIR = $(tmk_root)


@@ 32,6 45,7 @@ TMK_PATH = $(TOP_DIR)/$(TMK_DIR)
QUANTUM_DIR = quantum
QUANTUM_PATH = $(TOP_DIR)/$(QUANTUM_DIR)


ifdef keyboard
	KEYBOARD ?= $(keyboard)
endif


@@ 41,7 55,16 @@ endif
ifndef KEYBOARD
	KEYBOARD=planck
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)

ifneq ("$(wildcard $(KEYBOARD_PATH)/$(KEYBOARD).c)","")
	KEYBOARD_FILE = keyboards/$(KEYBOARD)/$(KEYBOARD).c
	ifndef ARCH


@@ 51,6 74,28 @@ else
$(error "$(KEYBOARD_PATH)/$(KEYBOARD).c" does not exist)
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
	KEYMAP ?= $(keymap)
endif


@@ 68,7 113,13 @@ else
$(error "$(KEYMAP_PATH)/keymap.c" does not exist)
endif

TARGET ?= $(KEYBOARD)_$(KEYMAP)
ifdef SUBPROJECT
	TARGET ?= $(KEYBOARD)_$(SUBPROJECT)_$(KEYMAP)
else
	TARGET ?= $(KEYBOARD)_$(KEYMAP)
endif



ifneq ("$(wildcard $(KEYMAP_PATH)/config.h)","")
	CONFIG_H = $(KEYMAP_PATH)/config.h


@@ 83,6 134,10 @@ SRC += $(KEYBOARD_FILE) \
	$(QUANTUM_DIR)/keymap.c \
	$(QUANTUM_DIR)/keycode_config.c

ifdef SUBPROJECT
	SRC += $(SUBPROJECT_FILE)
endif

ifndef CUSTOM_MATRIX
	SRC += $(QUANTUM_DIR)/matrix.c
endif


@@ 104,6 159,9 @@ endif

# Search Path
VPATH += $(KEYMAP_PATH)
ifdef SUBPROJECT
	VPATH += $(SUBPROJECT_PATH)
endif
VPATH += $(KEYBOARD_PATH)
VPATH += $(TOP_DIR)
VPATH += $(TMK_PATH)

R keyboards/clueboard1/Makefile => keyboards/clueboard/Makefile +1 -0
@@ 1,4 1,5 @@

SUBPROJECT_DEFAULT = rev2

# MCU name
MCU = atmega32u4

R keyboards/clueboard1/clueboard1.c => keyboards/clueboard/clueboard.c +6 -1
@@ 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) {
    DDRF |= (1<<0);

A keyboards/clueboard/clueboard.h => keyboards/clueboard/clueboard.h +13 -0
@@ 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

R keyboards/clueboard1/config.h => keyboards/clueboard/config.h +8 -29
@@ 22,29 22,10 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.

/* USB Device descriptor parameter */
#define VENDOR_ID       0xC1ED
#define PRODUCT_ID      0x2301
#define DEVICE_VER      0x0003
#define MANUFACTURER    Clueboard
#define PRODUCT         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 */
#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)) \
)

/* 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
 *  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_FUNCTION


#ifdef SUBPROJECT_rev1
    #include "rev1/config.h"
#endif
#ifdef SUBPROJECT_rev2
    #include "rev2/config.h"
#endif

#endif

R keyboards/clueboard2/keymaps/default/keymap.c => keyboards/clueboard/keymaps/default/keymap.c +2 -1
@@ 1,4 1,4 @@
#include "clueboard2.h"
#include "clueboard.h"

// Used for SHIFT_ESC
#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) {
        rgblight_toggle();
      }

      break;
    case RGBLED_INCREASE_HUE:
      if (record->event.pressed) {

A keyboards/clueboard/keymaps/max/Makefile => keyboards/clueboard/keymaps/max/Makefile +49 -0
@@ 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
\ No newline at end of file

R keyboards/clueboard2/keymaps/max/keymap.c => keyboards/clueboard/keymaps/max/keymap.c +1 -1
@@ 1,4 1,4 @@
#include "clueboard2.h"
#include "clueboard.h"

// Used for SHIFT_ESC
#define MODS_CTRL_MASK  (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT))

R keyboards/clueboard2/keymaps/skully/keymap.c => keyboards/clueboard/keymaps/skully/keymap.c +1 -1
@@ 1,4 1,4 @@
#include "clueboard2.h"
#include "clueboard.h"

// Used for SHIFT_ESC
#define MODS_CTRL_MASK  (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT))

A keyboards/clueboard/rev1/Makefile => keyboards/clueboard/rev1/Makefile +5 -0
@@ 0,0 1,5 @@
BACKLIGHT_ENABLE = no

ifndef QUANTUM_DIR
	include ../../../Makefile
endif

A keyboards/clueboard/rev1/config.h => keyboards/clueboard/rev1/config.h +37 -0
@@ 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
\ No newline at end of file

A keyboards/clueboard/rev1/rev1.c => keyboards/clueboard/rev1/rev1.c +1 -0
@@ 0,0 1,1 @@
#include "rev1.h"

R keyboards/clueboard1/clueboard1.h => keyboards/clueboard/rev1/rev1.h +4 -4
@@ 1,8 1,7 @@
#ifndef CLUEBOARD1_H
#define CLUEBOARD1_H

#include "quantum.h"
#ifndef REV1_H
#define REV1_H

#include "../clueboard.h"

/* Clueboard matrix layout
 * ,-----------------------------------------------------------.  ,---.


@@ 30,6 29,7 @@
 */
// The first section contains all of the arguements
// The second converts the arguments into a two-dimensional array

#define KEYMAP( \
    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, \

A keyboards/clueboard/rev2/Makefile => keyboards/clueboard/rev2/Makefile +5 -0
@@ 0,0 1,5 @@
BACKLIGHT_ENABLE = yes

ifndef QUANTUM_DIR
	include ../../../Makefile
endif

R keyboards/clueboard2/config.h => keyboards/clueboard/rev2/config.h +13 -72
@@ 1,32 1,10 @@
/*
Copyright 2012 Jun Wako <wakojun@gmail.com>
#ifndef REV2_CONFIG_H
#define REV2_CONFIG_H

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.
#include "../config.h"

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


@@ 45,55 23,18 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
#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
 /* 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
#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
\ No newline at end of file

A keyboards/clueboard/rev2/rev2.c => keyboards/clueboard/rev2/rev2.c +47 -0
@@ 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
    }
}

R keyboards/clueboard2/clueboard2.h => keyboards/clueboard/rev2/rev2.h +4 -4
@@ 1,8 1,7 @@
#ifndef CLUEBOARD2_H
#define CLUEBOARD2_H

#include "quantum.h"
#ifndef REV2_H
#define REV2_H

#include "../clueboard.h"

/* Clueboard matrix layout
 * ,-----------------------------------------------------------.  ,---.


@@ 30,6 29,7 @@
 */
// The first section contains all of the arguments
// The second converts the arguments into a two-dimensional array

#define KEYMAP( \
    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, \

D keyboards/clueboard1/keymaps/default/keymap.c => keyboards/clueboard1/keymaps/default/keymap.c +0 -184
@@ 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
  }
}

D keyboards/clueboard2/keymaps/max/Makefile => keyboards/clueboard2/keymaps/max/Makefile +0 -11
@@ 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
\ No newline at end of file

M keyboards/cluepad/Makefile => keyboards/cluepad/Makefile +0 -4
@@ 1,8 1,4 @@


# # project specific files
SRC = backlight.c

# MCU name
#MCU = at90usb1287
MCU = atmega32u4

D keyboards/cluepad/backlight.c => keyboards/cluepad/backlight.c +0 -54
@@ 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;
}

M keyboards/cluepad/cluepad.c => keyboards/cluepad/cluepad.c +49 -4
@@ 1,15 1,60 @@
#include "cluepad.h"

int pwm_level;

void matrix_init_kb(void) {
    // put your keyboard start-up code here
    // runs once when the firmware starts up
    matrix_init_user();

    #ifdef BACKLIGHT_ENABLE
        init_backlight_pin();
    #endif

    // JTAG disable for PORT F. write JTD bit twice within four cycles.
    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;
}

M keyboards/cluepad/cluepad.h => keyboards/cluepad/cluepad.h +1 -3
@@ 1,9 1,7 @@
#ifndef CLUEPAD_H
#define CLUEPAD_H

#include "matrix.h"
#include "keymap.h"
#include <stddef.h>
#include "quantum.h"


/* Cluepad matrix layout

M keyboards/planck/Makefile => keyboards/planck/Makefile +1 -0
@@ 1,4 1,5 @@

SUBPROJECT_DEFAULT = rev4

# MCU name
#MCU = at90usb1287

M keyboards/planck/config.h => keyboards/planck/config.h +7 -1
@@ 23,7 23,6 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
/* USB Device descriptor parameter */
#define VENDOR_ID       0xFEED
#define PRODUCT_ID      0x6060
#define DEVICE_VER      0x0001
#define MANUFACTURER    Ortholinear Keyboards
#define PRODUCT         The Planck 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_FUNCTION

#ifdef SUBPROJECT_rev3
    #include "rev3/config.h"
#endif
#ifdef SUBPROJECT_rev4
    #include "rev4/config.h"
#endif

#endif

M keyboards/planck/keymaps/experimental/config.h => keyboards/planck/keymaps/experimental/config.h +1 -0
@@ 4,5 4,6 @@
#include "../../config.h"

#define LEADER_TIMEOUT 300
#define BACKLIGHT_BREATHING

#endif

M keyboards/planck/keymaps/yang/Makefile => keyboards/planck/keymaps/yang/Makefile +1 -0
@@ 3,6 3,7 @@
#   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.
AUDIO_ENABLE = no

ifndef QUANTUM_DIR
	include ../../../../Makefile

M keyboards/planck/planck.h => keyboards/planck/planck.h +7 -0
@@ 1,6 1,13 @@
#ifndef PLANCK_H
#define PLANCK_H

#ifdef SUBPROJECT_rev3
    #include "rev3.h"
#endif
#ifdef SUBPROJECT_rev4
    #include "rev4.h"
#endif

#include "quantum.h"

#define PLANCK_MIT( \

A keyboards/planck/rev3/Makefile => keyboards/planck/rev3/Makefile +5 -0
@@ 0,0 1,5 @@
AUDIO_ENABLE = no           # Audio output on port C6

ifndef QUANTUM_DIR
	include ../../../Makefile
endif
\ No newline at end of file

A keyboards/planck/rev3/config.h => keyboards/planck/rev3/config.h +8 -0
@@ 0,0 1,8 @@
#ifndef REV3_CONFIG_H
#define REV3_CONFIG_H

#include "../config.h"

#define DEVICE_VER 0x0003

#endif
\ No newline at end of file

A keyboards/planck/rev3/rev3.c => keyboards/planck/rev3/rev3.c +1 -0
@@ 0,0 1,1 @@
#include "rev3.h"
\ No newline at end of file

A keyboards/planck/rev3/rev3.h => keyboards/planck/rev3/rev3.h +6 -0
@@ 0,0 1,6 @@
#ifndef REV3_H
#define REV3_H

#include "../planck.h"

#endif
\ No newline at end of file

A keyboards/planck/rev4/Makefile => keyboards/planck/rev4/Makefile +5 -0
@@ 0,0 1,5 @@
AUDIO_ENABLE = yes           # Audio output on port C6

ifndef QUANTUM_DIR
	include ../../../Makefile
endif
\ No newline at end of file

A keyboards/planck/rev4/config.h => keyboards/planck/rev4/config.h +8 -0
@@ 0,0 1,8 @@
#ifndef REV4_CONFIG_H
#define REV4_CONFIG_H

#include "../config.h"

#define DEVICE_VER 0x0004

#endif
\ No newline at end of file

A keyboards/planck/rev4/rev4.c => keyboards/planck/rev4/rev4.c +1 -0
@@ 0,0 1,1 @@
#include "rev4.h"
\ No newline at end of file

A keyboards/planck/rev4/rev4.h => keyboards/planck/rev4/rev4.h +6 -0
@@ 0,0 1,6 @@
#ifndef REV4_H
#define REV4_H

#include "../planck.h"

#endif
\ No newline at end of file

M keyboards/readme.md => keyboards/readme.md +1 -2
@@ 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)

* [Clueboard rev.1](/keyboards/clueboard1/) - The old Clueboard.
* [Clueboard rev.2](/keyboards/clueboard2/) - New and improved! The Clueboard, revision 2.
* [Clueboard](/keyboards/clueboard/) - The 66% custom keyboard.
* [Cluepad](/keyboards/cluepad/) - A mechanical numpad with QMK superpowers.



M quantum/audio/audio.h => quantum/audio/audio.h +3 -3
@@ 1,3 1,6 @@
#ifndef AUDIO_H
#define AUDIO_H

#include <stdint.h>
#include <stdbool.h>
#include <avr/io.h>


@@ 7,9 10,6 @@
#include "voices.h"
#include "quantum.h"

#ifndef AUDIO_H
#define AUDIO_H

// Largely untested PWM audio mode (doesn't sound as good)
// #define PWM_AUDIO


M quantum/matrix.c => quantum/matrix.c +23 -23
@@ 86,29 86,29 @@ uint8_t matrix_cols(void) {
    return MATRIX_COLS;
}

void matrix_power_up(void) {
#if DIODE_DIRECTION == COL2ROW
    for (int8_t r = MATRIX_ROWS - 1; r >= 0; --r) {
        /* DDRxn */
        _SFR_IO8((row_pins[r] >> 4) + 1) |= _BV(row_pins[r] & 0xF);
        toggle_row(r);
    }
    for (int8_t c = MATRIX_COLS - 1; c >= 0; --c) {
        /* PORTxn */
        _SFR_IO8((col_pins[c] >> 4) + 2) |= _BV(col_pins[c] & 0xF);
    }
#else
    for (int8_t c = MATRIX_COLS - 1; c >= 0; --c) {
        /* DDRxn */
        _SFR_IO8((col_pins[c] >> 4) + 1) |= _BV(col_pins[c] & 0xF);
        toggle_col(c);
    }
    for (int8_t r = MATRIX_ROWS - 1; r >= 0; --r) {
        /* PORTxn */
        _SFR_IO8((row_pins[r] >> 4) + 2) |= _BV(row_pins[r] & 0xF);
    }
#endif
}
// void matrix_power_up(void) {
// #if DIODE_DIRECTION == COL2ROW
//     for (int8_t r = MATRIX_ROWS - 1; r >= 0; --r) {
//         /* DDRxn */
//         _SFR_IO8((row_pins[r] >> 4) + 1) |= _BV(row_pins[r] & 0xF);
//         toggle_row(r);
//     }
//     for (int8_t c = MATRIX_COLS - 1; c >= 0; --c) {
//         /* PORTxn */
//         _SFR_IO8((col_pins[c] >> 4) + 2) |= _BV(col_pins[c] & 0xF);
//     }
// #else
//     for (int8_t c = MATRIX_COLS - 1; c >= 0; --c) {
//         /* DDRxn */
//         _SFR_IO8((col_pins[c] >> 4) + 1) |= _BV(col_pins[c] & 0xF);
//         toggle_col(c);
//     }
//     for (int8_t r = MATRIX_ROWS - 1; r >= 0; --r) {
//         /* PORTxn */
//         _SFR_IO8((row_pins[r] >> 4) + 2) |= _BV(row_pins[r] & 0xF);
//     }
// #endif
// }

void matrix_init(void) {
    /* frees PORTF by setting the JTD bit twice within four cycles */

M readme.md => readme.md +1 -2
@@ 14,8 14,7 @@ For an easy-to-read version of this document and the repository, check out [http
* [Preonic](/keyboards/preonic/)
* [Atomic](/keyboards/atomic/)
* [ErgoDox EZ](/keyboards/ergodox_ez/)
* [Clueboard rev.1](/keyboards/clueboard1/)
* [Clueboard rev.2](/keyboards/clueboard2/)
* [Clueboard](/keyboards/clueboard/)
* [Cluepad](/keyboards/cluepad/)

The project also includes community support for [lots of other keyboards](/keyboards/).

M tmk_core/rules.mk => tmk_core/rules.mk +19 -5
@@ 51,6 51,13 @@ ifeq ($(COLOR),true)
	BOLD=\033[1m
endif

ifdef quick
	QUICK = $(quick)
endif

QUICK ?= false
AUTOGEN ?= false

ifneq ($(shell awk --version 2>/dev/null),)
	AWK=awk
else


@@ 524,7 531,12 @@ extcoff: $(BUILD_DIR)/$(TARGET).elf
	@$(SILENT) || printf "$(MSG_FLASH) $@" | $(AWK_CMD)
	$(eval CMD=$(OBJCOPY) -O $(FORMAT) -R .eeprom -R .fuse -R .lock -R .signature $< $@)
	@$(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
	@$(SILENT) || printf "$(MSG_EEPROM) $@" | $(AWK_CMD)


@@ 570,7 582,7 @@ $(OBJDIR)/%.o : %.c
$(OBJDIR)/%.o : %.cpp
	@mkdir -p $(@D)
	@$(SILENT) || printf "$(MSG_COMPILING_CPP) $<" | $(AWK_CMD)
	$(CC) -c $(ALL_CPPFLAGS) $< -o $@
	$(eval CMD=$(CC) -c $(ALL_CPPFLAGS) $< -o $@)
	@$(BUILD_CMD)

# Compile: create assembler files from C source files.


@@ 600,9 612,11 @@ $(OBJDIR)/%.o : %.S
clean: begin clean_list end

clean_list :
	$(REMOVE) -r $(TOP_DIR)/$(BUILD_DIR)
	$(REMOVE) -r $(KEYBOARD_PATH)/$(BUILD_DIR)
	$(REMOVE) -r $(KEYMAP_PATH)/$(BUILD_DIR)
	@$(REMOVE) -r $(BUILD_DIR)
	@$(REMOVE) -r $(TOP_DIR)/$(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:
	@echo VPATH=$(VPATH)

A util/travis_compiled_push.sh => util/travis_compiled_push.sh +23 -0
@@ 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
\ No newline at end of file