###| CMAKE Kiibohd Controller Source Configurator |###
#
-# Written by Jacob Alexander in 2011-2013 for the Kiibohd Controller
+# Written by Jacob Alexander in 2011-2014 for the Kiibohd Controller
#
# Released into the Public Domain
#
#| Please look at the {Scan,Macro,USB,Debug}/module.txt for information on the modules and how to create new ones
##| Deals with acquiring the keypress information and turning it into a key index
-set( ScanModule "avr-capsense" )
+set( ScanModule "SKM67001" )
-##| Uses the key index and potentially applies special conditions to it, mapping it to a usb key code
-set( MacroModule "buffer" )
+##| Provides the mapping functions for DefaultMap and handles any macro processing before sending to the OutputModule
+set( MacroModule "PartialMap" )
##| Sends the current list of usb key codes through USB HID
-set( USBModule "pjrc" )
+set( OutputModule "pjrcUSB" )
##| Debugging source to use, each module has it's own set of defines that it sets
-set( DebugModule "full" )
+set( DebugModule "full" )
+###
+# Keymap Configuration
+#
+
+##| If there are multiple DefaultMaps, it is defined here. If, the specified DefaultMap is not found, defaultMap.h is used.
+set( DefaultMap "kishsaver" )
+
+##| PartialMap combined keymap layering. The first keymap has the "least" precedence.
+set( CombinedMap colemak capslock2ctrl )
+
+##| ParitalMaps available on top of the CombinedMap. If there are input conflicts, the last PartialMap takes precedence.
+set( PartialMaps hhkbnav kbdctrl )
+
+##| MacroSets define extra capabilities that are not provided by the Scan or Output modules. Last MacroSet takes precedence.
+set( MacroSets retype )
+
###
# Module Overrides (Used in the buildall.bash script)
###
# Path Setup
-#
-set( ScanModulePath "Scan/${ScanModule}" )
-set( MacroModulePath "Macro/${MacroModule}" )
-set( USBModulePath "USB/${USBModule}" )
-set( DebugModulePath "Debug/${DebugModule}" )
+#
+set( ScanModulePath "Scan/${ScanModule}" )
+set( MacroModulePath "Macro/${MacroModule}" )
+set( OutputModulePath "Output/${OutputModule}" )
+set( DebugModulePath "Debug/${DebugModule}" )
#| Top-level directory adjustment
set( HEAD_DIR "${CMAKE_CURRENT_SOURCE_DIR}" )
add_definitions(
-I${HEAD_DIR}/${ScanModulePath}
-I${HEAD_DIR}/${MacroModulePath}
- -I${HEAD_DIR}/${USBModulePath}
+ -I${HEAD_DIR}/${OutputModulePath}
-I${HEAD_DIR}/${DebugModulePath}
)
include ( "${MacroModulePath}/setup.cmake" )
PathPrepend( MACRO_SRCS ${MacroModulePath} ${MACRO_SRCS} )
-#| USB Module
-include ( "${USBModulePath}/setup.cmake" )
-PathPrepend( USB_SRCS ${USBModulePath} ${USB_SRCS} )
+#| Output Module
+include ( "${OutputModulePath}/setup.cmake" )
+PathPrepend( OUTPUT_SRCS ${OutputModulePath} ${OUTPUT_SRCS} )
#| Debugging Module
include ( "${DebugModulePath}/setup.cmake" )
PathPrepend( DEBUG_SRCS ${DebugModulePath} ${DEBUG_SRCS} )
+#| Default Map
+# TODO Add support for different defaultMaps
+configure_file( "${ScanModulePath}/defaultMap.h" defaultMap.h )
+
+
#| Print list of all module sources
message( STATUS "Detected Scan Module Source Files:" )
message( "${SCAN_SRCS}" )
message( STATUS "Detected Macro Module Source Files:" )
message( "${MACRO_SRCS}" )
-message( STATUS "Detected USB Module Source Files:" )
-message( "${USB_SRCS}" )
+message( STATUS "Detected Output Module Source Files:" )
+message( "${OUTPUT_SRCS}" )
message( STATUS "Detected Debug Module Source Files:" )
message( "${DEBUG_SRCS}" )
OUTPUT_STRIP_TRAILING_WHITESPACE
)
string( LENGTH "${Git_Modified_INFO}" Git_Modified_LENGTH )
+set( Git_Modified_Status "Clean" )
if ( ${Git_Modified_LENGTH} GREATER 2 )
string( SUBSTRING "${Git_Modified_INFO}" 1 2 Git_Modified_Flag_INFO )
+ set( Git_Modified_Status "Dirty" )
endif ()
#| Branch
OUTPUT_STRIP_TRAILING_WHITESPACE
)
+#| Commit Author and Email
+execute_process( COMMAND git show -s --format="%cn <%ce>"
+ WORKING_DIRECTORY ${PROJECT_SOURCE_DIR}
+ OUTPUT_VARIABLE Git_Commit_Author
+ RESULT_VARIABLE Git_RETURN
+ ERROR_QUIET
+ OUTPUT_STRIP_TRAILING_WHITESPACE
+)
+
+#| Commit Revision
+execute_process( COMMAND git show -s --format=%H
+ WORKING_DIRECTORY ${PROJECT_SOURCE_DIR}
+ OUTPUT_VARIABLE Git_Commit_Revision
+ RESULT_VARIABLE Git_RETURN
+ ERROR_QUIET
+ OUTPUT_STRIP_TRAILING_WHITESPACE
+)
+
+#| Origin URL
+execute_process( COMMAND git config --get remote.origin.url
+ WORKING_DIRECTORY ${PROJECT_SOURCE_DIR}
+ OUTPUT_VARIABLE Git_Origin_URL
+ RESULT_VARIABLE Git_RETURN
+ ERROR_QUIET
+ OUTPUT_STRIP_TRAILING_WHITESPACE
+)
+
+#| Date Macro
+macro ( dateNow RESULT )
+ if ( WIN32 )
+ execute_process( COMMAND "cmd" " /C date /T" OUTPUT_VARIABLE ${RESULT} OUTPUT_STRIP_TRAILING_WHITESPACE )
+ elseif ( UNIX )
+ execute_process( COMMAND "date" "+%Y-%m-%d %T %z" OUTPUT_VARIABLE ${RESULT} OUTPUT_STRIP_TRAILING_WHITESPACE )
+ else ()
+ message( send_error "date not implemented" )
+ set( ${RESULT} 000000 )
+ endif ()
+endmacro (dateNow)
+dateNow( Build_Date )
+
#| Only use Git variables if we were successful in calling the commands
if ( ${Git_RETURN} EQUAL 0 )