changeset 31:a004d4015fbb

Making sub-modules of matrix for HeathZenith and BudKeypad - Parent module no longer allows for a stand-alone compile - Added HeathZenith matrix (pinout still needs to be done) - Updated the HeathZenith keymaps - Changed the original example matrix.h to matrix_template.h
author Jacob Alexander <triplehaata@gmail.com>
date Sun, 16 Oct 2011 21:38:56 -0700
parents 91901960eac4
children ac1ea964c75e
files Keymap/heathzenith.h Scan/BudKeypad/matrix.h Scan/BudKeypad/setup.cmake Scan/HeathZenith/matrix.h Scan/HeathZenith/setup.cmake Scan/matrix/matrix.h Scan/matrix/matrix_template.h Scan/matrix/setup.cmake setup.cmake
diffstat 9 files changed, 387 insertions(+), 159 deletions(-) [+]
line wrap: on
line diff
--- a/Keymap/heathzenith.h	Sun Oct 16 20:08:37 2011 -0700
+++ b/Keymap/heathzenith.h	Sun Oct 16 21:38:56 2011 -0700
@@ -27,11 +27,11 @@
 
 // ----- Variables -----
 
-static uint8_t  keyboard_modifierMask[] = { 1, 17, 33, 49 };
-static uint8_t alternate_modifierMask[] = { 1, 17, 33, 49, 62 };
+static uint8_t  heathzenith_ModifierMask [] = { 1, 17, 33, 49 };
+static uint8_t  heathzenith_AlternateMask[] = { 1, 17, 33, 49, 62 };
 
 // Default 1-indexed key mappings
