mirror of
https://github.com/AppleWin/AppleWin.git
synced 2025-01-04 02:30:53 +00:00
e1b0b20aad
* Bump debugger version 2.9.1.19 * Cleanup * Debugger: Update DISK INFO to display disk info across 2 lines of text * Debugger: Fix ConsolePrint() to wrap long lines of text * Debugger: Update DISK INFO to show last nibble for non WOZ floppy image * Replace optional pointer with reference in GetCurrentState() * Add Log.h to Disk.h * Cleanup GetCurrentState() * Cleanup whitespace * Add single line output for DISK INFO foundation. Still need CONFIG DISK # * 2.9.1.21 Added: DISK INFO [#]
354 lines
10 KiB
C++
354 lines
10 KiB
C++
#ifndef DEBUGGER_CONSOLE_H
|
|
#define DEBUGGER_CONSOLE_H
|
|
|
|
#include <cstdarg>
|
|
|
|
#include "StrFormat.h"
|
|
|
|
enum
|
|
{
|
|
// Basic Symbol table has > 600 symbols
|
|
// Lines, was 128, but need ~ 256+16 for PROFILE LIST
|
|
// Output
|
|
CONSOLE_HEIGHT = 768,
|
|
CONSOLE_WIDTH = 80,
|
|
|
|
// need min 256+ lines for "profile list"
|
|
CONSOLE_BUFFER_HEIGHT = CONSOLE_HEIGHT,
|
|
|
|
// Input
|
|
HISTORY_HEIGHT = 128,
|
|
HISTORY_WIDTH = 128,
|
|
|
|
CONSOLE_FIRST_LINE = 1, // where ConsoleDisplay is pushed up from
|
|
};
|
|
|
|
// Color ____________________________________________________________________
|
|
|
|
// typedef unsigned char conchar_t;
|
|
typedef short conchar_t;
|
|
|
|
// NOTE: Keep in sync ConsoleColors_e g_anConsoleColor !
|
|
enum ConsoleColors_e
|
|
{
|
|
CONSOLE_COLOR_K, // 0
|
|
CONSOLE_COLOR_x = 0, // default console foreground
|
|
CONSOLE_COLOR_R, // 1 Red
|
|
CONSOLE_COLOR_G, // 2 Green
|
|
CONSOLE_COLOR_Y, // 3 Yellow
|
|
CONSOLE_COLOR_B, // 4 Blue
|
|
CONSOLE_COLOR_M, // 5 Magenta/Purple
|
|
CONSOLE_COLOR_C, // 6 Cyan
|
|
CONSOLE_COLOR_W, // 7 White
|
|
CONSOLE_COLOR_O, // 8 Orange
|
|
CONSOLE_COLOR_k, // 9 Grey
|
|
CONSOLE_COLOR_b, // : Light Blue
|
|
NUM_CONSOLE_COLORS
|
|
};
|
|
extern COLORREF g_anConsoleColor[ NUM_CONSOLE_COLORS ];
|
|
|
|
// Note: THe ` ~ key should always display ~ to prevent rendering errors
|
|
#define CONSOLE_COLOR_ESCAPE_CHAR '`'
|
|
#define _CONSOLE_COLOR_MASK 0x7F
|
|
|
|
/* Help Colors
|
|
*/
|
|
#if 1 // USE_APPLE_FONT
|
|
// TODO: char *g_aColorTextStrings[] = ""
|
|
// TODO: replace with CT_STRINGS[0]
|
|
// TODO: CT_COMMA
|
|
// TODO: CT_COLON
|
|
// TODO: CT_PAREN_L
|
|
// TODO: CT_PAREN_R
|
|
|
|
// Console Help Color
|
|
#define CHC_DEFAULT "`0"
|
|
#define CHC_USAGE "`3"
|
|
#define CHC_CATEGORY "`6" // Cyan
|
|
#define CHC_COMMAND "`2" // Green
|
|
#define CHC_KEY "`1" // Red
|
|
#define CHC_ARG_MAND "`7" // < >
|
|
#define CHC_ARG_OPT "`4" // [ ]
|
|
#define CHC_ARG_SEP "`9" // | grey
|
|
#define CHC_NUM_DEC "`:" // Lite Blue looks better then yellow (_SearchMemoryDisplay), S D000:FFFF A9 00, PROFILE, HELP BP
|
|
#define CHC_NUM_HEX "`3"
|
|
#define CHC_SYMBOL "`2" // Symbols
|
|
#define CHC_ADDRESS "`8" // Hex Address
|
|
#define CHC_ERROR "`1" // Red
|
|
#define CHC_WARNING "`8" // Orange
|
|
#define CHC_INFO "`3" // Yellow
|
|
#define CHC_STRING "`6" //
|
|
#define CHC_EXAMPLE "`:"
|
|
#define CHC_PATH "`:" // Light Blue
|
|
#define CHC_REGS "`6" // Cyan
|
|
#else
|
|
#define CHC_DEFAULT ""
|
|
#define CHC_USAGE ""
|
|
#define CHC_COMMAND ""
|
|
#define CHC_KEY ""
|
|
#define CHC_ARG_MAND ""
|
|
#define CHC_ARG_OPT ""
|
|
#define CHC_ARG_SEP ""
|
|
#define CHC_NUMBER ""
|
|
#define CHC_SYMBOL ""
|
|
#define CHC_ADDRESS ""
|
|
#define CHC_ERROR ""
|
|
#define CHC_STRING ""
|
|
#define CHC_EXAMPLE ""
|
|
#endif
|
|
|
|
// ascii markup
|
|
inline bool ConsoleColor_IsCharMeta( unsigned char c )
|
|
{
|
|
if (CONSOLE_COLOR_ESCAPE_CHAR == c)
|
|
return true;
|
|
return false;
|
|
}
|
|
|
|
inline bool ConsoleColor_IsCharColor( unsigned char c )
|
|
{
|
|
if ((c >= '0') && ((c - '0') < NUM_CONSOLE_COLORS))
|
|
return true;
|
|
return false;
|
|
}
|
|
|
|
// Console "Native" Chars
|
|
//
|
|
// There are a few different ways of encoding color chars & mouse text
|
|
// Simplist method is to use a user-defined ESCAPE char to shift
|
|
// into color mode, or mouse text mode. The other solution
|
|
// is to use a wide-char, simulating unicode16.
|
|
//
|
|
// C1C0 char16 of High Byte (c1) and Low Byte (c0)
|
|
// 1) --?? Con: Colors chars take up extra chars.
|
|
// Con: String Length is complicated.
|
|
// Pro: simple to parse
|
|
//
|
|
// <-- WE USE THIS
|
|
// 2) ccea Pro: Efficient packing of plain text and mouse text
|
|
// Pro: Color is optional (only record new color)
|
|
// Con: need to provide char8 and char16 API
|
|
// Con: little more difficult to parse/convert plain text
|
|
// i.e.
|
|
// ea = 0x20 - 0x7F ASCII
|
|
// 0x80 - 0xFF Mouse Text '@'-'Z' -> 0x00 - 0x1F
|
|
// cc = ASCII '0' - '9' (color)
|
|
// 3) ??cc Con: Colors chars take up extra chars
|
|
// 4) f?? Con: Colors chars take up extra chars
|
|
//
|
|
// Legend:
|
|
// f Flag
|
|
// -- Not Applicable (n/a)
|
|
// ?? ASCII (0x20 - 0x7F)
|
|
// ea Extended ASCII with High-Bit representing Mouse Text
|
|
// cc Encoded Color / Mouse Text
|
|
//
|
|
inline bool ConsoleColor_IsColorOrMouse( conchar_t g )
|
|
{
|
|
if (g > _CONSOLE_COLOR_MASK)
|
|
return true;
|
|
return false;
|
|
}
|
|
|
|
inline bool ConsoleColor_IsColor( conchar_t g )
|
|
{
|
|
return ConsoleColor_IsCharColor (g >> 8);
|
|
}
|
|
|
|
inline COLORREF ConsoleColor_GetColor( conchar_t g )
|
|
{
|
|
const int iColor = (g >> 8) - '0';
|
|
if (iColor < NUM_CONSOLE_COLORS)
|
|
return g_anConsoleColor[ iColor ];
|
|
|
|
return g_anConsoleColor[ 0 ];
|
|
}
|
|
|
|
inline char ConsoleColor_GetMeta( conchar_t g )
|
|
{
|
|
return ((g >> 8) & _CONSOLE_COLOR_MASK);
|
|
}
|
|
|
|
inline char ConsoleChar_GetChar( conchar_t g )
|
|
{
|
|
return (g & _CONSOLE_COLOR_MASK);
|
|
}
|
|
|
|
inline char ConsoleColor_MakeMouse( unsigned char c )
|
|
{
|
|
return ((c - '@') + (_CONSOLE_COLOR_MASK + 1));
|
|
}
|
|
|
|
inline conchar_t ConsoleColor_MakeMeta( unsigned char c )
|
|
{
|
|
conchar_t g = (ConsoleColor_MakeMouse(c) << 8);
|
|
return g;
|
|
}
|
|
|
|
inline conchar_t ConsoleColor_MakeColor( unsigned char color, unsigned char text )
|
|
{
|
|
conchar_t g = (color << 8) | text;
|
|
return g;
|
|
}
|
|
|
|
// Return the string length without the markup
|
|
inline int ConsoleColor_StringLength( const char *pText )
|
|
{
|
|
const char *pSrc = pText;
|
|
/* */ int nLen = 0;
|
|
|
|
if ( pText )
|
|
{
|
|
while ( *pSrc )
|
|
{
|
|
if ( ConsoleColor_IsCharMeta( *pSrc ) )
|
|
pSrc++;
|
|
else
|
|
nLen++;
|
|
pSrc++;
|
|
}
|
|
}
|
|
|
|
return nLen;
|
|
}
|
|
|
|
// Globals __________________________________________________________________
|
|
|
|
// Buffer
|
|
extern bool g_bConsoleBufferPaused;
|
|
extern int g_nConsoleBuffer;
|
|
extern conchar_t g_aConsoleBuffer[ CONSOLE_BUFFER_HEIGHT ][ CONSOLE_WIDTH ]; // TODO: std::vector< line_t >
|
|
|
|
// Cursor
|
|
extern char g_sConsoleCursor[];
|
|
|
|
// Display
|
|
extern char g_aConsolePrompt[];// = TEXT(">!"); // input, assembler // NUM_PROMPTS
|
|
extern char g_sConsolePrompt[];// = TEXT(">"); // No, NOT Integer Basic! The nostalgic '*' "Monitor" doesn't look as good, IMHO. :-(
|
|
extern int g_nConsolePromptLen;
|
|
|
|
extern bool g_bConsoleFullWidth;// = false;
|
|
|
|
extern int g_iConsoleDisplayStart ; // to allow scrolling
|
|
extern int g_nConsoleDisplayTotal ; // number of lines added to console
|
|
extern int g_nConsoleDisplayLines ;
|
|
extern int g_nConsoleDisplayWidth ;
|
|
extern conchar_t g_aConsoleDisplay[ CONSOLE_HEIGHT ][ CONSOLE_WIDTH ];
|
|
|
|
// Input History
|
|
extern int g_nHistoryLinesStart;// = 0;
|
|
extern int g_nHistoryLinesTotal;// = 0; // number of commands entered
|
|
extern char g_aHistoryLines[ HISTORY_HEIGHT ][ HISTORY_WIDTH ];// = {TEXT("")};
|
|
|
|
// Input Line
|
|
// Raw input Line (has prompt)
|
|
extern char g_aConsoleInput[ CONSOLE_WIDTH ];
|
|
|
|
// Cooked input line (no prompt)
|
|
extern int g_nConsoleInputChars ;
|
|
extern char * g_pConsoleInput ; // points to past prompt
|
|
extern int g_nConsoleInputMaxLen ; // = g_nConsoleDisplayWidth-1 = 78 // Maximum number of characters allowed on input line
|
|
extern int g_nConsoleInputScrollWidth; // = g_nConsoleDisplayWidth-1 = 78 // Maximum number of characters for the horizontol scrolling window on the input line
|
|
extern const char * g_pConsoleFirstArg ; // points to first arg
|
|
extern bool g_bConsoleInputQuoted ;
|
|
extern char g_nConsoleInputSkip ;
|
|
|
|
|
|
// Prototypes _______________________________________________________________
|
|
|
|
// Console
|
|
|
|
// Buffered
|
|
void ConsolePrint( const char * pText );
|
|
inline void ConsolePrintVa( const char* pFormat, va_list va )
|
|
{
|
|
std::string strText = StrFormatV(pFormat, va);
|
|
ConsolePrint(strText.c_str());
|
|
}
|
|
inline void ConsolePrintFormat( const char* pFormat, ... ) ATTRIBUTE_FORMAT_PRINTF(1, 2);
|
|
inline void ConsolePrintFormat( const char* pFormat, ... )
|
|
{
|
|
va_list va;
|
|
va_start(va, pFormat);
|
|
ConsolePrintVa(pFormat, va);
|
|
va_end(va);
|
|
}
|
|
|
|
void ConsoleBufferToDisplay();
|
|
const conchar_t* ConsoleBufferPeek();
|
|
void ConsoleBufferPop();
|
|
|
|
void ConsoleBufferPush( const char * pString );
|
|
inline void ConsoleBufferPushVa( const char* pFormat, va_list va )
|
|
{
|
|
std::string strText = StrFormatV(pFormat, va);
|
|
ConsoleBufferPush(strText.c_str());
|
|
}
|
|
inline void ConsoleBufferPushFormat( const char* pFormat, ... ) ATTRIBUTE_FORMAT_PRINTF(1, 2);
|
|
inline void ConsoleBufferPushFormat( const char* pFormat, ... )
|
|
{
|
|
va_list va;
|
|
va_start(va, pFormat);
|
|
ConsoleBufferPushVa(pFormat, va);
|
|
va_end(va);
|
|
}
|
|
|
|
void ConsoleConvertFromText( conchar_t * sText, const char * pText );
|
|
|
|
// Display
|
|
Update_t ConsoleDisplayError( const char * pTextError );
|
|
inline Update_t ConsoleDisplayErrorVa(const char* pFormat, va_list va)
|
|
{
|
|
std::string strText = StrFormatV(pFormat, va);
|
|
return ConsoleDisplayError(strText.c_str());
|
|
}
|
|
inline Update_t ConsoleDisplayErrorFormat(const char* pFormat, ...) ATTRIBUTE_FORMAT_PRINTF(1, 2);
|
|
inline Update_t ConsoleDisplayErrorFormat(const char* pFormat, ...)
|
|
{
|
|
va_list va;
|
|
va_start(va, pFormat);
|
|
Update_t const r = ConsoleDisplayErrorVa(pFormat, va);
|
|
va_end(va);
|
|
return r;
|
|
}
|
|
void ConsoleDisplayPause();
|
|
void ConsoleDisplayPush( const char * pText );
|
|
inline void ConsoleDisplayPushVa(const char* pFormat, va_list va)
|
|
{
|
|
std::string strText = StrFormatV(pFormat, va);
|
|
ConsoleDisplayPush(strText.c_str());
|
|
}
|
|
inline void ConsoleDisplayPushFormat(const char* pFormat, ...) ATTRIBUTE_FORMAT_PRINTF(1, 2);
|
|
inline void ConsoleDisplayPushFormat(const char* pFormat, ...)
|
|
{
|
|
va_list va;
|
|
va_start(va, pFormat);
|
|
ConsoleDisplayPushVa(pFormat, va);
|
|
va_end(va);
|
|
}
|
|
void ConsoleDisplayPush ( const conchar_t * pText );
|
|
Update_t ConsoleUpdate ();
|
|
void ConsoleFlush ();
|
|
|
|
// Input
|
|
const char *ConsoleInputPeek ();
|
|
bool ConsoleInputClear ();
|
|
bool ConsoleInputBackSpace ();
|
|
bool ConsoleInputChar ( char ch );
|
|
void ConsoleInputReset ();
|
|
int ConsoleInputTabCompletion ();
|
|
|
|
void ConsoleUpdateCursor( char ch );
|
|
|
|
Update_t ConsoleBufferTryUnpause (int nLines);
|
|
|
|
// Scrolling
|
|
Update_t ConsoleScrollHome ();
|
|
Update_t ConsoleScrollEnd ();
|
|
Update_t ConsoleScrollUp ( int nLines );
|
|
Update_t ConsoleScrollDn ( int nLines );
|
|
Update_t ConsoleScrollPageUp ();
|
|
Update_t ConsoleScrollPageDn ();
|
|
|
|
#endif
|