1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- /* Copyright 2017 Potiguar Faga
- *
- * 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 KEYMAP_BR_ABNT2_H
- #define KEYMAP_BR_ABNT2_H
- #include "keymap_common.h"
- /* Scan codes for the Brazilian ABNT2 keyboard layout */
- #define BR_CCDL KC_SCLN // Ç same scancode as ;: on US layout
- #define BR_SCLN KC_SLSH // ;: same scancode as /? on US layout
- #define BR_QUOT KC_GRV // '" same scancode as `~ on US layout
- #define BR_TILD KC_QUOT // ~^ dead keys, same scancode as '" on US layout
- #define BR_ACUT KC_LBRC // ´` dead keys, same scancode as [{ on US layout
- #define BR_LBRC KC_RBRC // [{ same scancode as ]} on US layout
- #define BR_RBRC KC_BSLS // ]} same scancode as \| on US layout
- #define BR_BSLS KC_NUBS // \| uses the non-US hash scancode (#~, sometimes §±)
- #define BR_SLSH KC_INT1 // /? uses the INTL1 scancode
- #define BR_COLN LSFT(BR_SCLN) // shifted :
- #define BR_DQT LSFT(BR_QUOT) // shifted "
- #define BR_CIRC LSFT(BR_TILD) // shifted ^ (dead key)
- #define BR_GRAV LSFT(BR_ACUT) // shifted ` (dead key)
- #define BR_LCBR LSFT(BR_LBRC) // shifted {
- #define BR_RCBR LSFT(BR_RBRC) // shifted }
- #define BR_PIPE LSFT(BR_BSLS) // shifted |
- #define BR_QUES LSFT(BR_SLSH) // shifted ?
- #define BR_TRMA LSFT(KC_6) // shifted ¨ (dead key - trema accent)
- // On the ABNT2 the keypad comma and the keypad dot scancodes are switched
- // (presumably because in Brazil comma is used as the decimal separator)
- #define BR_KPDT KC_KP_COMMA // keypad .
- #define BR_KPCM KC_KP_DOT // keypad ,
- #define BR_1UP LALT(KC_1) // 1 superscript ¹ alt+1
- #define BR_2UP LALT(KC_2) // 2 superscript ² alt+2
- #define BR_3UP LALT(KC_3) // 3 superscript ³ alt+3
- #define BR_PND LALT(KC_4) // Pound sign £ alt+4
- #define BR_CENT LALT(KC_5) // Cent sign ¢ alt+5
- #define BR_NOT LALT(KC_6) // Not sign ¬ alt+6
- #define BR_SECT LALT(KC_EQL) // Section sign § alt+=
- #define BR_FORD LALT(BR_LBRC) // Feminine Ordinal Sign ª alt+[
- #define BR_MORD LALT(BR_RBRC) // Masculine Ordinal Sign º alt+]
- #define BR_DGRE LALT(BR_SLSH) // Degree sign ° alt+/
- #define BR_EURO LALT(KC_E) // Euro sign € alt+e
- #define BR_NDTD LALT(BR_TILD) // Non-dead key tilde ~ alt+~
- #define BR_NDAC LALT(BR_ACUT) // Non-dead key acute accent ´ alt+´
- #define BR_NDGV LALT(BR_QUOT) // Non-dead key grave accent ` alt+'
- #define BR_NDCR LALT(BR_CIRC) // Non-dead key circumflex accent ^ alt+^ (alt+shift+~)
- #define BR_NDTR LALT(BR_TRMA) // Non-dead key trema accent ¨ alt+¨ (alt+shift+6)
- // For 101-key keyboard layouts, the ABNT2 layout allows
- // the slash and question mark to be typed using alt+q and alt+w.
- // The shortcuts are provided here for completeness' sake,
- // but it's recommended to use BR_SLSH and BR_QUES instead
- #define BR_ASLS LALT(KC_Q)
- #define BR_AQST LALT(KC_W)
- #endif
|