1 /* Copyright (C) 2011-2013 by Jacob Alexander
3 * Permission is hereby granted, free of charge, to any person obtaining a copy
4 * of this software and associated documentation files (the "Software"), to deal
5 * in the Software without restriction, including without limitation the rights
6 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7 * copies of the Software, and to permit persons to whom the Software is
8 * furnished to do so, subject to the following conditions:
10 * The above copyright notice and this permission notice shall be included in
11 * all copies or substantial portions of the Software.
13 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
25 // ----- Includes -----
28 #include <avr/pgmspace.h>
31 #if defined(_at90usb162_) || defined(_atmega32u4_) || defined(_at90usb646_) || defined(_at90usb1286_)
32 #include "avr/usb_keyboard_debug.h"
33 #elif defined(_mk20dx128_)
34 #include "arm/usb_keyboard.h"
39 // ----- Defines -----
44 // ----- Functions and Corresponding Function Aliases -----
47 * Note that all the variadic functions below, take comma separated string lists, they are purposely not printf style (simplicity)
51 #define dPrint(c) usb_debug_putchar(c)
52 #define dPrintStr(c) usb_debug_putstr (c)
53 #define dPrintStrs(...) usb_debug_putstrs(__VA_ARGS__, "\0\0\0") // Convenience Variadic Macro
54 #define dPrintStrNL(c) dPrintStrs (c, NL) // Appends New Line Macro
55 #define dPrintStrsNL(...) usb_debug_putstrs(__VA_ARGS__, NL, "\0\0\0") // Appends New Line Macro
57 // Special Msg Constructs (Uses VT100 tags)
58 #define dPrintMsg(colour_code_str,msg,...) \
59 usb_debug_putstrs("\033[", colour_code_str, "m", msg, "\033[0m - ", __VA_ARGS__, NL, "\0\0\0")
60 #define printMsg(colour_code_str,msg,str) \
61 print("\033[" colour_code_str "m" msg "\033[0m - " str NL)
64 #define info_dPrint(...) dPrintMsg ("1;32", "INFO", __VA_ARGS__) // Info Msg
65 #define info_print(str) printMsg ("1;32", "INFO", str) // Info Msg
68 #define warn_dPrint(...) dPrintMsg ("1;33", "WARNING", __VA_ARGS__) // Warning Msg
69 #define warn_print(str) printMsg ("1;33", "WARNING", str) // Warning Msg
72 #define erro_dPrint(...) dPrintMsg ("1;5;31", "ERROR", __VA_ARGS__) // Error Msg
73 #define erro_print(str) printMsg ("1;5;31", "ERROR", str) // Error Msg
76 #define dbug_dPrint(...) dPrintMsg ("1;35", "DEBUG", __VA_ARGS__) // Debug Msg
77 #define dbug_print(str) printMsg ("1;35", "DEBUG", str) // Debug Msg
79 // Static String Printing
80 #define print(s) _print(PSTR(s))
82 void _print(const char *s);
83 void usb_debug_putstr( char* s );
84 void usb_debug_putstrs( char* first, ... );
89 #define hexToStr(hex, out) hexToStr_op(hex, out, 1)
91 void int8ToStr ( uint8_t in, char* out );
92 void int16ToStr ( uint16_t in, char* out );
93 void hexToStr_op( uint16_t in, char* out, uint8_t op );
94 void revsStr ( char* in );
95 uint16_t lenStr ( char* in );