mirror of
				https://github.com/mfulz/qmk_firmware.git
				synced 2025-11-04 07:12:33 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			173 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			173 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						||
Copyright 2020 rupa <rupa@lrrr.us> @rupa
 | 
						||
 | 
						||
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/>.
 | 
						||
*/
 | 
						||
 | 
						||
#include "unicode.h"
 | 
						||
 | 
						||
combined_mode_t combined_mode = CM_NULL;
 | 
						||
bool _seeded = false;
 | 
						||
 | 
						||
#if defined(UNICODEMAP_ENABLE)
 | 
						||
const uint32_t unicode_map[] PROGMEM = {
 | 
						||
    [CCIR] = 0x20DD,  // COMBINING CIRCLE  ⃝
 | 
						||
    [CENT] = 0x00A2,  // ¢
 | 
						||
    [CHEK] = 0x2713,  // ✓
 | 
						||
    [CKEY] = 0x20E3,  // COMBINING KEYCAP  ⃣
 | 
						||
    [CUI]  = 0x26A0,  // ⚠
 | 
						||
    [ECKS] = 0x2716,  // ✖
 | 
						||
    [EFF]  = 0x017F,  // ſ
 | 
						||
    [HAS]  = 0x262D,  // ☭
 | 
						||
    [HUN]  = 0x1F4AF, // 💯
 | 
						||
    [IBNG] = 0x203D,  // ‽
 | 
						||
    [IRNY] = 0x2E2E,  // ⸮
 | 
						||
    [LALL] = 0x2200,  // ∀
 | 
						||
    [LELM] = 0x2208,  // ∈
 | 
						||
    [LEXI] = 0x2203,  // ∃
 | 
						||
    [LPRO] = 0x22A2,  // ⊢
 | 
						||
    [M4]   = 0x2669,  // ♩
 | 
						||
    [M8]   = 0x266A,  // ♪
 | 
						||
    [M8B]  = 0x266B,  // ♫
 | 
						||
    [M16]  = 0x266C,  // ♬
 | 
						||
    [NEG]  = 0x20E0,  // COMBINING NO  ⃠
 | 
						||
    [NOPE] = 0x1F6AB, // 🚫
 | 
						||
    [NUM]  = 0x2116,  // №
 | 
						||
    [OM]   = 0x0950,  // ॐ
 | 
						||
    [SMB]  = 0x263A,  // ☻
 | 
						||
    [SMW]  = 0x263B,  // ☺
 | 
						||
    [STB]  = 0x2605,  // ★
 | 
						||
    [STOP] = 0x26D4,  // ⛔
 | 
						||
    [STW]  = 0x2606,  // ☆
 | 
						||
};
 | 
						||
#endif
 | 
						||
 | 
						||
const char *d6_map[] = {
 | 
						||
    "⚀", "⚁", "⚂", "⚃", "⚄", "⚅"
 | 
						||
};
 | 
						||
const char *dance_map[] = {
 | 
						||
    "〜( ̄▽ ̄〜)",
 | 
						||
    "(〜 ̄▽ ̄)〜"
 | 
						||
};
 | 
						||
const char *dance_more_map[] = {
 | 
						||
    "ƪ(˘⌣˘)┐",
 | 
						||
    "┌(˘⌣˘)ʃ"
 | 
						||
};
 | 
						||
const char *flip_map[] = {
 | 
						||
    "(╯°□°)╯︵ ┻━━┻",
 | 
						||
    "(ノ-_-)ノ・・ ┻━━┻",
 | 
						||
    "(ノꐦ⊙曲ఠ)ノ彡┻━┻"
 | 
						||
};
 | 
						||
const char *flip_back_map[] = {
 | 
						||
    "┬──┬◡ノ(° -°ノ)",
 | 
						||
    "┬──┬ノ( ゜-゜ノ)",
 | 
						||
    "┬──┬ノ(ಠ_ಠノ)"
 | 
						||
};
 | 
						||
