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