mirror of
https://github.com/osiweb/unified_retro_keyboard.git
synced 2025-01-08 08:32:25 +00:00
126 lines
3.6 KiB
C
126 lines
3.6 KiB
C
// -*- mode: C; tab-width: 2 ; indent-tabs-mode: nil -*-
|
|
//
|
|
// Unified Keyboard Project
|
|
// ASDF keyboard firmware
|
|
//
|
|
// asdf_keymap_table.c
|
|
//
|
|
// initialize keymap setup function table
|
|
//
|
|
// *** This is a special versiof for testing.
|
|
// *** Not auto-generated.
|
|
//
|
|
// Copyright 2019 David Fenyes
|
|
//
|
|
// 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 3 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 <https://www.gnu.org/licenses/>.
|
|
//
|
|
|
|
#include <stdint.h>
|
|
#include "asdf_keymap_table.h"
|
|
#include "test_asdf_keymap_defs.h"
|
|
|
|
// PROCEDURE: asdf_keymap_setup
|
|
//
|
|
// INPUTS: (uint8_t) index - index of the keymap setup function to call
|
|
// OUTPUTS: none
|
|
////
|
|
// DESCRIPTION: This function calls the keymap setup function specified
|
|
// by the index.
|
|
//
|
|
// SIDE EFFECTS: See Description
|
|
//
|
|
// NOTES: This function is necessary because functions defined in external
|
|
// modules are not considered compile-time constants by the C99 standard, so the
|
|
// array cannot be initialized with a compile-time declaration.
|
|
//
|
|
// SCOPE: public
|
|
//
|
|
// COMPLEXITY: 1
|
|
//
|
|
void asdf_keymap_setup(uint8_t index) {
|
|
switch(index) {
|
|
|
|
default:
|
|
case ASDF_TEST_PLAIN_MAP_INDEX: setup_test_plain_map(); break;
|
|
case ASDF_TEST_CAPS_MAP_INDEX: setup_test_caps_map(); break;
|
|
case ASDF_TEST2_PLAIN_MAP_INDEX: setup_test2_plain_map(); break;
|
|
case ASDF_TEST2_CAPS_MAP_INDEX: setup_test2_caps_map();
|
|
break;
|
|
|
|
// keymap assignments for the virtual device tests
|
|
case SINGLE_TESTS_KEYMAP: setup_test_vdevs_single(); break;
|
|
case DOUBLE_ASSIGN_TEST_KEYMAP: setup_test_vdevs_double(); break;
|
|
case TRIPLE_TESTS_KEYMAP: setup_test_vdevs_triple(); break;
|
|
case VCAPS_TEST_KEYMAP: setup_test_vdevs_vcaps();
|
|
break;
|
|
|
|
// keymap assignments for the hook mechanism tests
|
|
case ASDF_TEST_DEFAULT_SCANNER_MAP: setup_test_hooks_alt_scanner(); break;
|
|
case ASDF_TEST_ALTERNATE_OUTPUT_MAP: setup_test_hooks_alt_output(); break;
|
|
case ASDF_TEST_EACH_SCAN_MAP: setup_test_hooks_each_scan(); break;
|
|
}
|
|
}
|
|
|
|
// PROCEDURE: asdf_keymap_valid
|
|
//
|
|
// INPUTS: (uint8_t) index - index of the keymap setup function to check
|
|
// OUTPUTS: (uintu_t) returns TRUE (nonzero) if valid, FALSE (0) otherwise
|
|
//
|
|
// DESCRIPTION: This function returns TRUE if the index corresponds to
|
|
// a valid keymap.
|
|
//
|
|
// SIDE EFFECTS: none
|
|
//
|
|
// NOTES:
|
|
//
|
|
// SCOPE: public
|
|
//
|
|
// COMPLEXITY: 1
|
|
//
|
|
uint8_t asdf_keymap_valid(uint8_t index) {
|
|
uint8_t valid = 0;
|
|
|
|
switch(index) {
|
|
case ASDF_TEST_PLAIN_MAP_INDEX:
|
|
case ASDF_TEST_CAPS_MAP_INDEX:
|
|
case ASDF_TEST2_PLAIN_MAP_INDEX:
|
|
case ASDF_TEST2_CAPS_MAP_INDEX:
|
|
|
|
// keymap assignments for the virtual device tests
|
|
case SINGLE_TESTS_KEYMAP:
|
|
case DOUBLE_ASSIGN_TEST_KEYMAP:
|
|
case TRIPLE_TESTS_KEYMAP:
|
|
case VCAPS_TEST_KEYMAP:
|
|
|
|
// keymap assignments for the hook mechanism tests
|
|
case ASDF_TEST_DEFAULT_SCANNER_MAP:
|
|
case ASDF_TEST_ALTERNATE_OUTPUT_MAP:
|
|
case ASDF_TEST_EACH_SCAN_MAP:
|
|
|
|
valid = 1;
|
|
break;
|
|
|
|
default:
|
|
valid = 0;
|
|
break;
|
|
}
|
|
|
|
return valid;
|
|
}
|
|
|
|
|
|
//-------|---------|---------+---------+---------+---------+---------+---------+
|
|
// Above line is 80 columns, and should display completely in the editor.
|
|
|