const char *joy_map[] = {
 | 
						||
    "ᕕ( ᐛ )ᕗ ",
 | 
						||
    "٩(ˊᗜˋ*)و",
 | 
						||
    "٩( ᐛ )و"
 | 
						||
};
 | 
						||
const char *joy_harder_map[] = {
 | 
						||
    "\\\ ٩( ᐛ )و //",
 | 
						||
    "✧*。٩(ˊᗜˋ*)و✧*。"
 | 
						||
};
 | 
						||
 | 
						||
const char *choice(const char *choices[], int size) {
 | 
						||
    if (_seeded == false) {
 | 
						||
        srand(timer_read32());
 | 
						||
        dprintf("_seeded the roll\n");
 | 
						||
        _seeded = true;
 | 
						||
    }
 | 
						||
    return choices[rand() % size];
 | 
						||
}
 | 
						||
 | 
						||
const char *d6(void) {
 | 
						||
    return choice(d6_map, 6);
 | 
						||
}
 | 
						||
const char *dance(bool more) {
 | 
						||
    if (more) {
 | 
						||
        return choice(dance_more_map, 2);
 | 
						||
    }
 | 
						||
    return choice(dance_map, 2);
 | 
						||
}
 | 
						||
const char *flip(bool flip_back) {
 | 
						||
    if (flip_back) {
 | 
						||
        return choice(flip_back_map, 3);
 | 
						||
    }
 | 
						||
    return choice(flip_map, 3);
 | 
						||
}
 | 
						||
const char *joy(bool harder) {
 | 
						||
    if (harder) {
 | 
						||
        return choice(joy_harder_map, 2);
 | 
						||
    }
 | 
						||
    return choice(joy_map, 3);
 | 
						||
}
 | 
						||
 | 
						||
bool u_x(const char *text) {
 | 
						||
    send_unicode_string(text);
 | 
						||
    return false;
 | 
						||
};
 | 
						||
bool u_xp(bool is_shifted, const char *shifted, const char *plain) {
 | 
						||
    send_unicode_string(is_shifted ? shifted : plain);
 | 
						||
    return false;
 | 
						||
};
 | 
						||
 | 
						||
void zalgo(void) {
 | 
						||
    unicode_input_start();
 | 
						||
    int number = (rand() % (8 + 1 - 2)) + 2;
 | 
						||
    unsigned int index;
 | 
						||
    for (index=0; index<number; index++) {
 | 
						||
        uint16_t hex = (rand() % (0x036F + 1 - 0x0300)) + 0x0300;
 | 
						||
        register_hex(hex);
 | 
						||
    }
 | 
						||
    unicode_input_finish();
 | 
						||
}
 | 
						||
 | 
						||
bool combined_text(uint16_t keycode) {
 | 
						||
    if (keycode < KC_A || (keycode > KC_0 && keycode < KC_MINUS) || keycode > KC_SLASH) {
 | 
						||
        return false;
 | 
						||
    }
 | 
						||
    tap_code(keycode);
 | 
						||
 | 
						||
    switch (combined_mode) {
 | 
						||
        case CM_CIRCLE:
 | 
						||
          register_unicode(0x20DD);
 | 
						||
          break;
 | 
						||
        case CM_NO:
 | 
						||
          register_unicode(0x20E0);
 | 
						||
          break;
 | 
						||
        case CM_KEYCAP:
 | 
						||
          register_unicode(0x20E3);
 | 
						||
          break;
 | 
						||
        case CM_ZALGO:
 | 
						||
          zalgo();
 | 
						||
          break;
 | 
						||
        default:
 | 
						||
          break;
 | 
						||
    }
 | 
						||
    return true;
 | 
						||
}
 | 
						||
 | 
						||
void cycle_combined_mode(void) {
 | 
						||
    if (combined_mode++ >= CM_MAX - 1) {
 | 
						||
        combined_mode = CM_NULL;
 | 
						||
    }
 | 
						||
}
 | 
						||
 | 
						||
combined_mode_t set_combined_mode(combined_mode_t mode) {
 | 
						||
    combined_mode = combined_mode == mode ? CM_NULL : mode;
 | 
						||
    return combined_mode;
 | 
						||
}
 |