|  |  |  | /*
 | 
					
						
							|  |  |  |              LUFA Library | 
					
						
							|  |  |  |      Copyright (C) Dean Camera, 2012. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   dean [at] fourwalledcubicle [dot] com | 
					
						
							|  |  |  |            www.lufa-lib.org | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Copyright 2012  Dean Camera (dean [at] fourwalledcubicle [dot] com) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Permission to use, copy, modify, distribute, and sell this | 
					
						
							|  |  |  |   software and its documentation for any purpose is hereby granted | 
					
						
							|  |  |  |   without fee, provided that the above copyright notice appear in | 
					
						
							|  |  |  |   all copies and that both that the copyright notice and this | 
					
						
							|  |  |  |   permission notice and warranty disclaimer appear in supporting | 
					
						
							|  |  |  |   documentation, and that the name of the author not be used in | 
					
						
							|  |  |  |   advertising or publicity pertaining to distribution of the | 
					
						
							|  |  |  |   software without specific, written prior permission. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   The author disclaim all warranties with regard to this | 
					
						
							|  |  |  |   software, including all implied warranties of merchantability | 
					
						
							|  |  |  |   and fitness.  In no event shall the author be liable for any | 
					
						
							|  |  |  |   special, indirect or consequential damages or any damages | 
					
						
							|  |  |  |   whatsoever resulting from loss of use, data or profits, whether | 
					
						
							|  |  |  |   in an action of contract, negligence or other tortious action, | 
					
						
							|  |  |  |   arising out of or in connection with the use or performance of | 
					
						
							|  |  |  |   this software. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** \file
 | 
					
						
							|  |  |  |  *  \brief ANSI terminal special escape code macros. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  ANSI terminal compatible escape sequences. These escape sequences are designed to be concatenated with existing | 
					
						
							|  |  |  |  *  strings to modify their display on a compatible terminal application. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** \ingroup Group_MiscDrivers
 | 
					
						
							|  |  |  |  *  \defgroup Group_Terminal ANSI Terminal Escape Codes - LUFA/Drivers/Misc/TerminalCodes.h | 
					
						
							|  |  |  |  *  \brief ANSI terminal special escape code macros. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  \section Sec_Dependencies Module Source Dependencies | 
					
						
							|  |  |  |  *  The following files must be built with any user project that uses this module: | 
					
						
							|  |  |  |  *    - None | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  \section Sec_ModDescription Module Description | 
					
						
							|  |  |  |  *  Escape code macros for ANSI compliant text terminals. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  \note If desired, the macro \c DISABLE_TERMINAL_CODES can be defined in the project makefile and passed to the GCC | 
					
						
							|  |  |  |  *        compiler via the -D switch to disable the terminal codes without modifying the source, for use with non | 
					
						
							|  |  |  |  *        compatible terminals (any terminal codes then equate to empty strings). | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  \section Sec_ExampleUsage Example Usage | 
					
						
							|  |  |  |  *  The following snippet is an example of how this module may be used within a typical | 
					
						
							|  |  |  |  *  application. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  \code | 
					
						
							|  |  |  |  *      printf("Normal String, " | 
					
						
							|  |  |  |  *             ESC_BOLD_ON "Bold String, " | 
					
						
							|  |  |  |  *             ESC_UNDERLINE_ON "Bold and Underlined String" | 
					
						
							|  |  |  |  *             ESC_RESET ESC_FG_BLUE ESC_BG_YELLOW "Normal Blue-on-Yellow String"); | 
					
						
							|  |  |  |  *  \endcode | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  @{ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef __TERMINALCODES_H__
 | 
					
						
							|  |  |  | #define __TERMINALCODES_H__
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Public Interface - May be used in end-application: */ | 
					
						
							|  |  |  | 		/* Macros: */ | 
					
						
							|  |  |  | 			#if !defined(DISABLE_TERMINAL_CODES)
 | 
					
						
							|  |  |  | 				/** Creates an ANSI escape sequence with the specified payload.
 | 
					
						
							|  |  |  | 				 * | 
					
						
							|  |  |  | 				 *  \param[in] EscapeSeq  Payload to encode as an ANSI escape sequence, a \c ESC_* mask. | 
					
						
							|  |  |  | 				 */ | 
					
						
							|  |  |  | 				#define ANSI_ESCAPE_SEQUENCE(EscapeSeq)  "\33[" EscapeSeq
 | 
					
						
							|  |  |  | 			#else
 | 
					
						
							|  |  |  | 				#define ANSI_ESCAPE_SEQUENCE(EscapeSeq)
 | 
					
						
							|  |  |  | 			#endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** \name Text Display Modifier Control Sequences */ | 
					
						
							|  |  |  | 			//@{
 | 
					
						
							|  |  |  | 			/** Turns on bold so that any following text is printed to the terminal in bold. */ | 
					
						
							|  |  |  | 			#define ESC_BOLD_ON                     ANSI_ESCAPE_SEQUENCE("1m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Turns on italics so that any following text is printed to the terminal in italics. */ | 
					
						
							|  |  |  | 			#define ESC_ITALICS_ON                  ANSI_ESCAPE_SEQUENCE("3m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Turns on underline so that any following text is printed to the terminal underlined. */ | 
					
						
							|  |  |  | 			#define ESC_UNDERLINE_ON                ANSI_ESCAPE_SEQUENCE("4m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Turns on inverse so that any following text is printed to the terminal in inverted colours. */ | 
					
						
							|  |  |  | 			#define ESC_INVERSE_ON                  ANSI_ESCAPE_SEQUENCE("7m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Turns on strikethrough so that any following text is printed to the terminal with a line through the
 | 
					
						
							|  |  |  | 			 *  center. | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			#define ESC_STRIKETHROUGH_ON            ANSI_ESCAPE_SEQUENCE("9m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Turns off bold so that any following text is printed to the terminal in non bold. */ | 
					
						
							|  |  |  | 			#define ESC_BOLD_OFF                    ANSI_ESCAPE_SEQUENCE("22m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Turns off italics so that any following text is printed to the terminal in non italics. */ | 
					
						
							|  |  |  | 			#define ESC_ITALICS_OFF                 ANSI_ESCAPE_SEQUENCE("23m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Turns off underline so that any following text is printed to the terminal non underlined. */ | 
					
						
							|  |  |  | 			#define ESC_UNDERLINE_OFF               ANSI_ESCAPE_SEQUENCE("24m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Turns off inverse so that any following text is printed to the terminal in non inverted colours. */ | 
					
						
							|  |  |  | 			#define ESC_INVERSE_OFF                 ANSI_ESCAPE_SEQUENCE("27m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Turns off strikethrough so that any following text is printed to the terminal without a line through
 | 
					
						
							|  |  |  | 			 *  the center. | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			#define ESC_STRIKETHROUGH_OFF           ANSI_ESCAPE_SEQUENCE("29m")
 | 
					
						
							|  |  |  | 			//@}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** \name Text Colour Control Sequences */ | 
					
						
							|  |  |  | 			//@{
 | 
					
						
							|  |  |  | 			/** Sets the foreground (text) colour to black. */ | 
					
						
							|  |  |  | 			#define ESC_FG_BLACK                    ANSI_ESCAPE_SEQUENCE("30m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the foreground (text) colour to red. */ | 
					
						
							|  |  |  | 			#define ESC_FG_RED                      ANSI_ESCAPE_SEQUENCE("31m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the foreground (text) colour to green. */ | 
					
						
							|  |  |  | 			#define ESC_FG_GREEN                    ANSI_ESCAPE_SEQUENCE("32m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the foreground (text) colour to yellow. */ | 
					
						
							|  |  |  | 			#define ESC_FG_YELLOW                   ANSI_ESCAPE_SEQUENCE("33m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the foreground (text) colour to blue. */ | 
					
						
							|  |  |  | 			#define ESC_FG_BLUE                     ANSI_ESCAPE_SEQUENCE("34m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the foreground (text) colour to magenta. */ | 
					
						
							|  |  |  | 			#define ESC_FG_MAGENTA                  ANSI_ESCAPE_SEQUENCE("35m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the foreground (text) colour to cyan. */ | 
					
						
							|  |  |  | 			#define ESC_FG_CYAN                     ANSI_ESCAPE_SEQUENCE("36m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the foreground (text) colour to white. */ | 
					
						
							|  |  |  | 			#define ESC_FG_WHITE                    ANSI_ESCAPE_SEQUENCE("37m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the foreground (text) colour to the terminal's default. */ | 
					
						
							|  |  |  | 			#define ESC_FG_DEFAULT                  ANSI_ESCAPE_SEQUENCE("39m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the text background colour to black. */ | 
					
						
							|  |  |  | 			#define ESC_BG_BLACK                    ANSI_ESCAPE_SEQUENCE("40m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the text background colour to red. */ | 
					
						
							|  |  |  | 			#define ESC_BG_RED                      ANSI_ESCAPE_SEQUENCE("41m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the text background colour to green. */ | 
					
						
							|  |  |  | 			#define ESC_BG_GREEN                    ANSI_ESCAPE_SEQUENCE("42m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the text background colour to yellow. */ | 
					
						
							|  |  |  | 			#define ESC_BG_YELLOW                   ANSI_ESCAPE_SEQUENCE("43m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the text background colour to blue. */ | 
					
						
							|  |  |  | 			#define ESC_BG_BLUE                     ANSI_ESCAPE_SEQUENCE("44m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the text background colour to magenta. */ | 
					
						
							|  |  |  | 			#define ESC_BG_MAGENTA                  ANSI_ESCAPE_SEQUENCE("45m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the text background colour to cyan. */ | 
					
						
							|  |  |  | 			#define ESC_BG_CYAN                     ANSI_ESCAPE_SEQUENCE("46m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the text background colour to white. */ | 
					
						
							|  |  |  | 			#define ESC_BG_WHITE                    ANSI_ESCAPE_SEQUENCE("47m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the text background colour to the terminal's default. */ | 
					
						
							|  |  |  | 			#define ESC_BG_DEFAULT                  ANSI_ESCAPE_SEQUENCE("49m")
 | 
					
						
							|  |  |  | 			//@}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** \name Cursor Positioning Control Sequences */ | 
					
						
							|  |  |  | 			//@{
 | 
					
						
							|  |  |  | 			/** Saves the current cursor position so that it may be restored with \ref ESC_CURSOR_POS_RESTORE. */ | 
					
						
							|  |  |  | 			#define ESC_CURSOR_POS_SAVE             ANSI_ESCAPE_SEQUENCE("s")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Restores the cursor position to the last position saved with \ref ESC_CURSOR_POS_SAVE. */ | 
					
						
							|  |  |  | 			#define ESC_CURSOR_POS_RESTORE          ANSI_ESCAPE_SEQUENCE("u")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Sets the cursor position to the given line and column.
 | 
					
						
							|  |  |  | 			 * | 
					
						
							|  |  |  | 			 *  \param[in] Line    Line number to position the cursor at. | 
					
						
							|  |  |  | 			 *  \param[in] Column  Column number to position the cursor at. | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			#define ESC_CURSOR_POS(Line, Column)    ANSI_ESCAPE_SEQUENCE(#Line ";" #Column "H")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Moves the cursor up the given number of lines.
 | 
					
						
							|  |  |  | 			 * | 
					
						
							|  |  |  | 			 *  \param[in] Lines  Number of lines to move the cursor position | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			#define ESC_CURSOR_UP(Lines)            ANSI_ESCAPE_SEQUENCE(#Lines "A")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Moves the cursor down the given number of lines.
 | 
					
						
							|  |  |  | 			 * | 
					
						
							|  |  |  | 			 *  \param[in] Lines  Number of lines to move the cursor position | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			#define ESC_CURSOR_DOWN(Lines)          ANSI_ESCAPE_SEQUENCE(#Lines "B")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Moves the cursor to the right the given number of columns.
 | 
					
						
							|  |  |  | 			 * | 
					
						
							|  |  |  | 			 *  \param[in] Columns  Number of columns to move the cursor position | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			#define ESC_CURSOR_FORWARD(Columns)     ANSI_ESCAPE_SEQUENCE(#Columns "C")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Moves the cursor to the left the given number of columns.
 | 
					
						
							|  |  |  | 			 * | 
					
						
							|  |  |  | 			 *  \param[in] Columns  Number of columns to move the cursor position | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			#define ESC_CURSOR_BACKWARD(Columns)    ANSI_ESCAPE_SEQUENCE(#Columns "D")
 | 
					
						
							|  |  |  | 			//@}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** \name Miscellaneous Control Sequences */ | 
					
						
							|  |  |  | 			//@{
 | 
					
						
							|  |  |  | 			/** Resets any escape sequence modifiers back to their defaults. */ | 
					
						
							|  |  |  | 			#define ESC_RESET                       ANSI_ESCAPE_SEQUENCE("0m")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Erases the entire display, returning the cursor to the top left. */ | 
					
						
							|  |  |  | 			#define ESC_ERASE_DISPLAY               ANSI_ESCAPE_SEQUENCE("2J")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/** Erases the current line, returning the cursor to the far left. */ | 
					
						
							|  |  |  | 			#define ESC_ERASE_LINE                  ANSI_ESCAPE_SEQUENCE("K")
 | 
					
						
							|  |  |  | 			//@}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** @} */ | 
					
						
							|  |  |  | 
 |