-static uint8_t defaultMap[] = { 0,
+static uint8_t heathzenith_DefaultMap[] = { 0,
 				KEY_GUI,
 				KEY_1,
 				KEY_2,
@@ -96,7 +96,7 @@
 				KEY_RIGHT,
 				KEY_SPACE
 };
-static uint8_t navigationMap[] = { 0,
+static uint8_t heathzenith_NavigationMap[] = { 0,
 				KEY_GUI,
 				KEY_F1,
 				KEY_F2,
@@ -162,7 +162,7 @@
 				KEY_SPACE
 };
 
-static uint8_t colemakMap[] = { 0,
+static uint8_t heathzenith_ColemakMap[] = { 0,
 				KEY_GUI,
 				KEY_1,
 				KEY_2,
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Scan/BudKeypad/matrix.h	Sun Oct 16 21:38:56 2011 -0700
@@ -0,0 +1,80 @@
+/* Copyright (C) 2011 by Jacob Alexander
+ * 
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ * 
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ * 
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+ * THE SOFTWARE.
+ */
+
+#ifndef __MATRIX_H
+#define __MATRIX_H
+
+// ----- Includes -----
+
+// Compiler Includes
+#include <stdint.h>
+
+
+
+// ----- Scan Mode Setting (See matrix_scan.h for more details) -----
+#define scanMode scanCol
+
+
+
+// ----- Key Settings -----
+
+#define KEYBOARD_SIZE 16 // # of keys
+#define MAX_ROW_SIZE  16 // # of keys in the largest row
+#define MAX_COL_SIZE   1 // # of keys in the largest column
+
+
+
+// ----- Matrix Configuration -----
+static const uint8_t matrix_pinout[][MAX_ROW_SIZE + 1] = {
+
+
+
+// Just layout the matrix by rows and columns
+// Usually you'll want to set the scanMode above to scanDual or scanCol_powrRow/scanRow_powrCol
+// The mode allows for optimization in the kind of scanning algorithms that are done
+// 
+// The key numbers are used to translate into the keymap table (array) (and always start from 1, not 0).
+// Thus if a row doesn't use all the key positions, you can denote it as 0, which will be ignored/skipped on each scan
+// See the keymap.h file for the various preconfigured arrays.
+
+// Scan Mode | Col 1 | Col 2 | Col 3 | Col 4 | Col 5 | ...
+// -------------------------------------------------------
+//     Row 1 | Key 1   Key 7   Key32    ...
+//     Row 2 | Key 3   Key92    ...
+//     Row 3 | Key23    ...
+//     Row 4 |  ...
+//     Row 5 |
+//      ...  |
+
+// See Scan/matrix/matrix_template.h for more details
+
+
+  { scanMode, pinF0, pinF4, pinB7, pinD3, pinF5, pinF1, pinD1, pinD2, pinF6, pinF7, pinB2, pinD0, pinB0, pinB6, pinB1, pinB3 },
+  { pinNULL,  1,     2,     3,     4,     5,     6,     7,     8,     9,     10,    11,    12,    13,    14,    15,    16    },
+
+
+
+};
+
+
+
+#endif // __MATRIX_H
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Scan/BudKeypad/setup.cmake	Sun Oct 16 21:38:56 2011 -0700
@@ -0,0 +1,35 @@
+###| CMake Kiibohd Controller Scan Module |###
+#
+# Written by Jacob Alexander in 2011 for the Kiibohd Controller
+#
+# Released into the Public Domain
+#
+###
+
+
+###
+# Module C files
+#
+
+#| XXX Requires the ../ due to how the paths are constructed
+set( SCAN_SRCS
+	../matrix/matrix_scan.c
+	../matrix/scan_loop.c
+)
+
+
+###
+# Module Specific Options
+#
+add_definitions( -I${HEAD_DIR}/Keymap )
+add_definitions(
+	-I${HEAD_DIR}/Scan/matrix
+)	
+
+#| Keymap Settings
+add_definitions(
+	-DMODIFIER_MASK=budkeypad_ModifierMask
+	#-DKEYINDEX_MASK=budkeypad_TheProfosistMap
+	-DKEYINDEX_MASK=budkeypad_DefaultMap
+)
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Scan/HeathZenith/matrix.h	Sun Oct 16 21:38:56 2011 -0700
@@ -0,0 +1,69 @@
+/* Copyright (C) 2011 by Jacob Alexander
+ * 
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ * 
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ * 
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+ * THE SOFTWARE.
+ */
+
+#ifndef __MATRIX_H
+#define __MATRIX_H
+
+// ----- Includes -----
+
+// Compiler Includes
+#include <stdint.h>
+
+
+
+// ----- Scan Mode Setting (See matrix_scan.h for more details) -----
+#define scanMode scanDual
+
+
+
+// ----- Key Settings -----
+
+#define KEYBOARD_SIZE 63 // # of keys
+#define MAX_ROW_SIZE  12 // # of keys in the largest row
+#define MAX_COL_SIZE   9 // # of keys in the largest column
+
+
+
+// ----- Matrix Configuration -----
+static const uint8_t matrix_pinout[][MAX_ROW_SIZE + 1] = {
+
+
+// TODO Pinout
+// Note: Pins 49 and 60 are connected together, by row AND column, why? dunno...(shift)
+  { scanMode, pinF0, pinF4, pinB7, pinD3, pinF5, pinF1, pinD1, pinD2, pinE0, pinE1, pinE2, pinE3 },
+  { pinF6,    1,     2,     3,     4,     5,     6,     7,     8,     0,     0,     0,     0     },
+  { pinF7,    16,    15,    14,    13,    12,    11,    10,    9,     0,     0,     0,     0     },
+  { pinB2,    17,    18,    19,    20,    21,    22,    23,    24,    0,     0,     0,     0     },
+  { pinD0,    32,    31,    30,    29,    28,    27,    26,    25,    0,     0,     0,     0     },
+  { pinB6,    35,    36,    37,    38,    39,    40,    41,    42,    0,     0,     0,     0     },
+  { pinB3,    47,    61,    46,    45,    44,    43,    58,    0,     0,     0,     0,     0     },
+  { pinA0,    50,    51,    52,    53,    54,    55,    56,    57,    0,     0,     0,     0     },
+  { pinB0,    62,    63,    0,     0,     59,    0,     0,     0,     0,     0,     0,     0     },
+  { pinB0,    0,     0,     0,     0,     0,     0,     0,     0,     33,    34,    48,    49    },
+
+
+
+};
+
+
+
+#endif // __MATRIX_H
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Scan/HeathZenith/setup.cmake	Sun Oct 16 21:38:56 2011 -0700
@@ -0,0 +1,35 @@
+###| CMake Kiibohd Controller Scan Module |###
+#
+# Written by Jacob Alexander in 2011 for the Kiibohd Controller
+#
+# Released into the Public Domain
+#
+###
+
+
+###
+# Module C files
+#
+
+#| XXX Requires the ../ due to how the paths are constructed
+set( SCAN_SRCS
+	../matrix/matrix_scan.c
+	../matrix/scan_loop.c
+)
+
+
+###
+# Module Specific Options
+#
+add_definitions( -I${HEAD_DIR}/Keymap )
+add_definitions(
+	-I${HEAD_DIR}/Scan/matrix
+)	
+
+#| Keymap Settings
+add_definitions(
+	-DMODIFIER_MASK=heathzenith_ModifierMask
+	-DKEYINDEX_MASK=heathzenith_DefaultMap
+	#-DKEYINDEX_MASK=heathzenith_ColemakMap
+)
+
--- a/Scan/matrix/matrix.h	Sun Oct 16 20:08:37 2011 -0700
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,149 +0,0 @@
-/* Copyright (C) 2011 by Jacob Alexander
- * 
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- * 
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- * 
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- * THE SOFTWARE.
- */
-
-#ifndef __MATRIX_H
-#define __MATRIX_H
-
-// ----- Includes -----
-
-// Compiler Includes
-#include <stdint.h>
-
-
-
-// ----- Scan Mode Setting (See matrix_scan.h for more details) -----
-#define scanMode scanDual
-
-
-
-// ----- Key Settings -----
-
-// -- Example for scanCol --
-/*
-#define KEYBOARD_SIZE 16 // # of keys
-#define MAX_ROW_SIZE  16 // # of keys in the largest row
-#define MAX_COL_SIZE   1 // # of keys in the largest column
-*/
-
-
-// -- Example for scanRow --
-/*
-#define KEYBOARD_SIZE 16 // # of keys
-#define MAX_ROW_SIZE   1 // # of keys in the largest row
-#define MAX_COL_SIZE  16 // # of keys in the largest column
-*/
-
-
-// -- Example for scanRow_powrCol, scanCol_powrRow, and scanDual --
-#define KEYBOARD_SIZE 69 // # of keys
-#define MAX_ROW_SIZE   8 // # of keys in the largest row
-#define MAX_COL_SIZE   9 // # of keys in the largest column
-
-
-
-// ----- Matrix Configuration -----
-static const uint8_t matrix_pinout[][MAX_ROW_SIZE + 1] = {
-
-
-
-// Just layout the matrix by rows and columns
-// Usually you'll want to set the scanMode above to scanDual or scanCol_powrRow/scanRow_powrCol
-// The mode allows for optimization in the kind of scanning algorithms that are done
-// 
-// The key numbers are used to translate into the keymap table (array) (and always start from 1, not 0).
-// Thus if a row doesn't use all the key positions, you can denote it as 0, which will be ignored/skipped on each scan
-// See the keymap.h file for the various preconfigured arrays.
-
-// Scan Mode | Col 1 | Col 2 | Col 3 | Col 4 | Col 5 | ...
-// -------------------------------------------------------
-//     Row 1 | Key 1   Key 7   Key32    ...
-//     Row 2 | Key 3   Key92    ...
-//     Row 3 | Key23    ...
-//     Row 4 |  ...
-//     Row 5 |
-//      ...  |
-
-
-// -- scanCol Example --
-/*
-  { scanMode, pinF0, pinF4, pinB7, pinD3, pinF5, pinF1, pinD1, pinD2, pinF6, pinF7, pinB2, pinD0, pinB0, pinB6, pinB1, pinB3 },
-  { pinNULL,  1,     2,     3,     4,     5,     6,     7,     8,     9,     10,    11,    12,    13,    14,    15,    16    },
-*/
-
-
-// -- scanRow Example --
-/*
-  { scanMode, pinNULL },
-  { pinF0,    1       },
-  { pinF4,    2       },
-  { pinB7,    3       },
-  { pinD3,    4       },
-  { pinF5,    5       },
-  { pinF1,    6       },
-  { pinD1,    7       },
-  { pinD2,    8       },
-  { pinF6,    9       },
-  { pinF7,    10      },
-  { pinB2,    11      },
-  { pinD0,    12      },
-  { pinB0,    13      },
-  { pinB6,    14      },
-  { pinB1,    15      },
-  { pinB3,    16      },
-*/
-
-
-// -- scanRow_powrCol Example and scanCol_powrRow Example --
-// The example is the same, as the difference is whether the row or col is powered, and the other is used to detect the signal
-  { scanMode, pinF0, pinF4, pinB7, pinD3, pinF5, pinF1, pinD1, pinD2 },
-  { pinF6,    1,     2,     3,     4,     5,     6,     7,     8     },
-  { pinF7,    9,     10,    11,    12,    13,    14,    15,    16    },
-  { pinB2,    17,    20,    30,    40,    50,    60,    59,    38    },
-  { pinD0,    18,    21,    31,    41,    51,    61,    67,    39    },
-  { pinB0,    19,    22,    32,    42,    52,    62,    68,    47    },
-  { pinB6,    27,    23,    33,    43,    53,    63,    69,    48    },
-  { pinB1,    28,    24,    34,    44,    54,    64,    0,     49    }, // 0 signifies no key at that location
-  { pinB3,    29,    25,    35,    45,    55,    65,    0,     57    },
-  { pinA0,    37,    26,    36,    46,    56,    66,    0,     58    },
-
-
-// -- scanDual Example --
-// The example is the same as the previous one, but uses both columns and rows to power and detect, needed for non-NKRO matrices.
-/*
-  { scanMode, pinF0, pinF4, pinB7, pinD3, pinF5, pinF1, pinD1, pinD2 },
-  { pinF6,    1,     2,     3,     4,     5,     6,     7,     8     },
-  { pinF7,    9,     10,    11,    12,    13,    14,    15,    16    },
-  { pinB2,    17,    20,    30,    40,    50,    60,    59,    38    },
-  { pinD0,    18,    21,    31,    41,    51,    61,    67,    39    },
-  { pinB0,    19,    22,    32,    42,    52,    62,    68,    47    },
-  { pinB6,    27,    23,    33,    43,    53,    63,    69,    48    },
-  { pinB1,    28,    24,    34,    44,    54,    64,    0,     49    }, // 0 signifies no key at that location
-  { pinB3,    29,    25,    35,    45,    55,    65,    0,     57    },
-  { pinA0,    37,    26,    36,    46,    56,    66,    0,     58    },
-*/
-
-
-};
-
-
-
-#endif // __MATRIX_H
-
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Scan/matrix/matrix_template.h	Sun Oct 16 21:38:56 2011 -0700
@@ -0,0 +1,153 @@
+/* Copyright (C) 2011 by Jacob Alexander
+ * 
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ * 
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ * 
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+ * THE SOFTWARE.
+ */
+
+#ifndef __MATRIX_H
+#define __MATRIX_H
+
+// ----- Includes -----
+
+// Compiler Includes
+#include <stdint.h>
+
+
+
+// ----- Scan Mode Setting (See matrix_scan.h for more details) -----
+#define scanMode scanDual
+
+
+
+// ----- Key Settings -----
+
+// -- Example for scanCol --
+/*
+#define KEYBOARD_SIZE 16 // # of keys
+#define MAX_ROW_SIZE  16 // # of keys in the largest row
+#define MAX_COL_SIZE   1 // # of keys in the largest column
+*/
+
+
+// -- Example for scanRow --
+/*
+#define KEYBOARD_SIZE 16 // # of keys
+#define MAX_ROW_SIZE   1 // # of keys in the largest row
+#define MAX_COL_SIZE  16 // # of keys in the largest column
+*/
+
+
+// -- Example for scanRow_powrCol, scanCol_powrRow, and scanDual --
+/*
+#define KEYBOARD_SIZE 69 // # of keys
+#define MAX_ROW_SIZE   8 // # of keys in the largest row
+#define MAX_COL_SIZE   9 // # of keys in the largest column
+*/
+
+
+
+// ----- Matrix Configuration -----
+static const uint8_t matrix_pinout[][MAX_ROW_SIZE + 1] = {
+
+
+
+// Just layout the matrix by rows and columns
+// Usually you'll want to set the scanMode above to scanDual or scanCol_powrRow/scanRow_powrCol
+// The mode allows for optimization in the kind of scanning algorithms that are done
+// 
+// The key numbers are used to translate into the keymap table (array) (and always start from 1, not 0).
+// Thus if a row doesn't use all the key positions, you can denote it as 0, which will be ignored/skipped on each scan
+// See the keymap.h file for the various preconfigured arrays.
+
+// Scan Mode | Col 1 | Col 2 | Col 3 | Col 4 | Col 5 | ...
+// -------------------------------------------------------
+//     Row 1 | Key 1   Key 7   Key32    ...
+//     Row 2 | Key 3   Key92    ...
+//     Row 3 | Key23    ...
+//     Row 4 |  ...
+//     Row 5 |
+//      ...  |
+
+
+// -- scanCol Example --
+/*
+  { scanMode, pinF0, pinF4, pinB7, pinD3, pinF5, pinF1, pinD1, pinD2, pinF6, pinF7, pinB2, pinD0, pinB0, pinB6, pinB1, pinB3 },
+  { pinNULL,  1,     2,     3,     4,     5,     6,     7,     8,     9,     10,    11,    12,    13,    14,    15,    16    },
+*/
+
+
+// -- scanRow Example --
+/*
+  { scanMode, pinNULL },
+  { pinF0,    1       },
+  { pinF4,    2       },
+  { pinB7,    3       },
+  { pinD3,    4       },
+  { pinF5,    5       },
+  { pinF1,    6       },
+  { pinD1,    7       },
+  { pinD2,    8       },
+  { pinF6,    9       },
+  { pinF7,    10      },
+  { pinB2,    11      },
+  { pinD0,    12      },
+  { pinB0,    13      },
+  { pinB6,    14      },
+  { pinB1,    15      },
+  { pinB3,    16      },
+*/
+
+
+// -- scanRow_powrCol Example and scanCol_powrRow Example --
+// The example is the same, as the difference is whether the row or col is powered, and the other is used to detect the signal
+/*
+  { scanMode, pinF0, pinF4, pinB7, pinD3, pinF5, pinF1, pinD1, pinD2 },
+  { pinF6,    1,     2,     3,     4,     5,     6,     7,     8     },
+  { pinF7,    9,     10,    11,    12,    13,    14,    15,    16    },
+  { pinB2,    17,    20,    30,    40,    50,    60,    59,    38    },
+  { pinD0,    18,    21,    31,    41,    51,    61,    67,    39    },
+  { pinB0,    19,    22,    32,    42,    52,    62,    68,    47    },
+  { pinB6,    27,    23,    33,    43,    53,    63,    69,    48    },
+  { pinB1,    28,    24,    34,    44,    54,    64,    0,     49    }, // 0 signifies no key at that location
+  { pinB3,    29,    25,    35,    45,    55,    65,    0,     57    },
+  { pinA0,    37,    26,    36,    46,    56,    66,    0,     58    },
+*/
+
+
+// -- scanDual Example --
+// The example is the same as the previous one, but uses both columns and rows to power and detect, needed for non-NKRO matrices.
+/*
+  { scanMode, pinF0, pinF4, pinB7, pinD3, pinF5, pinF1, pinD1, pinD2 },
+  { pinF6,    1,     2,     3,     4,     5,     6,     7,     8     },
+  { pinF7,    9,     10,    11,    12,    13,    14,    15,    16    },
+  { pinB2,    17,    20,    30,    40,    50,    60,    59,    38    },
+  { pinD0,    18,    21,    31,    41,    51,    61,    67,    39    },
+  { pinB0,    19,    22,    32,    42,    52,    62,    68,    47    },
+  { pinB6,    27,    23,    33,    43,    53,    63,    69,    48    },
+  { pinB1,    28,    24,    34,    44,    54,    64,    0,     49    }, // 0 signifies no key at that location
+  { pinB3,    29,    25,    35,    45,    55,    65,    0,     57    },
+  { pinA0,    37,    26,    36,    46,    56,    66,    0,     58    },
+*/
+
+
+};
+
+
+
+#endif // __MATRIX_H
+
--- a/Scan/matrix/setup.cmake	Sun Oct 16 20:08:37 2011 -0700
+++ b/Scan/matrix/setup.cmake	Sun Oct 16 21:38:56 2011 -0700
@@ -6,6 +6,13 @@
 #
 ###
 
+###
+# Warning, that this module is not meant to be built stand-alone
+#
+message( FATAL_ERROR
+"The 'matrix' module is not a stand-alone module, and requires further setup.
+See BudKeypad module for as an example module."
+)
 
 ###
 # Module C files
@@ -22,10 +29,8 @@
 #
 add_definitions( -I${HEAD_DIR}/Keymap )
 
-#| Keymap Settings
 add_definitions(
-	-DMODIFIER_MASK=budkeypad_ModifierMask
-	#-DKEYINDEX_MASK=budkeypad_TheProfosistMap
-	-DKEYINDEX_MASK=budkeypad_DefaultMap
+	#-DMODIFIER_MASK=
+	#-DKEYINDEX_MASK=
 )
 
--- a/setup.cmake	Sun Oct 16 20:08:37 2011 -0700
+++ b/setup.cmake	Sun Oct 16 21:38:56 2011 -0700
@@ -20,7 +20,7 @@
 #| Please 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  "matrix" )
+set(  ScanModule  "HeathZenith" )
 
 ##| Uses the key index and potentially applies special conditions to it, mapping it to a usb key code
 set( MacroModule  "basic"  )