From 1728b7b66894ea1c6265db06dc4b6bbcae832aff Mon Sep 17 00:00:00 2001 From: michaelangel007 Date: Thu, 24 Aug 2017 12:36:46 -0700 Subject: [PATCH 01/64] Bug #466 Update HELP SYM to double-quote symbols --- source/Debugger/Debugger_Help.cpp | 73 +++++++++++++++++++++++++++++-- 1 file changed, 69 insertions(+), 4 deletions(-) diff --git a/source/Debugger/Debugger_Help.cpp b/source/Debugger/Debugger_Help.cpp index b912b8b1..3c009d79 100644 --- a/source/Debugger/Debugger_Help.cpp +++ b/source/Debugger/Debugger_Help.cpp @@ -210,8 +210,9 @@ void Help_Categories() void Help_Examples() { char sText[ CONSOLE_WIDTH ]; - ConsolePrintFormat( sText, " %sExamples%s:" + ConsolePrintFormat( sText, " %sExamples%s:%s" , CHC_USAGE + , CHC_ARG_SEP , CHC_DEFAULT ); } @@ -322,6 +323,17 @@ void _ColorizeHeader( pDst += nLen; } + +void _ColorizeString( + char * & pDst, + const char *pSrc, const size_t nLen ) +{ + strcpy( pDst, pSrc ); + pDst += nLen; +} + + +// pOperator is one of CHC_* void _ColorizeOperator( char * & pDst, const char * & pSrc, char * pOperator ) @@ -343,6 +355,18 @@ void _ColorizeOperator( } + + +bool isHexDigit( char c ) +{ + if ((c >= '0') && (c <= '9')) return true; + if ((c >= 'A') && (c <= 'F')) return true; + if ((c >= 'a') && (c <= 'f')) return true; + + return false; +} + + bool Colorize( char * pDst, const char * pSrc ) { if (! pSrc) @@ -363,6 +387,9 @@ bool Colorize( char * pDst, const char * pSrc ) const char sTotal[] = "Total:"; const int nTotal = sizeof( sTotal ) - 1; + const char sExamples[] = "Examples:"; + const int nExamples = sizeof( sExamples ) - 1; + int nLen = 0; while (*pSrc) { @@ -386,6 +413,11 @@ bool Colorize( char * pDst, const char * pSrc ) _ColorizeHeader( pDst, pSrc, sTotal, nTotal ); } else + if (strncmp( sExamples, pSrc, nExamples) == 0) + { + _ColorizeHeader( pDst, pSrc, sExamples, nExamples ); + } + else if (*pSrc == '[') { _ColorizeOperator( pDst, pSrc, CHC_ARG_OPT ); @@ -416,6 +448,25 @@ bool Colorize( char * pDst, const char * pSrc ) _ColorizeOperator( pDst, pSrc, CHC_ARG_SEP ); } else + if ((*pSrc == '$') && isHexDigit(pSrc[1])) // Hex Number + { + _ColorizeOperator( pDst, pSrc, CHC_ARG_SEP ); + + const char *start = pSrc; + const char *end = pSrc; + + while( isHexDigit( *end ) ) + end++; + + size_t nDigits = end - start; + + _ColorizeString( pDst, CHC_NUM_HEX, strlen( CHC_NUM_HEX ) ); + _ColorizeString( pDst, start , nDigits ); + _ColorizeString( pDst, CHC_DEFAULT, strlen( CHC_DEFAULT ) ); + + pSrc += nDigits; + } + else { *pDst = *pSrc; pDst++; @@ -426,6 +477,7 @@ bool Colorize( char * pDst, const char * pSrc ) return true; } +// NOTE: This appends a new line inline bool ConsoleColorizePrint( char* colorizeBuf, size_t /*colorizeBufSz*/, const char* pText ) { @@ -1281,10 +1333,23 @@ Update_t CmdHelpSpecific (int nArgs) // Symbols case CMD_SYMBOLS_LOOKUP: ConsoleColorizePrint( sText, " Usage: symbol [=
]" ); + ConsolePrintFormat( sText, " %s\"%ssymbol%s\" = %saddress" + , CHC_ARG_MAND + , CHC_SYMBOL + , CHC_ARG_MAND + , CHC_ADDRESS + ); + ConsoleColorizePrint( sText, " Note: Valid characters are any characters above ASCII space ($20)." ); + ConsolePrintFormat( sText, " You %sMUST%s double-quote names containing special characters to be recognized." + , CHC_WARNING + , CHC_DEFAULT + ); Help_Examples(); - ConsolePrintFormat( sText, "%s %s HOME" , CHC_EXAMPLE, pCommand->m_sName ); - ConsolePrintFormat( sText, "%s %s LIFE = 2000", CHC_EXAMPLE, pCommand->m_sName ); - ConsolePrintFormat( sText, "%s %s LIFE" , CHC_EXAMPLE, pCommand->m_sName ); + ConsolePrintFormat( sText, "%s %s HOME" , CHC_EXAMPLE, pCommand->m_sName ); + ConsolePrintFormat( sText, "%s %s LIFE = 2000" , CHC_EXAMPLE, pCommand->m_sName ); + ConsolePrintFormat( sText, "%s %s LIFE" , CHC_EXAMPLE, pCommand->m_sName ); + ConsolePrintFormat( sText, "%s %s \"PR#\" = FE95", CHC_EXAMPLE, pCommand->m_sName ); + ConsolePrintFormat( sText, "%s %s \"PR#\"" , CHC_EXAMPLE, pCommand->m_sName ); break; case CMD_SYMBOLS_ROM: case CMD_SYMBOLS_APPLESOFT: From cb138c97d4036206678f4f396f76387f5079c55f Mon Sep 17 00:00:00 2001 From: michaelangel007 Date: Thu, 24 Aug 2017 16:33:03 -0700 Subject: [PATCH 02/64] Bug #469 added command line switch to disable PrintScreen key capture --- source/Applewin.cpp | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/source/Applewin.cpp b/source/Applewin.cpp index 81573081..aed3f1fe 100644 --- a/source/Applewin.cpp +++ b/source/Applewin.cpp @@ -77,6 +77,7 @@ static bool g_bLoadedSaveState = false; TCHAR g_sProgramDir[MAX_PATH] = TEXT(""); // Directory of where AppleWin executable resides TCHAR g_sDebugDir [MAX_PATH] = TEXT(""); // TODO: Not currently used TCHAR g_sScreenShotDir[MAX_PATH] = TEXT(""); // TODO: Not currently used +bool g_bCapturePrintScreenKey = true; TCHAR g_sCurrentDir[MAX_PATH] = TEXT(""); // Also Starting Dir. Debugger uses this when load/save bool g_bRestart = false; bool g_bRestartFullScreen = false; @@ -1035,6 +1036,10 @@ int APIENTRY WinMain(HINSTANCE passinstance, HINSTANCE, LPSTR lpCmdLine, int) { g_bDisplayPrintScreenFileName = true; } + else if (strcmp(lpCmdLine, "-no-printscreen-key") == 0) // Don't try to capture PrintScreen key + { + g_bCapturePrintScreenKey = false; + } else if (strcmp(lpCmdLine, "-no-printscreen-dlg") == 0) // Turn off the PrintScreen warning message dialog (if PrintScreen key can't be grabbed) { g_bShowPrintScreenWarningDialog = false; @@ -1233,7 +1238,8 @@ int APIENTRY WinMain(HINSTANCE passinstance, HINSTANCE, LPSTR lpCmdLine, int) } // PrintScrn support - AppleWin_RegisterHotKeys(); // needs valid g_hFrameWindow + if (g_bCapturePrintScreenKey) + AppleWin_RegisterHotKeys(); // needs valid g_hFrameWindow LogFileOutput("Main: AppleWin_RegisterHotKeys()\n"); // Need to test if it's safe to call ResetMachineState(). In the meantime, just call DiskReset(): From 2ec3255863b8f5cedbe17ebb8323c64b076cafab Mon Sep 17 00:00:00 2001 From: michaelangel007 Date: Thu, 24 Aug 2017 16:40:21 -0700 Subject: [PATCH 03/64] Add comment backlink to F.R. #469 --- source/Applewin.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/source/Applewin.cpp b/source/Applewin.cpp index aed3f1fe..fddafe1c 100644 --- a/source/Applewin.cpp +++ b/source/Applewin.cpp @@ -1036,7 +1036,7 @@ int APIENTRY WinMain(HINSTANCE passinstance, HINSTANCE, LPSTR lpCmdLine, int) { g_bDisplayPrintScreenFileName = true; } - else if (strcmp(lpCmdLine, "-no-printscreen-key") == 0) // Don't try to capture PrintScreen key + else if (strcmp(lpCmdLine, "-no-printscreen-key") == 0) // Don't try to capture PrintScreen key GH#469 { g_bCapturePrintScreenKey = false; } From efdce696fcd636c2d88f8d15d16c52006cac3281 Mon Sep 17 00:00:00 2001 From: michaelangel007 Date: Thu, 24 Aug 2017 16:59:19 -0700 Subject: [PATCH 04/64] Fix off-by-one bug wrapping in debugger console #476 --- source/Debugger/Debugger_Console.cpp | 1 - 1 file changed, 1 deletion(-) diff --git a/source/Debugger/Debugger_Console.cpp b/source/Debugger/Debugger_Console.cpp index 0c5b3f8e..171ee512 100644 --- a/source/Debugger/Debugger_Console.cpp +++ b/source/Debugger/Debugger_Console.cpp @@ -147,7 +147,6 @@ bool ConsolePrint ( const char * pText ) { g_nConsoleBuffer++; } - pSrc++; pDst = & g_aConsoleBuffer[ g_nConsoleBuffer ][ 0 ]; } else From df8d6c06a60a37fbd90979723c484865689f3ef3 Mon Sep 17 00:00:00 2001 From: michaelangel007 Date: Thu, 24 Aug 2017 18:43:10 -0700 Subject: [PATCH 05/64] Fix #473 read debugger script file not being properly zero-terminated --- source/Debugger/Util_MemoryTextFile.cpp | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/source/Debugger/Util_MemoryTextFile.cpp b/source/Debugger/Util_MemoryTextFile.cpp index dfd54fe4..5835fa12 100644 --- a/source/Debugger/Util_MemoryTextFile.cpp +++ b/source/Debugger/Util_MemoryTextFile.cpp @@ -34,7 +34,7 @@ const int EOL_NULL = 0; bool MemoryTextFile_t::Read( char *pFileName ) { bool bStatus = false; - FILE *hFile = fopen( pFileName, "rt" ); + FILE *hFile = fopen( pFileName, "rb" ); if (hFile) { @@ -47,9 +47,6 @@ bool MemoryTextFile_t::Read( char *pFileName ) char *pBuffer = & m_vBuffer.at(0); fread( (void*)pBuffer, nSize, 1, hFile ); - - m_vBuffer.push_back( EOL_NULL ); - fclose(hFile); m_bDirty = true; From d9e9ef34ab6b02b899142fe8d724fc6313810eb6 Mon Sep 17 00:00:00 2001 From: michaelangel007 Date: Thu, 24 Aug 2017 18:43:54 -0700 Subject: [PATCH 06/64] Add note about vector clear() insert() at() --- source/Debugger/Util_MemoryTextFile.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/source/Debugger/Util_MemoryTextFile.cpp b/source/Debugger/Util_MemoryTextFile.cpp index 5835fa12..edb87954 100644 --- a/source/Debugger/Util_MemoryTextFile.cpp +++ b/source/Debugger/Util_MemoryTextFile.cpp @@ -43,7 +43,7 @@ bool MemoryTextFile_t::Read( char *pFileName ) fseek( hFile, 0, SEEK_SET ); m_vBuffer.reserve( nSize + 1 ); - m_vBuffer.insert( m_vBuffer.begin(), nSize+1, 0 ); + m_vBuffer.insert( m_vBuffer.begin(), nSize+1, 0 ); // NOTE: Can NOT m_vBuffer.clear(); MUST insert() _before_ using at() char *pBuffer = & m_vBuffer.at(0); fread( (void*)pBuffer, nSize, 1, hFile ); From be4161635911599848030e0444947145d02c3d13 Mon Sep 17 00:00:00 2001 From: michaelangel007 Date: Fri, 25 Aug 2017 07:22:08 -0700 Subject: [PATCH 07/64] Implements #462 sans: help disasm --- source/Debugger/Debug.cpp | 37 ++++++++++++++++++++++++++- source/Debugger/Debug.h | 1 + source/Debugger/Debugger_Commands.cpp | 1 + source/Debugger/Debugger_Types.h | 1 + source/Frame.cpp | 3 +++ 5 files changed, 42 insertions(+), 1 deletion(-) diff --git a/source/Debugger/Debug.cpp b/source/Debugger/Debug.cpp index 45718325..9517038a 100644 --- a/source/Debugger/Debug.cpp +++ b/source/Debugger/Debug.cpp @@ -188,6 +188,7 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // Config - Disassembly bool g_bConfigDisasmAddressView = true; + int g_bConfigDisasmClick = 0; // GH#462 alt=1, ctrl=2, shift=4 bitmask bool g_bConfigDisasmAddressColon = true; bool g_bConfigDisasmOpcodesView = true; bool g_bConfigDisasmOpcodeSpaces = true; @@ -2489,7 +2490,7 @@ Update_t CmdConfigDisasm( int nArgs ) { case PARAM_CONFIG_BRANCH: if ((nArgs > 1) && (! bDisplayCurrentSettings)) // set - { + { iArg++; g_iConfigDisasmBranchType = g_aArgs[ iArg ].nValue; if (g_iConfigDisasmBranchType < 0) @@ -2505,6 +2506,30 @@ Update_t CmdConfigDisasm( int nArgs ) } break; + case PARAM_CONFIG_CLICK: // GH#462 + if ((nArgs > 1) && (! bDisplayCurrentSettings)) // set + { + iArg++; + g_bConfigDisasmClick = (g_aArgs[ iArg ].nValue) & 7; // MAGIC NUMBER + } +// else // Always show current setting -- TODO: Fix remaining disasm to show current setting when set + { + const char *aClickKey[8] = + { + "" // 0 + ,"Alt " // 1 + ,"Ctrl " // 2 + ,"Alt+Ctrl " // 3 + ,"Shift " // 4 + ,"Shift+Alt " // 5 + ,"Shift+Ctrl " // 6 + ,"Shift+Ctarl+Alt " // 7 + }; + ConsoleBufferPushFormat( sText, TEXT( "Click: %d = %sLeft click" ), g_bConfigDisasmClick, aClickKey[ g_bConfigDisasmClick & 7 ] ); + ConsoleBufferToDisplay(); + } + break; + case PARAM_CONFIG_COLON: if ((nArgs > 1) && (! bDisplayCurrentSettings)) // set { @@ -9647,6 +9672,16 @@ void DebuggerMouseClick( int x, int y ) if (g_nAppMode != MODE_DEBUG) return; + // NOTE: KeybUpdateCtrlShiftStatus() should be called before + int iAltCtrlShift = 0; + iAltCtrlShift |= (g_bAltKey & 1) << 0; + iAltCtrlShift |= (g_bCtrlKey & 1) << 1; + iAltCtrlShift |= (g_bShiftKey & 1) << 2; + + // GH#462 disasm click # + if (iAltCtrlShift != g_bConfigDisasmClick) + return; + int nFontWidth = g_aFontConfig[ FONT_DISASM_DEFAULT ]._nFontWidthAvg * GetViewportScale(); int nFontHeight = g_aFontConfig[ FONT_DISASM_DEFAULT ]._nLineHeight * GetViewportScale(); diff --git a/source/Debugger/Debug.h b/source/Debugger/Debug.h index 45d06185..27ee49a7 100644 --- a/source/Debugger/Debug.h +++ b/source/Debugger/Debug.h @@ -83,6 +83,7 @@ // Config - Disassembly extern bool g_bConfigDisasmAddressView ; + extern int g_bConfigDisasmClick ; // GH#462 extern bool g_bConfigDisasmAddressColon ; extern bool g_bConfigDisasmOpcodesView ; extern bool g_bConfigDisasmOpcodeSpaces ; diff --git a/source/Debugger/Debugger_Commands.cpp b/source/Debugger/Debugger_Commands.cpp index c01e068a..515504b1 100644 --- a/source/Debugger/Debugger_Commands.cpp +++ b/source/Debugger/Debugger_Commands.cpp @@ -420,6 +420,7 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA {TEXT("N") , NULL, PARAM_FLAG_N }, // 1--- ---- Sign // Disasm {TEXT("BRANCH") , NULL, PARAM_CONFIG_BRANCH }, + {TEXT("CLICK") , NULL, PARAM_CONFIG_CLICK }, // GH#462 {TEXT("COLON") , NULL, PARAM_CONFIG_COLON }, {TEXT("OPCODE") , NULL, PARAM_CONFIG_OPCODE }, {TEXT("POINTER") , NULL, PARAM_CONFIG_POINTER }, diff --git a/source/Debugger/Debugger_Types.h b/source/Debugger/Debugger_Types.h index 66014dab..d50bdde8 100644 --- a/source/Debugger/Debugger_Types.h +++ b/source/Debugger/Debugger_Types.h @@ -1319,6 +1319,7 @@ const DisasmData_t* pDisasmData; // If != NULL then bytes are marked up as data // Disasm , _PARAM_CONFIG_BEGIN = _PARAM_REGS_END // Daisy Chain , PARAM_CONFIG_BRANCH = _PARAM_CONFIG_BEGIN // g_iConfigDisasmBranchType [0|1|2] + , PARAM_CONFIG_CLICK // g_bConfigDisasmClick [0..7] // GH#462 , PARAM_CONFIG_COLON // g_bConfigDisasmAddressColon [0|1] , PARAM_CONFIG_OPCODE // g_bConfigDisasmOpcodesView [0|1] , PARAM_CONFIG_POINTER // g_bConfigInfoTargetPointer [0|1] diff --git a/source/Frame.cpp b/source/Frame.cpp index 338d6e23..b6d917f1 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -1346,6 +1346,8 @@ LRESULT CALLBACK FrameWndProc ( break; case WM_LBUTTONDOWN: + KeybUpdateCtrlShiftStatus(); + if (buttondown == -1) { int x = LOWORD(lparam); @@ -1399,6 +1401,7 @@ LRESULT CALLBACK FrameWndProc ( } } } + DebuggerMouseClick( x, y ); } RelayEvent(WM_LBUTTONDOWN,wparam,lparam); From 16122690938e0fdeca3b2581a5a587ee12ef9bf1 Mon Sep 17 00:00:00 2001 From: michaelangel007 Date: Fri, 25 Aug 2017 07:36:31 -0700 Subject: [PATCH 08/64] #462 Added for click --- source/Debugger/Debugger_Help.cpp | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/source/Debugger/Debugger_Help.cpp b/source/Debugger/Debugger_Help.cpp index 3c009d79..4b8c54e0 100644 --- a/source/Debugger/Debugger_Help.cpp +++ b/source/Debugger/Debugger_Help.cpp @@ -1085,10 +1085,12 @@ Update_t CmdHelpSpecific (int nArgs) { ConsoleColorizePrint( sText, " Note: All arguments effect the disassembly view" ); - ConsoleColorizePrintFormat( sTemp, sText, " Usage: [%s%s | %s%s | %s%s | %s%s | %s%s]" + ConsoleColorizePrintFormat( sTemp, sText, " Usage: [%s%s | %s | %s%s | %s%s | %s%s | %s%s]" , CHC_COMMAND , g_aParameters[ PARAM_CONFIG_BRANCH ].m_sName , CHC_COMMAND + , g_aParameters[ PARAM_CONFIG_CLICK ].m_sName + , CHC_COMMAND , g_aParameters[ PARAM_CONFIG_COLON ].m_sName , CHC_COMMAND , g_aParameters[ PARAM_CONFIG_OPCODE ].m_sName @@ -1105,6 +1107,23 @@ Update_t CmdHelpSpecific (int nArgs) DISASM_BRANCH_OFF, DISASM_BRANCH_PLAIN, DISASM_BRANCH_FANCY ); ConsolePrintFormat( sText, " i.e. %s%s %s 1", CHC_EXAMPLE, pCommand->m_sName, g_aParameters[ iParam ].m_sName ); + iParam = PARAM_CONFIG_CLICK; + ConsoleColorizePrintFormat( sTemp, sText, " Usage: %s [#]", g_aParameters[ iParam ].m_sName ); + ConsoleBufferPush( " Set required key combo. (Alt, Control, or Shift) when left clicking" ); + ConsoleBufferPushFormat( sText, " 0 Left-Click (no Alt, Ctrl, Shift)" ); + ConsoleBufferPushFormat( sText, " 1 Alt Left-click" ); + ConsoleBufferPushFormat( sText, " 2 Ctrl Left-click" ); + ConsoleBufferPushFormat( sText, " 3 Alt+Ctrl Left-click" ); + ConsoleBufferPushFormat( sText, " 4 Shift Left-click" ); + ConsoleBufferPushFormat( sText, " 5 Shift+Alt Left-click" ); + ConsoleBufferPushFormat( sText, " 6 Shift+Ctrl Left-click" ); + ConsoleBufferPushFormat( sText, " 7 Shift+Ctrl+Alt Left-click" ); + Help_Examples(); + ConsolePrintFormat( sText, " %s%s %s 0 // Plain Left-click" , CHC_EXAMPLE, pCommand->m_sName, g_aParameters[ iParam ].m_sName ); + ConsolePrintFormat( sText, " %s%s %s 1 // Require Alt Left-click" , CHC_EXAMPLE, pCommand->m_sName, g_aParameters[ iParam ].m_sName ); + ConsolePrintFormat( sText, " %s%s %s 2 // Require Ctrl Left-click" , CHC_EXAMPLE, pCommand->m_sName, g_aParameters[ iParam ].m_sName ); + ConsolePrintFormat( sText, " %s%s %s 3 // Require Alt+Ctrl Left-click", CHC_EXAMPLE, pCommand->m_sName, g_aParameters[ iParam ].m_sName ); + iParam = PARAM_CONFIG_COLON; ConsoleColorizePrintFormat( sTemp, sText, " Usage: %s [0|1]", g_aParameters[ iParam ].m_sName ); ConsoleBufferPush( " Display a colon after the address" ); From 6cabe7740fb4c93178e40d323f5eaf945e555bb6 Mon Sep 17 00:00:00 2001 From: michaelangel007 Date: Fri, 25 Aug 2017 08:56:23 -0700 Subject: [PATCH 09/64] #481 Extend arguments from 55 chars to 127 chars --- source/Debugger/Debugger_Parser.cpp | 8 ++++++-- source/Debugger/Debugger_Types.h | 4 ++-- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/source/Debugger/Debugger_Parser.cpp b/source/Debugger/Debugger_Parser.cpp index 5244d054..46edfeef 100644 --- a/source/Debugger/Debugger_Parser.cpp +++ b/source/Debugger/Debugger_Parser.cpp @@ -111,7 +111,7 @@ int _Arg_1( LPTSTR pName ) } else { - _tcsncpy( g_aArgs[1].sArg, pName, MAX_ARG_LEN - 1 ); + _tcsncpy( g_aArgs[1].sArg, pName, MAX_ARG_LEN ); } return 1; } @@ -304,7 +304,11 @@ int ArgsGet ( TCHAR * pInput ) if (nBuf > 0) { - nLen = MIN( nBuf, MAX_ARG_LEN-1 ); + // Does anyone actually "need" > 132 character output??? + // Technically, we are capped via ParseInput(), g_aArgs[ iArg ] = g_aArgRaw[ iArg ]; + //if (iTokenSrc == TOKEN_QUOTE_DOUBLE) + // nLen = nBuf; + nLen = MIN( nBuf, MAX_ARG_LEN ); // NOTE: see Arg_t.sArg[] // GH#481 _tcsncpy( pArg->sArg, pSrc, nLen ); pArg->sArg[ nLen ] = 0; pArg->nArgLen = nLen; diff --git a/source/Debugger/Debugger_Types.h b/source/Debugger/Debugger_Types.h index d50bdde8..2fa7f557 100644 --- a/source/Debugger/Debugger_Types.h +++ b/source/Debugger/Debugger_Types.h @@ -256,7 +256,7 @@ MAX_ARGS = 32, // was 40 ARG_SYNTAX_ERROR= -1, - MAX_ARG_LEN = 56, // was 12, extended to allow font names + MAX_ARG_LEN = 127, // extended to allow font names, GH#481, any value is good > CONSOLE_WIDTH=80 }; // NOTE: All Commands return flags of what needs to be redrawn @@ -1259,7 +1259,7 @@ const DisasmData_t* pDisasmData; // If != NULL then bytes are marked up as data struct Arg_t { - char sArg[ MAX_ARG_LEN ]; // Array chars comes first, for alignment + char sArg[ MAX_ARG_LEN+1 ]; // Array chars comes first, for alignment, GH#481 echo 55 char limit int nArgLen; // Needed for TextSearch "ABC\x00" WORD nValue ; // 2 // WORD nVal1 ; // 2 From cf743203ce8ad7ca7ac9dd8aedbaaa3216de2ffb Mon Sep 17 00:00:00 2001 From: michaelangel007 Date: Fri, 25 Aug 2017 09:29:30 -0700 Subject: [PATCH 10/64] #483 click to toggle flags --- source/Debugger/Debug.cpp | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/source/Debugger/Debug.cpp b/source/Debugger/Debug.cpp index 9517038a..b6fc94d8 100644 --- a/source/Debugger/Debug.cpp +++ b/source/Debugger/Debug.cpp @@ -9752,6 +9752,31 @@ void DebuggerMouseClick( int x, int y ) CmdCursorJumpPC( CURSOR_ALIGN_CENTER ); DebugDisplay(); } + else + if (cy == 4 || cy == 5) + { + int iFlag = -1; + int nFlag = _6502_NUM_FLAGS; + + while( nFlag --> 0 ) + { + // TODO: magic number instead of DrawFlags() DISPLAY_FLAG_COLUMN, rect.left += ((2 + _6502_NUM_FLAGS) * nSpacerWidth); + // BP_SRC_FLAG_C is 6, cx 60 --> 0 + // ... + // BP_SRC_FLAG_N is 13, cx 53 --> 7 + if (cx == (53 + nFlag)) + { + iFlag = 7 - nFlag; + break; + } + } + + if (iFlag >= 0) + { + regs.ps ^= (1 << iFlag); + DebugDisplay(); + } + } else // Click on stack if( cy > 3) { From e660c999795aa33ae2210da94c786d5a328b56f6 Mon Sep 17 00:00:00 2001 From: michaelangel007 Date: Fri, 25 Aug 2017 09:40:21 -0700 Subject: [PATCH 11/64] #470 Add PVS Studio report --- ...c Code Analyzer into a Project - Medium.pdf | Bin 0 -> 902697 bytes 1 file changed, 0 insertions(+), 0 deletions(-) create mode 100644 docs/An Ideal Way to Integrate a Static Code Analyzer into a Project - Medium.pdf diff --git a/docs/An Ideal Way to Integrate a Static Code Analyzer into a Project - Medium.pdf b/docs/An Ideal Way to Integrate a Static Code Analyzer into a Project - Medium.pdf new file mode 100644 index 0000000000000000000000000000000000000000..2b0b601dce2d74b6ea7ed13713f9f2532a12b30b GIT binary patch literal 902697 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μWGB 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

1&g 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

#1} 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ν)tk~H|l)3hmh_?NLu_v?Qa@5iAb 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%0D2435BGO5y-_zjeFEJGA+^V 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 z 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

PTR0;2`g0;5HGEfDb#AXW{?GVrRkf;yeBUN34i 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%0Au~KM|JL4xU&Ba<_v8M1j9RiPn9YEOHaaj`_ z#u$?^$fOU_X@tw7^i3>pT*WR6cr`TCHqhVN*WcXNhdSON5BB%e0kY7!!dA3*vc35$ z(LY>-s_wOU?X_s2AEETt@|5P{*k*!P7+L>~R|Kp=fKI5zl)%(dyJ>b9xG50!SHP>1 zcyG|x1fQ?OeNmi8R)k$@(3eENPYK@U;SR>ZRz^XVZ+$<$@-}(t255R|VD=O=2(9Z+%V5pay zzpDc{D?pZ)jWsX|!l19MErOMml^mO)x3XCL+kuL^hYLcod+hlid6q8vkB)?8nT}=6g>e*Wd&RyQEp|R_r zy0G%;U5EB<*(1A24)Wl>ZTt3Y*(1F{Msl5u@M;O*)sEjqh1W>zBw&TEt0e(eJ5WND ze6r?mgLPY9Y~1nYZ_y9ir9SSEe!E%3X#I{4n?*lum3aTRn1$?KE5-d*yH#8csJR|F zZg*JC?(fyrhuy_<*#8;2hvpZd`d`8bm_iRe9lZ z{i-@|X{t=#pL#(z6RhGh80jt;IIBW zuX^DP!lDjff5k?lM2GmqW5LNK{aU~Jg;!i^ABWt{9P6eJbx{U7Ci*)k`nstDJ!3sx zgY7L{4RyVBwSz4ULv4-pkuC^*l#v!bqi>Sd$DioqlLw|JhH1lSJRp}cz!>RZ4!5z# zJJ}OmOmY{40v@AxWU!4n(lpXq(pi;Wo*tSX<<*=WMXt$bHk7cNzD~7O&U~w!ZL9p= zTgz?xN^i<<%8Q8e|6=j>!TZ+_OLCLG&+~X3I(VdoY0mr!KRJ^zQzW+ zCyCby5l!jKX8>_3UV-<;12$68410rExUrTrQ(oihm)j%(zR!>(| zXKOk9GiYnX7AwEKHn*iBqp3WtwKB84I-{*Bv-xXWQ&D7dQB+d_N#L?j%?dv#TyDpz z$quc}#()Z4CKaKaFvxvCDoib~Rp6-#qTP$)yuQYJBYzd|kxOz&3$jf1vq<#*6k%@? zZ2dOmi?OfiOOLnDoSy638$PztefVDcx~+kp^Xq4ypXiuAy7$TOvEzFqPfH7bdz&CP z$H+jh=n&udh=2rAP(ox-T6_e6C5;%#jt8@^bXEW;0k7c0%*^<#%=jE40HWxJwUS*a zsHGu2B`O00FgYqCH5&X?OhiCTgnwLQAY7wDd`SU5kOu|zt1u7L(%?r_u7Fe^PfJTM zR{?f*KGs&wA3oR_y|sDy#_6rG%e(g$j}1(9p1ixKYoMu3G>dB9JEi&Hw3g12Qc+O}%f_EnNk*NN)=u|xOw?S^ZGUu_UK z`g7OQKeidJ+Wu*WoY^+%HyefC3&}Vt9(GhZY^QYCX1|)n!K1!+@5OyENwoQ#>TaLv z<(LuRmL2MoO$x}04$4Um%TA5R$&4z>Pbeu!BDPM%Lolo@ }(sVmPSc$M4Kkk`~$ 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%0DkP7WpbRE<|dRKJ~osXY- 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 z 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

bJh7AMK+rNqm{>36-)HF zTq?s(k`B?&j(5+Fd!NP2bQI-q@I0ZS9KG)|7W0)wT&hB-E#RsjI1sl4>T7l))lZh1 zpRH2l`dr|ZT$hI%N-;ga>bXo`jTve%eT_ujiW@r!V>j;HOPcyg=YGoAt29A2>?I97 z6jCo`>>>4_LAA?-$!ARGJ_x=`WdQY4+8$g5bQ;#^M|H635V8z_EawreVMJpBf!7+= zx{T;t`zUloHmdU&F}RPpdi3gyZ=zz}CnR>dIM?aab?(Ob^xG>>(q5NjujM|Nym_NH z!mlmVXZl{;VMFPD+w;BNnw_Eg&5`;KqxBn;Et_*4+Y3GWEB$+GL%XX37us1J*n@Sx zeeYH4&TR9}Ow;ys)6Pue{;QVbrH&(D*IYB*G`J3(EX_3>Ewq46mfB91S`Ox$Ag>+0 zYC?tRBNa!(6u{Ly%bpQ<0BfSwLWsx9Vui}$&B2~Otoha4D3svB(qBwXQ4^I{q(0^{PYaph ziqLpfWHJ-OsxuRMut-mP%EO*=XOXaHro*e~UNPU3>N{RZwe-~ZZwFQ~>avKsEWVK9 zvi#zLGb1JjUI>g9aYe}#FfeZhNi!vJS%v?ul>bIae<8$lMd)7^>&LH2@Z0G+YIVi= zSvE zO7@6_k=)c2W9nAeGYCr*iI7(^5IZ!**N?4|~8SNvTdb)rBcK2#?LorEtm9lvTknyo*auGt+bIT|Ye*qpOelr)wa zI*}IswmkJ?Q{Hx0>B)5C$;;N``L5%|?$edt)3v_y^`TGeL!Vy{p0D(s&Ub#A@BVY4 z`+TZtyRUq`Eq{OT`RQowF7Rr)@zY$(?(mE4;pd05bsLlA??#H=4HtYIE8ZI|-5)An zu1Gsy7I#0>(rB{FpE{)2{y*m$8liYK~5 zsveo#vt2!&divhN6}L%cm=m|qC!jtuE?OuH=SXAaN*@+KSV(v}3QX2cCTotX4Y~v9 zcHott!`IWQYaDqnj|_B_1%khFl3(Y5xkBRtZ*Zvyo+5&e=)}M( zicg`N%V-0MAy_m1*J+EXPu$rB(Caxe&k(JXPKtuV??7ze44 zP26xKBAk>_9Cf%8b=^VXXDRbEmw1^=VD+?=xj};ag{}I9t^1wtW+?+q1#q=~TrF%| zZ7?H1$@0QMeLY~m*#9NE;EFk|Qkh9;ep2g%BxDsOhsN*GNLO* zmDnW(f)#D9#DJ-9uo8jG`Wd@8yt;TH$oU2JJq9ty?7%2Sjz1Ajzx>@_F>AD$AjU!z zXD*7f5XD~=Jakf)VxHxgSCPn+W3R}x#&X!oM-F5bi$I0$HnJ=SBFmA;u$Mh#Nz-is zZlVYF;w(P)m@Ch66cups5+PMCR6G*{sg#v`s*FpO3f1{s#eIAEEeF#3l7s3WSG_EG znFhb7I^V}qeVyL772~nrYY>dA`|SzBl^fV5)Y1 zs`mJ0!!bCkmyM_Mji)agj;5*)C##M}Do%#Vcbc--ic@ADM$Dw&cwKyFzqRPFukv8D z=6I(0Xs+$(W&6oe*ZFGCr`LU--wb?S?LS-WI-P4jnQlFwX*nOOf8Ub-x-NUOy=cGh z8R%@h?tH3YZ|FIAt-aC8cY_7%eNQ(B3l1krkH?eF6|y*d?gFk+iej+9kEdjk+H>oA#q|N*q#?7#&0Y1w-maEM)x}keKMx1R(73*hu9N=cDTPS=3y>&zbbMw6SL*O{6E32YAS2|jP?uwb zsjt+64c(LvV8#6fr+J0bwhGDdC!GBYN%IQ-J`94G_k*!l1&QXOBy(Y^9iGG0J>?m4 z*s2U$Jk1&arFdvZq}j+*EhTr&`FG6tcg+R&t;FfJ@+=1|%MnXwi5@vgbJ+5y9IRA8 zl?liS0a+nCT~5&Ck|R5_N%dV6o2UxyHK!H0dd`#1?$d4_Q?71fM#QTToe}cjtee+MPv2=*uMxdVAE1xYb`a`Tz#XP( z5Rsjve$?dMuXF1lbZrVli&9^&)Ha%27jNBKy?=i$A@)^FRF9W?t%9tk@VTh)jm&!| zFA6_amM)5%mFXlJ)o*LE*Qy_V09V#lwBJ>BK2rMy%wGR9^q#S=Y`ycz+qOrW-A|8( zOHYTMy{pMu$iMftdiNq%kDlnLxd*pr?j+9KOKu6j-WD61WpYm@ z^|4Y_po1_%KtzkFNFkYkY47ViqC}LREjNrSPdEC+%2nY4EJ6aj5_vfY-0gWTEUqhy z@5U0k+e^Ic5wF~AI1I7?P|S-$23FsAB?edp^T}Xf6bBFCkzsraFcsn`zwUq($s>SN zk+e`>1#nhqKr<0T`zypN0F*!#FGAzAlEtb-Ar*&UB~RvH$$%`5oPiYx(3H$0{u{3t ze}#h+1Gs(T6@`$6L;EJ>)XDAYz6 zVkh#qmIm0O0fN3ZaxV*+2kK_bT&}@E?$(5_gWA_Y zt^iqxR|rt@?=Rp8fBHK3=0g9KSD52BSY7by0#@|DL=NcIXmxCJWEBhgFhgFUjLz zC490>s3_wR<$U6qkbEX2%6YOE8+G;`Ho6ZRU5E9~Lpl>^L~9x|Is>eRb@~B~W>BpgQ0c}DE&!_u7mq%*zFDql zBh{_As!l@HNvSrazFiG?)WE(*M1bmXRjbz2>FTkRoH7@eP^;6Hh{R7=_B9yZuG7tj zhrPZTe^~hFW7*@4s>eIc1@EhJw(9cF`m0aI8+S)*_NE$kryCAun)WB^j;9(AhigA} zmYxi}_&i#7Jn&+>yA*UbR&zdChmMja>vo4KKXeuC^p^v#PUq@R=IQ}i$8+^(pqbi} ziRZ^-m8U}$$34Yc)fuk~lh?8nmoj6QauT+xvrqekUudx8yC?q_5Vc zZ*@F9>MPl8FPP0snSYu(asTGz-8;43{#k_PiQYYvR9E@b$4-!a1LV40KA$E-;akt~TIr3Z` z_-^(BcLy=zm7Ulfb+Y1uvjRF@6gK?DD+hrWOX%k)4dmjG0Rx>-(E`N4P)7_D=7dME zzZ$A29+)cjDRsFjaxnvBVV-uBm%YZ@LE{08vc!z$G8Zcx zkmYWt@N_`DaNhijRiO>1S^E5D-!Z|(Kly>j26>SRK;9vMsA8^HsA9K z@*ruZA^=wC%u4YUR=8Hh8+D;(;x3+gzMtCP*Zz^ifrR?3qWaU~@@>^V$Y<87c1%~i`%%d%otdq@M?4ks-Rq+@TpSV_>6R}APvt5T{)(%kgLmN$`?{aog5*n ziO{xC`c{RpnbbAn8dy6uE-67bj*}Bu&+Oz4J)A8pJ1`m3RfmeGCkKdQxdGjP`IV%P%)|-<1hn;0d zgH`W4OW$@B?n2Cb*?KhBd@$E^IM;kM({wP^a4=T8GX#(=_OMkMuZT651nS>~fGor-mV%M99SOWbF9$8Zdp~FiUhAtEUa2e?G$AVm zuwr=i&0NV4uP)DZfM^SfP_ELJGY4nH2qm3(@;Q z#4Ev%G7#{J&%74=DzIA^m*EvK>L>gguW;I55x^^kRLlyb0>S3yWpVOVN%9rp&8s3% z(iQMps4;TvC3eCU?oA8fT|4s+AKSCo5u>uaB%aRsz zfl;b59#+bcgTJZ}5amLwlrJk}OG|k~om5}yL=|$>54q|n2TXT~h5uj{!J~3@0fh>$ zYEwX!!M6Z2JX5+BN;G*QMS++qktxeCbtR#z0XmVoCQ{o-tBKUr$yJSnwhmL(NEJ=E zww*F`Ds>%{rjycik(wS-+ksL2O0ZRWa8^Sa!?4!auheznigrxVL25cx`g*ydOYhRI zbE(1ARRsJMRgG5PVsdRYxb(SuPhGp-%-#6#1w>;VEDLNRdJesUNn5=^J zWU}fMVjwuHfwJw^r$_At2lY7{CHGdc;uq3mUZzE^JiWc&T6{e4{C#`ja%1k!@QY($ z)O7vMRL%Zu{ozdA!DP+OK*dH|!MpmLx!jv8MXBpA9`&b&Pi7|`w3mMBf3e?IJo7YV z>~Z|7f?E@hqt~9@JL)LfZz*`0o6;N|FqV3=z+kNP3wo+_zQw__H6DpvNxD?g6BXMK zaIHNwJWH*O6Js~TWT;H-V#5y-D8nRLS1Z1|jnE%rno#BAAoH}7c-V@|Y^p)yviiQ+3G zxr!(b#62aQ{z#_pI$gU?#c;pziuPBK2NMK}B=A=vJ7^H(XTy%j<83QOXlNJvwQWROK?LuHta=mtv~VJC^C0To5tDzpNu(7a|@*afT{ z<=_m19pu+o5Pl82?aQ-%Y+gg zt%FF_6^Mii=GsU4c)a7p}TkWu`*RR6)5GNwq~{ zWr>h1!4%I`hFX=W7S}aWMos|1%l>*v9t3ua^sLS=}n_q?_lY-ZX&8TX?)C9=Dso`ZdY{gL)yv?@e69 zTKtW*gd0ooVY6`|$K}~awRy*#WvDEww``-cXuG}me4y%}qhzJ*-d;=YQCq=Y{o}0{ z8S7>DHlC*+wd8&3E$&${JxrX-Ox$lSIO%=1@;qau^2u&b^=9AmtB0-(P3lJT4Czc{h0pvz?lb8Q|V!c z_1W+z-V~-yrY5%CxLy|+T;k&OSYgaoxZjuP5;$0-4ZlF^UGICNB`~(yJNy=8KqpbK zQ0B=IxH$@a*fMXn6y(Md7%ka>LMnhyz(e@x;Q;wg;^!m|V5255-sokY7zpO$fc9Qs zt8DpREc&GVo4oAMb!LA@u^;@dy%2JxpPj(pPH@d$eBDVF29cACqv*$@3qd(V6o-i6 zqV)H@fKd#oXi*7#B8g8X(h2UCNXaNgghJofb1E*$=q_JzPoPAiH+OjyJh{yyZ;6SU z5+YfQC5!Q75uPZNCknAdA&?43Q4tWzQzlCc=^CFDxhc|#gt!;!M8Fz>-uj_;e<3Ux zGeJJcPJG<~zh*7*14da0(P}C50&{g$9O9&n61jy5On&xCXLGs9OlrC+0Xn(ake)1s zt1WpUhEyQ*(FVzAi+?L)fK{%wz|`g!Zv$mt?=@QzMmx2MrP0|a)fS}UDy}rc6=sCW zoCGP%NXm>-m@5>hN&#IDB(G4!Rk|JDWd(kP!hio-y?|Z*D(2peiBUCU`$$ydQB|up#)rDnMMI)6WFD+WaHN`WJ5ZPr2<6GOHh?R{trs{!h8}KV-Dz zv}D%*DT}x&3BN21{)H3xlf(5N9m9V`<0qmobK|e_63hij=7MwwEX_`uhDxoF9@A~5mF&mz$0?F*aJt|T@D^; zD{=jmrTo#}$4QrF2&wdpsP~C_A~)vAjD?uKM5-^7>ndi!(hUvOw+FrS#4>$J6^lcJ#lTcC1!|R2LcHG#j z@#s{!H<6}VLf_%yS4kOOXk2^z!^fhM#$yr&!)|o=`d2E{4{ca+Km0S}s%4E(I_`o- z@bp4piS%;@9d4hH)#p`&vLe&Ki+K2 z`_PoP)mpgQR&>~2_ObfOQqk?5y2po&PdCcb-{jw3%uZOzP2PE)c~F~k)SUmRyL7kt z>6@yI?Y8`rk;=oNiv4~FkLAZbWykG>$1MdrHIMsK{Kr#6H;U7COS3-YrfuY9yw6LU zdlbhqr}@u z>ggbMwdJGc>h@reBxpi}y%1Q0sAVSrp$%=He9+}(5kL&d5v>7E65!i4wj{_&8p4qW zu!I4&f*_VC#6c3~B)`FyBVKWdD1;^;6&VW->Tlvx%qE^sff9LSqJT_72jl-6ujuqg z-33g2qZVxLz!P+Sh20d%Q^eRU5drK<5fRA(9Ep$K8zur9Ib^&@dzW-elISDZB#6co z4hjcPWiP*OFK2iaXe$b`lLuIf{jEfdVDD!w3vy5auY%cHe|x2e73K_9%3S73H(&=| zfn2^Lm9sU@=qs{pNuv$^x3VjSR~PMKRAzEul+IdVuvNjTwxE<|1S5u5-`dzvT9)4+CcNFS*q}WtKlkY`|IlAxoZaCw*uy%b@khLH@*vcnX-JySSHd6;D{gT$b=DOO)pz&a)R6FzotDFloM% zG@p$X@yL8WmCeQOJ4hc06!B~#z(R=sho$;=ZZhdr>=shx9hoh6ej?N7NwgXEl5DoD zkdA~!GO|=cR$-bNTw6!#Yj9naOkI!Z>ZEE=gIwDv)ig@f%`y$ZsuMRL$@MJ~b(>7v zilf7>c9nCp+PRk0SK-dJz#Gl3-cN;+gkOG-`{BnN zmO~?@8gh0UHM#YWsz#o;i6iLX3wy=l0l9nt$GWA`cA2qm)i9w#rR z$1bKtzstXKTA%m1r5I55u`YYF@yT9W{#NVLt(M%w?vjJn{Oy{@+m)FgO74#&2aYF) zOe9?&jSiekj#|8vxc=z=O6KkNMGrr>moGfMy;_*{rXpvvrFgf$@^JLU(fEs#k!K$p zvnSHRhZ6#(Z%2$JM)yWuZwFSpL%fRVV+#jJ##imd;S zu=nte>$=iC+ma=bR3t*hn{$qp3mG6m zl-`Gm*mi4}pHLF$0#GHjlBmhCMk_5hiTV~!s-i_yF!$#YQ{J^T-lhhZDkG>V6rE7^ zJ(Wi%K-QKhU+aMj-t6)ui-eUio=&#v|37lmH=c2|z7(Treg? zfR#0^y3=ZGQg+569s;Z&9-@|YyC0G%SS+n%KuGwo0!;Zg$b;H2tsOU-F{LpqHHPJ; z2)gRDDWakaPovhfQ-HTTmZ>{^$Kue>%JJWU}M=c*pm1qt~07 zj%P}am1GZ>mRxFWxzpcwzrX)LEdF^#_0!zISHlCp+A;pegG=8oO`dPtHmOOyG(BQi zIZ1CMgce5Y;LRSISdQSiP(Txo?Q`W)34LtuYGz0Ifh$zn;SD{RnEiiUX|1QB^#a&w~n>tJpfM zd|vsbDp-A3&C5wxeTy}RBB41cm{XE9BRkXZxsp2}ptgrm#vEph0ooiA5`A2JP)tG? z>>{l$!fXddVOj^KgMe49H~)j0McqBj8@!k#nB}ZwLx=hz}OPdw?>@? zGEp72fmdh^+vRAovAIsFve0X-Q_JVo>t}*N)gzU$-Xod{T41ZvAtx0CUL{JRsZ=oL zBP$Luu+XtSu`F-6vF#0w$@2K`Ir`6rq|KChGy(YytpSJFn^e=;a; zGT(reC2T~z;x^grCYyc_VjvnEifu60c%_Hl)BY=7^#zpvB02Yo(7V}d#46wi3&hbv z9$+;Y6sE$`VpQLOX)C0@ivmocGtPTSV;83Ei7MW;gT^Y@DoO)79pVcL!_jGP5JJ1sT8mBS!s);`)d&YgHVoXx(9!?{lgS*yV>HZs{_W)K&qt@8bo6{0OV1Pprams(g)!&txcjJx#lB=y!GPuBksxB_5>`_u?oXJ}b$* zsw)3gd(&_GJO8#a`|I)Ccf;NPxHSGRyJ!EnF!pb|X8*Rj@SB<5Kg{<3adzOB!|lHt z>-yDj$G3frFT1z>V!Y$eD`Wq9WZ^$P-T7zmV5gQL{r&aK&i}l8@ZZnu0t5Cxc8~vI z$H>oyIQ-gIaR)Oe=K{mEq63oaVk^&uzm1p z@8HYv!Ed)uUTSSvbgW*A=%Cmx0UVK3LkL?*sS4v;1fveTmh5yfI%Kg4Guy=(&72Or zDveTAIG81=CL(~gViG#MjDbf|YH@i>6wH+h{;DR-)Z5uF zQYzrI4OiL;wK*a-hWM7K*ow*UvXe4BD}@A@>fz!!Aqi_26K^M-mZ(u5HfoAgKvpff zG|+@RxFzEF4Gd)g1Kr6LGRs1`uktXGw=w)Zs3e^4X;0>*rh}$;okX5jnUDjFLVzl= zfmfwi8rD=0TvpsIu-(m;g$A?xBaTrR)IQXm!UVv|_8tpbXgoVQbfbUZtj}Xdy!yz2 zJScqx{>ser%DevNjU))Lvbgt6-g8#;29pM7wZV+Oqhasr9{1g?e ze#EQMs5Kna28*PDB55q7jRutALVm1J7!UB1L2)u9ZV#!8QFWQr(TD~dU6HegFm@B_ zK3rYJwf&^AN@@GSO0gzFli+}kitb^-ImFusS#y=Kc2ed6Id#G=J7i>b@YbqRG0Ix~ zj9XVMIqyU&H}hbgcV_EXOB#<=wC;DS7Fl}-WA5UtRoOkHCytoOL-}jJ?8732Q0J7E zJZ)ybh*g|-%g^eW&(-94IdMjCKG#y`%Z%Lf1K+7MNiZ3hdRG%u6fZ=^~+q#llqF=TQjeE8h$;~ z_m@4>e_oyW>*2+J`*i1DjxYWD>D~YF>8{_djD9!S^M|>i7wyd_HTj4n?q~R2IK9eB zyGZtg={#s@{_X74|2}@`k1Gpbj}3e^G4Q*6bN|=*BmZ&cz`vZ__4B!*Z$|rG4fYpQNo3K#&63 z8bxnz33FS+Y%TB#6B`J*9+#RZ1vU`+>OE355=t|nv`|`$m;0J=xt-GCyB@yN+X(c% z-$m+O6jC>B^pHj`WelJzO5NeLk$NL2`sD?Cz}L8v99L2ks;~5fh#m;~F%X@ydE zlKk3VO`!l7TlZJnmDIeFT2eBTtT`jtb7E{pLMIKUP+NO!%$too>>a}yH?sY592g6K z=N4RU3=2&Wq1CIoq5mih6{)~e_40{+DLtrUJ1Dy;0!a`!WI5S+51K8V;b5 zePdyLGGdGauL`)aLIkU+kT?^PP^%SX?Pl!Vw7rM4R%yqZe}$6Z5zalrf#cFv8Do{! z0a+mb-kgJ+1$*GwUfSFR`B97`%cQ2av*xmz8l^4x$8965lJ_b1y+}Q-?5b>Ct!!IK zY+cZ@vy8bzaQ14+eOh9tWbG1+{jz&NaSyBhm4)$D&ID>5QxYfS_%YE1`A;WL$gxkY z^f4oOGM+sV&z>!-dDJuTa(LqD(D?P%uHA++TpS+wpkValLim+>9l! zfT2?C+eZ9RJo_qJ`E6PC6Fc$3Nj-NG&rJ7`YTlQWd!qb6(e6m{Em6EJ$@fj;p03?g zl^cqDTT`E>k}p%q2d?u~dFk&uTAo*yJgX@OcKx=e?fZ_V-{m@gJJj`up`L#l>-!&l zo&P-C_p~DWqPpz+w))4_CFd>qf~!7hsQUF#*Pj;0{&nx%-wyBi*Mp0HJG%1khZcW1 znS0by^SE`(x1AkVQt7=IxjRhl!Gu*>*-OjEH0O(w%KMEie_mSp_0;%xql4d14gYE9 z{2zDE{%OzL|2n?^S923jy4r8n)z4uJz-lZajzonKOd2KRVN6_BlLwsg^OeolYP-*t z*I%q_-k-|Os`?-!c3^B1#@1r!1m6}$t7i2|Lf%4%O{`uU+zZzt7u*n__! zwRT)-180J%U4-U)svgShp#WCMSs_?)E_^wS0#b{na+5K0p!0izls!j>YcHo&w|TECq1Nd>m5lXe=>!$G+rq&9{%pIS|r-Ha#d z!_F2DR@FhHBA{0U49J7!A*-|)H8Xf_>a|J&z$@(syed-C0WDqZ3-KyljBdt3;PUG2 zv7j3RUWH=upqmWG?E*WmLWqF~P#&rL5>^b%mEjEwMWp)3);_k?4{Y^)OMBl^)-JnQ zueSrN09ojq;QI!eA+t&2Ht5_2AeF&x@`Oy6!)$^#FA8oCA^{WGv zb$~`t@&(A+=XtGzZ2nEKUg&ZPF}aI%cCz*|XU)^bJZF!w7JPMe(N5(jocVTfX#u@d z*}Ai`bxJQm<2zV;L3DO1iJfX}S+tipeK&6$)Z#~s$mk=ASZs;TL1Ir zy5DuR{$o$apL5;MN;A*Pvd=3^A7qo4Oy!KkT#1`cw^e=H)BL;1fq&jL^Uu5I{(b-A zzwVxUm21A7buPq>M_X&JXUcYm=^e$yt_Z&z;+DhQLBTv}Ca;uj`Q7-;Zzsl|b+$b2 zX#ReD;JdN@?IBUXwr&)5gs%_OM zT@dU8sq$IL>?edCjPD}kW=z}$$u1(G>--pND{X8=?V9>FFit_fJ|eYJMiZ%l8Y#Vj z(i%vu{tdy)>L3Tm+J?y>a9nkej4-JQmywAgRan~@1L(A_4#wz!4W;@?s)GWXXM2D$ zaugaJoTJSi?+gp-A@^D_(OspiJIbOH$KDO^@Dh#D^9FvR0WZ@^dPdF6D4tZ{6)ITy z4+JOIcm=6&Moi2|NaL)X@4Q-jGUykt@_R8p<#%L(H$%4yIzt>_3f=tG%evi+)5+MK ztlh>~O@!6}pbiTD|Emtx?v;}{In^!1S}_AW6~GGeU~|;BRY(AD^IXTcMcZoKChB!CW9Fdxp5C! zZn5J%1hm)X6uvfB{#jbm-Yqaj||>%8)(^PzgX=db)ec5mR7#&0nA z4JNzE^H-b9|AJQrxygOat9OA{R^*+$!ap^A^?t|xkic@AI| z;6d{dZ9bxGkH`yAWf4=C34JF4)YA6g+FnB6OX}dYRylh=haMV&_R`>~48YVr2Ew4Z zk9GD+$tBueAocB(K1b<`sAB2%QDzrzKw3|IL>L1iCba3j@ z*4CZ8)%D)yzIO{&!opc2bE|aQozl9S$?~ga;)1As!HG9D{aHHob+-KLOw~7;%CFNE zUnNVwN|d}xB3?Z)ZHR%-ZTqodg0s5G2{#1cI?r8WS=bG4pE7xK~y3%fZgyjOYHmF!pcDGq2j~&e_TrmiD<3J0Tk9?93iQUJ9|hNqs)Z ztqS%T2eqi(uW$M7*x18{x?5YTzUu1uroZc1SL-h)Mt?psdZD~}uVhT)TyKc(i*kJg z-$#o5lr+q$xhOj;y9< Oh;@bCNd)2{DID{j?6grJFHZ2(3P%Y>R@Y(zZs`I$W#A zymul>U080y^=86oCe22)F`Fr)kxr&J*@RnsWBonMa5=Jf}jNI@@rF` zIvJyzMPsSJTy@|m`a$UHr}Gz;4!$w)JhwJ19W)^(K~qv{T1wBznMrRJs6QvcSDsgE zn)D|vc*n|}@Rb5Eeg~d+J8PGBy*fip(d!acB?$PX^Tu>Wf`=mnGaz(60 z%xc17bs@VZfJQM?f`C^cbZoF9Y@JqN4Q07j` z+=XiI+FnXWBK1A6(%v30#UQ~3NVV!UXzk_P9jvH6EL+8eRz z%UbFJZ=R#2FID@iZ0UF9m9Nt2mx=6GsdC`eH<^l8Dd1K1MJ)N$wjUYhBTau~fXtVP z1n8coeJSw3E8k+>Q2|-XU0wZBmaZ$}UCX$mDNkeWW7mG0!?<%pS1u{S1(Erjr!Gp|6-D@rCC=&M-I|hT&0D|kZ~y&x-_P3X zuO-ZLy8M}B9-_5#PU%73-Vu>@)7BEE?iXW+mBc<)J?&wHI@^*TBkY}O@or~WhZR5!NHr;? zrsVXjoS9X!lX7yMRA`#9H-r60yz-9(t|vjXLA;9leeA$14_S~0(VKqdYP*~Qb|GYO z&NQ%5M%Az}G(ihsg@(hoF=i8KY$LQLO-aSZE>j zcJx3HWVe%GvFtX&0$8E?Rm5uYFXxKJ>cW=KtEzxj5j6dNh9B{2?a83I-iU=-up+k4 zt950904_7*4ZQM^l_=8fLdz~R!Adz^0L&M!0AGk#u8*m8a|QCQym8jM7yh1C{@i1q zSKPg*4=bNnsFPun!)&l<)FY}#f2#kGS4Qw%Gwd;Hom4)x#?bvZXkhy& zy2DGG3@8)D{7g_n*LX$IJmi_MJ`+-=1JZ0*S%_-jvKGSf0_t*?mcsI41nqZ3RnUsp zodw@Vz^Hwm_Ve+5LL7CRlIAjN?-XM@cxQog7L?Q|jjlZ!7L!}TlKF8YQA~Cl>4`-3 zgjtp&wLV-PBBW`-TyZjc?92{MUt)~~QrXFy$DPu%*{z=@Yd%Xt8Tr~())09 z^40v}_3qq^sJ47u*zw`!?hlI&=&=hWHJ``JFWY5T)bx4Q{+ux{3HA*w{ybChELHk4 zRq|Cj^UMVhWx!bhuK-pr;+dyT@}=wLLGQ632#nS*%By}^S@YO(Zwm4aUIN`!bYJ&X zST2mq06cC$&QfowON8p0wqBn!T z3In5*CQPjhOSJ)^J|aWvsRyrxp?-rF#sFUd0ziSlWen-{wy_ql8vbtpz`3oP+V6O7hWBdWgEUH|YY`%WwZP4>Uo8DlP@1k1;(TV1F z41g7?x4&nG-Zg^nAYQGD(=S+Fis&S5=!P)+ZV;yVQgkhP-3 z7sS{s?~Ib#P*iTkq$%%9_^fC0)xg}{!SUlw4a2ff`{4)MHg4=KEZieW7fMR+ZK=JME$c;-PO^CVsRB3toQN!5#N`Qt?9v73Gd88Cy8^)gZV%+0=Vv(N1G zQ#1Kgk3Uk~XIAQ|m3*YfA8PIc#knur4^-!#Y~K+L&~0A7&M22j@gmM&rR1BuaaVC} zi{@2If;TS_!slW7x~N{}#Y?PkRaCAB$|X*^1RL4BX~nN7=1Gjc$cfh!<2)xG3r0RA z*(;`dGnu)SDg82){W4W@v$W!n2$ogZ5oPB?^!5m|Oo}@wX%Q1vDD9w{JZ7d3aL8p{ zNR^*3llw*UxSjqyTXWRP?&6GPQXMM7M<`_gk{}`U;d~C~VFN<`3Pei-gwk9@cSfWf zW%Qv(Z+bV5O5B}<-hrWj)`lU@v=N?2Us`^je^UV#y{WYiQ$0ZWjDj~6Z?Cq~YCC%B z_XBm}8knnI4_SR2Iy>A;8a@6gJj&{4%zoMgWDT$uaATN36V%7nG|D;STx=5c7{sTA zBr-w}4|(q*8`fEyZ0t@-=A>jz2aQkkR@?bSrdDi1)B=Cu6r0MpIOQ=vN;R8!)+vQ2Uf@uaxfQ6YaFqghMJ+ zAT@V#F;EK$IFeh*SUZ#I;xg@YstI=+qBgpeIchaToW_XT6pc0F$%bfrYtXJLGRijt zvh?bZ1-wEftbkD#&?~$ihKdM~$^iLQ_sWP_hM8qivjVrP$T+A1cgv!-KVinVSY9yH z6UC-mV8wt`0H^|Vxje|-Y{xdcvCR$$A?pou1p+Ijew6QC&_41nJhh}v_L?l^14n${ z5z%Ukn{0NY&TLRQ6b4Ze%-=G<31ot&Vm6xiyXY1PZ}x&WE9M9B@o%Y_LM5D(O$@8U^*Gem|CbO3e=bWINCb=&J^@io%i>J}t z(X2lkx%644{CTGQS-KoH5AEawGyXJ|d66vjjn<2J$qOg@)Ji?pVviK}v5^2hP-FKM z=Z7B2J|JX0jVw%qR*?_qIFxaV7*2wmoVW9E!|d)D;}?|2+|cny}*d)7~wo8 zU)Ai(s`)u9UlP>|oOG6C;V*oa6)$P_m$CFkD|S}3P6_%c1=ZCLN#+X1Z4Z!>g^~FX z1-5Dd=a)%s4{z^R++~74z!|H&v6GUPNf|v+HIlmpdpjvFkn%)?8>O@XU=)xF;|EE} zlQ=|4LtwoqX@FEZBSJSO_Yz7ku5^=H520ln19*kFr2N-XTi*bb--y00 zfEzHXlhHenv@X`@qV*ou1a-4U4`=3BtDDk0(L+G9$K%xi>-eShKH9sUk8uVW&tIWm zvW6HNcr`>@BLFVME^CCcCb$@AiU-S-oRLyUViK7yG+F@!G0+A9nkEEmj58+$ds>c7 zqn=M|g15$4W10hVWx+bdTa)Nkuf&X!9O3Oz!5-$Fe#Yu%tR6JN6kuhwVCuGFuC|DU zxYvZM?Tm#gRG0=_0s*EVEQ4U*!MdPU3cQojj5|%3(-^gzakqttH6mWwjR32#+Yt8F zXuK}$ZV6Zw1zP!LwW2uBE8kyvyfW5!1s2PImuM5U$}kIfRgT$}L=0dBD#sj%aX^7 z@O1jNMH7h+cin z-g?-mIiQvu(6gsAwdX6Fj;FTl(KCx;Y!1E*;71{RrI9*(?X_`^{Z7F8NntDQE+t#{ zmUYkRRl^i~4Eg~FUs?mAKI5eKmTx`X+c;A;2a#n#?E@k~!)sP3m5+BbfGF_nP^;)tj{U=BB$KZ+-I@u12=WoO#-Z*l~z7O1O3XLrpq41GxzMoT`PXq zPCSmKpT#oI;@Pj#<=>WW`9=BG=fEpB`@}?^>X90I2-MQ!4^$U;1-1$Rbz3k%KCIxK z8yr|H73c(lJqW0EUyZ@$3L)JD8>Sf7MCqES+|~J+WuZYBp7N-__2_=>VPB&?4mTUnMy;q z)qtHtGI}T-^(sJ~@)|*b58e&PDE$qhhjFm6^BoJ`b3jz8@^hb#dAao!mRE^(GWoex$N4+Up}x5rrvP3=R+YW%yp&>t}jeEtu9$nw{vT`xpencE$!?t*arb0<~HxtDSM$XdA%QgrN%6 zwxGVXSgi{gtz^6jv+KhaB2~l%fy>$!a<&ESnqsq}PzPRB78%uE9;|rHtJnStIjbn- zL4XyI3S^Z=%nZ6B$H<0#0j4aJ1OZl%3Ly{vkXN2ObM=~6f9J3MdtP~%0{MMbUaJ*E zKR}j_GN3>77|G*ZRYz6#Qq{-43LExlbAl`X*QzI7O68u>TIz#Tcn}2SUaRt zoK7?z)~bM77c1ItHT9qLoYg!yZOWXcj0xHpr_C|O8l{Xu_}Ay-srO0aABwjWDl@UB zDYJfnN%ur__;IbDj98dxTlyDq7>4IBRSOM(pk3R3D9qIOZ%FNo@SRy-LYj)jOb6!$63pXTJV zvVNSA_DAV`5ptE__Ta)Uf?ozGVeAsdE#cx0T-=WF3*flI>|B`LK?*Chv`F%c1h8jF3i1xt~-AD6MY|Sv`c@ zO)8KIJ3Wilj+!>#5HA0HnnQ1{3HBYN+CeC<1-=Xa!6$-?>moH+Jy_{E#^|Gs9BuT$ zhA|#y4hI2 zltvOE0LI%G$G1`dD6mxkE1y@s*YfO^){G-w)rU<$7HoW@1-z;cIcvyrwuRl=pbdGj zy4ZwBSXpdT{r~eS9|nO}B@rW5D8;?|CK3T98B{YN3pI;+yhh0?qEs#fwl;I+Iq*xsZC_@1S&2lf6!B!0wD?>rGr%>uC6m!L5U$N9zB#cC~ zu_#CxizuUEWg@IBgv_Og4UupcmE6OmcVO-=GP#${?BOy1uH$a)s!_5GUof;e$Jonq z230R5^yM_ly2F&&P3YS&y|hr!-wq`{;M&FV$yD>0vu#u_pE1f0SG9c6J9%w%`;msu z`B-*{RchY-V9Q(Y^?Y2oBFZP?sndz{89nwnXMWCESHRC0shdC;H~TVG{ybj##7@3U zmcC3^yeO&sdG$8XtJ11x>9YGy68zPZWC`dQ_^xE>lSCF6_1H;0f?u+ekFDfWGYS3* zkoC+?1EB6orthZKJ(cgWZt?mpUh_TGo74iM1$&5ucV*|cWL;$h$b)wb`(X@dX`cfk zk?c8E`ka$KCD{`g^(oGrh>%Bu(c>6-iV{vz{1K8pMDVLodKF_2(b8^=--!XN_+^Y; zj&Ms6W_yI053vBNg($a(3sXUSJHagw>}-_Y4v~;kx6|^nWG_qB6d}z3nh1Go;O<;N|&VCh1%48OzE(Kq3T_ef9o;g6)LdnIW+jr$WcZ={9L2Zc8Y;~tBq1^9CE^mn`h%}Qy2)tr`v75o*tlEx#|2xAV@#xP@yu;vJ3qu&|H z?elJ{??&w$P6uhXQ5JxxS4_3wW>o=Ky_s#pjBeWP7gBv((rci~pH^lf`T%v=E zft&Jq1s1CrjknV4y$+E2h};+ji{-RYiFP^(VXz@$)`tLA_PQEEPF*Ahc@WkuK&_Bd z6)>ybsJEk2IYFyzZRS;Z7}eM-qK+T^APJU)O{YKvWF?9fG^inH`MgR8k-W+6X1vJu zi&yJaEO)a9D>OSa=6VkY*UeQtkW${)l@Cn6m0kVN^6FPV=9Mq@JspG|2!3F(9;vtw zOzwS?@kr&v%IB3oG8AAHeoKqIrG>l$IP3K*-(UThSH=0bHyYB$!#ZGUpit~96nhJW z{$i;=sN@1lZ&2+Ise@s402Gu5g3@ppzQT>sh%#I(EJf`V!Yj738AyW5WPBH$S`|wV zsg(!R$~|()3=Q8J_M#YHQqnuL%r3ifyH)~UAw6NGCnPmT@^yLjx0PFeQB(i>hPGeS)V<79d|g)ks-)^= zw&H2J^l>u#IOZ$!)X6*n*_p>?3Ix1*ZfCxVmp#_JY2_*@-C#BUvu^Rm6-M|{Q6IXA`%e6-s9#{ji-H2YI!gn=<_W6dkGV`JWZ){tT{vLGn57po2ImBQUw9EMreqK>IkU} z5@J6l_TdsJM@W5`l*6S?OlS*ponBPz2I~d(DI#>?62!({0t9AB_0pVH>weDXN3~rchuMcq*@KWz_|(rf94MPrwTPsxIi%huj7%;n%OgUm=SXw5o%EEUVl* zkK>;rEDOJGyDAOn*?|8XP|t<{N_rA(Rk60lC_e_8>zib;FYJDP~@2~u- zyC<)u0g&~Uf#f|O94eNF0_t!Oq>Y4i*!LDmy@g^=fzVqd_66h~h=c*9&qG#!NEr-k z{Q+q(s7&Dc1YwMYl&&qB6yy1A z+Um#D?vT_K6gvVUAghBin+2zu(v1%>=BGueusmDe_w2|QHy8FDZ|==eQtdk**8anL z1Mf$7VA>hC>SlT4StW6rw>~44Go*Bp)6PleSUwtEY*Q=PBf=U<0=5aU%O9UIKdLW*$4~$9DR$m40X>ALx(- z6Hl%5%UJ0nJ$YYo-_(!r1p-Wc$*906pcAauC>b{JK78EmJYXo&cX5|0z?5ug^qA0qh!IKMB#?ujzH!t{Pd+((If2w@kv ztSGYryoz!=Fn$LHKQaJZ{9K4!#JC-lw8E%6D0zui76478G(#%e0a>&@5f-N~X^zsj zvlgr~gfdHN@culd&r;eHp^Q`V7#J-~7>e=(5uq=_gL3{F6}lsQdyoaMl_M0t($yUm z!F~1OGVGBk&9_NDh`LY(O#89C3RSNk`e>sEKu7Amqy|39lip8jgN!jQI5S#u-pGt{ z;HkW;MUe{v&RAo-J?>owF)5(4#`)RB{=pfv$p^!HvE7e^;<}RFd1o{Tbc9FMupu!v zsw8_^uu^&lX?4;zdXUG*!6P-|dUX+3{xMxu$TwqV7nkf;N{6)y@K+#6g`l>m-bK4P zKA97eePRmYAs`Die`1z@9?)x4(BD*ZM6U}PbwRT(U~CKM+lt|1;%!8#1xtXM!tusP zyb*X6a%#LV2&x8N1uWoIzL~)rgjM!Nr)aiVOBbzmTLt{}*DLpG70Y~jI~AKD z>{-%XV3SKidXlxqDPth2_5!8?LVF?GQ7rUCls??-Bdktb-xlHPS*YGAt0o50; zS=rXv!Dtold{p(54V~{5><9>#<6G~PwO(>64o0Ly0q#gKdm_l5CzV@D@^-xBMz-`? zB7515f39es@!~mI`CJh1B$MCNZT)$D?Ju^}{kFF0_jN5lE3JN>C;?18gxu$*K~Lh@ zr>WBC>GEgEGO$<=ob*F0_0UY-*W>rq*gYlo$Vk3$vH&i?j?blaUcD*bL; z<$v%k!MGu5kOwbN?0K5K%t=>8?XskSzk)CbusVrTr*Qrx#-3rMlO%T(=Z=!XAwt*} zVRnb9-4SM2gxifVdvInC#_o=CV6k@L5D$4k)(TjxsIZ6$JK!Bc+DWU+l)OlYi-f#L zstbfVPpAvPC|a9}N;8K)B1&nxK-WXZ8{bUBVYA|-~!c)#d&vSu@()#GY2Yj?`2b_VQ?z9k@3 z7P2+Pe0@aiViLnz`IuhW%O;y6MsrwciJ}=+U6hmK5`8=f!3xyNC%PC1%oSkD7a$85 z)fm>+)f6@wf_g*10@W9pbwz-_SUa95xm{;B%6L0d$kA!(% z<&WOzX>@*2&%>(NKk00~sl-~n9mPP;Tp<<209M|u&HfA-+dqTj$ud54^$+tUEH4$> zKCJTo3P|M@+kIrQ;IdGe-Qc`&$Lt3PR_uqahb$9EJy%*3^5B2VtH4i@7T42$RSb?=WEcS%teoP-Atv=H3#m%mW z)*V%bXssp4HUyaL`yuNmA6I>hRlHkR@eiB&J`5bw6BpgGD^A5RT-zVu&vMTFbnQhk zc3DZ?)JyKz<@c?MTTbaEGj@{YkCV(9Uc9L4x83-oROZ+9^?z(_`&mWBt4!I8c2 z?RP9Zv=R{g09gR57wPhEE4F@JQVqNUfAzplJ+jjf2?1FTwD>*6h4rECcQUyCx{j* zlXl?h4pIj#k=g>T%|xU*Oj)FiW!7Gz&3RniPG~zA3j`a4HO82yH9tSjG1_*{+|HZx zyya_(gIuPKa1hqCK0@k_aD$B6PfD=Q5#j)PyeRhozC7i?fT5hI_?d2iF>?9XsI4;! zG(e)llwX?y4Z_bg_}!vHUsM>TwK2{_jR&wof}^!zN}b?sbR=1DCRlrnvBqh0K}l`* zv>(GpI0>j?+&jY@hWJp!OD7rSNU#s z09U-&Q@~TPmIxTH6*S^&_4YieAPg2c@j~RU^1S-^HLp;o=!Yia6&lB9uh-k<_g^DR z@OUMxBMb4$Vm8|BMs)Kjy~Zo%eV5o|N8d9dz^k9?{w-Z=ywcvNT&bbA)OAu7y`}kr zee=g`%g0>HCtT}hzU>pBmed9QYO~b&i2z0`SF8f81_J6pu{s#gh62h2W=>+}G-fUU zte6D&t4YF|rCk8j4DF6aAtYK;lrurvBbYG|lzWT#p0Ly#k#iBXFRJA*_)<54RNa`- zjaxZ7Hh^gpQSp3j$JLI}DJ4_>Zc*)qK+k4!pOpMeiht>p9u9MdBEm^pKh4|c=rOz1=NCi4C$e-f;u?TyLl8!~$ zeL?aFDIBBaeSjv&gBZV$koMv1UYy$pydpr54W+%byq8uGvM6OYrS7No1B|hc(smK@ zjddxTz?FcXgRIce2hhZNVP2Na~BE0UN;A0;Mfb3OKRtw7#7& z5U*Hco-;w)IcthFh8ca7Ge%e)e#G?Q60C!iIz*|1qyp6H!Nksp&;=n8_rT>LtDn|~ zd3%sE`yee6s&A!oUi#}_gO$fCdzgXHX8@)K2)PdvVTIooNHxalW2`X>e>9_ydlv#u zc;}J*gUJhOdO<;2QZh?wdb^UD^LPce%J0RRxMr>ZR@z5-Uio?O z?|CI|d_9qGomVXC8nvnS(Pe@lFAUn`Ml_@y&1rwrU%j2@Rp<@*o~jry^_HIBzpXcZ z$TWS-HGRakeB$#;?krNe3*^qt;IgEiLS+zaRX`mMXk%e>0<)&c_%soprQ!=bxT(}w z)aoe`1|r%BVT}^@FlG)$^!||A85D^hcFkNa~L$gM>ba>-|v;FaTfh$Q;~YQc*8KI(yQ zv1E5mutz!Zj$qydK=B4_V7tL~VIl?-5G1e%9t}aC_2dLA)1V(uq_!G@Z z)*PdaG1{Eq>}er3D<{xEDjhJDSya-CN@`I~ZC}fPfTnR4O=&V{Eb)9@^WI-Y7RTiAZXgN9 zinLgfz9ubRWO%aTMJ6a#XnDme*Lye!=E`-!SwR>?m3G^P^ym329o4KXPbRv%*>hIw z^(!A!X!XSVgN_leOn!sOYy_dcP{5RbMHjKbBsN$e9M+BYdUJaO!3xc}3Ls~t1rVt~ z8l=C%x3ofU1LmsGQ{zW02$0oUD76<#9Yr#%K&_5K8H`rXW@)fU8Y-5?!ul)~TTv?) z__8S`JBp_UB8kCBau7@AB6e@o%0&!NU&QPU!)gr@)(~O$Vh}F)=1I03lHF4y{VG=W(kXdvWuBSo$6Dg4miWpk`6gce z(#}4Cmqy}+n|&V3K5yg37>@?2(H!MpFm*rs_u``^TG6eJr0rZk(Iiq$ADMB zt|wr(JW@RXKnd1E$wdNQiS`4@xx*Q^S^W;H-$v5za60G~qk;Z675oS+_+K=-g&L|D0MF`@5ZEEn6!t`RwCfClw}<9ps|Rd!&3{GvXip*G0uM4*-z?+ zX!|JV91~&(X>DhioePjlq_l(8cM2A0iPaYwbBQq*SPQhs*+8vX)}CR^Nm3ujlu=wB zBh*n`86xCiTpq$rAuGByCKw){NjRsEHj$X2mL51Zs(~8P1+!%qhm0 z;S)1rYRc;o9T(ywLJU>X7}Q1YU;W%BIBim*T}m|2W_6Iye2AytkJg5zcGm5YQaya4 zi?G`xdRs*6#Ed>VHpnGm?IoQa(&?q#ekKmis)vfVN39Ob?!=u=+-=9)wusXbwwgm` zW3k>zC0a43C2E7(iC8-khZXkugu-lT4gs~>z75FPp^&!{q7p)CBd0qvq z>L9F!fAAT2RUWb`!d3>dUV)S-l)Z_^YNAMw7wd6wR>fMZ(1@WYfTk~JvjOrv6)IS{ zfGO0y;5RVD+@iSgW`X@<|2g0rLVz-VbYC;NrE8Ne`7v;PF#9H(+hFtPY@k2i*vMZc zk1m(DeG%_k#CvY!Z8Q9q0gAqDh2KF6zGDR6wUFMiLK~cdx0TIr$(!Gn3*MGD|3v-d zCkm)>GY_z827SVVS~d%91tO5DH>mf8&B3rS9yKR%dya|EvZ-l0JxQlV$asIm=_$6l zip|bqqpeWsC|0^ddM;x1<4!MT_D1y_4xY*cUO@)z3rqc&2tSAyl=yBdd%Y=lt+D4! zMg3kSHWr|o-~G7xy@GjKI~A)sCZ`TW)nmBvIUl>}R^4S?CzQ8N43N&>0Ava`>O6rc&#=Vtn;o_t|tzK)f>a!a3^nHOg2 zxs!Po%RY58kG#s&11EjYPCT%afUKwBrV^!oR|9fc@G)lcv7H89JunjYw3yE;-(~rc z@R1S&OaZSzu(`{dfGk+Ojebus?~B%59^Nq?%FYub{@97#F|;c@_XW#d;>D|ya#>Q& zbJFLm2jf)q zf+iRX1bGb&I-{LY$aT8T~M!{uK7PzK)uYQgy=bq*`cb)*Q zKvBPS=RD0aE^ujvN2eYZSDejsPZV4J{So>5ZV<1$ z0()L--R!_Cug@y~5YQ{FYas80;QFj%&rq4`qeRiU=J#LoO8h_ZirJXw6?z&7fC5at zx2_-X3Qf2|qho+nX5byO7q0hfAqH6R3L(yVcje=eayEONFBwH z=8OT%9VQcFbZVS*rXP+R^#!p_4xieugOJ_ZwoP#kG; z=Nziz1VwVrAhHNHIp-(=$`K)f$Qk>bd+xh`tzN86tCC&XQ^HA2_pEA0V`rd@x)ubIrszW%Q*SF&rrZ?}q zB00O4*6mnOb+9^ds+qqm+Sdj9Ha&OM9M{V)?ant&$4jeiTy*=h0F?HG(I4lu2{m|E zSpBtS-M`w_{&&Z^FG0%}uLyl5Axsni1$1D9tpceq0kr@t=-*EHzn${GAn+<^p)s)3 z@hxZpuRb{;Ccgt#Ve5P({OXoJlLGuzEFcTK`eqfrMD?q$W=N@}RY(<&A0_gGD6B97 zR`L9c?!KnQD{)$&+cG>C<>!k2LNli%Z9-5+SaC4VJ;}+Bv*M$y*puNO09I)jDhON> z?!jVZ#k&ZGkq{E0`&sEn0a?AAc|WJ#qsJ9#_wz`F#!b3YnSC>FU(e7@7q8{at10bf zTJK@(A*DE?hJAwDOOG*9dsw|!vY%LmJFPgnO`WwfiTd6_k@L@w(pXJ6*YMULt` zYoBMWbF6hyp!hl`kh8pfmbcE(oekVmbaYMuS+r@K{K~q&axTV`taBnyAUr%J_`d;D zj1yn4h#{wW?}F%G5QB??e?bZ^3DJc2F9`lc-n+bb2Mqf0Jy8*PWR z^4>hWkhwEu?oM0#BPbnVgQHv+lPZQ)SK6i!1Hsro@oEpCl%|5qinWV+Dj$G~8HG7` z_5BL`Shf(|5DX}?vLOJqxrugO#oF9No7=&wwFyGa6)=^cE$*ulb|)-W)Y8z}81brU z?uKCFUwCDO^(1U?=H9){D=UhD7TtcqjXOgBpS+5j87$>bVbFoZFpqkKkV|ZSHF__B9)DQ#eRq?Nf77mvy)SLc$R_oU= z>c8^AK#Hu7HnmmICoBAHhu=tv-Y!HKjCh6lC%s~^K1UV{m_jg|6Nwf3D}={SDw)bL zQ!Mjb5??6FtfGTg&sFo8tUr}B@MMhagp&zl)1G>0w@a zNJkm!VU%bh^)PY|eMrYgobfQP-OmD9+C#>?$C&gaBi6aYI5#P;wCh>(Mn=D#QtxMs z-kdSOI)j`&C_4Ru)hF7ICHs-)-B+Ajym6h=uI2TcoOx5QZwSr}fk4*<+WByeqvI8U z>ayt4>Xr!KWnZLadFQ<7pXdE^oO_ycPP61RM^3Ytc&B;)4C|lfyx*AUA?uxDT+C19 z-BWqM%{|TfXE^_C-Z_)A&oj<>*1f>G0Mr#RydqFt=KagS7w4Uy(;1F7^&upl6{3wm zB?L+Tq!=8N!=rN0Ee3~0|By_Nr{9$~HZ}`u8<^D%%=#v2TgKcg_%Kulgph7cEEl&X z)U6FNl3=$~I?VVWRX1OVc?AJqF|rQ9ak2j4Ie!K1%R#}OT(B2o)~Cw&U{vg>qP=3= z*kwU6vUcaZooNI{YOZL>JrlrFQBpNW!X)X%ZS89l4vtIg82c;Vudi$uV?{Rv&8kYr!jG`}PrM@X z(z$+7%B%Q92^acLydwV_uVR1IOk<#pv3XGiR?SP@zxgYT@~T1Gnb3D7j6F$vZ_?hE zviGL!{mph)v%Nn__NSZ!8M3#@*Z~h#FYjtpcQh#5>ZENA^3G;`UzY68ksS@vu7t9u zS=*P=52Q3;YFC4BFk@V{I|n!He|g~4)7^(IJEdLq>8;D^_O47EPv$SM%4Jr$km4?7 zg$FX}w+fSP`)q05GqXIS7bki0-f92fb$krkKL_n^?9xZK{gc!FEnM}*Z-1-#|1Na= zpF-ysEBtDO-{_VvVO*pFH$W|zt2h+`R&o96pQQY6zwLjDtNy37`j0~U*PsRZ?3X|J z<YHn%7d= zwWM-4Z$0J#D7T+?o@DeP)`Dvt*Meb*^a{p(!R(buuj1Sj&71fm!drJGa$9ol3RJg6 zz{Na1C%055c&bI&p)l5>vp&+)+pK0GIcn4D%P zqfY0YvtShKon;a9{PRM1Q7WEeowE_IE;87@vsygkpLp#$lur`b*#*`u1Kv-@H;uXOAPh{Q$oabG@+k+m!3#=P3g zgc#=wS@ZD_yxN-f>83H!>gH`J514|XqH18SM^5WhddZGnqIx(R2%L}b56jQ$?TymDjJcyx+*Z$RZ{T+~%UwzJP)0wimHXH2eRuf6%}6D?X=FiZLdiyF!j!A`Czxaw~HT0@skU; z)AGS8zSX>sdiX*2o--;y@y!Z#JY>66up${Op$g2wMNE)cN0~RlhsssF|wL zkyQa#bjR?cS}A1Bi8AV|Ha7u9P5-@NK9}SfL42ueFI5A)8e@bBUU{aPGdg*u*n?T& zNrrozVWUxa(3F4BoCmV*CmA@d$9d^dUU`Jf$S9BVRDHlyq$g}F6{-1tO6a(Zs&kANkLOu9EBADkoXL}mv;*0_!g^Gk ze@iLfkcv0u5|DLO2yYu5*Ywu&oPRQFAIq4>^7dt`?Pj?4qSe+-cT2YR=B+Ls>94ex zbvHJOZObzqEA#6b#qBw3pBNm{%3Yk_#kdDp{~#9}5ei3z!eKrDAT4C&Xw7OLTZnlTD>7H^_GnYSZRucp zHr$p8wxqm`P4=dwvnl0o0Hd1RbqR--t>^+AdQT9dJGVE}u>%6H5@vKh4(Uj`ZAquH zYiP8}Ca9;*Dk`~~UX2CCymG3ofJQ$jA{B*|SL50%NGxkbRA8?n@p(7VmZ9-xp&q2s z6T6~a*_V;1haoyxaGCwX{XskOSI#`I=vni$-cEkxRdx}H7v0RsPA??s1$0*{TD)3h zH!UK`#cuNwC$X3ST#ZYe#zj`cBD3}vy>_8q{j*a2vkG2qYS1?~8e1F9?I2Z?y|v!h zxKiF+EpMn2q4mp!jkW5AT4__QytQ84-E8j9IXe^b`W4yjjpF{C)s=-qZu#nUe0Ews16HR0(eghzg>P>8lj*zc2H_RnGK2fzFQ(a$S`SJ3Ck zTz!tH_0cKB`s%m*v(WxOEo=Vix5m!ut6lhN6=1hMM5_p?R5!j$7?-oY(rUanZ?V9u zFS`5QuwO{>v>?4yHRQpmh*x8*j6C>MGA6)n@CsZ?GW|KeFDvxrM8v~BSgAA*J%O{z zNRP78uyH7nN+Sf$=8$eJ;v%`ttT`C zl2O5((h5%%Z(Oj4!7I@il+8Yc^zz32ymBum-_6PQIsE}|#z!691E%uE^{jd$qhWHF zC$~B4I)lt;-xi(Qa9q4~nK4f{Yo`+`m~)l$FLT}nU<$BG+h;T6Y!82?<> zIh`iIr7V2uT+X?``WHa0oO_Y+uJXY(9sw}8CKj%W;Wetlye^8=p`C?clM9#3wySRE zdAseTTKLr{opIWZo272OyoYht)$tuw*$oZiuAIGxbNA3=AiSMFLdn<%eZqhfn|vlH_wI-iTKV)pBGuU?9-YO&q0*s5Km16knJihsaj=^GpLP4$r)^euJ9#u|0) z3TeX%X=AkvZCa^ph*cwRZqUK2Ew$pt75N>F0zI81Z|!LkPfGX)wXO$iC$=Aby7Tyh zmQDK`g^mTw+J9QMZFy>ceg0rW=C?F|MKErO=8e4kfYlx``ZKHW+G(8usm$W6QFuqn zZ_L7bv+&Jt{YvQWc^?h;qv?Giw0!hIC9iq?4X=OF+^=SU@taA_6|jI2y!r#*s0SY< z1Th!v0;6JT(Zah`{AL!v+2w!w?f)!v{$A+(TIl%bwS4f(?0;b$|fG?D5)?AB-eN)fESY80gZvWxhwz$?1ZpH8>? z`zTxQb?X&KB`Ysv{e`SOqs{HYaE>2k6)b!sjM?oh5~X}2Dc{WM zbl-l8FYPvK-GD2xkbuVa3h4Iz9LiSN2txGoj1DO5Mq@?{~oECv^OpC&TZ6@1O6j{)Yl(RW$uWc|kG}#-I&blO7+ib0i0wA2#+GZ!}Td=>It7gip&d6M~ zH(IStR!gH%MkH(^;8kn1>q1zs7aGhEjH=b#I*m4nHrT)v43)c*AO?b0KHWRiotL}P zp|Dy(Wvy_`6?Ajs$X``>6}2&V^RS{jFi?N>H(tSOEpg=~uJ|2RkO%!oUd@>+BlRxT>aXT_wPJzZu}th(CUh>xD6U#AuB}!! z))|{>jjav#mU??zBZ0Qm>zk1cS1Ma-gzdG`!L)fKZ|`f8_BDy!ta&3?H?`};i+#V{ z3fF8|o?QKpmFpJN?x;#1Z4wUFv-_%(7m+Vy`=RFdNOrGaAhwJN_P5g7e-+lfmfbg! z_t7dN@x7t@uDIVwi4w^``m;akerg-pbkktnmy`M3LBxgkN2PBHD-aP4H$wQXhXZ0S| z=w*#3tTD)#qdXN}e^68hC3Q&BhGla|CWE5cCmK(9T7>VDodLz`mz*bp-NRcC;H=Wh zoveB%tK3M6x3cP82BDrjl${5H{ZKCSYVG&smR`N%7GJoWrtG?!^{(ZDD>?s4*1MQ> zDYbImHLh@-FWwZ(SK07}P=avfavn4bu1Miksc=m$UX_d2)Y4_Ca7hX-iQ&blW_4B! z&nTtydfNrNb3HdH;yq+O4)7SK;>P;YPOP#qHs<*b*S({ht)N57C+iIk(E4aOl z%5m1cVz>8pY#rNj;K}NpH^ViXtDF6we%`paac6b5JEa^;DtnfvPNdX_Zu@P;d1M5S zRQC}rlDLyubh(C&EOP-|GS0lT$FhL_6bs(jB1bqh@}!oX-ZGd@;#; z1y9gEDCQ^REIiE$KItw-IH=$C;FILMY5D55e0Iw3 z?80j^_!zVTR&SjmT-N78`xnH+LhDDL^6IS}ydwdS^$z~ZDSYwEe-zvQ2-`l{uz!Bs zL<(NLmB~BR`KVXQS+G^$Rg_X`{r{h47{iJ-Hi-5I$$Y_!FBKL3YCOk|Ww{Af9Lo!X z8Fnzk59g(UEV7|A%1C3J0%{HBg#HZIpW#8LXSz3S_=B8ANkw6$4M)O!ATI-A7=blt zAg_(US+QDwULBEL@M=(`b@fLqdBS^-c;{wDzMEBg@*2|O2yf!A23}_n7EX|XtRYz+ zk*pEL9+AnAY!851g7rkO`emn2B#(KkmoZZn8y;*O>yPR?feg4{mV9n|$ex)OwvQ+!D&S#THz- z#uP5Ge#J_`R!JdXbsm_Kf(uf3Nhw~|iofyxNx}b3DgLULy4CQI?Clku4H>Cen<^)A zTNHAVtU9iC9NSj7uj-KpmsEIF_lrS!wLqz&B`keamDIUHT3xNIU8%0E zQP-?gS69mz*G8iFs#3R9>)UI!?RB)_;Ww$}ZtM2Ztw$$!9lKN7bSP`A`lX@p)6(^e zo4V85;YR*=vve}SpGgY$WbYPlUu@XAkVbmh2l?h)@#A}poE{*!oQsM zFGk^`=EsYL0jp>yPrAF*XU+Lyc(79cwEeH9|5nsr^Xf;HyjRIb-TiF&A7R4`4`%GW z;=BVM#NB3OMObT_}3R`8k>AZoGvmQRKDPldMkLCbr<$}PNg z!Z%hxWd~r_2dDTMInfT^nI7~xYH#>p`0q65gMo(y_^#h!*l5EQ`J_0sy+NZm{f4J0 zLU|y~jpU?pPMZ{raaJA90bj~A zJg3(>YZpcU7SJgt4>3xtVX%u)qlp&Hm4Phg#!w#COC1%RQE-McdvogJy!nVRdvf}% z6n`HNS+k$FhD2vXw1;?e0G5o`ha_uMaYiIErnpox<{o_7lZx;P2GpC?dveBO&hF#M zBhGp(ko$T4PDZ)M=zZXoQF_2Tx3c=(ymgOr?g{Q~#=Xb;55(eqp>Uh?Z!z92HaaMr z^KWwj#_L&fi}CM?rTbF(fn2`E`R5pNo^{Ui?m617Kz`%wQ-X6^_RngCOQhwz+i`|; z98*iXbLRRwwrxeKvo^OrDeYDKF1xgqC)=}TSI#}adWZ7fKJJ|I#slmxid*t zB|$2ink#w=Dvg0Hjnr9{8udcGUaU7t^;W6D3hT_ER`+TQw?>D&T9_+4tasqAVn%t@ zF`(>7Bo+ats%WJ>4udhT^r}e9e+YoEQnW%fcPnsd<$wt}s#(RQbzv#(4&|3&^u(nu zztrRD=(0;(imAD__6&IS=X!gp(#lRNSBXV56*erg8h^3t7u$7RPp9h15|kwXG04s^!ia1sC@=x?8K{O-scCDeqQc z``GqhN46ioR@}TNrME3?2!E<-U)Z>%nmN#<9!qPd(#qMCd^IiJ%`1;#0AK?UXEbM0 zbDwG6jOM>k{aML*B{_(J?^PtJmfuOsC(V!cMW_27#5=dlFD|D2PDb!8x(;vwV(%ny z$$YOlbXkq%zt!y5viU}`-^%tI$$BMPvy%DV09*Wbmj514u!Hxc@QIY(lhQj%z*@GEj63E!LEOT~Hv zs9N4f)5EXvO3>blCVssyrvDX?w1dx9@JiHQaLOCm{9p$!buy#U1%nfuJdqd2a{>fp z!DT_CtTdb!N3!y0P8kDj^4f4#9%qd=cImy_`a<_dS#2b*4rZmH9N?x6=aqqs*q7w{ zlH5>M!o&VF+?vv#0n^mMJPn2;g7r8n-%kp?83nr6%=hH9KF%Hx$YUTVZ;ZOV& zCbYt&1}f4z{FvxL6LK)ZyF;AapEn2c<`74QSo=vey#LS40?p{p%6ac zg9m(gHBZiD^|N{N3}c^WtrMKl%^D{}=QlGvMT%$qwr;(+oAo+MV&YCM;yY&0ticv7yo4kg(U& z;<>pdVXSU2IvcHZ*$&uiJM&JHAgjeTDDqb*Ziba|NLD5)V!(}s*#jU4c7WveSM9#rdpw}S}C_y z38iIhxQr<-=USEvEep~InNsh%?xAg`?zQhd!iH;?X8fO)k)IZ>TGY5ZA?>P{_9f&a zDg9(hKa*50HOsd$GX541iq@E9PssMT?o6uAl;S*7oEh19A(H2uJAo?j zUYi~i`6alf@U>mhOEZ`Tg8cGx+n+H#!0MG-eCZUxu9sj7P(vbKVRQky;yXak_CJt- zw#1VFsC=#3&>M}s)twKf_fesEr3+-b>{`IzL1Pr*_@ROOlDN;nM$5Y=2Kpu z%qtT)8RIykjOJw6s^OeCoR+|=;fzFuNmd?Xv}Y1|u6j=eD`pgUHNvR#yov>a#a|j_ zjbX+ZVsyAH@M>HlqmtdvnFG9q@kw5LLYA@; z5NurXApmWdcZVf+R1HRCe^~X0AT1a%iepwdqI)Bni*eNQC*79Ev=i0o1Fu9{K}Yx(b`~Z^*?~{hD)5GWJQ{y+GQ}IUT=|mZO@# zk2NI)u0f z#q}uUJ}9QvyeO~olwC)uJ*)Iz&39oPVm***PsZDwb}>>#ZKA-`uCy16!m7#K(r9jO zus1YX8)31UXPj#qREbJW8Ca~1LGdpjts6eU$W#=KfK$E&53SHe=t zD>gdtlvxb993>SnJg98568{>jG zE+7pVvy%HlATM|udMUc^6bJqa2@a9!olFo3zi%)#XR)aJinnlyvK}oQ8MO5M0S*c= zO?TgE-W$z*9qE5i-12rvJ(eFqw_?!tkaw=Y{S6-m&g&&@!povm}UN z^}-HjtzZ_iWP>2q=3lXh7(D%X_1f z=aN37+RqgGsbo-IG3rxRonq7pRvpbr;MEZ97Nfyg#p6g$fxxQ?4%tv2Wi()FFe?L1 zF|RNIslcdM;1#YsMVb@LQQiQr2Jku(8CTp9nG6b~f-Ke?6dkCKvoP`bHHj+31`ff=T_^KRvZ(3#K|Ga9XAT&R%ya6kCT=O()yH?#!Y`r z^G0=V+zfENUv~N>5B}=0;J{)%65U>b^z!yS*1E;$*Q33;F6E5NdGi|Y-qBlb86B6@ zwsUgnv_y|=KBKo>DXc%Pm$s*swe|V-73pm$We;ORlumMZL@k0>5Uv~${cf$ipLIa0 zIat{TbIzf>I}akbCIISt+>5MKOs#ovMNJDqqzF(^%jm(pcaWhvkau^bT)-+;yk>A` zlI%>m6{TG`t1Ss@6G+u)uWv9nHdz~*$-23gD)5Td(gCG8Kz+wlBpL?O@nOy62VNln z8s!FSo>zr>JFK&*o2vbhS0vJRUd4IPS^iz_a#HbERdYQInEXdxEr~MV(m7r&b(N)_ zyo`$at0k~iHbkklI1Yfc7c|<{%Bg4}$t-l{JyoTLVIhg`22x%%#SK?WD!f|x|Kn9h zl@w<{kg9!!)Urb8s8hG*!(-m&GcCKXtvhtcTve`SgrAm>pH{9~o?Ty+-@207RmbhC z7mhZozh&{Ezf5VemOx{PIzy6{`1&`vDL$Lp<}n=DpQH3?Jhg z&3mc3uN3E{>bz9k7YaNHd7(Pb0VUl9oiKrBB2B9Vn$idW1zx=`v^_P*jP1W5!E?)} zih%a|2VT96kQFc9`Q#O8pM&jxc91bK380U5@IusQ1^qQbqDEdR)+@yZrruiKJKKMy z+0&x_Og5j&7I-x!M9AVa>aSR&KN%Wfq^CTr7kI8mc~Bi?)G>xmhO^Xe0Y`Bd9K#bh zys=V$njeBO%fnpBaY%e_1XHRrE?J|z30~2vJFQb$PZ+HSjyI>lT#YC`1YSML>;0@X zB6;I#NJ~|$^(e}EH2Os@3xbt`Vs^!I2o`Hh32A;bOJgywNXw+t3SLcGg$d0aRh(gk z3@Z-8Cal+>?Dq-o6Y8>p$D-FOAS9A|f_q1BZ;9R=y>v-%e$A*Svf3$u&{Mw||CH8t z-dugoUh|vXxvfdt&>*d@W7j9dZF&2UQaGX%4v5}fmdwfS;+zA52Yelp;jioibb~c3 z+6vM{Duj-)K@6*yR~V5E52oqz{O|Yv=5&M$shf(@AN&nz1UoV zPTQKStqF5mlf9kp&p>uWyxP=gZ)%{hTHk1{Pgv_3t@xOm&W31BO~UGkS`<2?#;U(- zRoaaYm;ZrRCU{lxSG7j5o=}TbOA56#1NtkisHkqw-2?=(+*sfJRn>Qq72io!q1In` zwd_Yy&9{cSAeFS-lb3sRW2*|RYzE+3;^yOh7#795#9$<}NJSZCCx5A!tK={9TQSgX z_NJxZVb!qcPrR!BUwGBJlxtlsAOk{$CCtW*d#bqO`ud|6JNNJ4%KnP1yEv);qpn<) z*_zZg)${9@XSP&l_tbJn64IF*xh91-rNVWV;1A_3)_N!)3zX;|an7ES-3i`$(#-dy zxF=~IAFFW|pH^!|u%|hDhBaq6>$&L6N@P~DUn|ZVH6jmOmhMAu^#J30Bm8KFA5{On z?7mgNvG5Bi;mM%WYZY$FgI;Rxb1+J_pGTycR;(G7%tTy*k9w}V6jKU$rrJ*x3vTME zYQH4mbK86A6`uoBk!A=DhS0R(PMiOMSD*aym#~#KJdp6M>AeT3NQe>hIEud2-S?*d z7Oc}iPWu%ip=wV{<|GgDi1^V@slPI(Al{hZw9$xEh=iclIIjU>uv;`CX2qebFp`(X zITakke26wV@BKL!m8;EIcIFEP;j?or~QC4|Dic>m_5I7TcHGo&5J*K)( z7_~PmJ%KBe;+uv}90`#DM`eFfFODezc-50p<_#496{o^^mqn4qJ7YkW8~|4M7Q7U2 zG@^%NR%zTWkDA4CtMJqa;jcziXH<3RHv3vIp!kpR6D7A#4tqsf#kwat_a*9m(mZ)!>ZYde&Nd!P#(JY2VVQwk}Suso}S#%>#1zklxy*lnzS40l|q+ zSv@3qP#0$%QD_U+VcDmr!)Fb89(2~&o2>8(E{m?gPn!FiEnun}M9R7cQZ{rr;~dVo z(MUz_3Fh3RF|Q(*b&&NyD!Q3W467{Z%95Q)2fT_`-(a$}$=a0AH#O3YL*u@M&5dMJ zgB9~?UBX)1V61A?JL`=0I=!RbXsgqrGn%PlYE^7iWV$-yVtd-1JNqW)75N*loMOF8 zc~$qFSG0$rqL^3l-1Ap>V3fCFUOrjjMX;iZ!(ha#`4u;IwA`jbs*0A{(sEahU`2UF zV_@X0B3|W|xY>%cveOHr_Vq}~Un;O_UO?B~RJMy*MEzBKH;^tB1g~fV!=HGy;%B}3 zKk=%(oc9*z+G~}4O2@5D$M0|b?R0VH`XsS`PHI0jSU)#~Rhd#%y0eB^Tgz^#Wp_6U z$1~)wJbdoOKH? zoDc%OUXlVL;k53|#uh8$6{z*WDbmF|kv`1nvs?V)m!QvnX)Z7p-qO;#1JV18PVmxn zr&ViG)CL%7kd=lxWkS%Oi6;EjNLEA`1fw9#F~(ktCPaqzHb9^j#^Jm;l%o(EW0g?= zD#Q1u+5Qymg#gn4z-O`rO=<3gLLz^qM{Qch5O4NzI(YRcCu1B{Lm-PTaOQ1TtUkts zK&>Ic0l0=mcOFeYmayh4@S~!K=ivE(TR&&vb%wQINDGGbaKtE#Sj923Fm43HirXjI z1Bwfpjhf{Vvt`h1d7>72#NbxmzLZffX0?lXx@{mu5Sb=QlU12c^;hvA7?jT*i1o63Rq~f4QvmWbL5?{2m89K@rj_@ILIO>5%2Hcajc12q^(5e?3l)W|KY)aUhn#hJmYeSR0y53j?a3$Tf%?>6l zwQ9!?$3}EUr`}*(J$GDJYlG1ebuZARH%$ zNSH-dKH7d^4pvqM{%Vm^S!fd%tmtX-Bte@N;zi9=bw3-?66Ws(_La28u0z$4zgoUf zS-w!MTBt5xpe*}YhA=Nzi(P8xjSbybRwMeY?QGDTUsCo@P2{KM@RwZMGImWJ*Rdko zxjeP0mN}9$k7upZIdX|}F6XT4d2(O$2dvh9qttJN{aP@n2EBO=Sz`#%1OHcN)W=By zAD>CVoR*#Eii-dUe+9jeomrLA=A{-q2ggKu1(Rvf!kmsEmEt@T%o)LYr-g5o0Lk&C zgjaAVrd02_>`aUBRPIYXc%cWBSE4m07!$IM5DMYLI~m=Y9M{OWW=&`|G#-u9#D8i! zlLncx+!-gBvAvjGGZqbovv6OA_lgwadOPKnSEk+Xk)riGWqQReeQ-(?Wwan4LT^d< z3a>!pCwXalv(&9Qld>@;s84cYe@-0cwMh|pAYD_d~zdElE^Tr@& z^mBSYMV8XXz+ZWQ%z!}Pub@7b!fKEwF|S4Ho(fs7a9AoIk%Dg7@0No(`6txE zakX$%@(%)5Ja|Q7f7O)%ugn7(6Ud5T1s%*-hw|?HD&`nm@r1%ETGV_91Y`ZUTD3p# zcIBKu@hWBR%ZIzO{*IIr^J+`8xw$z$@&+c<;yjpNLUM~M?Nt<3zgX#b zjCnPGH!#{RCK2t&{v)q`yc@VODz>kf(~rE0VFdwP@Kop8_HM|y{*t`%Q=Rcsqw`a9 zVL`TIDZhG!ytZ1}-XQI$<##uVhf>;E&Z7t7|dZIl+4^(oPYrg@qNL9JQU2WLQ==c)&k!5UGgWQ2Go=1+NZ zTB3Y=M%jh5=)aV`S&`xn#tgiAA-hq*$9yikvqne_6#|H8jqp1C%u4o{Y>z5rR3&4o zGXZE=koz=JJee>EgvqoUzVvBh1AG_U*R-ua&ZKXP zV9_~m4rjnCWi&_Mt8rEz170%HP)4RoO9Mbw8oWZZ)P}P_mK4wNmd+?H-at%-;_fWC zHC`Wre-rRm!x#{ZK>=LS`*|ZaSFyk97s#Ms4sPF*i?58Ku`$xr~TMSPq zg_CNjTk^X_cV0(D_n71#SArvgL(f``bdV*mSO@dgft&$w?MoR4QpWx{9g4UV@3$~t zPLFwYXpUD0qPjYG1weJ>U65*L(%6%+F#$_=q$^99cch)INt?ndX>Mw^HYAMo34L9I z9v^$UDG~cCXH9g*P29oW*nX%vHHwD@TiNz^j%ktgB zIdkPicLUvd%^?ez^5=Pl4CpKewZ6-acvT@)Y_XO(YE|X%(|EO@9Cuzt6KOe|RkXd; z(zunqQf#Lkp|l;;iZ?e-Ewa;#?9`%YiekicdJF6f4)ts}! zB%Ze=G_oiw{#2v=)aWiuw=CmYm-20k+4jZUnx*2#Dtb`Pv7~vPqvze6PSXXgm(%8z zjB&A1ywoUOZI&)2ayQfby}a^()$TLOy`1ter##AQj~Ts>wT3uzoHKx+X^DPFDX)0z zdBh@o(2x+PqMQhOfLI6NGdKwl;rX)jLi6c|Q6evR=Q$)I9(uE~|6B=XB>x%jO!D@$ z?7uJy&$QsF;*IjO0diEd$5n4!^T%}$@r25BCroF8V#77f8jhObN9d|RV_2elFO0}!M5ZfrhGh?mtM0=R&3E9>NHiIhy(zWuR4v4P z3o)kV+ZgB-iFRs@!FQ>&cm+2#qK8A&R8w=+uXv9%_rBuZ_{oy(E(fC5(N=G{41v)=E<*W z_^TZLsuWIXh0|K;xZp(x(?=5Acydhij=)?o79Ckk?8DJ`AZJ1}7^cj5ULA}!4xOh{ zyi3fFyh1`e2xPH-7vlj|5d77Sl(92yV%*lOZfP=MtKz-*HYKf%O-3YheWMPoYf!f| zyPKN{c(p#-C8l!hDI8S7>1ZJB^;TQL{0pz*hnTd~>!muaMB72l@0g;a*-~$p>dbOI z?tOGYL*eCo+F)t}OX zN!1$>EI5i`#3Icb*ZpzBpD-g{8Qz3RfUL>LTtQ=+1;zgAg+NUAq8;; z!~~e4c1xm;YaG`VT5O*%ieq{>sCa#n(=WSJsyCo|4;AOSU|$u?E1Y$aqo=Z-VT_X* zr8_Af&+4Z|?}Af4Uv4|)myc@B_B6k~KC`wuy|Y<5D!?O!M}?p(t#)PQBfNQ-HM=?U zH^n=x2B#JOlFP6-E1nM%x`bQ8xUMS5yb*Fa>k9H%s>Aojo}cpN_h%S=*9OHZ*A4nypl)Q{4ca=Gt469VNq2LTv#H73I0q}*c9kHVjo_8tQE$h*YMA4*{bu}ewCTrIIP5wGTt4ov;>CtiV6i3Js2H7&H8 zoAs+n*edyQlX9&|z1FPUOzHP>2AtLHtavlU-bx8~(jwhi zm(w5Q)ti~M2L z9aNoR-5Uk6>~P!)Mh$mFcg8G#(h7!EGOD{1R`8S*rrq*$zcd?^XT0K+?az>K)+^1} z!7M4fc1mx-E4TdGDZV1bmp0WaQhMc3y|zoQNeRz+L&`I{`&6|j6?;-P$7Kr|qjb`T zc{nR=P|$`c#PB71OfttoRE`oG9%(W%pOe&dX>gjqMzYcbo(Zza zWJ;nVG$~jkcqgOI(n-ObQVIP9R6=`n5r;){L^Q|1PtBXqJs@jXc1Nhcs!S-gV6)h zW*4nxS+pH1M@5O0qf2!TWL+r2lpinNp%?Sso-Emo=$El+0L)msv-Ylx1#=Z^M~YV0 zw>8^4GVb<_vn6Q*UmF?>Xj8)6m@qfd=5{yU-*`i`5#KtxMU1n$$yuEss~YW2fUC)x zZ)xag0mjRHXBO-1Lai0`T+!QtbG&kXuvihV zYCRw3s@iu~xK0)1*~^H%)GRB|I&#(~XXK zx^XDsm$>=(q?>rT4Q;ieiveSQ6^V9)#sw?7CHn%i{vSreLbCzjT4>e(LKR_3UAZ7G zvr|>iX~oa#iUm=b{cpVTeya8UQP;Ytd29yZ>Npx&FZx#`D&w7xsuUtB!!zP9IARt+wlT|_AV@m)nC?uG@Tuv~Sm7)f<&>aVr#wr_&+QU4>$JQ8 zpe+0*#rO&|p*nP<16nmQ#%1y}x>YwE-KQJo>6LNG0!AoF;CwjRpgziKQ4l6^wQ7P@ zo*_lz+ZlP1)1ofWSEmlBN83SQ)| zq?lI-gBBv;gcgo#zz$-aOQpEOl7n|LzKBU&jUNH5fF`A~R3{FMw9+mG!%A^bDh!B0 zzZ5DxRvZu7>+~GdND<33` zrVjJ&LiR2u&N~~=wz{@bIFTCeeUEFBy}4|J!dYIa=i(H&_{pIaeZ6;TNhZ}iwWx@<}NcIt8wKTF=qYpnnMZhBZ19PJX}hICt}OzcWU zh(G%J#>x;PT@^eh#f-shouhjH_vM7RiSx?du4S(|sJ?|Q;koXJKE~ALaM9dCWnc{( zwo5yg=zLGFI*gL|ax&kpCeA zZ<0S9yeH$s<}FB5=C)}~MWj~K9Gxy}R|yyG98+9_BVG8`mo7+SZT#7z6kRuHj^(GZ zXni<1&Peid@-L!|v}t~@XI6SzZH0Ei4s)UA;b=(S8IYy7UB{L7h%^+h)F*x3fiVqaesx|aGKs!6MR-m` z)&VLF1>2pQHBmVaDDIMm746>x9s~EHGeg0rE)Ef|&k`&jDj6jB22Dp{0&6{4jKfIP z!IK2InA=EO|B-;wZ?!G`7q5lGlx|9=APy6i(wV8V1IyD@+dd{?n7(&{RZ_)tfT6_r z6u=q>Y7jwJ`$#T1_*(JZ^6jHEP$_)dFE>@Nxl9%-pm1N8eAOj(s{ErOpOs2Cncvp# z`dejqx1`KyVV}Uf?@zk_O_X40wKABrhps!5yhNCbV$(Gt1R~rK@}9+DG4oI%X<6v8 zqIJJts3#X$ywM!qK?33pa3BI(F-WOEkZz|^U+|c3G~?;+sJjYWVsre=aFKqvs~`L8 zOkK{|HhPyV_i>48S7EDwqsF#}MqJgl3$LyZQK4;_yuEJ5dUj$g%rx^DFNHU{I?jcV zHgA8YMKTGKn?CJGI18kDX>oiGDdV?*J&Y@$;V3NhSFMU&{90qvp{_`I)}qm~;W$I! zyH+Qy&Bctio>ylSv0k(X6CwV1zamt^#A{_=Wep!cgqz3mT1HDNrJSWkn2;xo(Jf>- zU7d{!8ac+0Y9XSXII1lX9^Tk1w2xnRbIqIt88Ce5>|`=x=|+M%S>swm-Dd#0LA&s` zT77JdS&qR^&9YW2LS8#E?9Ds50yw8-R}RGD!y*r9P_E$~qm{&GY_k-;tL-eL)r; zr$pE57Cf$%S*XTYB;k6cI+%=Lu&Sea0J&P#Cbfyf_?b-RTV_)?`(BXtsb`^g#aLTB z8zV;+7TVd6_inu^2xZ`0nt=J*I?1_Msb{%L-(lIlC>oFY-CL$7rKBTUDUa9c&|V@G zjCQ=T$(xgU+X{LxIVbv&tW;2j2GYv}h?(~{p=&EQ-y-J+%MtSTU&MP#h_KJe+>UYz z*x5O8NlM@yC^=id2zM@s=T1#dsa3C?k#5)X_T<(NiI)OMG~=LbgdV~kkf$po>wb0u{Vfs;`W zWh`2m*~&yo1V%LpshHoCE2Xzg%xo?n%b%+>f))PmW6xKT%h*MrmfIL2Mu}kh?qx!? zZpT$YAr4MI&jms=Ch!ljloKB+JC1x4d0>*?l~KL%sp*)F2K}0F-8?KZog?^n%Yu#F z$=)RuT?K$^HrC{B@+}P#54m)v(-wV}n8aWy@GL|rp{i01z)zq54NDqgF!b$;W|pmQ z4h0weFY#P3G}I`;&gKZdS9~L(=>;$M9p;5Ob1n0c*>G3i$*kF2kJL;)%+C&+pW%4k zzuj7;j)Ow#+{C>v62q$9+LIy!mhJf|f?!{Jiky?lEf)8vsoN}D^w>9MXvsTT)k3Ic zD!8NE5xgT zBu^kSN%WPh4xm6u!0NsrVJXmx{H#EK$~nww#B#!IFv=3@0QYZP^s zr1F~Gj?Q>Y>{NRrjW8UBd%W$jddkd_wW~%A=6EpZb(U~KE!z=QZS(vJqo5!P8|KU17s9k_i1bu* zQlAS#S@Sg7!LKSZ zs&@7Wj5IX@igy(^RC%wKF^pPX+aZ8)CyO}2uQ z^{l$dIV)$ed~3?uqrVI|H<2J&_0Ht5HFM&j4Cl&N$Uk}3&5ihV2E_rP9#dr7aSMCY z<||F*o|u(I)h~s-W7$L^F6~?(KfGNNk`Dn=8Nf-@KAPpx_!Sd+C8`ya___Fdq{~gP z_ThFp5R)$v_!jM-l;c;mW%dvrm}0tZytom4tJpwzE-)-WG+~8vw-H!{MQ>xFqb|tk zHjSwv_f}mPh~%clM7$Mp7Ob5#7yc?Kw{~bzbeJLc=aj0MmVwO*%qA44l+O&y$f~Ro zB|-DFAl+Xbpo0rtSOblGlyNrPHSj!-V4zc+CK2>#PPNqp5=a7CuwWduu@t^ADLrqE zSoH`}4&}i8&5GciDri_Gd$;Rm4y}m@qCoHtcjej|i(GkwGWj?nl7ixI9!HZ}p6eFL zvpxBIbgSXF!&k!oP);ZU$Hlb`zVTl1Y4ou0c(k7!lFlCw7b&2TW3nQU(x!}2A!1KM z##brDo=bHEtV<-kI`~XauE$r1csFN41;ryHU2(fGc*??b-6AC$8X)pCJi&kS*6M_M z)U4ZCSwRPtoLod~$&PKJTZy{o6g_xPS5)3hZfZ3bt`x6L-}};bG#kkYN|oJdC_jZC z4xwDsgZS7BBqJM{Dl{bE6mEyqwDk)QJD9&fhFZHa!qjRi=UC%^M^}v9D2vRJ&h>*K zr`2>Ia}1n+-bEhoDs7358B9YVxft&Lz9Q>|z@$Cjw0NOXB;QwKIcb=+l-?)uJQUH~ z^=GKHC=1j8qw_5Lq<|cfj6~e@>V0D3-hD*6Wk`Vo+4_;fNva^(CTlx>dV8U(M zV5%-lc)Ai#x|I*~%XkRFd|mKSW7YM~xd={`Zcg3VKqON88KUV)tl3T%?sc~R_NCxH zhD4~Q`&Z$AurI8Fv<4Ho&LA`s2&jKc4cb6T}6fAP9p_NC=xES!an4#)0anzqic?^GM4#P*HzC&UDT4<)hvGB1bw*kZc?JqUt& z4P;;Z`&9JZF+n#O%09E~^}eQ)^pG99Ks|hQT@ZrA#NHf!-Vp)pN6Anxm=kVj-*q>} z`+kbxEa1ugRG|w4QNi`9S|m=W!lkO6G85has?DbKkYD&uTO!8bz?0X=yt*V9gQ+d3 z>LZY8))DCzooUG91Vrmzo46YhO^EVbPq`c2tO@rcgM0QLWc6x7a4hPjm66V)zQu0t zZ>YKL79pW592>o&b1jgf{+PDgSOtZP;K8U1Y86ycXQRP|KeNV4;hE*fR(xB!Vk#@e z#w`L<{zM|;Vucm>HxEHA6HZ!SU#A>sUOeOfRN$+9t5a+HevC)=Rs@gJn+UE6UM{or_ZuH= zhNDu1Vn$hF%wPh-t_&y^HEr$2HiyA4MFAF75xki<&a)Za z_WSQd`xx8PzDaTWo$(sG>{&CB)c*FO*rQqY9bJ))=iSzihO;l&>K0wM(0=$M9@7RH z8cGtAm7Wlytyj>M)zP%8#AOX%xWmqTLEu^TuhWJ@VN7|wkt-5HOrt9~Ir~d6H7J9R zLI-NCD@VRBuV7i$?4Ge2x%$|!&hPM|sC!y)X7;8ouFhsgcK>NP7+b?}au6{Q{ingl z$0%WC>uTmq#3*5F)>T_gbo>}|ul|>CFBmZX zYG5}zV(|I=IOFih$iDD`^!fUQ#{F{Bdo0*YLugVo6EIHrnEUyBvHvRg`TEvM=r2nc z@Yzdwv40%E`$_zTT^W#kJF?yTer@x5LfHFxq4RMNc=mm69c)= zOU~qA*b=wW-Zm#`r5@sl?hd#&+y`Wt(fX^IG5pH?IB|uiROGvmm=!)h7--6wPWc1% zt=~%LK8X`j*gmf6tuxOk!C(y0 z>J;&>3$!YR=$HNeTJ;UP0?M*@8ufP1=B{b)JJe_kVxQtnU_OJ8NOussBy=x6UxxHU zuuv{=-d|20>fM>+Ecf3IohMJ@?0ky(VQ$#&iEVkY6#`P8Sq;2aC^I9C2%*!E}3c5+S}J?W7MD-QPzJRZPj- zh3Qx_*gs*fb8PN{>MzVfWj;*Ur1||UNYF`{-@BoYtr|I_z1G3{XmE9xU1d-+LU)R& zO@6w*Rq-M5kS}>@*B0@BiQ272!lT%2MS2AGSPsGFYt$VX67?`UgaQRzG6T+%6y+i7 zl35{dj{XLkvmAOY&isO(VK_QmYH1|QMw}X%=)$g3kZ7l4{XCF_XZq+$FK;cSgMC+z zcQGxul*EuJWMHKfTt}Y4Xjib0zTd#zYquy0osKwOLc^b*3ZCsKgm_n$G1SxMBNy5w z>r=73DP(e?$b+I?e0*(|L39*{J&CZqK{sHXWocx@<$~l!gWro(GR;d&sDit-*Y;)l zr_ORMj5^v#G|I0eI6<-$q_TY+`%4Sk1{G4N$_Y(DB&tVemZ z)AD?TsYf8A6($N_`Gp176YHv)z^JMAolGl%-$e(sc2!32{K(Wr|8d^jYtA#{;$XQs zG~xS{fW>&nFQ?x{=PrXYsXITQR<^)`uh(W>*Oj0~-P7F>(!=+UiiXNGXjh-BVdpx0 zJbA1a23-x?PpMt*KFpK3cpCPXgW?IkZ=n_tt@5Vpw)0WYlb z!MjL+MtzgYT7J4v1VU9-I#@mKmi>nXPZ36#@t$s6D*iUOz9pGuO5P_6tt@~BJ?VFh zXhoweBL%~YCFmcgR9sgS%mh6bq&&BhBv~ z8NR;w1SE4T6$o6Mv))DZbHtbd)mWOLse>5?7anxcJ;!{}@5e!+n)#-vjEdhv2Z6x6 zISfR;#n2mP-MAW9@bPkV9u`h~<|r~mEC!+PD3&A>{vJW4nX&3!+P*WI7gqN{evNEj z0BwDA7C-M!`_K?$LaW;|{2#4lT2Ref$C{E)@VC zefd8sHA~EwPDGSb0$e-*64nIfy!4Pxs9*TmMP)We(e%1S>FL1QwmKTzfiQ1&^R7r^ zN~AgxRDn^u>F*FqQFz_^ZKQhqjW1O%NtDWyY2A7qOq8kT-rl5+q4KyuedwE+%pC&% zCA;2fcCFilnkK)6kREG|{DV*mqM?fRmgIW*1D$-e_up1}Q{PFT1aXCHFSf+;nPuQ8 zeflS;z2(YL&2?F0n#4RQrr7j=Fc6M&vrIMGCM36pG+EqOVSGv)E|>ByJ&jUYPN-O2 z_*T??lZxqs=DY{yw|z}O@XozMHUQZkXLJ;F&o9Vz^6b%KHabd|w|R|%)lHSwnL;5n zN^yn^APiqJQFG~x$g%$P_9hOd*?Qo>fvKnH&JkDr3phG?X})HKX&Jg`8?JSJTgGDU z&vu7%sIzuBoi^i^wSVPmmQGdNMMaU#HcXyP2TkYXc}#7T3h1?x_`&e8m{sCxM-42O z6Pn9R8j=B|zqOGnnowWPGPO#a#1d+!$Q@1l+J#mB; zv;U4&MqfYRaBQQ~_DorK9Hz2P1+cPB6qrkokw*t!W30`R);sWvPoM^)%qk&JJ}L2- z>m4mLxjThW2CE;uNNTxeT7Rb=tp1>x3mKzxcr4NEh}$)H4y>|d zILOhHacZA6Y)Fkll#yn`Qm#&SYA?Y0fdQT5;tuH3C^c?pT7eS{wZy2^nmiOi+E{H$ zWHr~_#VQ47r!>|s$H}aT2;Gbh?jkls)XZE#`pcw9(4<0R*j`fJ zoAYu*0hiaLH86heybIG?8E2-CgS4u5SP5oWeA6~OE5+R@ws6E(!yNZBw%C(UyE5?a z&Cw`C0Od%Mq#fqV;iPq-Q`EoBJ9OMO3W|OSp|d%9Zj?ctS=^=CCTMe-GgFe;OsVNJ z&rRK~vdJ@(3})FS+!=otaPUTnj4<)?pHoXdL6Vn#U5*$YuTsl4?bd*eXpe+M*|YZ&o*myHL!o?6!k3Eauig?l;Hws&lGj3y3!K;%F4ihmPQ~G zUG6L&Q6>dzN0Mk(zf(PCrtX9Vs&P*nMftO~vu_SNf%#TbSP+}i^Gw(Jd5BW#C=u`> z;E*<#a{BUHo``ZPQ(PvI8Tex|=<9vrbDM_v2MBU#>_8^5s*z3T)V6dCHjv`78zu&( z{?`s(#?b@uY`la>8s-;P!Ti!i^|}9vz9V4I59CTiH^MLG1y*KM=7tYzEBJBXi`=QP z`nKCXN~6~n;)Zk&TqIHbWjs+|lNw@0#9$?F1qzPJPhDcUawW0zMCnR9P9zEUuR~qM zE=ItSxAF!wPABe=Qf;zANtwmBbCbmJT|CnqMyBCu9l8bqeM+vU7Yy~aEFy`*WBt{D z3%>+>lGLwM;d7)n-4QHkZa%bmsbZE+AW9k*vVK90kNwEAsn(?bt2Ncbn==5Y;}Mxc zsP5C&1RmgSubd6K*i zgZE)!{a*%mR}n0}gw0y8#}|I!TWIOGDY_?OrR zL1@^Hvp7p#yOBqrCXwv2^xUC3^N@>3DB{aEA~Yo~%EfWUY*_OdG_%h3BwBRvgykNM ztAJXA&O?r~J~V21n?e&U?MQ-R9_G-}O*nYkTH{;JDQVE9(WT}uwW?XyiO}$kifs~{ ziTQX1+*OA1q+(Xd1FwdNzTmpzXlu{qDfCz{#Ctg1sfHdB+pf&ajeI6N*}w}SZthZe zk7{X)@#g&ubitxaxoMNk0^~QEwMUK-algYep38?yC+V~auHS281Zlge@KQzAz#~r9 z<^qni6(%g?tki^RZb~G%j7EnWitE+6Y*Rwd0dcp^^d%^sD80~$YOIsKp#n5+sPI=# zyx;NQF_$3SXig`2_{89jD3_azI_N*TxXDQm4BqF6cSXC@N;I<*h%wZUf5xW0v5H%N zr!`hO%IS{Y`{8s3j0r@BS32T))ks`z<;XOWg2Fcc%0uW3lsDhs;U+KCeqoF4xv|<1 z4xmR+qnMDkX=6nvWxocd1VN}#n%aR5{t@X`G;Zk*F#oc|uTK8aOp?j5bo9;o5ab{= zP|*nQa!}}bqHD=R#UMTuEL4r^xieI;>1v8~ntKt(xI1?H4>yqUU-g3TW=aQO&qb$& zB@~mSmQs$j;&uc2hM; zlQ!+?F%)aog%R?HMSb-&6vxr9VWJ7@PBrSXhQ}yudfJPgRJ5>hrN`Q`Tdxeda}6-&!!KvQ+ks2lukvgsx5x;xTqO_>@*gpE!`GmK z;H96KgpeDOpE%%wg%ooSk_^d@*>KXb5!3wkSasf!UeAdk#|D>v9#~>LMPE((DuZ6* zxJImSskzs!^XxD?b&(t;8DK)A?F-X+xMyJwGQ;EEgd!>hTUEISGFHD;x%}8LDm`r zWn4s$`M)Q_$F{{jUV<{a)agyg;pqR^A79uV zo(zqtO<@5$0Q!7*REHuToJwt=T+rj$_(G+7-T?K8=QB{c#b<<8i4U@Jd4Qx17$iO& zoCidpTXr=9_;4eYf>LF>ecfm$@7Uzp40AO1CG9Ko2VJ;nFUocfBZ*~<%R14%>xb{4 zC5)6f{V0v%Kygj%|!-X0NAF@X)vM;u|cjA;`n9tyGr%~fPo?B zPP&&e=oZ$s{ok*BB~OY%T=0W zC8llhJE~@Aewj+BsZmJYD5D`dNM86TZ*J~5xRb7RDA)cUlk@~K!H7vZoCvCU4mpfY zgkG+UzwJ*IpfQ6W##1FjC)S$F6Sq!Uslc$O&N=hsQ&dQR0dQ**Evoqrn7BuMU%MSj zrkdgN+o;)vq`9r@vnZC@X2%OqvOIW)$Q294i^WTfL(qJqkr%w2ad?Ryr)aWr$PUQd@K)&FbU1`o% z2tobGd-V<=5+`t7a?fUdC`RH7IKpaW-fsN=RSXT~PV+x8KUX)|)Hnq0<0jP%VE}Emi;^ zay2Kg?8N^qCj#Qfa!09wV?)|h*u|+(IaZq&>QE^p^e->++uX}B_sU17$Cg~_1<}qL zI61!1D;VuM>#zTB9cwE*Kjmtwfi<0mZf1P`!wL(3G@*Xh=&hL$brdZ5lQaYmojw0B zP{D$XL{O7-kA0C^Z>9TF-*%R^RW_aTV{um%%bgN;p$xVOotJk;tIi)0dgc7(y$NWc zi>Q+3q7BQWna^Ds1^`XXJ|GxrUt%e+4wiFgI7qp4jh+7bdpB`LWjw)yf4*Z@*}Y46U^X^d@afhn)9w)6Tt6{^;zu@A zJbBD>jl4~09%-t)hTol+JFs(Zo*(AzOBw9jk(-BdFgr5_PSLeSoyB$sn!=Q3Ja?q4 z^Sp-t7*y0<^>&;6?HNG@E|lWgd_n`l9RdK{l*^kq@xkRG@Cu|n79ccL7kP_)0Vk~$ zHYq-QJ~J12NpxeoxapU(Ol8Mu#lMMaPn46JyrmDYJYFQ9hyKkFZqq4LA&+-I8YypC z%Q4DaFfA2^XoO}weX-4kvMIf9m}@Yxk;MK08^4^V{Q?jUQZ`OA1YC6Z@vr5g2h;$6 z(|cKJ#hkR3fR~!>W;=!~WlEwBmE$BTUnCcqY@Y&Zx35x&i>H8|j@_Ql9YF_d`n}VK{|?YsxSX-!5450t4+#^N;WP#703wSOYlJ)(n z_pdeEz;eVS$~0Erpm?V?Z?>Dy{r_$r-BFu^7x4c7ahCNxR3ukLe;-fqpT_I+3!%(sn!_hjkA_Ln|3kE!^Z!J|Ket;234COkId{IJv&$l!>^Q{)e#q4`KTs@}G$L7w>;Wxc^6l`@bT3a9`s& zn|+P+->!hb{~cxjkMRFS+5gYHaE!`kE)H(aCT1>QxDkws&JHFjX0Bh;Gb)Nn5HYHn zdAbrYN`Jja&Aw_F{FjRUFO~k9N!-&_QpNQvQvaWOC7FoW|DzThqa-sC+kdS5Pm_h{ zze;}T!6@PIrPY68{7gjL|HGAFCSv)oMPE!7BDVjP{Ew`hnW>eLh=V7Q&VP*KU}hoW zit$J=(xQ2g(jSBcyX}t+{7qHuNKn!)sV${+vbXW{V;|v3pCA1bpXL1j zo}YR@Zv}gI3?h;C2|u0${a;!MKlwk(Q~wouJUu9UeE)b`>HTQ?9QpjXNE3WtdVk*d z?6xup_{iNS#HYIYBu?)AxS7cH_Yho<6a2Wt`WzCb5)^s98QBhakv#q<__^@)v&{$Q z=B-ZN_Q0)9{`NBS{)Z0B@UQdq41d<)$@6r8zwCsA-M_~)!5;;V{`1hdlx?9wpi{|S z#~qT-wqLaWG6Hm;Wm5udC*orK5hm&Y?RshK@6&=D!5eOK`+|3IQ_n{oz8S~uHMy_m z+F?_4A#QFiJA_HhwhUoAF09Lq--7cKqt&P@Lo|Ke2srNI*5d6hphc(f5SneJ%GCC= zHt_=1_6sON1K5^Xc|1PMUB_N0)XG061#5m=gg0dpDUjDtU_Ubk=ld~Z590+Jbunur z45bjKDuOJ!W2kW(NG}zv;*nY$WR1Nb*3EKG5h20Dr)4MZAbE^OGG?5$j zR{z61Y<_CjSTdhlF7{EcgL;P9TA4zwozkSGwNJRPrk=g$&+llO3M|E{tX(sd3kyCo^wwWVQV=6ii!%jdl6Ns)W(vHAG#yuuR1_+HZ2 zh4a!B^Uvag9cTQClikekc1sHpJBrY1zYvd6|>T!k5!FwIHu7#3f=jSEX0c5sja&Hc)6U$;+cHUbBC#H3R@k-E7<(> zOqJk=)(!O{*9N(vN&>Zh)e9pXmp4uFL|@!o->;z zh8m#6+``DBif8KWUnf~BvVb^YD^vbn4^P>#UiM3`m*!@^uh^Wl`>a!KS{VY=F~g%{ zcDm(UQ(3+Cx@xRlV{Zl5H)lt$&tTjdw0Wa=2o}2sh~d4dztaDuEoil4pFX#yGoaYM zz6zJsazJ-~ehR{n{P;)&Wb@zOnyc{qMk#{rmBL1(m7aD==qnU!#|)^dJtK`7WTH1!YE$Ga*v5waw#)m2T}#54 z3FVG_*N{nre2^kqQX3--vs@QLq7J28#hE!%szFteWTi5>%_ef7o?Nf^!I~xrti1BL z!{+MyplkD9COxGRCDxxBc{r3uNAVDZ5*Y7xWqGn+Tco;OrU_GO0QqlQxN@0h*#Rb<>~8_O^+lF7wP1)i)aEXJP)dDQY*{yS0z(O?*RUx>5tSwP zM3c%jC+qU)ode(YJT3kB?-sk#v$t_pVDb&xSy18@@0Q+z?Z%f~4@FwWitPtn0L7^7YG8vQIc!rqKCaYqHLgjYFps5-QO~T>*zz0-?h`nqOqZ;BA7xR&FJ?9eRPwnJ)v@54WriKe zh;%2nzobEuu>Gpn=v^VfW(K@HoN}lmk+7U9>C$_vm}67azLY_dNI9yZ#5Eyh-3>tO zR5NCSJ)J`~7^$)ZI@b440PZs9dQ#=jPT{&VdDog0)6QeEA5~B0=epJn8(3TC=uA_6 zWMgcYU<-phBl#NcLJS9<=;?_&WWA2__yDIwL!#Ul7liBIoyueuWq?SSB#a~rEb@<< z?7%-)zsN{mOc@>Je^b)ZN6FJ*!0es4L^_ELW=D&ovCoyZoTKIHTLfA6wArtlGrU(2 z^H=F%aCc7=#R?!`bIzBPD+)mD4aWyA!Aeq6uevJ&lV&sXolFbDkeky{sT!I)G}>lr zb~<--qaW`Q-{@?6-M&AjTjan6%KQbaVtj*Lu*qL5hr+~4 z?WBEdfXPGCMYkgn`(BH7y$>pQuKO85p3+ShaV(vUOki3p|BGzH{Bf>{J19-#wuvHo zu+W$8!CG55`MvICU5>vW*6Ay8R1b*!G+kNAP?E)!{7gjt*Pyrq?Iy^K&X^{qI~ImJtfJ?=X$qV^9Lab! zhl`WStwyDnfv!OHuLAHf-i>22C(7=55W0HWa~%Z>c#8w@-;u^&mz-={c?c!j+~ED) z1Is_E1K&u_njXxLq=}TIVnfR7I>atQC#4Bk;1E2r@3Vpt`mW;}_<3(Q3!MFO^-Sro z2AOO&B_k2wNOy$DXbp2rRRHvASyJ(;S7wB#GYDR+$+6g*D@| z*Y63LOd=5`m64`gdXNm8lC&X@Z0?8@B`WP7LQ7~ro2MfG@R5XMP88z;4X@34IUDJ& zF8h&%N;;bO7zojk-i+nZC5fGQSpa8@hs=&K6W`n88FMY&+?FYfkHln0;_1dO1ODVT z0wHwWUDl4Qs8mRXF(Aa0Mb-pM1633BDmj#Y$+!36{G#g|^r}r!GQHT7FKYZoX8wZ> z^{Oa;|Fv^X3Ude-OqX4gfSqxwzAn|Kd$BH>g*0OUq>yQxRk$@t$TN@_N7hoImD4+eI(q^dWQl7OM#D)UUHJH%61S1`Zl6rbf0XcCW15}7%YkO(3mbs?5JTCG4Rfp za)4BkwXGG?35)E7>2Y`-zu*;UDh*uo+#LesjRn(4078e)QPL~O7YU|#39IIm^Ik7~ zuuH1fM0p`AV&n;cjn3LpM5m~@oBmXH*AE&plAdUZA6h*s+|zJOHP|}RCHRsB88b~S zzUSd$jd(VbwWsLr2P>{FA6!HcR1)hFdx&I`;L`0`Eg_J<)%Sy`$oYOHe7%Z98+QFL zd|G5c;@u7Ds&HC=+=QAmilekzk|z@qpNpMGnvd6{U5On#pj70!q(-SC>dn)>HN((N zaVQW=SG^lLaoJznI-Rw!z)?h1DfpsfNQ~mjb^e0YY9&rz&vNdsHmDc;u69$T@Y)8R z&u<6C6aK5EF7;=G7`!#rQnDu|ec8~OdJe&@@|3tRTn4E{|E?@1h9zK9!;dz??A3l8 z2G+EHZr#14oMgmOK|r_@((e}mTT^XS?V-&TZjgg8q0?G;pU06Az1UfWHZB;0AUB32o|n{fK>hXZcuT8vD#0~0RovDBs#YPr`XOxGqN5+6e+qnnwY_? zDv&twR{i>o%V_@Rz|@_~8LD_oe2xdo2{LXt$d7WKn5_YumKyvIGrn0n-Ww1{@^R6x z$nH7>RIckm;#R2yM4khoJhuTg^3y^0iQF7mu&=aSUR;oPV?#+Me;&gFlj@Z7+PnQY2FP}8egZqd3%cWH5 zy0mNeDx(lo`}Q#tuQZ$iv~va%+&Dq_z!#8K?&>S9F+A?z_hM?80?knJ#uZt6EGV~<^W=b9N7u{Hjm0>ass+yI)DM8uq z0MPB8n+rREOe{F`(yyRnuFJsA@^q~ocZZsc%0zNsG~E_7C(1&glc;I~JtfE`CsqFV zJ__i4RT4?6XTbJX{ddCnqNk48untxMwjk_Xr(r_?JN%xF<;#W4eu>4r?+LFnMnJ8( z;KLf~EQL?Rwxn{lafM`z%&MgF3s+m?jo9EjKhLdjAtyj0_1#Z{7a(A^_Ox#4PO}D$ zqP}URiifCmvPD=yrHAvhl_YgM;}i7PiBfqM<7j`rr>kR09J*)f@xZa}W<6ns z?~o??*gB5w^1!$iiUEeH2e^(8P}$G_R)gVF#DV(kj$-LZ=}8LhuXEch@A@|OZwL+i36L5hBA5C}av;jtf2{e*2D8|P*PL;bEkI!4__&Q*V4 z8U^ch)4y=wc^bdIfY07Lvl`34(wVGyI)?;?$Au@&q1)DzVSZuxRhBO5(?>XqRWcn%Qu>Luw1Z@C2y@H4tIBCw$$ zlm2paBQrzb))UIb1{IuZ(7NRU<?YQ&zo&~)1zg$~@q4pWaHpW;9X9_h88LS7k zoiCyWhezldnX*~7{o?AvUsYC3ST>Vd3WYhWH6p1)*BgrtV~QMqh6hN=(^?{BttK(I zr@0fdc}#-5iZ53#fr0^Vxc@_>h(~kW+PpVFzM0M%CjYVaR0kfo?ERYA@hQYmuuYx^ zFE?2F(1m8zIAg#m1g}tGS0vR}pT0UM(l@Mpkr2pqwVx6ymEzx4`Ii6}lVk}KHBEX9 z9W8RiuOMaN1Cl<(y8Z>4LP}t*LG0ScLy09qQS|l}F-Z!l_XBRG-&q4kEkYe z5JNiVP#6Nn_fmI3deF}DH|UW(fxrBS`3f~LRN|?v_mW4!1RvXv(&?N94TmZT?pl}? zZc@jpzi9%Sb#=O=i?nWkQ)h6;>Tg0*wiJdN5sK0&po0vhZnvAC8zlaezqsZnZd${x zusrC2H=DF*7lXGJ>CwNoRy;m^t>)MgJt%p>`eK5TL{d?zw}a>D}wBOz)V;E{5>HbLAlmBE)DYrAo{1X8V*Mj`xJKs~91<)1qaTw$0{r!;id zz|f1oogQPBK*j#6Oi{ewVHDK=AmGK%=!jWN%RhJQ>0XwGfV9OFH6JR`**%^lttR_V zWrXC4MT?2DpXj5T@y`rJC~Z8ZHph~NF?rK#dd_BESuXzb06vqi|R zwu`SKd6%d@q77xgRY!!fpmkJH+#)^Ra~jI7_IB1{QzBuT{0*yAia(@ZBC;-&?86DnE=o?=tbL-VQ6p7d->s=;8NetNJfK1qYCJyoSeLz)b} zW+tJvk!#L*xEx9hxp~YrL6E8PCO(z=o;e!WV?zWEZ)Q8rq(U?So&UZp`|);q4wz@j z3?laV$<;;QQ=h)dKj=g(CdrEbm8a%F>C!z?Q@TjsIUIo8KUqtDaRIus!a=|FxSo-V z#^nHcW&h4Vi;LXUkPB=qSYEz})Jpb9y3EW=^)HD^;}HC_Rgp#=Dwg04>yS$Tqu(-v zvS3Uzor$Ji<&_vv^EmCN_`1$K`bWsiQqNYDDGHHz1sMFMBX!CP4(o4*CYa?7U4%&kX7^1X2N1C?96HjzkF z9#&807IKbCHFi$*CP78jnn{io>t2*88_GV?`*s&??y2uU>ekavYeaM@^u)KU1Njsy zV5i>cp&j{j7}O9GoBZxZrsf=T$9vHY=2hr}>E+^jmr_W!2tCfBz%%j;{u@_D#8E?$lBw9R}W$n1-<(iiocKg^z zZX*2Ad}xROs+0^{>JKkTE2<`Pa91L{6=~XiI5`pK{op=$@3WQfK^k#f9qSNSaTk(T zgBEHC6li@#d)F13Aq0qqpLPTq8c=<>bvM0iC#V+%XU0a4H1k z55un#;9z$68Mu)E{6}@|CJU@NDDw5BD2yk9qs*P6l}0MJ*1SmDd_Q~N5J1w_&w}b5 zloe?H?^zCOKV>MOG;SGAf~J*~ca~)Pu-!@Ckr72^kZrklyF$BSQPEJ-H-o2$8$Wt{ z^d*($Li17&7?y|`2FMlQY82-k)0W&rsj%sqF_WCo5yA#zHQZpQcBt2*<2FL^?NIW> z#gDorv+pHLrxxa&j+AiX$+FI)_ICz#vZuoa*j1aKEO(SS$DD=csNF(u)ZS|B*!d;8`8@Bte&)-S+wJY;)Qm; zw+a9|gWVf8@%ZVq*0Y`HgLaC=rR3p4`;IS7kj~SjzY4gA6o-oFxDX>uga=-|N#WA9 z(zZ(RIWa&w=S!lEJh;H^#g0<0=ZZdRbQ`TXxq~A~qxZrmp~*N_oS9GzWBmA8Pca4n z-#Vejil9u%3DKb>oPvTz{!vI_cnFAtSQx$W#fIe{QEC1@{^td4+xIzIdouysxC*WT z{#L4sT@}Byf_!uJqKukLeQJ&T&E?{}8&MW^ovM#i%U_D|y4uHuj4cf&C|bOk$`R@v zVCi1b!9wyFSpq}ClOv%_=_UYhwLET^@(f84gh7)m*|W2I3L#xc)f{>`Q4%Rx)?vN? zi)iS9$i6$C1x_akSlLE;g!1^wvzOCpOkN7_wcU@|D$zh0*f#P@cg0Z>+X7^LBPp)t zTxqy|T+pj7j3ZnjnI%k+zDW>YxNv=luu9(b@Cwa;%Kt)9Tm2uUiHqv!#@f}n}IY; zKwEi%f>nTyFQufXYHPVX+;4f&qoNx<|KN2~VB8peZ`ctTJVB)5Eat`aLbFPaf@|{e z$Q8>~wlqNVM{`;XYf!-2lrO5Yf;SejqE!CEiXd^-@JRJ^CU{peW}^&;&f=HMDrS=T zpaGozp_OCa3KN8?SuYjua&Kd;K|U-)>?XMQ_jhD{Rw`Ge9I}kyx)aqhUI$A4P){CC zsetmft+yUqlC?*_fqwG0zuVK1|55p?hV{}b_mTkOX@2`g?*GNyTLs4vEK#Cjw3wNh zStDj<=8=UKvovD1n3a4(nXbT2Jm9i6l5XMCaJMyLqVXk z{*=*#pj!Cj;p;eRao1W_xMNLDqy~XUhsW{PGfH4lFPcSe@OaGEw=l$7uV=~w=k2mJ zjT}q&OW|tGpG0CM`!fw~?yQoB<&h>FqKkoQ3e7TMzq)0n6-`MFJI9|{t#OWyENe9h z-68v92PX1=o#B( zxtI~;C$#R6kSfR~3A>gGQ<2?+U3_pmHMVJ{rJ&qE!>+2i2lOJ#EX?AG=z}!;%aV2m zgl@)U@asrzsFwgWRN--;-6S>ka_ah5n3@wKKVQLY@+}BgoL4X@i%cbOl#d(6P?NS%Y!Jq zoJ_e3PB}GSy>0$^k^-xY9$u9Z2J<}*&Cgr`Dsi`9IsgTZ0Y`oPVJEK&O$F~J5!G|c$JNbcylD-BvF6~jgm=n5;$exwmB!`JOB-8p^a zj${9V#hr=w?zhC?swdi{!MEmIz6@YWjS_Je9Gh%cf%;{xA|%+WH1Z~?8cQX(#4xPg zf!E0_azkx^o>qN*B!$e$MfyxmQ01ne{XC1S?^2=~Lvus;HMiAj_jXfM!Kj&>bIF9JKdj>iW7&RGcAC-#Ht~&9o z){9aJUi+hS&h2JzSB7qHI5o29;UAGb_G$M6d7T+u9Z>Ga7(*-=(o-}ec+vDYp}+r?AnjW z%~p;mt?#?dap7__uRRWX?;S(DxRjP+PHUM`0ufgZL@9FmE6s71)UAy+L=)%J5x}dPII3eh;ZlDcw=Xj*Vy;D9R?B?n&YHl$Vf%$6|}W>M%Q?!F@g5x1o8(*Jr3YP zJHDIZyEr$+F!k;)-(Y-X)zgn(e1m$CS}m@N!&RMgDv@6!O(kN(BWL1h2lccLD*B12 zHALUgL%+Qy^3Bb_DjeJ1Oa_Z{1NgC6OwN^>K|kdOyH0k8=I5?)+0x^`w}F1TH&+eC zfS;t8vXUCZZao2;jnkp|v2q|#{w_j2X|}qkC>z)hkY~4kr3NUkfxByUnRe3uuZANEAC9?|1FKX zWhXAT=!v3VVvyXLloFpZGXf!oqB8Xvtl~@_pYtZ8WTsS`;RN4Fr@N-4l)2JB*7NX% zrn*urJ&hItS1P!}+LUi^m;3e_6B}ck^AVS1;OF&-{_b)R{dcz@!0xxJmsu?LmCE#| zO^0BXRDM?%xNW#xOG@BY9<$WZf8?IY=UzboSMPcrvsFD3{gxM0K$(yQ1(HXI_Op;@mqES>J-$tcziL7pWvnwiSi@ z2Vi?AleEa<5P_!{aje$|lM7Hl+9ZYf{Obey5S-pz0^s&URt0Qtu65h5j3#!x=UduW zc^tbf@lm)rt)G1AFATAy8+@tjls<0kQSQk9+LBc%H*VhQ_9x`J`!&b#ikp%PybV(Q zC^YKew-f?!e;4mhob&7CD)gdP$*?=o03-iAe6}WeYtG71A4%VeHz8bfFxK(eYob&lN z|7eoITvWfS^aJ16j-0l8GAAFmfcQn?*E@6+vPY13TFaVQzqx~l`wn;x9U#<4Drgib z((~sJ)#k9V?CWgBf*@wQ3Y>jEs8m}Wl7;Y(VD?5u5N|Sb+Dg>V)UIwDid|H>DW^b(qIy9HbJ5@A}-R8<0&hl7*&^2m`<;9 zDNY7qgr;rb!&a=Sl#gfu1_R)OoY|_$et^qq6j9SnY__~bIKvc+mpW08WneY`xmnL{T}dvpVK9?=LH>NanJ9x z^qri*7}oZqeIpP{mG)`+e&;WAa?AjLS*rS`E2!}23M+Rm4Y}vD0AiL@rvyvkm)uCL zx*YnyAnPGBoBJQiZ~ONrkU<($h|Z`|BSa-#5L#VyzjGbk(fE45^U7Fu6aS1K(Kr7=!?+kBGa9-b-%J9*?TL(A2iExKrR__2H%uZhB@@4*}yU^v}eRW^aHL+owZReFmx2^r1$&vUzx4?4Ahi@b?e z_8V#!3ek$ye!aJpuvQoMvmG zDAb&?G*!32v`>lK9vK^QW$)TlOk(+@Mn*ul`h* zTcb2MRm>F+KiB3+xZ|3)1|AvYOv#}?^-^@VdC|B?^7v#eXg*X%BP%Nex~7I#)kWyD zb3(o#JnrKUF64CB!UpruGqH1&R~K$2o#8diyrTZm(cFZ-Ey~lQ(^4LHA$>*r8qx}ozBRE93sn_qg^B5aL-@fx=Chx~k{aawO~aV1=H@ro zY{xB7dNREcS)FHkLY1!0P5#rj**^5DFGC@`UpH{YB#Bz-(y57+i+l_rNYF&Cm@RQc z#h~9s0O3D`SJzw3R8Wh8`_OuDDP{gbvQeg*s-U9Dwj4i>-FU;J)=e;70~8?Y@@x@W zk+x?A9to9UWg|4BT1E>hpT&9SGB3s`{K%X3M@fUlySiBNHpm4IpKj2rzPgr}2OK16 zna%>8Pz(#s9&Gc{pERZQ7)xC{J+RD5lo%_Jc6$D5w&2jjJ$i`zEw~%C^0T)Ja!j;?97SkU@w zK@qh=2yX4{ob(UnOd85pjz1@k_yd0+?*UdaJu#O^t1ykDTNp=MHSw= z@Y{#jw#zrWG3j2BPB*1q#UVK2+(#%<9l(D+)RpRDpTy>S)tzR?ioZjC3cIF zBu&JYFwhJZUxv%an<2H!dGYOLQ>w{>Fs|^ma^#d&w@7}>K*?sVn5d5s%hT)(HAGaW zCy6Yg-`_meNmJ8a)NDx?+6MS^M$`2yj%=ARMb(Po%tASZ<;h7Jt$e@ly(CwpHSsf~g}9d=%ifeBH95B45X+mU;{-y*bSe}P!fx==Gbz>3b#o2a zqy|UkW>b@Us@(XS96vT!<4M1Gz_D6rC@q!9L)odu+9fjmR;wP$Hzu2bv~cqT-By7N za36x`6*MkC-;XQ_o_W&p=(Ht*LND-}sj zwPS;r*N1+aPp*7joF#uj;5)Ix(kI-_6*IRN=uNvJ^ zk4=vEzJ=GDU9qe10&89GpOLZ!k&flfSLMa5gsSz42N@As!9AaWuAPrNKo7BMdu*P2 zk$T+|*5)A+QIbghP?L9fZ~3drHchxoVRFLC0qEOO%i+b$0|w-kRKYx-Pw7lm{n@wK zE%|K$5`IdTbzI0x`CCw80Ezt91#-x&HJW;rZ!W5?qKZi~1XrNhTam!FNWyx{kPkqV zyi<(Hw?$}8bj^vwSJZbOI=1{}yo!dgB$&mj4n23IvNb5O=Oqu{6N48YQjZ<^md%j` zi7Xvy%h%m9k5+*tBxuAdW;$5Yp;7;)3q1b^W3SI(1gG{NnDh{5K-EYh1$Ke6tr>~D zWz@QdJO4ZWsDSzvfC(E27Gr#-o5_wg>GUr*lN~N)e2}%}l*Ii`^pUoH)3rM*S&o#< z!<$6uIO=8^Pm0{u7T6d!e|l;xn85=k zMq-n!z)c5bglo1?qGnE?nyQ(XuB@Zjmabw3XYxYnl5G9>YPRt5|6*G|y!EFr!hm%9 zh?;Viu7=O89=bTX^gntl+4y?FiX&K)>Mc9~L-D75t|Hi$U(rvekB!P7G~Ca%*TjAf z-0%AbFLuW|^8ZHL{}(?0|7+Ac$NvVvbNycd;Kdyso&JN*2jl4fCyM{S3M4j74>R}w zMiVI6INBkxNjSM$fO&NOi=Jl(@fSa6~mmLh$=V#>r z{1;m<{vUAu|8i>XZsX(#_DasCts#%}p94AlH+Oeu0X8--FE3V48_%!2+^ptK4s4c= zY-ViiT(f@Dt{|!c;i;L&~#OV89RM!F=FaPyM`$Jc?vIO?; z{F=O1`lo`=kB6=T2j#X+{e(7WzHDGA%2?yGkocvm*}kWdTCq`NH=*#~hvMSD1)0~I ztAFnY|NeypR&h)PJ~#Y(n*fvl{5uqFF$jpo=>25){1y1`@h#y&^z)3Y@BP*H`6l7t z=Xd|lm%vGIc4MP|k`({mpMU`$hR<_>?;oN8Q9%6CSE@2FN6-=5Kc=wf3NZiA)xVcl zWiYc=@z(sKVcFIr&%ry3pxvSWltdrEF5Q1hsqf&TO(gK`Y>TZF;RZJ6TOKwqj6x~d z-gj~IPnWmad%RDV0XDwRpH8BluN)2&R>Pj6f8N38f`2a~SOa&-x|)sx{KEU(L`9pd zH`7^^!am#;cgdQX?5j|B6uqXKXyJ>p^E9gj!!!LHfUVaFLq!fms1m{g2oJkzm3-DS z74ca{jbUCiE%1I124)dortBj$P|Jd(g~BXk zBN?dorrVOizBbX`oZk0(nHO5^C(^f`M-Kh0Y7({l^idofJ7GrlA?PKzFP)$VU2I6bmzF8rLwtChV>iDIn0!n4UiL`#0`p`^#Wmbp z%kiuFY40Z;i3WopMr5|-x#+x?&PrgZWc6F4pPUCjLd%|}oOJVtrXIwr3!_w+NuF>7 z|31-M1+~Bo{-fxDBK`NBLhKU${kWe1IxNlgz=O1fV6KyH(5>e_&`ZYLp8yT+aDx8O z{Gji;Vdd*5=m*1{CiCyNwOvG6=B2mdQ;iZ*Ciu@5Z+=}>KQpW=Kf^oc%Q?YtR?_JT z>clc4+1p2wCBPPTNRyKQ^-yMi5r1+rDu9z|WIq>*xaIAoU(@Y}!f!xHDysa~0tynQ zrUml3BDdt-uQd5qasZ#^@qG6RNw}%4^y5)eM%L+}y(6uXr?yMwl=zzOS7BPl(>7yo zYkQ2GLMz~XB=s5QdTG8r=*=Dj@-U9Nw_#Bm+``zh4`-6yr^RvF2E(HIWwKA zliaNeFj*Eweqe_QU@@zA67hwwcG`CqWDoY|w>^n#MoL;2ZM{G0y+9Dr;A^cVtRJL% zq}J&3&U~?L{aNfen>BUqIm%Y>>Ak=)-Q)d6sxdq#3n+~>&vuo|ic5`daz%yL8CH$C zY=GC9@^BjWrYANL)*?&k;hrg?k06*HWQZX76ylV=1v>q7#hHI`N+vt~IBX!pew{li zKKu7iQK=(UmgrRE-IY))Cr`~y z+rP7hKDzg@Qr<6rBC;g~hn9Z%#}>AwQC{ChuUs;{B<=E>{(Xt%5!TQwd4%9RwAA*A z13?f>w3o@A?5xN4JpVnFbfL@rOL=h{i6Bj~#<5EUQQ-=8<5|L_CfGNPFGnFNp*l3g zF!YST5~Ub|y(T$DTA;!(CRtX~g{@j8tnf!tRL87KY@7;DV%=y#pOhv1kW_Iz8blYJ z!xxN6M!=V)SW%2k$Ei2Duwh%(*8AmySrCm->oMnsYb|* z5@Tutq3>OrW{ajIo5*gp7vpX}DaR5vXi!|k)X4*9Yfvm!Q}-sWltqcW9xcr!UCGy2 z6#M(MvD>n(|mE zzgX2{#9-z}ie^bA_aDQ8~zu88Pn*Ad8jt5V~X9(C{voF*LA# z52&-)?M~d@3CuP4PDQ&q6=p>t;_hl6PIIh1_{E5`$^@myDo`*@rv-ILw);2ISu@ES z!MH2S>&*+lg6Pk)kK&lG7b?rlKsTR@d0T#nU(%JE+=eSE9H_%5qPe;CVKUNny zUNdIe68o9*RMD#-(-yaUQXp+0o=TL{L|u3Y8Cd!Vnvc4Wc&20s;7=!h(96%bNK?_@ z_@kzu|2JRxW=?jZe)eFIOq=5=7#%w45{t{a<(uYHRMrxEEdo-f*tN95s~FUS^uA5h zmVDtmwjIX5^V9;)eE4ofuBU4Uf=w3<6kf_GY&yDqbqqL+jLd5;v!j??H(|>7a5gee zneC+N_I5AhIXmXk^OQn*ye~TL!ZO+euPhL zL#CyxXnYP|<^6yP4-3-86fz#nH~xcTiN%3A%@nL`Tg{racmx_HH^?5bd=OludO~Ea z_K+wm*#pIIk|{VRckneVoq`G9_Ovjb%<{RMma9Gg3``F1*n3fhwVy9{;Ug4_bi@QQ zSLby8==H;DyWCs&dAuQ_@o-?e8Xe5ws1f==O2W|rtjPG8jX9V_3l;y=xEaC35@~ou zSlwrAs|M@-%U*e^-Q$$CrncR~=F^j4N6ri7tzQn1*t|N*2_x zhSYX8TUQ@PBH?wEbEDWew6e-tNE!vyvI6ZEExmDE46gs3LfW)BKCJRlO?s|Ix6ISI z?WnDKLfi5^Sxcz)Rxi*9FF=X!7S=4JNScOOiOw6^%+7UF_DIKmYnS)*4$;LhqGZ%3 z_2*brGh*ppssVN&4L)C%Xn~8yz`@ygXMiEn_>@hrxII&r&v^L}3z-fW%a=H@PlAZa zRXT-!*qY1{f=ue(>FX-LI0$^2KP5$UvR7uB?U-9I^ ziNNSLdS}x#siw;7wy3jN8gOyXfYz9aOwVU>=@r)iGSC8*sDGs@jcq6&98(BO<2hxv z*|t$ojMtG)Em!vXjXRpB%>>D?K6FWDsx@qP z&!GX$PxB|uUV#eFKC+?DnwXpBpUM~xt_Cq#5cbvPyOU;o4W$$WXQJt9x*T8TSnBU4 zJ2Wy>$I7_OI|jxmmh?hfk&JW7c)ysWt_CE|8;XnB#!eoC%H zN#YT4lb%5zRuQa9w90gnxu~rS1%k+}`3-YdhHDL332StxQ`I<$&crDT%e3UoBT$z~ zVhDkMuFUKBW`|u2C;8rQT?Te}-wNcUwi*r*AM>bJKo?Kjggiw+O`DuZ@L!n46vnfa zU04e&*6hynydWj}R=% zkcO^Wj!84@9C%1a)o+!5sZ?+1t+e zyHcT{-VlOrXCp_&qZ)g%f$0sJ+!MrvT9v0W@8%1mqP(H8Hmzhx5_EVf$5%KoIR*i6 zg|4Zo$RYvvdIon<42<)qYiPQs=y_=}7MxYTK&PxC6BIc7!piGsb7QdqrTZEXPWQrt zmrfblTDB)5u;{0{^aW4|56ic~FqN92Z zp)Lc#5kv~eCZiZ7d&lBCL=s38qF_%)ahM|r!Ez;S6C)s-r>yHIIFBhWfU*lC{mgh zK~QB|_y`#F;xO#Ig{KMN+>>$M5rjQi6oI1H-7`-|Z@)-fU?5yaMe@iag7v0bC7FDd zS`VRl_Hl>Z1kIKE_2u@UcS+`$cA?B&r|r=WX|aCSMuRZC1edgJslS*B+{HGGU`8U_ z=a)OS%{yQ5?}P^keLOBJloJ~B6ojEgh8D=+W@sl?uH<`7*>&+nWgADHY|_~NS@rV> zmQsGe_XihKnED2pnd7SZks}Vp<+gMb0h}#<_k*rMBLlZ2JPjz?RwV_UJUU3I|jG{Ol;n~ zI&#u1e?GhNF-^EW9@JN2*39TeGVQXfXrD(Las5%0aT+JocHR4FRd8Xvxee5c*q|2 zj+K1I5W@OVWs6x45^1_>E2vw&`kY!5?I)}@*y@;T*OB)!v^wP_%Zy%r&Alhe59G!N;09UElQj z@-26z>c#7ZkY`KoAk-o4%AGa(*IAflj^@%2jZ{%d2{%qaS0zNmibv+`tCue9AKwO5 zQ?v+#s|+;{X}_iIj~&M2@^jE3|23c7nyqt2~9n?q1sPbfzo&Ak?^~dJB!PT1hxgGP8G_fik zPla2VmlGa?*6O7)qFG{9G;yxgg$zw@rfw3_x^?j#oW<%;m9!$VixF3v{-JNZxq;6N z0;?azhk>pL1p@>ead1w4HX~ z2&=`wf@WM`P^(5-*aDL-MIE}Y6;Bsod-+i;vhTs}F2Y*eM%+Vi*Ckw8G;Z}+;8tTyM8@1d;PNiK}qoygq$uATHfImpu z9z_kUrjbWMEwD>0doa6)Rig|M4*rf$v^7HUCzcLOS+%!c^6AJuN7OlWWp6Na|LN%@ zHAzC1A}?p>Elix5LUDTta z+r}NgP}O9F$Y}$+gx;JJzY%u1my_pX^F=LLmXimNm)~l#Nx6_tm2Dy$tR=r^Kj8}1 zwBDV?b`?&mnWmZf+|!i8@RB)Yw%3s5hGJ?==q4Q+7poZ%U>P$H?}j`Wn7Ow}vZ_%| z*=YvfS0mdzBh&BzWRF=lK`BukFKx8U>#C)LIZ9M%wqK-MobFCroZCdp{kurzFY#o= zq52i-`fBouGxYqkb9FHyZdN&Kyfx9HHu;+KTAbgOu|A9=N|Jy;Z3iz{oqK^vCbTCN z=gjt!q_qBrZ#;!Gye?Rp-NW85-7WQ>l_cx+!mquIOh9rK%L6zIpNLAVjr5>+EJtS`D?@NvDNjL^bJHGz-%f+fgmK^eayVk0c16aJ$e2GS}4^TS1dlN!4fC z7$7=6*P_=`W>5tUX;jE_&Pkb$j3;8$?!)hc{3iH**DeWdc@a3=U>}Au z`gaV`J7-KdMaxvWRyQ0k@kDFBH(MBBVaw&u&|ws%LenGtZ*R7)-ZGF&NN99So)^m` zU%L8fMm9hbv`M-=BO7I<_kg(ONUIh5xH^T0g+Kp6K-sxhYClgUUq9u9SxV}eu^O@; zq;TtSm&2GnB1KjKRZsoW`sgV+bGMTM0qaKN_e);6V3a*pgDBD{;IDFBc7yW^a-{j` zIK9n7fv1S0mQe8Pkzfs5mQpL7r(fz{#8JKZqo=ua z6jSzC8Hs;6qyM=OIK5XrlSODfzl)CyB*s(dlDRx=Yu2xfR84sz_R5SkaT}?4+z^eV zyfN3mh|!fU)}^Nsq08o3i&efrg_pk4QtuOUiT?mu{81TJkU{%!qsaHla-Unc3WL7?YnbFN*0*CO4no;D|2G>M;E?Eik z2cJj)g7sdg@)*N?=Eu^*WR!IHP4(s|=S1VkKVPa3IFA?p{)z}DI_=2HONuCs_L%Et z=gd=B^hacNFUKGgxKVhA;3h4Z^@OAUy)Gx^s5#64>U!|Ti+i3YTyU|5Br?0n0vElDhX_gUUFzstDknR(%Dg1P;?6{gjBw)PQ$QTXKle-jWzvR&q0E@7{Egpi?RX)j5iEspn4PeRK15h6?^k74YcFX(n6~rmyeeoDjW&E?` zTxN4B=nA$oooL@Z%D=k3oDMr5VebQ)wX6JPiH)D{^%`S9E1RA5ktK-oQ)Cvz+9lez z@VSdf@g;b=SE;dh4mvQjdh2QexyCJ|GYf@Vr(E4R9=Imx{3gUso`;)EN}shBvs(M)Su%9ZnaRRF;Soe@G#rx z=fEHa#_BY_LX$$v3pRQSzd=db^OVP9k_ndIrBDRDBS8;1LtNaO60)oFIKC0Vch!*C zWMKc8jLQRKTv6u;CCC`FIHgX*fgK={2%)~NwEkAFpzTrDz-A?yf*;9sk-OWF?HB>G zuupzqhoZ;*IPvKZ!PJJa*?JaL9g}A6FKffg9mVm|RW+pk49+h*(A9+R*|@40W0tPDq*-?A?YLe+I<9N8i9D}SZ1 zN;xfDiaRAGiKyB1_E_HpF9w;&Urvwg#MN+y=B#Enw9PtDU@`U|L-!vW>;6dUZ2uCm zIDq}Kzd30y#}xeW=~CG>QOi78m#5agRuaQMZfB-Kmw2KPtnWgt+zPz#+q%(S$XW`|+bN!!aPZ>Q{EiHuDOjg} zG`>0MYMjhG>b!-#gb}N()Lor6vb(WNH^C@q!at^E*DX-0;ePExtVIB--DVq!7=53B z<$=AdqTu=IneK$TUb(jtF0!@HMoH(hh{ipC=DO$%mGwUKy<%I5KdV3cs+Vxu)6IhR z1SCjl&%1T4Z!^hHzX45~4s-Dl3`Jv#In)t<0lHp6XD3DR}^&59dFtNXj` zkh(h`C0cb~08K3$0wI(9Csy+wk8wMzHR*at&iA{ zA>a7s!3DvMl$Yn7iQViM^SN9Es>9kGUeyx)YRPLaR-Q@(<1|zuX0t`{!_#g%;s&9{ zB~FsYJ7)m~4inz=qe-=FDRbDkNNfzpo1# zs%q}MkLOsJQeTp$rzLS#fWL?IR*({Tm8pvAL)$>)?4N2yrNPKyM!1#U%PH>fKU^yT@s>qdfXAP@KmN)E;!8`CW9fPlV$D1;Gjn?v{ zCTyVSSxk4)ozs{)7oDnecD~E@I>12C#-3v=@K{OI=ybYLeNQoLO2Wd9rkoX8-e*u| z{P*KH3vff3uX}6K1V0UC4&N3wufWVD4O-!sq-nUrxxO}PoOa(BIZvqlwo z->YGpU~mebo0!e)_lx$Y)8p178vaV4_HmFh4NAyr4b17ZYUXSq-|cmqWEzk>{#{3k=~l?mcus8<;}18$x=ds- zPVj4NRF!SZ)X_EGmnXLV93ZJ1)Ozbm4qx9Ah5f+m)OK(yE#$f=OBsOkE{KCGS8aml zc)@;xb<(MJXsfQU=rmM~F;Z7@1fL0~4F0WIV_F@F2Ma=NC!sWWoE`pX=whY}T@1yqnsZ$%IfBo;|6^wg}m;#?Bwfh0Q zyX+$b7`PEgb63H+y+BXo)!$ha*Ae} zsO;Q-4l_y0vrdD|5!{GJd*cZ#@KR$($^Xs;aNT;RUHYy~2}#~Wq0s#B$-EGo+!*D` z#X%-j2|*Nnp$t0Zq@P_8}K`*hl z3jOCVSi+z+RN-E4Q7*EV$D3<3CRuQFo>b-06TVnh)1+A}>D2BXuG_dOl|QB=n8?r} zv1$0EuVRHxfidy3hSPU==+r3!WOBJ-3CIea44Gj7Jpxncga(n}+|hSEC87u|vZkj+ z^u&fRRe0MxT2n{sS20Q#XMCq6i2<`o9ltFVqV6L~Mn%lSQ3;R|1nNBlIs6Dr`Bgq%k!KAC8 zXsAztz05H;t13w)i@I`+943|H>9o#gYh4()=vjqx6~yR8x5qw56#}}!i{tL=Sb2ao z{FQ@Fr4RDXl)p};0I^73Tc$Co*un`%0TuBI3)gR!#JF2GPm3O&y;obvAHnN}5a(jc zxDcCGI5_fW-Dh=@#0C(HD;nFSA<`O!0V_f%Up+`0v|`~>e691=AzIA zC0qHPF8<%!i-K=3uT%VajNffec9}R9h<8X&Kr4s}`b$fZN1j${cS7kqRPplGbr^_$ z(ZXuK%UD}uDsv3>=JT&)f!d`IU2@2w6I^FKg}7l)bo5n713SKgx5WeA_xduh%gE?A zj;W{p;w6$xZkBd_;puGfWs zo^4ce)Gi#|pvX}o{gIy5QlYfPLonsx9p;dOrm@lwECF0D9rU5cwAM8cum9aS{1n+i z*Yg9RIOsP&Mi|O5sW=D{fDz_Eqbb5ZD}1{?tpi8SU_W=*i+NtI@rr0M4$nSCF#^7> z<}#r}?t7B&@Cri!>q)u=#xLmLY>mq9VR>7*6Yn?kN>1#_ykXOJW<48nY^ z+@>z40q==|yZe>vCv;%m-14}JL%2ojh29+>&#~_XE7tas*L3HG*It)Xs{;jjib&OR zAX?QccBT!S{`y^7mQ`ZZcKMi>#GIk0P1Mu6hTiEjIG#wGP~^@`sA`|{{Q_pyY_AF$lUWz&3<(eae@HPRGt9} zzt`%`V;xBAE&3l+xp@1WMm8w~SQ8SB7{rjJO4tAkxF211GaEFZVgCE|9A8&ZxAI+& z%gESbt(j3~ZexEN-=^h+-;s+ug+SY&iGS5Vmwj%-bo~3Y&_EW|F4WgE-mH0 z;%+b2U))vw@b=TF1Wyx9fsn#m_kG<0AMQLeqoj2WUHX}KVPT1fb$IegC?`0VKh3t*RU2;g7GI>A_aMd1Zk*cIiuhY&Je)PWsYYColDl(Ku zyjb%ePGVl6AF%uQ=W7c8OPE$*3-yQYBsyR7)D86y?I1e$;&gy}Yn|UP13J(O4p!F zpjr^JP!eKvs?uTm$_cED3F(<7j{DTO$^~KUOc-qh#U3T-Htgmjjr;35OvNY9=|U?L zMNGKanJ&X4nQqz>k6F_-8yLarOutk+1w}Cr2?M+TlmU{~CA%wC5C>s$i|McbxqgZ% z#eRPIfY}}XwqU{L-kTKsO5Cd~Rvt&mnM+CG$mqS}2nRHuUhb5`KB{F}L|uA#_0528 z&SD7GY3%v-s+;{Q51C#0D2vuPBQ&(XZIEMFYY{IH&1XNJGL9`koj9=jUfjSr+4HGs$OYK7XM+(5r z+DgZVsp;?*uR%6@H|yQ8(ioM|NxM3_^2Y9EVkPtly#0a!2FCBkFYX^2GTjF~F9 zf6OT^0VS_0!osm$_XZyku;*dP#V>{<0$XPh@w6QvHwZHdkP`LxM zbFA$=#r4;}xZS`FF;Q>8iGx`eBu;rrJIu&6srDKjc=$wt6;`Y=mWPl8uNm&zF(#ES z9J?)WhwVjP{wzEKP4+g5P24evb##&3ag<8vMOfyf z8m>LhkqYJSYyGx@m0C2s;|1N&BS?td>@Mdh+(`^CSvl_Pi$|jK_tp>xdPCY95zY1G z_*U}wMtNffaG=2siEoHB`3Q!HsYc|?UGjbk$ zi+YHb9faApmIb8BWW%Qm>44k-3*=y-&OO1jHz*gOylI~4f2!9!mk|!(+!9PT$C{hPO*4^TGV772SvCrOb8tE}s75Y#Ea427H zENmoiQE<>?jgsc!$1muG_L#8)V+$HNr^_PK+UHZW1G#5=slQxN3pp}jmX`mvIy9^b zv~Ch~+55TpZse=142{G`Q0TDsm=oqC9@@_2fKy8cw7-epa87#Nu|@fhB5z4K#C5& zR=thPC``1n2m}RIgO`dMkiiU^w4ALwme4iqUgVWsRwPe`R(HINQ8pGK@ zca$f_p7$ak`#@#2?zP$FWLP&p4KeLd7G%Kkgsn?GUnfzDhu+2C)bFLTvF2iCt^wXD zH>t0(lG~0`CECf)iuOvyS$9R(jXyJf-#`*zTfDsbe(ZNOw1tw;O@k9y7EP*KI%Xj zU3_+BW73+|;!7o0=6ix0RxImkHnx`HH?&#-E*&epL1$v3~EnlLEOL5V5XfEgfP!#Rc+# zc9Wm#dp$bi6JL9rmV4n`y_p^wf{otV zTp)-f`Y^Hi$gzIKcWxx2iLo0J?pPGBhjf1K&LjR0?%p!Cj-Y81H8aJ`%nUIcGcz+Y zGcz+YGcz;WiPzDlE9XBtLwhk48M>k1+;srVn46 zer7jGgq+d$y)Hom~KV7=*L_8eU2NeGkcU}-_p$hpnC*JzC*BL%w1fLrCBzT z%n;I1%GGmsBS!Xo6@o8W9)OdW35h#*1f2lf`Q!(~E6^hZ|5WjBMMhdqVMJrhuU>l@qO}@$@DSS2TE0fa*)BV-|&=o_wYu zLyTi@sXJ{*RS^xJ0CZM%z4Bp^MYuD?GLpD1y z?0bU{EcmJOpD+-H!av|qN`JSZv{O-G$+fNd!&iwwGDd;Pd zQU7{esiuRZAlVN66K@9^77ggvn%04X`y=Ul%_g6fCRY`y$A56Y$hYXqS<5k;&~6-D=0jF)M1wJFE&y1ST7D>vEOjP#_O z7yHv@;8Z9KIojKjy$e4z0i%V`W1#*8QRULWJ$QTAnmpmXZP|^I^O6Of+v(mMRB77& z0!-F-vzY}qQIPErHxdH~l(&HXPQWHfW?L+S1&>h5)C=K0$i6;NTI*oWL;(dXEU1Ra zN}y5NG#|kAc?mug#y;G;x?)b{;e5%wXn-j*Q`dkZfXm~zcR+v;Wn;F_+FqY`(x8c@w)a%udEo%AyKe4IKM zR!_ZGHpp*m$*In5=G}kmGIPbSncCfQRMT6;^|=dz!qp1BO2(^V@Z*RFj$9;$22%E$ zS&oW4U`{kQKa3>TP)L9DI6V}_9TCE#8jd!X5fIA;T)W<353|T{`Oi5=7A4GR$Je!I zv2C1P$x;xTGh!Mb*FNR9Cd;KLeQTH>VEJY1C2%%+bUk<9zl6MrnA$R*H$k@yBJ_6< zQqq2+rhHF6829%e=MLN{5xewpj~aiDskH>P$TQlwX~)#TwL4hW#G@XLiPSnLioghI zkJ#t|VHZ-Yu9mS#>I!*GO?l^XtHT77!UN1`lX#+>g zrgZtQL&5E$PS28Yhp@w2OEN@Vfw)T3g~1=-T`!&{hR2iN+!QCN(-ls~v}(|01^Tot zdcewOm%qA$wSHFptpLj@eY_!y@9$?(E0A}5SD$GL@f^E~l9#XuE+dfs-VFwM>1O6( z3!lYIO^O#1xJDb((sb6fIqOz0Ot3HJt)ExJQRs78jg`3AWewg9%q$9S2dv7y$*a*9 zls~QJInen}<0PoJTfK9;k6XPrXx5W@!;IRdG-bq9k4sw1c8$w2)bMp3&{l5RzoG>w zcqD_?<8B=npWycsr?nL6}^b<(KUuVq}yBL_`9~(+`qY-j(d3 z^m6uR^C7?pZgxBUrMXt}Lqh4-C&lGgtCIhF!`J&YFm!5QN%w^46G-;_BoOdk@KT|E zJcfP#rtkv&`H>I+q(eCz`26S?cxU_g`~3AB{PFrSFfBkXxbsz%81VK0Y)JC|Llp42 z>F|OVq70;7Kb!@c9Vkovdfg3pe<7OXl>XIW+@E%=!w#IxTYZiG$n1@$IniM*uQh3Y z8U5A4Kk)H+8iYy6>b)D-Cg${ z@v#POyDC>Pu#v!*>9Wn=bgBD1J3aBM(KxE{rXKw*Da5D@Dl~)e%7Ot@I4wl4iY|=) zWrMqREdh0|Jr1NOA3U@h0{wy^)8%L{BLtJ9>dBY?;umbowKnP40D-Rl8s373uO?ac^uUyVdMjWgM^ z_zLVO`qlI1tAd_YkUwSOLOyJRj7tgc>=M!!GRhJ^xJcpRU^dkz*RJ3klvl1L_y!Q-iO+wwWA1Ocw8H0+=6Xmm=i3ufWP2peJ`$gyScAl0 znt6*!(GFCT`azi1EEUbimTG6}V_Aql*Oe%$sZ@#scN(dVFXgdrI`^UOOdKL6oJ(&gzpnp2Sfyoer?*67>#|ZhccFwN}IdHJGOinUUEwoil3N6!I{pn|JUUTKA6R zCDoQXI-0XT-wJAw@KGhx8mwY0G>!Y4wJ|#DE@oHK;x@ENIpF^6A!Ffm!;tNf!iwit zDmQ5>o5Df!kfaPJe$r}mJYxlT?>1Wgc^G$N3ROR62m8mGr)< zQmY&0`U%7YEHVWID4x~K3f+EvWypG!%JjwJcp`%V`K4vqz=X)q{Cu`-3 zR4pzOV{E#H+ue_6w6>}Yc8!!6D61d^EoJnYRtE2&c*GOw^`)cSCU1_Eh5IN=E5&AK zO})aUGTKj?uqX~xD#a)r_##@HlS6+;mqa*N0ar7xUf(+^IXJGSxhCtoYeK)1CE=`M zgPczzpgP66Q`>V7L%%&l#R&7`zQjQ4rcFRq&P{I4O+`H@^-s7zE>uLI{19)r5lM})T*)N2Q@;}$hDJV_$xZsOkL<^V_mr!uSj8og z`sx|&+|D-(<%plP_$h@RV!7m$LA3dda>nX7ht`kaZ`D=<+FyhHwb4}UQBDWC4bjBT zT*?#NdhuSlzdEf?HRoAqM!N83TCuvSy_H)889z4~R5v3lRQ#(=ZBye!8>{nU4ONE~ zbcOB+Z}V_3YvQL!7MnIINyN3UvhtU|&Ky76mp_bxG?z)nymKW~Fzm`kY#Yh9(~Tj2 ztT``pYn+>flB1~cb;%&FYe@G*s~v`e6=zpyj=EA;oy?nD$b;fdVqjwQd`pp9N_Jwo zsM3s3QJr)-@N`nUM)pgTv$95+gkD!wb1LH}CzM)F$+n6e@caU%a`C zn0EgC*p-hAaGJWzfOB^ttu)Z02uoAX3Zs^4f;uSdnC8iC26*J55ZBeJPq2TQiB$Nu zT=bJ+YmfCM$|hE2*+lGuC-I?rIV8VT>`9n(TUW~8!a>H4Zrz_p3MeuqCZk$)77w4dShS6khL)3xZXWB zr@@|$>wr@#q~ny8gY(S2p7uQ{k-l#G7qGVj`<68k^r!@FQGq-PW&x$~md;6xj&s+yUzyZ;$EJBq89&=-sy1b&1!d%py3l1CD{e#viAesOY=y_^Qrcs%8B)XXu-3Y zfRBK5{Y_K`ZZOke!)C|h^qE)SK zZLD>Sl%>^BeoI}q73BAmOz^dm(5+oYdtA@dmXsCcA8tx%$X9&nSkywLo_&0?ev*|{ zo2+wv!;Khan(DIE+DU4i5KEQN{@m0oXk(Z`$yH(4^5qIKM zH&s^>~Sqs|nAbcWTGQZUKkTC7OXejy>Vg{q-kUv44MNSbZXSBxmOV3*u7VW1Iun0P$W@F+-(o*z$wLZ_NCWcYTexd_$!_Y2HD?Q~ zh{p34)RfrDGF4n19uXD=_7Ex0-UL4*wd)s}ix%)KSCk4 znO#F!)QG3~_02Cc{*hQGC)8LFCO2iKpetWw$4 z8`)G4Dzol<6+{4aeWrnL7 zOZtdhg{+1|Ng@QT{93wZX=e8;sqNVjt9x~RN8C@x8sKYD9c9Zc9G8`Eb%aBD)|Hka z-LK9hqELb$Tz-b2X4k3Rked&jyt?WBI3C_(rigLy8upQ#B#)frnrwuNq|PES2@|VQ z;=N-IW*uwC0PWWyhnYl{{4t|`9=aO=*T`n@QGsv7Rq*n+wN={~_WGX$_BOTWq9_@b zED7+nHJWl3L8^<(!%gLA%dX=u@f~FcglWcj^o~vAuUJn|RcJrYn;fGF(UbG08SN_@ zRuE^`>uT6|jza>9$bZ@bw$h>tW!loGupu5*jqaY4`t4x??z5#57IuTsPrVPt$!-N1 z#bD;snNt3MbR{AP=XAUVfC9eoN9F7>?!lawa|wjS-(2}6qh|Ij@miS)~H}8-_q~1)eMR>c%=W%^8414 zoMg?Lcdvq3e+T8^meqxAyaE2hvcYm6{K%(Q*W>1wS9^nP$+rW(+lZUX?G}7u3YxO{ zp}LR|{{9(odmA;BUcfG41J6aDgwlbGptr_TAuj6W`i^1u9lX?FwPwV z$D$Vd3}nVkIGdj|>P?CcycBcGu}eM4+l;MOyWnl}G0j->#KnH;j`6x^d+&XxRvw?$ zpjVg8PIVOc zO-CBT4L^LIhY^tw2Z4cOK{BMlRu3hIX63OoU%VE^lp40udAvt5M1f&s@qAMMS!-4@ z-~(f~wL+yxY=uo`V6_>f>knliKzf4+Q%3U#t1E4_BeB?8+g_C z{kSG6HBpv&!Pd>3osnA0An8%lKZB7^@Z`?}iA70GB;okmku9%azu-YyOA|;J@fV$i z38-_=%jCLd;1&t6@(u*x@Hnx~rOgw> zA*k~QMnP^IN8K^+kHIoVy3d_7Hy#tyoclq|NF*6EwGy@H+g{1Nj^gOnO zAmanzSqx|70yDC%5}69#Bg)t3swZ^BA28m?>vL^iB!a$0slhy2BRS=Ol;{d#I&q>Z z8!{YlTw0HA6D0KLat^|h-@OKIhB&7|LH-1;UM|O# z9Bpg^ugb8|a_M=JA%&f}0%Kx2iZFTT5-w z$howUBhLZe9I|H0_yp3AK%HlXOr-P$`+xk`NuGo${Rrng_oHL)2tVYXn(>vj6d`fV z29}I-zI_up@&Tjyqh>NzqRMp)1%RwyGueGc!=HY_t8^q8|HTSu{D4vHcN4iq;Yf0B zg%15hlAnf*^HIfeGOu9$DVW!OE0lj5`K)9;p6c_@^Q$9csd(K+?PTcj?BkJSUaqcu z_yh_-LaSyn*+C73m$)-$=Qex=`|q0nR32Wa|4(C!TDh1q&QRLGp1Vhqdjoy(KF5-I z$-35NYpML;|D;G93Q;YX8S&l6A&zoV3O`LwO=<@2Y;UNpTewidQXH5O4re6ol$NQT zzqx*9mR7eF>!n5?!NHWltq%@>}Q zyjg(qAY#M20?rOqR3nkIv6_BKuB0a8=9t3Vur(wm37TtcdBNkrPSnnn!Ioe|6qPCT zSy!%a07km-VOsyp3sVNB;d^9FgZ(*KC|_MN;iloCpylCtiKStmq>z#g4ytkB7~u*e=V4m!3&R+S-asJe}*4v~!dNC3Wi-k6MqKL#$y9dyCPn^nHE?+%ic8 z?VPh56mwJHP&P7jo|Yj#KpP({P(Bhw+HzxSFGQ~I+6HmobTK5_7$$tLuto96;E)59 z#iBT6Zl+$!Q|Sy30?0nqM2v*8Rf=(4g1B|1op_R4O0C&$^5IYWhSX#T(?kG<>J0w7 znFSQmR;AoijkmY%ZWwBt$tJnhJy)OIJq%`GBqbNy^_5Z5CE4p+ax!62(JZ)?Iw@

v4|##3Ooi(1V3+c_4MgUZ;Lc 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�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 OFAq01Bcp_( Date: Sat, 26 Aug 2017 15:38:47 -0700 Subject: [PATCH 12/64] Add MSVC 2017 Community build instructions --- docs/compiling.txt | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) diff --git a/docs/compiling.txt b/docs/compiling.txt index d3cb37b9..0dbc3150 100644 --- a/docs/compiling.txt +++ b/docs/compiling.txt @@ -1,6 +1,45 @@ How To Compile/Build AppleWin ============================= +MSVC 2017 Community +=================== + +1. Install [.NET Framework 4.6](https://www.microsoft.com/en-us/download/details.aspx?id=48137) + + NOTE: The installer _will still_ complain about 4.6 even if [4.6.2](http://www.microsoft.com/en-us/download/details.aspx?id=53344) is installed. +) + +2. MSVC 2017 Community Edition + + a. Install [MSVC 2017 Community](https://www.visualstudio.com/thank-you-downloading-visual-studio/?sku=Community&rel=15) + b. Run `vs_Community.exe` + c. `Individual Components` + + NOTE: Not all of these may be required but they are recommended: + + + * [x] .NET Framework 4.6.1 SDK + * [x] .NET Framework 4.6.1 targeting pack + * [x] C++ profiling tools + * [x] C++/CLI support + * [x] Git for Windows + * [x] Graphics Tools Windows 8.1 SDK + * [x] Graphics debugger and GPU profiler for DirectX + * [x] Static analysis tools + * [x] VC++ 2017 v141 toolset (x86,x64) + * [x] Visual Studio C++ core features + * [x] Windows 8.1 SDK + * [x] Windows 10 SDK (10.0.15063.0) for Desktop C++ x86 and x64 + * [x] Windows 10 SDK (10.0.15063.0) for UWP: C#, VB, JS + * [x] Windows 10 SDK (10.0.15063.0) for UWP: C++ + +3. Clone the repository + + git clone https://github.com/AppleWin/AppleWin.git + +Older MSVC instructions +======================= + 0. Install git 1. Clone the repository From 7039c2a5757edabc6021254ab28020eca7ac74aa Mon Sep 17 00:00:00 2001 From: Michaelangel007 Date: Sat, 26 Aug 2017 16:44:20 -0700 Subject: [PATCH 13/64] Don't offset viewport when full screen. #464 --- source/Frame.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/source/Frame.cpp b/source/Frame.cpp index b6d917f1..7f8c0f6a 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -2178,7 +2178,7 @@ void SetFullScreenMode () buttonx = GetFullScreenOffsetX() + g_nViewportCX + VIEWPORTX*2; buttony = GetFullScreenOffsetY(); viewportx = VIEWPORTX; - viewporty = VIEWPORTY; + viewporty = g_bIsFullScreen ? 0 : VIEWPORTY; // GH#464 #endif // GetWindowRect(g_hFrameWindow,&framerect); From b5c5dcf638652b26655c1a2644a370b1bcd2ae14 Mon Sep 17 00:00:00 2001 From: Michaelangel007 Date: Sat, 26 Aug 2017 16:45:51 -0700 Subject: [PATCH 14/64] Fix poor code formatting --- source/Frame.cpp | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/source/Frame.cpp b/source/Frame.cpp index 7f8c0f6a..387ae8c6 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -2154,19 +2154,23 @@ void SetFullScreenMode () g_main_window_saved_style = GetWindowLong(g_hFrameWindow, GWL_STYLE); g_main_window_saved_exstyle = GetWindowLong(g_hFrameWindow, GWL_EXSTYLE); GetWindowRect(g_hFrameWindow, &g_main_window_saved_rect); - SetWindowLong(g_hFrameWindow, GWL_STYLE, g_main_window_saved_style & ~(WS_CAPTION | WS_THICKFRAME)); + SetWindowLong(g_hFrameWindow, GWL_STYLE , g_main_window_saved_style & ~(WS_CAPTION | WS_THICKFRAME)); SetWindowLong(g_hFrameWindow, GWL_EXSTYLE, g_main_window_saved_exstyle & ~(WS_EX_DLGMODALFRAME | WS_EX_WINDOWEDGE | WS_EX_CLIENTEDGE | WS_EX_STATICEDGE)); monitor_info.cbSize = sizeof(monitor_info); GetMonitorInfo(MonitorFromWindow(g_hFrameWindow, MONITOR_DEFAULTTONEAREST), &monitor_info); + left = monitor_info.rcMonitor.left; - top = monitor_info.rcMonitor.top; - width = (FULLSCREEN_SCALE_TYPE)(monitor_info.rcMonitor.right - monitor_info.rcMonitor.left); - height = (FULLSCREEN_SCALE_TYPE)(monitor_info.rcMonitor.bottom - monitor_info.rcMonitor.top); - scalex = width / A2_WINDOW_WIDTH; + top = monitor_info.rcMonitor.top; + + width = (FULLSCREEN_SCALE_TYPE)(monitor_info.rcMonitor.right - monitor_info.rcMonitor.left); + height = (FULLSCREEN_SCALE_TYPE)(monitor_info.rcMonitor.bottom - monitor_info.rcMonitor.top ); + + scalex = width / A2_WINDOW_WIDTH; scaley = height / A2_WINDOW_HEIGHT; + g_win_fullscreen_scale = (scalex <= scaley) ? scalex : scaley; - g_win_fullscreen_offsetx = ((int)width - (int)(g_win_fullscreen_scale * A2_WINDOW_WIDTH)) / 2; + g_win_fullscreen_offsetx = ((int)width - (int)(g_win_fullscreen_scale * A2_WINDOW_WIDTH )) / 2; g_win_fullscreen_offsety = ((int)height - (int)(g_win_fullscreen_scale * A2_WINDOW_HEIGHT)) / 2; SetWindowPos(g_hFrameWindow, NULL, left, top, (int)width, (int)height, SWP_NOZORDER | SWP_NOACTIVATE | SWP_FRAMECHANGED); g_bIsFullScreen = true; From ab7d803c105f81d91f70a95ffc14411e7eb10b24 Mon Sep 17 00:00:00 2001 From: Michaelangel007 Date: Mon, 28 Aug 2017 08:20:41 -0700 Subject: [PATCH 15/64] Fixes #484 --- bin/APPLE2E.SYM | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/bin/APPLE2E.SYM b/bin/APPLE2E.SYM index cefe8e07..b33faf1e 100644 --- a/bin/APPLE2E.SYM +++ b/bin/APPLE2E.SYM @@ -1,4 +1,5 @@ ; Apple 2 Rom Symbol Table +; Version 4 GH#484 ; Version 3 Cross-referenced/Sync'd with APPLE2E.SYM & A2_BASIC.SYM Added Text Holes ; Version 2 by Michael Pohoreski - AppleWin Debugger Dev @@ -15,18 +16,24 @@ 0026 GBASL 0027 GBASH 0028 BASL -0029 BAS2L +0029 BASH +002A BAS2L 002B BAS2H 002C H2/LMNEM 002D V2/RMNEM -002E MASK/TEMPOP +;$2E aliases 3 symbols +;36 MASK EQU $2E +;37 CHKSUM EQU $2E +;38 FORMAT EQU $2E +002E F8.MASK 002F LENGTH/LASTIN ; Applesoft COLOR F24F ; ROM/Monitor COLOR 30 ; Reference: Apple ][ Reference Manual 0030 COLOR 0031 MODE -0032 INVFLG/PROMPT +0032 INVFLG +0033 PROMPT 0034 YSAV 0035 SAVY1 0036 CSWL @@ -281,7 +288,7 @@ C4FA AMOD6 C567 XHEADER C5AA WRITE2 C5D1 XREAD -; Disk Drive +; IIe Technical Reference Manual (1987), Page 317, $C3XX ROM C603 TSTZPG C607 ZP1 C610 ZP2 From bb4fa7e0493a99787f7affdac842441cb9a9d72d Mon Sep 17 00:00:00 2001 From: Kelvin Lee Date: Sun, 23 Jul 2017 00:24:50 +1000 Subject: [PATCH 16/64] Updated zlib to latest version 1.2.11. --- zlib/adler32.c | 113 +- zlib/compress.c | 45 +- zlib/crc32.c | 149 ++- zlib/crc32.h | 2 +- zlib/deflate.c | 1321 +++++++++++++------- zlib/deflate.h | 78 +- zlib/gzclose.c | 25 + zlib/gzguts.h | 218 ++++ zlib/gzio.c | 1026 ---------------- zlib/gzlib.c | 641 ++++++++++ zlib/gzread.c | 659 ++++++++++ zlib/gzwrite.c | 670 ++++++++++ zlib/infback.c | 107 +- zlib/inffast.c | 159 +-- zlib/inffast.h | 4 +- zlib/inffixed.h | 6 +- zlib/inflate.c | 585 ++++++--- zlib/inflate.h | 38 +- zlib/inftrees.c | 109 +- zlib/inftrees.h | 27 +- zlib/trees.c | 242 ++-- zlib/trees.h | 4 +- zlib/uncompr.c | 116 +- zlib/zconf.h | 326 ++++- zlib/zconf.in.h | 332 ----- zlib/zlib-Express2008.vcproj | 22 +- zlib/zlib-Express2010.vcxproj | 7 +- zlib/zlib-Express2010.vcxproj.filters | 21 +- zlib/zlib-Express2013.vcxproj | 9 +- zlib/zlib-Express2013.vcxproj.filters | 23 +- zlib/zlib-Express2015.vcxproj | 9 +- zlib/zlib-Express2015.vcxproj.filters | 23 +- zlib/zlib-Express2017.vcxproj | 7 +- zlib/zlib-Express2017.vcxproj.filters | 21 +- zlib/zlib.h | 1611 +++++++++++++++++-------- zlib/zutil.c | 101 +- zlib/zutil.h | 191 +-- 37 files changed, 5729 insertions(+), 3318 deletions(-) create mode 100644 zlib/gzclose.c create mode 100644 zlib/gzguts.h delete mode 100644 zlib/gzio.c create mode 100644 zlib/gzlib.c create mode 100644 zlib/gzread.c create mode 100644 zlib/gzwrite.c delete mode 100644 zlib/zconf.in.h diff --git a/zlib/adler32.c b/zlib/adler32.c index f201d670..73b36cad 100644 --- a/zlib/adler32.c +++ b/zlib/adler32.c @@ -1,14 +1,15 @@ /* adler32.c -- compute the Adler-32 checksum of a data stream - * Copyright (C) 1995-2004 Mark Adler + * Copyright (C) 1995-2011, 2016 Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h */ /* @(#) $Id$ */ -#define ZLIB_INTERNAL -#include "zlib.h" +#include "zutil.h" -#define BASE 65521UL /* largest prime smaller than 65536 */ +local uLong adler32_combine_ OF((uLong adler1, uLong adler2, z_off64_t len2)); + +#define BASE 65521U /* largest prime smaller than 65536 */ #define NMAX 5552 /* NMAX is the largest n such that 255n(n+1)/2 + (n+1)(BASE-1) <= 2^32-1 */ @@ -18,46 +19,51 @@ #define DO8(buf,i) DO4(buf,i); DO4(buf,i+4); #define DO16(buf) DO8(buf,0); DO8(buf,8); -/* use NO_DIVIDE if your processor does not do division in hardware */ +/* use NO_DIVIDE if your processor does not do division in hardware -- + try it both ways to see which is faster */ #ifdef NO_DIVIDE -# define MOD(a) \ +/* note that this assumes BASE is 65521, where 65536 % 65521 == 15 + (thank you to John Reiser for pointing this out) */ +# define CHOP(a) \ do { \ - if (a >= (BASE << 16)) a -= (BASE << 16); \ - if (a >= (BASE << 15)) a -= (BASE << 15); \ - if (a >= (BASE << 14)) a -= (BASE << 14); \ - if (a >= (BASE << 13)) a -= (BASE << 13); \ - if (a >= (BASE << 12)) a -= (BASE << 12); \ - if (a >= (BASE << 11)) a -= (BASE << 11); \ - if (a >= (BASE << 10)) a -= (BASE << 10); \ - if (a >= (BASE << 9)) a -= (BASE << 9); \ - if (a >= (BASE << 8)) a -= (BASE << 8); \ - if (a >= (BASE << 7)) a -= (BASE << 7); \ - if (a >= (BASE << 6)) a -= (BASE << 6); \ - if (a >= (BASE << 5)) a -= (BASE << 5); \ - if (a >= (BASE << 4)) a -= (BASE << 4); \ - if (a >= (BASE << 3)) a -= (BASE << 3); \ - if (a >= (BASE << 2)) a -= (BASE << 2); \ - if (a >= (BASE << 1)) a -= (BASE << 1); \ + unsigned long tmp = a >> 16; \ + a &= 0xffffUL; \ + a += (tmp << 4) - tmp; \ + } while (0) +# define MOD28(a) \ + do { \ + CHOP(a); \ if (a >= BASE) a -= BASE; \ } while (0) -# define MOD4(a) \ +# define MOD(a) \ do { \ - if (a >= (BASE << 4)) a -= (BASE << 4); \ - if (a >= (BASE << 3)) a -= (BASE << 3); \ - if (a >= (BASE << 2)) a -= (BASE << 2); \ - if (a >= (BASE << 1)) a -= (BASE << 1); \ + CHOP(a); \ + MOD28(a); \ + } while (0) +# define MOD63(a) \ + do { /* this assumes a is not negative */ \ + z_off64_t tmp = a >> 32; \ + a &= 0xffffffffL; \ + a += (tmp << 8) - (tmp << 5) + tmp; \ + tmp = a >> 16; \ + a &= 0xffffL; \ + a += (tmp << 4) - tmp; \ + tmp = a >> 16; \ + a &= 0xffffL; \ + a += (tmp << 4) - tmp; \ if (a >= BASE) a -= BASE; \ } while (0) #else # define MOD(a) a %= BASE -# define MOD4(a) a %= BASE +# define MOD28(a) a %= BASE +# define MOD63(a) a %= BASE #endif /* ========================================================================= */ -uLong ZEXPORT adler32(adler, buf, len) +uLong ZEXPORT adler32_z(adler, buf, len) uLong adler; const Bytef *buf; - uInt len; + z_size_t len; { unsigned long sum2; unsigned n; @@ -89,7 +95,7 @@ uLong ZEXPORT adler32(adler, buf, len) } if (adler >= BASE) adler -= BASE; - MOD4(sum2); /* only added so many BASE's */ + MOD28(sum2); /* only added so many BASE's */ return adler | (sum2 << 16); } @@ -125,25 +131,56 @@ uLong ZEXPORT adler32(adler, buf, len) } /* ========================================================================= */ -uLong ZEXPORT adler32_combine(adler1, adler2, len2) +uLong ZEXPORT adler32(adler, buf, len) + uLong adler; + const Bytef *buf; + uInt len; +{ + return adler32_z(adler, buf, len); +} + +/* ========================================================================= */ +local uLong adler32_combine_(adler1, adler2, len2) uLong adler1; uLong adler2; - z_off_t len2; + z_off64_t len2; { unsigned long sum1; unsigned long sum2; unsigned rem; + /* for negative len, return invalid adler32 as a clue for debugging */ + if (len2 < 0) + return 0xffffffffUL; + /* the derivation of this formula is left as an exercise for the reader */ - rem = (unsigned)(len2 % BASE); + MOD63(len2); /* assumes len2 >= 0 */ + rem = (unsigned)len2; sum1 = adler1 & 0xffff; sum2 = rem * sum1; MOD(sum2); sum1 += (adler2 & 0xffff) + BASE - 1; sum2 += ((adler1 >> 16) & 0xffff) + ((adler2 >> 16) & 0xffff) + BASE - rem; - if (sum1 > BASE) sum1 -= BASE; - if (sum1 > BASE) sum1 -= BASE; - if (sum2 > (BASE << 1)) sum2 -= (BASE << 1); - if (sum2 > BASE) sum2 -= BASE; + if (sum1 >= BASE) sum1 -= BASE; + if (sum1 >= BASE) sum1 -= BASE; + if (sum2 >= ((unsigned long)BASE << 1)) sum2 -= ((unsigned long)BASE << 1); + if (sum2 >= BASE) sum2 -= BASE; return sum1 | (sum2 << 16); } + +/* ========================================================================= */ +uLong ZEXPORT adler32_combine(adler1, adler2, len2) + uLong adler1; + uLong adler2; + z_off_t len2; +{ + return adler32_combine_(adler1, adler2, len2); +} + +uLong ZEXPORT adler32_combine64(adler1, adler2, len2) + uLong adler1; + uLong adler2; + z_off64_t len2; +{ + return adler32_combine_(adler1, adler2, len2); +} diff --git a/zlib/compress.c b/zlib/compress.c index d37e84f5..f2cdb31e 100644 --- a/zlib/compress.c +++ b/zlib/compress.c @@ -1,5 +1,5 @@ /* compress.c -- compress a memory buffer - * Copyright (C) 1995-2003 Jean-loup Gailly. + * Copyright (C) 1995-2005, 2014, 2016 Jean-loup Gailly, Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -28,16 +28,11 @@ int ZEXPORT compress2 (dest, destLen, source, sourceLen, level) { z_stream stream; int err; + const uInt max = (uInt)-1; + uLong left; - stream.next_in = (Bytef*)source; - stream.avail_in = (uInt)sourceLen; -#ifdef MAXSEG_64K - /* Check for source > 64K on 16-bit machine: */ - if ((uLong)stream.avail_in != sourceLen) return Z_BUF_ERROR; -#endif - stream.next_out = dest; - stream.avail_out = (uInt)*destLen; - if ((uLong)stream.avail_out != *destLen) return Z_BUF_ERROR; + left = *destLen; + *destLen = 0; stream.zalloc = (alloc_func)0; stream.zfree = (free_func)0; @@ -46,15 +41,26 @@ int ZEXPORT compress2 (dest, destLen, source, sourceLen, level) err = deflateInit(&stream, level); if (err != Z_OK) return err; - err = deflate(&stream, Z_FINISH); - if (err != Z_STREAM_END) { - deflateEnd(&stream); - return err == Z_OK ? Z_BUF_ERROR : err; - } - *destLen = stream.total_out; + stream.next_out = dest; + stream.avail_out = 0; + stream.next_in = (z_const Bytef *)source; + stream.avail_in = 0; - err = deflateEnd(&stream); - return err; + do { + if (stream.avail_out == 0) { + stream.avail_out = left > (uLong)max ? max : (uInt)left; + left -= stream.avail_out; + } + if (stream.avail_in == 0) { + stream.avail_in = sourceLen > (uLong)max ? max : (uInt)sourceLen; + sourceLen -= stream.avail_in; + } + err = deflate(&stream, sourceLen ? Z_NO_FLUSH : Z_FINISH); + } while (err == Z_OK); + + *destLen = stream.total_out; + deflateEnd(&stream); + return err == Z_STREAM_END ? Z_OK : err; } /* =========================================================================== @@ -75,5 +81,6 @@ int ZEXPORT compress (dest, destLen, source, sourceLen) uLong ZEXPORT compressBound (sourceLen) uLong sourceLen; { - return sourceLen + (sourceLen >> 12) + (sourceLen >> 14) + 11; + return sourceLen + (sourceLen >> 12) + (sourceLen >> 14) + + (sourceLen >> 25) + 13; } diff --git a/zlib/crc32.c b/zlib/crc32.c index 32814c20..3d523cb1 100644 --- a/zlib/crc32.c +++ b/zlib/crc32.c @@ -1,5 +1,5 @@ /* crc32.c -- compute the CRC-32 of a data stream - * Copyright (C) 1995-2005 Mark Adler + * Copyright (C) 1995-2006, 2010, 2011, 2012, 2016 Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h * * Thanks to Rodney Brown for his contribution of faster @@ -17,6 +17,8 @@ of the crc tables. Therefore, if you #define DYNAMIC_CRC_TABLE, you should first call get_crc_table() to initialize the tables before allowing more than one thread to use crc32(). + + DYNAMIC_CRC_TABLE and MAKECRCH can be #defined to write out crc32.h. */ #ifdef MAKECRCH @@ -28,37 +30,15 @@ #include "zutil.h" /* for STDC and FAR definitions */ -#define local static - -/* Find a four-byte integer type for crc32_little() and crc32_big(). */ -#ifndef NOBYFOUR -# ifdef STDC /* need ANSI C limits.h to determine sizes */ -# include -# define BYFOUR -# if (UINT_MAX == 0xffffffffUL) - typedef unsigned int u4; -# else -# if (ULONG_MAX == 0xffffffffUL) - typedef unsigned long u4; -# else -# if (USHRT_MAX == 0xffffffffUL) - typedef unsigned short u4; -# else -# undef BYFOUR /* can't find a four-byte integer type! */ -# endif -# endif -# endif -# endif /* STDC */ -#endif /* !NOBYFOUR */ - /* Definitions for doing the crc four data bytes at a time. */ +#if !defined(NOBYFOUR) && defined(Z_U4) +# define BYFOUR +#endif #ifdef BYFOUR -# define REV(w) (((w)>>24)+(((w)>>8)&0xff00)+ \ - (((w)&0xff00)<<8)+(((w)&0xff)<<24)) local unsigned long crc32_little OF((unsigned long, - const unsigned char FAR *, unsigned)); + const unsigned char FAR *, z_size_t)); local unsigned long crc32_big OF((unsigned long, - const unsigned char FAR *, unsigned)); + const unsigned char FAR *, z_size_t)); # define TBLS 8 #else # define TBLS 1 @@ -68,14 +48,16 @@ local unsigned long gf2_matrix_times OF((unsigned long *mat, unsigned long vec)); local void gf2_matrix_square OF((unsigned long *square, unsigned long *mat)); +local uLong crc32_combine_ OF((uLong crc1, uLong crc2, z_off64_t len2)); + #ifdef DYNAMIC_CRC_TABLE local volatile int crc_table_empty = 1; -local unsigned long FAR crc_table[TBLS][256]; +local z_crc_t FAR crc_table[TBLS][256]; local void make_crc_table OF((void)); #ifdef MAKECRCH - local void write_table OF((FILE *, const unsigned long FAR *)); + local void write_table OF((FILE *, const z_crc_t FAR *)); #endif /* MAKECRCH */ /* Generate tables for a byte-wise 32-bit CRC calculation on the polynomial: @@ -105,9 +87,9 @@ local void make_crc_table OF((void)); */ local void make_crc_table() { - unsigned long c; + z_crc_t c; int n, k; - unsigned long poly; /* polynomial exclusive-or pattern */ + z_crc_t poly; /* polynomial exclusive-or pattern */ /* terms of polynomial defining this crc (except x^32): */ static volatile int first = 1; /* flag to limit concurrent making */ static const unsigned char p[] = {0,1,2,4,5,7,8,10,11,12,16,22,23,26}; @@ -119,13 +101,13 @@ local void make_crc_table() first = 0; /* make exclusive-or pattern from polynomial (0xedb88320UL) */ - poly = 0UL; - for (n = 0; n < sizeof(p)/sizeof(unsigned char); n++) - poly |= 1UL << (31 - p[n]); + poly = 0; + for (n = 0; n < (int)(sizeof(p)/sizeof(unsigned char)); n++) + poly |= (z_crc_t)1 << (31 - p[n]); /* generate a crc for every 8-bit value */ for (n = 0; n < 256; n++) { - c = (unsigned long)n; + c = (z_crc_t)n; for (k = 0; k < 8; k++) c = c & 1 ? poly ^ (c >> 1) : c >> 1; crc_table[0][n] = c; @@ -136,11 +118,11 @@ local void make_crc_table() and then the byte reversal of those as well as the first table */ for (n = 0; n < 256; n++) { c = crc_table[0][n]; - crc_table[4][n] = REV(c); + crc_table[4][n] = ZSWAP32(c); for (k = 1; k < 4; k++) { c = crc_table[0][c & 0xff] ^ (c >> 8); crc_table[k][n] = c; - crc_table[k + 4][n] = REV(c); + crc_table[k + 4][n] = ZSWAP32(c); } } #endif /* BYFOUR */ @@ -162,7 +144,7 @@ local void make_crc_table() if (out == NULL) return; fprintf(out, "/* crc32.h -- tables for rapid CRC calculation\n"); fprintf(out, " * Generated automatically by crc32.c\n */\n\n"); - fprintf(out, "local const unsigned long FAR "); + fprintf(out, "local const z_crc_t FAR "); fprintf(out, "crc_table[TBLS][256] =\n{\n {\n"); write_table(out, crc_table[0]); # ifdef BYFOUR @@ -182,12 +164,13 @@ local void make_crc_table() #ifdef MAKECRCH local void write_table(out, table) FILE *out; - const unsigned long FAR *table; + const z_crc_t FAR *table; { int n; for (n = 0; n < 256; n++) - fprintf(out, "%s0x%08lxUL%s", n % 5 ? "" : " ", table[n], + fprintf(out, "%s0x%08lxUL%s", n % 5 ? "" : " ", + (unsigned long)(table[n]), n == 255 ? "\n" : (n % 5 == 4 ? ",\n" : ", ")); } #endif /* MAKECRCH */ @@ -202,13 +185,13 @@ local void write_table(out, table) /* ========================================================================= * This function can be used by asm versions of crc32() */ -const unsigned long FAR * ZEXPORT get_crc_table() +const z_crc_t FAR * ZEXPORT get_crc_table() { #ifdef DYNAMIC_CRC_TABLE if (crc_table_empty) make_crc_table(); #endif /* DYNAMIC_CRC_TABLE */ - return (const unsigned long FAR *)crc_table; + return (const z_crc_t FAR *)crc_table; } /* ========================================================================= */ @@ -216,10 +199,10 @@ const unsigned long FAR * ZEXPORT get_crc_table() #define DO8 DO1; DO1; DO1; DO1; DO1; DO1; DO1; DO1 /* ========================================================================= */ -unsigned long ZEXPORT crc32(crc, buf, len) +unsigned long ZEXPORT crc32_z(crc, buf, len) unsigned long crc; const unsigned char FAR *buf; - unsigned len; + z_size_t len; { if (buf == Z_NULL) return 0UL; @@ -230,7 +213,7 @@ unsigned long ZEXPORT crc32(crc, buf, len) #ifdef BYFOUR if (sizeof(void *) == sizeof(ptrdiff_t)) { - u4 endian; + z_crc_t endian; endian = 1; if (*((unsigned char *)(&endian))) @@ -250,8 +233,29 @@ unsigned long ZEXPORT crc32(crc, buf, len) return crc ^ 0xffffffffUL; } +/* ========================================================================= */ +unsigned long ZEXPORT crc32(crc, buf, len) + unsigned long crc; + const unsigned char FAR *buf; + uInt len; +{ + return crc32_z(crc, buf, len); +} + #ifdef BYFOUR +/* + This BYFOUR code accesses the passed unsigned char * buffer with a 32-bit + integer pointer type. This violates the strict aliasing rule, where a + compiler can assume, for optimization purposes, that two pointers to + fundamentally different types won't ever point to the same memory. This can + manifest as a problem only if one of the pointers is written to. This code + only reads from those pointers. So long as this code remains isolated in + this compilation unit, there won't be a problem. For this reason, this code + should not be copied and pasted into a compilation unit in which other code + writes to the buffer that is passed to these routines. + */ + /* ========================================================================= */ #define DOLIT4 c ^= *buf4++; \ c = crc_table[3][c & 0xff] ^ crc_table[2][(c >> 8) & 0xff] ^ \ @@ -262,19 +266,19 @@ unsigned long ZEXPORT crc32(crc, buf, len) local unsigned long crc32_little(crc, buf, len) unsigned long crc; const unsigned char FAR *buf; - unsigned len; + z_size_t len; { - register u4 c; - register const u4 FAR *buf4; + register z_crc_t c; + register const z_crc_t FAR *buf4; - c = (u4)crc; + c = (z_crc_t)crc; c = ~c; while (len && ((ptrdiff_t)buf & 3)) { c = crc_table[0][(c ^ *buf++) & 0xff] ^ (c >> 8); len--; } - buf4 = (const u4 FAR *)(const void FAR *)buf; + buf4 = (const z_crc_t FAR *)(const void FAR *)buf; while (len >= 32) { DOLIT32; len -= 32; @@ -293,7 +297,7 @@ local unsigned long crc32_little(crc, buf, len) } /* ========================================================================= */ -#define DOBIG4 c ^= *++buf4; \ +#define DOBIG4 c ^= *buf4++; \ c = crc_table[4][c & 0xff] ^ crc_table[5][(c >> 8) & 0xff] ^ \ crc_table[6][(c >> 16) & 0xff] ^ crc_table[7][c >> 24] #define DOBIG32 DOBIG4; DOBIG4; DOBIG4; DOBIG4; DOBIG4; DOBIG4; DOBIG4; DOBIG4 @@ -302,20 +306,19 @@ local unsigned long crc32_little(crc, buf, len) local unsigned long crc32_big(crc, buf, len) unsigned long crc; const unsigned char FAR *buf; - unsigned len; + z_size_t len; { - register u4 c; - register const u4 FAR *buf4; + register z_crc_t c; + register const z_crc_t FAR *buf4; - c = REV((u4)crc); + c = ZSWAP32((z_crc_t)crc); c = ~c; while (len && ((ptrdiff_t)buf & 3)) { c = crc_table[4][(c >> 24) ^ *buf++] ^ (c << 8); len--; } - buf4 = (const u4 FAR *)(const void FAR *)buf; - buf4--; + buf4 = (const z_crc_t FAR *)(const void FAR *)buf; while (len >= 32) { DOBIG32; len -= 32; @@ -324,14 +327,13 @@ local unsigned long crc32_big(crc, buf, len) DOBIG4; len -= 4; } - buf4++; buf = (const unsigned char FAR *)buf4; if (len) do { c = crc_table[4][(c >> 24) ^ *buf++] ^ (c << 8); } while (--len); c = ~c; - return (unsigned long)(REV(c)); + return (unsigned long)(ZSWAP32(c)); } #endif /* BYFOUR */ @@ -367,22 +369,22 @@ local void gf2_matrix_square(square, mat) } /* ========================================================================= */ -uLong ZEXPORT crc32_combine(crc1, crc2, len2) +local uLong crc32_combine_(crc1, crc2, len2) uLong crc1; uLong crc2; - z_off_t len2; + z_off64_t len2; { int n; unsigned long row; unsigned long even[GF2_DIM]; /* even-power-of-two zeros operator */ unsigned long odd[GF2_DIM]; /* odd-power-of-two zeros operator */ - /* degenerate case */ - if (len2 == 0) + /* degenerate case (also disallow negative lengths) */ + if (len2 <= 0) return crc1; /* put operator for one zero bit in odd */ - odd[0] = 0xedb88320L; /* CRC-32 polynomial */ + odd[0] = 0xedb88320UL; /* CRC-32 polynomial */ row = 1; for (n = 1; n < GF2_DIM; n++) { odd[n] = row; @@ -421,3 +423,20 @@ uLong ZEXPORT crc32_combine(crc1, crc2, len2) crc1 ^= crc2; return crc1; } + +/* ========================================================================= */ +uLong ZEXPORT crc32_combine(crc1, crc2, len2) + uLong crc1; + uLong crc2; + z_off_t len2; +{ + return crc32_combine_(crc1, crc2, len2); +} + +uLong ZEXPORT crc32_combine64(crc1, crc2, len2) + uLong crc1; + uLong crc2; + z_off64_t len2; +{ + return crc32_combine_(crc1, crc2, len2); +} diff --git a/zlib/crc32.h b/zlib/crc32.h index 5de49bc9..b7e25cf9 100644 --- a/zlib/crc32.h +++ b/zlib/crc32.h @@ -2,7 +2,7 @@ * Generated automatically by crc32.c */ -local const unsigned long FAR crc_table[TBLS][256] = +local const z_crc_t FAR crc_table[TBLS][256] = { { 0x00000000UL, 0x77073096UL, 0xee0e612cUL, 0x990951baUL, 0x076dc419UL, diff --git a/zlib/deflate.c b/zlib/deflate.c index 529f716b..dde73061 100644 --- a/zlib/deflate.c +++ b/zlib/deflate.c @@ -1,5 +1,5 @@ /* deflate.c -- compress data using the deflation algorithm - * Copyright (C) 1995-2005 Jean-loup Gailly. + * Copyright (C) 1995-2017 Jean-loup Gailly and Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -37,7 +37,7 @@ * REFERENCES * * Deutsch, L.P.,"DEFLATE Compressed Data Format Specification". - * Available in http://www.ietf.org/rfc/rfc1951.txt + * Available in http://tools.ietf.org/html/rfc1951 * * A description of the Rabin and Karp algorithm is given in the book * "Algorithms" by R. Sedgewick, Addison-Wesley, p252. @@ -52,7 +52,7 @@ #include "deflate.h" const char deflate_copyright[] = - " deflate 1.2.3 Copyright 1995-2005 Jean-loup Gailly "; + " deflate 1.2.11 Copyright 1995-2017 Jean-loup Gailly and Mark Adler "; /* If you use the zlib library in a product, an acknowledgment is welcome in the documentation of your product. If for some reason you cannot @@ -73,27 +73,29 @@ typedef enum { typedef block_state (*compress_func) OF((deflate_state *s, int flush)); /* Compression function. Returns the block state after the call. */ +local int deflateStateCheck OF((z_streamp strm)); +local void slide_hash OF((deflate_state *s)); local void fill_window OF((deflate_state *s)); local block_state deflate_stored OF((deflate_state *s, int flush)); local block_state deflate_fast OF((deflate_state *s, int flush)); #ifndef FASTEST local block_state deflate_slow OF((deflate_state *s, int flush)); #endif +local block_state deflate_rle OF((deflate_state *s, int flush)); +local block_state deflate_huff OF((deflate_state *s, int flush)); local void lm_init OF((deflate_state *s)); local void putShortMSB OF((deflate_state *s, uInt b)); local void flush_pending OF((z_streamp strm)); -local int read_buf OF((z_streamp strm, Bytef *buf, unsigned size)); -#ifndef FASTEST +local unsigned read_buf OF((z_streamp strm, Bytef *buf, unsigned size)); #ifdef ASMV +# pragma message("Assembler code may have bugs -- use at your own risk") void match_init OF((void)); /* asm code initialization */ uInt longest_match OF((deflate_state *s, IPos cur_match)); #else local uInt longest_match OF((deflate_state *s, IPos cur_match)); #endif -#endif -local uInt longest_match_fast OF((deflate_state *s, IPos cur_match)); -#ifdef DEBUG +#ifdef ZLIB_DEBUG local void check_match OF((deflate_state *s, IPos start, IPos match, int length)); #endif @@ -110,11 +112,6 @@ local void check_match OF((deflate_state *s, IPos start, IPos match, #endif /* Matches of length 3 are discarded if their distance exceeds TOO_FAR */ -#define MIN_LOOKAHEAD (MAX_MATCH+MIN_MATCH+1) -/* Minimum amount of lookahead, except at the end of the input file. - * See deflate.c for comments about the MIN_MATCH+1. - */ - /* Values for max_lazy_match, good_match and max_chain_length, depending on * the desired pack level (0..9). The values given below have been tuned to * exclude worst case performance for pathological files. Better values may be @@ -154,18 +151,14 @@ local const config configuration_table[10] = { * meaning. */ -#define EQUAL 0 -/* result of memcmp for equal strings */ - -#ifndef NO_DUMMY_DECL -struct static_tree_desc_s {int dummy;}; /* for buggy compilers */ -#endif +/* rank Z_BLOCK between Z_NO_FLUSH and Z_PARTIAL_FLUSH */ +#define RANK(f) (((f) * 2) - ((f) > 4 ? 9 : 0)) /* =========================================================================== * Update a hash value with the given input byte - * IN assertion: all calls to to UPDATE_HASH are made with consecutive - * input characters, so that a running hash key can be computed from the - * previous key instead of complete recalculation each time. + * IN assertion: all calls to UPDATE_HASH are made with consecutive input + * characters, so that a running hash key can be computed from the previous + * key instead of complete recalculation each time. */ #define UPDATE_HASH(s,h,c) (h = (((h)<hash_shift) ^ (c)) & s->hash_mask) @@ -176,9 +169,9 @@ struct static_tree_desc_s {int dummy;}; /* for buggy compilers */ * the previous length of the hash chain. * If this file is compiled with -DFASTEST, the compression level is forced * to 1, and no hash chains are maintained. - * IN assertion: all calls to to INSERT_STRING are made with consecutive - * input characters and the first MIN_MATCH bytes of str are valid - * (except for the last MIN_MATCH-1 bytes of the input file). + * IN assertion: all calls to INSERT_STRING are made with consecutive input + * characters and the first MIN_MATCH bytes of str are valid (except for + * the last MIN_MATCH-1 bytes of the input file). */ #ifdef FASTEST #define INSERT_STRING(s, str, match_head) \ @@ -200,6 +193,37 @@ struct static_tree_desc_s {int dummy;}; /* for buggy compilers */ s->head[s->hash_size-1] = NIL; \ zmemzero((Bytef *)s->head, (unsigned)(s->hash_size-1)*sizeof(*s->head)); +/* =========================================================================== + * Slide the hash table when sliding the window down (could be avoided with 32 + * bit values at the expense of memory usage). We slide even when level == 0 to + * keep the hash table consistent if we switch back to level > 0 later. + */ +local void slide_hash(s) + deflate_state *s; +{ + unsigned n, m; + Posf *p; + uInt wsize = s->w_size; + + n = s->hash_size; + p = &s->head[n]; + do { + m = *--p; + *p = (Pos)(m >= wsize ? m - wsize : NIL); + } while (--n); + n = wsize; +#ifndef FASTEST + p = &s->prev[n]; + do { + m = *--p; + *p = (Pos)(m >= wsize ? m - wsize : NIL); + /* If n is not on any hash chain, prev[n] is garbage but + * its value will never be used. + */ + } while (--n); +#endif +} + /* ========================================================================= */ int ZEXPORT deflateInit_(strm, level, version, stream_size) z_streamp strm; @@ -241,10 +265,19 @@ int ZEXPORT deflateInit2_(strm, level, method, windowBits, memLevel, strategy, strm->msg = Z_NULL; if (strm->zalloc == (alloc_func)0) { +#ifdef Z_SOLO + return Z_STREAM_ERROR; +#else strm->zalloc = zcalloc; strm->opaque = (voidpf)0; +#endif } - if (strm->zfree == (free_func)0) strm->zfree = zcfree; + if (strm->zfree == (free_func)0) +#ifdef Z_SOLO + return Z_STREAM_ERROR; +#else + strm->zfree = zcfree; +#endif #ifdef FASTEST if (level != 0) level = 1; @@ -264,7 +297,7 @@ int ZEXPORT deflateInit2_(strm, level, method, windowBits, memLevel, strategy, #endif if (memLevel < 1 || memLevel > MAX_MEM_LEVEL || method != Z_DEFLATED || windowBits < 8 || windowBits > 15 || level < 0 || level > 9 || - strategy < 0 || strategy > Z_FIXED) { + strategy < 0 || strategy > Z_FIXED || (windowBits == 8 && wrap != 1)) { return Z_STREAM_ERROR; } if (windowBits == 8) windowBits = 9; /* until 256-byte window bug fixed */ @@ -272,14 +305,15 @@ int ZEXPORT deflateInit2_(strm, level, method, windowBits, memLevel, strategy, if (s == Z_NULL) return Z_MEM_ERROR; strm->state = (struct internal_state FAR *)s; s->strm = strm; + s->status = INIT_STATE; /* to pass state test in deflateReset() */ s->wrap = wrap; s->gzhead = Z_NULL; - s->w_bits = windowBits; + s->w_bits = (uInt)windowBits; s->w_size = 1 << s->w_bits; s->w_mask = s->w_size - 1; - s->hash_bits = memLevel + 7; + s->hash_bits = (uInt)memLevel + 7; s->hash_size = 1 << s->hash_bits; s->hash_mask = s->hash_size - 1; s->hash_shift = ((s->hash_bits+MIN_MATCH-1)/MIN_MATCH); @@ -288,6 +322,8 @@ int ZEXPORT deflateInit2_(strm, level, method, windowBits, memLevel, strategy, s->prev = (Posf *) ZALLOC(strm, s->w_size, sizeof(Pos)); s->head = (Posf *) ZALLOC(strm, s->hash_size, sizeof(Pos)); + s->high_water = 0; /* nothing written to s->window yet */ + s->lit_bufsize = 1 << (memLevel + 6); /* 16K elements by default */ overlay = (ushf *) ZALLOC(strm, s->lit_bufsize, sizeof(ush)+2); @@ -297,7 +333,7 @@ int ZEXPORT deflateInit2_(strm, level, method, windowBits, memLevel, strategy, if (s->window == Z_NULL || s->prev == Z_NULL || s->head == Z_NULL || s->pending_buf == Z_NULL) { s->status = FINISH_STATE; - strm->msg = (char*)ERR_MSG(Z_MEM_ERROR); + strm->msg = ERR_MSG(Z_MEM_ERROR); deflateEnd (strm); return Z_MEM_ERROR; } @@ -311,6 +347,31 @@ int ZEXPORT deflateInit2_(strm, level, method, windowBits, memLevel, strategy, return deflateReset(strm); } +/* ========================================================================= + * Check for a valid deflate stream state. Return 0 if ok, 1 if not. + */ +local int deflateStateCheck (strm) + z_streamp strm; +{ + deflate_state *s; + if (strm == Z_NULL || + strm->zalloc == (alloc_func)0 || strm->zfree == (free_func)0) + return 1; + s = strm->state; + if (s == Z_NULL || s->strm != strm || (s->status != INIT_STATE && +#ifdef GZIP + s->status != GZIP_STATE && +#endif + s->status != EXTRA_STATE && + s->status != NAME_STATE && + s->status != COMMENT_STATE && + s->status != HCRC_STATE && + s->status != BUSY_STATE && + s->status != FINISH_STATE)) + return 1; + return 0; +} + /* ========================================================================= */ int ZEXPORT deflateSetDictionary (strm, dictionary, dictLength) z_streamp strm; @@ -318,49 +379,97 @@ int ZEXPORT deflateSetDictionary (strm, dictionary, dictLength) uInt dictLength; { deflate_state *s; - uInt length = dictLength; - uInt n; - IPos hash_head = 0; + uInt str, n; + int wrap; + unsigned avail; + z_const unsigned char *next; - if (strm == Z_NULL || strm->state == Z_NULL || dictionary == Z_NULL || - strm->state->wrap == 2 || - (strm->state->wrap == 1 && strm->state->status != INIT_STATE)) + if (deflateStateCheck(strm) || dictionary == Z_NULL) + return Z_STREAM_ERROR; + s = strm->state; + wrap = s->wrap; + if (wrap == 2 || (wrap == 1 && s->status != INIT_STATE) || s->lookahead) return Z_STREAM_ERROR; - s = strm->state; - if (s->wrap) + /* when using zlib wrappers, compute Adler-32 for provided dictionary */ + if (wrap == 1) strm->adler = adler32(strm->adler, dictionary, dictLength); + s->wrap = 0; /* avoid computing Adler-32 in read_buf */ - if (length < MIN_MATCH) return Z_OK; - if (length > MAX_DIST(s)) { - length = MAX_DIST(s); - dictionary += dictLength - length; /* use the tail of the dictionary */ + /* if dictionary would fill window, just replace the history */ + if (dictLength >= s->w_size) { + if (wrap == 0) { /* already empty otherwise */ + CLEAR_HASH(s); + s->strstart = 0; + s->block_start = 0L; + s->insert = 0; + } + dictionary += dictLength - s->w_size; /* use the tail */ + dictLength = s->w_size; } - zmemcpy(s->window, dictionary, length); - s->strstart = length; - s->block_start = (long)length; - /* Insert all strings in the hash table (except for the last two bytes). - * s->lookahead stays null, so s->ins_h will be recomputed at the next - * call of fill_window. - */ - s->ins_h = s->window[0]; - UPDATE_HASH(s, s->ins_h, s->window[1]); - for (n = 0; n <= length - MIN_MATCH; n++) { - INSERT_STRING(s, n, hash_head); + /* insert dictionary into window and hash */ + avail = strm->avail_in; + next = strm->next_in; + strm->avail_in = dictLength; + strm->next_in = (z_const Bytef *)dictionary; + fill_window(s); + while (s->lookahead >= MIN_MATCH) { + str = s->strstart; + n = s->lookahead - (MIN_MATCH-1); + do { + UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); +#ifndef FASTEST + s->prev[str & s->w_mask] = s->head[s->ins_h]; +#endif + s->head[s->ins_h] = (Pos)str; + str++; + } while (--n); + s->strstart = str; + s->lookahead = MIN_MATCH-1; + fill_window(s); } - if (hash_head) hash_head = 0; /* to make compiler happy */ + s->strstart += s->lookahead; + s->block_start = (long)s->strstart; + s->insert = s->lookahead; + s->lookahead = 0; + s->match_length = s->prev_length = MIN_MATCH-1; + s->match_available = 0; + strm->next_in = next; + strm->avail_in = avail; + s->wrap = wrap; return Z_OK; } /* ========================================================================= */ -int ZEXPORT deflateReset (strm) +int ZEXPORT deflateGetDictionary (strm, dictionary, dictLength) + z_streamp strm; + Bytef *dictionary; + uInt *dictLength; +{ + deflate_state *s; + uInt len; + + if (deflateStateCheck(strm)) + return Z_STREAM_ERROR; + s = strm->state; + len = s->strstart + s->lookahead; + if (len > s->w_size) + len = s->w_size; + if (dictionary != Z_NULL && len) + zmemcpy(dictionary, s->window + s->strstart + s->lookahead - len, len); + if (dictLength != Z_NULL) + *dictLength = len; + return Z_OK; +} + +/* ========================================================================= */ +int ZEXPORT deflateResetKeep (strm) z_streamp strm; { deflate_state *s; - if (strm == Z_NULL || strm->state == Z_NULL || - strm->zalloc == (alloc_func)0 || strm->zfree == (free_func)0) { + if (deflateStateCheck(strm)) { return Z_STREAM_ERROR; } @@ -375,7 +484,11 @@ int ZEXPORT deflateReset (strm) if (s->wrap < 0) { s->wrap = -s->wrap; /* was made negative by deflate(..., Z_FINISH); */ } - s->status = s->wrap ? INIT_STATE : BUSY_STATE; + s->status = +#ifdef GZIP + s->wrap == 2 ? GZIP_STATE : +#endif + s->wrap ? INIT_STATE : BUSY_STATE; strm->adler = #ifdef GZIP s->wrap == 2 ? crc32(0L, Z_NULL, 0) : @@ -384,31 +497,70 @@ int ZEXPORT deflateReset (strm) s->last_flush = Z_NO_FLUSH; _tr_init(s); - lm_init(s); return Z_OK; } +/* ========================================================================= */ +int ZEXPORT deflateReset (strm) + z_streamp strm; +{ + int ret; + + ret = deflateResetKeep(strm); + if (ret == Z_OK) + lm_init(strm->state); + return ret; +} + /* ========================================================================= */ int ZEXPORT deflateSetHeader (strm, head) z_streamp strm; gz_headerp head; { - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - if (strm->state->wrap != 2) return Z_STREAM_ERROR; + if (deflateStateCheck(strm) || strm->state->wrap != 2) + return Z_STREAM_ERROR; strm->state->gzhead = head; return Z_OK; } +/* ========================================================================= */ +int ZEXPORT deflatePending (strm, pending, bits) + unsigned *pending; + int *bits; + z_streamp strm; +{ + if (deflateStateCheck(strm)) return Z_STREAM_ERROR; + if (pending != Z_NULL) + *pending = strm->state->pending; + if (bits != Z_NULL) + *bits = strm->state->bi_valid; + return Z_OK; +} + /* ========================================================================= */ int ZEXPORT deflatePrime (strm, bits, value) z_streamp strm; int bits; int value; { - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - strm->state->bi_valid = bits; - strm->state->bi_buf = (ush)(value & ((1 << bits) - 1)); + deflate_state *s; + int put; + + if (deflateStateCheck(strm)) return Z_STREAM_ERROR; + s = strm->state; + if ((Bytef *)(s->d_buf) < s->pending_out + ((Buf_size + 7) >> 3)) + return Z_BUF_ERROR; + do { + put = Buf_size - s->bi_valid; + if (put > bits) + put = bits; + s->bi_buf |= (ush)((value & ((1 << put) - 1)) << s->bi_valid); + s->bi_valid += put; + _tr_flush_bits(s); + value >>= put; + bits -= put; + } while (bits); return Z_OK; } @@ -420,9 +572,8 @@ int ZEXPORT deflateParams(strm, level, strategy) { deflate_state *s; compress_func func; - int err = Z_OK; - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; + if (deflateStateCheck(strm)) return Z_STREAM_ERROR; s = strm->state; #ifdef FASTEST @@ -435,11 +586,23 @@ int ZEXPORT deflateParams(strm, level, strategy) } func = configuration_table[s->level].func; - if (func != configuration_table[level].func && strm->total_in != 0) { + if ((strategy != s->strategy || func != configuration_table[level].func) && + s->high_water) { /* Flush the last buffer: */ - err = deflate(strm, Z_PARTIAL_FLUSH); + int err = deflate(strm, Z_BLOCK); + if (err == Z_STREAM_ERROR) + return err; + if (strm->avail_out == 0) + return Z_BUF_ERROR; } if (s->level != level) { + if (s->level == 0 && s->matches != 0) { + if (s->matches == 1) + slide_hash(s); + else + CLEAR_HASH(s); + s->matches = 0; + } s->level = level; s->max_lazy_match = configuration_table[level].max_lazy; s->good_match = configuration_table[level].good_length; @@ -447,7 +610,7 @@ int ZEXPORT deflateParams(strm, level, strategy) s->max_chain_length = configuration_table[level].max_chain; } s->strategy = strategy; - return err; + return Z_OK; } /* ========================================================================= */ @@ -460,12 +623,12 @@ int ZEXPORT deflateTune(strm, good_length, max_lazy, nice_length, max_chain) { deflate_state *s; - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; + if (deflateStateCheck(strm)) return Z_STREAM_ERROR; s = strm->state; - s->good_match = good_length; - s->max_lazy_match = max_lazy; + s->good_match = (uInt)good_length; + s->max_lazy_match = (uInt)max_lazy; s->nice_match = nice_length; - s->max_chain_length = max_chain; + s->max_chain_length = (uInt)max_chain; return Z_OK; } @@ -481,33 +644,68 @@ int ZEXPORT deflateTune(strm, good_length, max_lazy, nice_length, max_chain) * resulting from using fixed blocks instead of stored blocks, which deflate * can emit on compressed data for some combinations of the parameters. * - * This function could be more sophisticated to provide closer upper bounds - * for every combination of windowBits and memLevel, as well as wrap. - * But even the conservative upper bound of about 14% expansion does not - * seem onerous for output buffer allocation. + * This function could be more sophisticated to provide closer upper bounds for + * every combination of windowBits and memLevel. But even the conservative + * upper bound of about 14% expansion does not seem onerous for output buffer + * allocation. */ uLong ZEXPORT deflateBound(strm, sourceLen) z_streamp strm; uLong sourceLen; { deflate_state *s; - uLong destLen; + uLong complen, wraplen; - /* conservative upper bound */ - destLen = sourceLen + - ((sourceLen + 7) >> 3) + ((sourceLen + 63) >> 6) + 11; + /* conservative upper bound for compressed data */ + complen = sourceLen + + ((sourceLen + 7) >> 3) + ((sourceLen + 63) >> 6) + 5; - /* if can't get parameters, return conservative bound */ - if (strm == Z_NULL || strm->state == Z_NULL) - return destLen; + /* if can't get parameters, return conservative bound plus zlib wrapper */ + if (deflateStateCheck(strm)) + return complen + 6; + + /* compute wrapper length */ + s = strm->state; + switch (s->wrap) { + case 0: /* raw deflate */ + wraplen = 0; + break; + case 1: /* zlib wrapper */ + wraplen = 6 + (s->strstart ? 4 : 0); + break; +#ifdef GZIP + case 2: /* gzip wrapper */ + wraplen = 18; + if (s->gzhead != Z_NULL) { /* user-supplied gzip header */ + Bytef *str; + if (s->gzhead->extra != Z_NULL) + wraplen += 2 + s->gzhead->extra_len; + str = s->gzhead->name; + if (str != Z_NULL) + do { + wraplen++; + } while (*str++); + str = s->gzhead->comment; + if (str != Z_NULL) + do { + wraplen++; + } while (*str++); + if (s->gzhead->hcrc) + wraplen += 2; + } + break; +#endif + default: /* for compiler happiness */ + wraplen = 6; + } /* if not default parameters, return conservative bound */ - s = strm->state; if (s->w_bits != 15 || s->hash_bits != 8 + 7) - return destLen; + return complen + wraplen; /* default settings: return tight bound for that case */ - return compressBound(sourceLen); + return sourceLen + (sourceLen >> 12) + (sourceLen >> 14) + + (sourceLen >> 25) + 13 - 6 + wraplen; } /* ========================================================================= @@ -524,30 +722,43 @@ local void putShortMSB (s, b) } /* ========================================================================= - * Flush as much pending output as possible. All deflate() output goes - * through this function so some applications may wish to modify it - * to avoid allocating a large strm->next_out buffer and copying into it. - * (See also read_buf()). + * Flush as much pending output as possible. All deflate() output, except for + * some deflate_stored() output, goes through this function so some + * applications may wish to modify it to avoid allocating a large + * strm->next_out buffer and copying into it. (See also read_buf()). */ local void flush_pending(strm) z_streamp strm; { - unsigned len = strm->state->pending; + unsigned len; + deflate_state *s = strm->state; + _tr_flush_bits(s); + len = s->pending; if (len > strm->avail_out) len = strm->avail_out; if (len == 0) return; - zmemcpy(strm->next_out, strm->state->pending_out, len); + zmemcpy(strm->next_out, s->pending_out, len); strm->next_out += len; - strm->state->pending_out += len; + s->pending_out += len; strm->total_out += len; - strm->avail_out -= len; - strm->state->pending -= len; - if (strm->state->pending == 0) { - strm->state->pending_out = strm->state->pending_buf; + strm->avail_out -= len; + s->pending -= len; + if (s->pending == 0) { + s->pending_out = s->pending_buf; } } +/* =========================================================================== + * Update the header CRC with the bytes s->pending_buf[beg..s->pending - 1]. + */ +#define HCRC_UPDATE(beg) \ + do { \ + if (s->gzhead->hcrc && s->pending > (beg)) \ + strm->adler = crc32(strm->adler, s->pending_buf + (beg), \ + s->pending - (beg)); \ + } while (0) + /* ========================================================================= */ int ZEXPORT deflate (strm, flush) z_streamp strm; @@ -556,203 +767,21 @@ int ZEXPORT deflate (strm, flush) int old_flush; /* value of flush param for previous deflate call */ deflate_state *s; - if (strm == Z_NULL || strm->state == Z_NULL || - flush > Z_FINISH || flush < 0) { + if (deflateStateCheck(strm) || flush > Z_BLOCK || flush < 0) { return Z_STREAM_ERROR; } s = strm->state; if (strm->next_out == Z_NULL || - (strm->next_in == Z_NULL && strm->avail_in != 0) || + (strm->avail_in != 0 && strm->next_in == Z_NULL) || (s->status == FINISH_STATE && flush != Z_FINISH)) { ERR_RETURN(strm, Z_STREAM_ERROR); } if (strm->avail_out == 0) ERR_RETURN(strm, Z_BUF_ERROR); - s->strm = strm; /* just in case */ old_flush = s->last_flush; s->last_flush = flush; - /* Write the header */ - if (s->status == INIT_STATE) { -#ifdef GZIP - if (s->wrap == 2) { - strm->adler = crc32(0L, Z_NULL, 0); - put_byte(s, 31); - put_byte(s, 139); - put_byte(s, 8); - if (s->gzhead == NULL) { - put_byte(s, 0); - put_byte(s, 0); - put_byte(s, 0); - put_byte(s, 0); - put_byte(s, 0); - put_byte(s, s->level == 9 ? 2 : - (s->strategy >= Z_HUFFMAN_ONLY || s->level < 2 ? - 4 : 0)); - put_byte(s, OS_CODE); - s->status = BUSY_STATE; - } - else { - put_byte(s, (s->gzhead->text ? 1 : 0) + - (s->gzhead->hcrc ? 2 : 0) + - (s->gzhead->extra == Z_NULL ? 0 : 4) + - (s->gzhead->name == Z_NULL ? 0 : 8) + - (s->gzhead->comment == Z_NULL ? 0 : 16) - ); - put_byte(s, (Byte)(s->gzhead->time & 0xff)); - put_byte(s, (Byte)((s->gzhead->time >> 8) & 0xff)); - put_byte(s, (Byte)((s->gzhead->time >> 16) & 0xff)); - put_byte(s, (Byte)((s->gzhead->time >> 24) & 0xff)); - put_byte(s, s->level == 9 ? 2 : - (s->strategy >= Z_HUFFMAN_ONLY || s->level < 2 ? - 4 : 0)); - put_byte(s, s->gzhead->os & 0xff); - if (s->gzhead->extra != NULL) { - put_byte(s, s->gzhead->extra_len & 0xff); - put_byte(s, (s->gzhead->extra_len >> 8) & 0xff); - } - if (s->gzhead->hcrc) - strm->adler = crc32(strm->adler, s->pending_buf, - s->pending); - s->gzindex = 0; - s->status = EXTRA_STATE; - } - } - else -#endif - { - uInt header = (Z_DEFLATED + ((s->w_bits-8)<<4)) << 8; - uInt level_flags; - - if (s->strategy >= Z_HUFFMAN_ONLY || s->level < 2) - level_flags = 0; - else if (s->level < 6) - level_flags = 1; - else if (s->level == 6) - level_flags = 2; - else - level_flags = 3; - header |= (level_flags << 6); - if (s->strstart != 0) header |= PRESET_DICT; - header += 31 - (header % 31); - - s->status = BUSY_STATE; - putShortMSB(s, header); - - /* Save the adler32 of the preset dictionary: */ - if (s->strstart != 0) { - putShortMSB(s, (uInt)(strm->adler >> 16)); - putShortMSB(s, (uInt)(strm->adler & 0xffff)); - } - strm->adler = adler32(0L, Z_NULL, 0); - } - } -#ifdef GZIP - if (s->status == EXTRA_STATE) { - if (s->gzhead->extra != NULL) { - uInt beg = s->pending; /* start of bytes to update crc */ - - while (s->gzindex < (s->gzhead->extra_len & 0xffff)) { - if (s->pending == s->pending_buf_size) { - if (s->gzhead->hcrc && s->pending > beg) - strm->adler = crc32(strm->adler, s->pending_buf + beg, - s->pending - beg); - flush_pending(strm); - beg = s->pending; - if (s->pending == s->pending_buf_size) - break; - } - put_byte(s, s->gzhead->extra[s->gzindex]); - s->gzindex++; - } - if (s->gzhead->hcrc && s->pending > beg) - strm->adler = crc32(strm->adler, s->pending_buf + beg, - s->pending - beg); - if (s->gzindex == s->gzhead->extra_len) { - s->gzindex = 0; - s->status = NAME_STATE; - } - } - else - s->status = NAME_STATE; - } - if (s->status == NAME_STATE) { - if (s->gzhead->name != NULL) { - uInt beg = s->pending; /* start of bytes to update crc */ - int val; - - do { - if (s->pending == s->pending_buf_size) { - if (s->gzhead->hcrc && s->pending > beg) - strm->adler = crc32(strm->adler, s->pending_buf + beg, - s->pending - beg); - flush_pending(strm); - beg = s->pending; - if (s->pending == s->pending_buf_size) { - val = 1; - break; - } - } - val = s->gzhead->name[s->gzindex++]; - put_byte(s, val); - } while (val != 0); - if (s->gzhead->hcrc && s->pending > beg) - strm->adler = crc32(strm->adler, s->pending_buf + beg, - s->pending - beg); - if (val == 0) { - s->gzindex = 0; - s->status = COMMENT_STATE; - } - } - else - s->status = COMMENT_STATE; - } - if (s->status == COMMENT_STATE) { - if (s->gzhead->comment != NULL) { - uInt beg = s->pending; /* start of bytes to update crc */ - int val; - - do { - if (s->pending == s->pending_buf_size) { - if (s->gzhead->hcrc && s->pending > beg) - strm->adler = crc32(strm->adler, s->pending_buf + beg, - s->pending - beg); - flush_pending(strm); - beg = s->pending; - if (s->pending == s->pending_buf_size) { - val = 1; - break; - } - } - val = s->gzhead->comment[s->gzindex++]; - put_byte(s, val); - } while (val != 0); - if (s->gzhead->hcrc && s->pending > beg) - strm->adler = crc32(strm->adler, s->pending_buf + beg, - s->pending - beg); - if (val == 0) - s->status = HCRC_STATE; - } - else - s->status = HCRC_STATE; - } - if (s->status == HCRC_STATE) { - if (s->gzhead->hcrc) { - if (s->pending + 2 > s->pending_buf_size) - flush_pending(strm); - if (s->pending + 2 <= s->pending_buf_size) { - put_byte(s, (Byte)(strm->adler & 0xff)); - put_byte(s, (Byte)((strm->adler >> 8) & 0xff)); - strm->adler = crc32(0L, Z_NULL, 0); - s->status = BUSY_STATE; - } - } - else - s->status = BUSY_STATE; - } -#endif - /* Flush as much pending output as possible */ if (s->pending != 0) { flush_pending(strm); @@ -771,7 +800,7 @@ int ZEXPORT deflate (strm, flush) * flushes. For repeated and useless calls with Z_FINISH, we keep * returning Z_STREAM_END instead of Z_BUF_ERROR. */ - } else if (strm->avail_in == 0 && flush <= old_flush && + } else if (strm->avail_in == 0 && RANK(flush) <= RANK(old_flush) && flush != Z_FINISH) { ERR_RETURN(strm, Z_BUF_ERROR); } @@ -781,13 +810,197 @@ int ZEXPORT deflate (strm, flush) ERR_RETURN(strm, Z_BUF_ERROR); } + /* Write the header */ + if (s->status == INIT_STATE) { + /* zlib header */ + uInt header = (Z_DEFLATED + ((s->w_bits-8)<<4)) << 8; + uInt level_flags; + + if (s->strategy >= Z_HUFFMAN_ONLY || s->level < 2) + level_flags = 0; + else if (s->level < 6) + level_flags = 1; + else if (s->level == 6) + level_flags = 2; + else + level_flags = 3; + header |= (level_flags << 6); + if (s->strstart != 0) header |= PRESET_DICT; + header += 31 - (header % 31); + + putShortMSB(s, header); + + /* Save the adler32 of the preset dictionary: */ + if (s->strstart != 0) { + putShortMSB(s, (uInt)(strm->adler >> 16)); + putShortMSB(s, (uInt)(strm->adler & 0xffff)); + } + strm->adler = adler32(0L, Z_NULL, 0); + s->status = BUSY_STATE; + + /* Compression must start with an empty pending buffer */ + flush_pending(strm); + if (s->pending != 0) { + s->last_flush = -1; + return Z_OK; + } + } +#ifdef GZIP + if (s->status == GZIP_STATE) { + /* gzip header */ + strm->adler = crc32(0L, Z_NULL, 0); + put_byte(s, 31); + put_byte(s, 139); + put_byte(s, 8); + if (s->gzhead == Z_NULL) { + put_byte(s, 0); + put_byte(s, 0); + put_byte(s, 0); + put_byte(s, 0); + put_byte(s, 0); + put_byte(s, s->level == 9 ? 2 : + (s->strategy >= Z_HUFFMAN_ONLY || s->level < 2 ? + 4 : 0)); + put_byte(s, OS_CODE); + s->status = BUSY_STATE; + + /* Compression must start with an empty pending buffer */ + flush_pending(strm); + if (s->pending != 0) { + s->last_flush = -1; + return Z_OK; + } + } + else { + put_byte(s, (s->gzhead->text ? 1 : 0) + + (s->gzhead->hcrc ? 2 : 0) + + (s->gzhead->extra == Z_NULL ? 0 : 4) + + (s->gzhead->name == Z_NULL ? 0 : 8) + + (s->gzhead->comment == Z_NULL ? 0 : 16) + ); + put_byte(s, (Byte)(s->gzhead->time & 0xff)); + put_byte(s, (Byte)((s->gzhead->time >> 8) & 0xff)); + put_byte(s, (Byte)((s->gzhead->time >> 16) & 0xff)); + put_byte(s, (Byte)((s->gzhead->time >> 24) & 0xff)); + put_byte(s, s->level == 9 ? 2 : + (s->strategy >= Z_HUFFMAN_ONLY || s->level < 2 ? + 4 : 0)); + put_byte(s, s->gzhead->os & 0xff); + if (s->gzhead->extra != Z_NULL) { + put_byte(s, s->gzhead->extra_len & 0xff); + put_byte(s, (s->gzhead->extra_len >> 8) & 0xff); + } + if (s->gzhead->hcrc) + strm->adler = crc32(strm->adler, s->pending_buf, + s->pending); + s->gzindex = 0; + s->status = EXTRA_STATE; + } + } + if (s->status == EXTRA_STATE) { + if (s->gzhead->extra != Z_NULL) { + ulg beg = s->pending; /* start of bytes to update crc */ + uInt left = (s->gzhead->extra_len & 0xffff) - s->gzindex; + while (s->pending + left > s->pending_buf_size) { + uInt copy = s->pending_buf_size - s->pending; + zmemcpy(s->pending_buf + s->pending, + s->gzhead->extra + s->gzindex, copy); + s->pending = s->pending_buf_size; + HCRC_UPDATE(beg); + s->gzindex += copy; + flush_pending(strm); + if (s->pending != 0) { + s->last_flush = -1; + return Z_OK; + } + beg = 0; + left -= copy; + } + zmemcpy(s->pending_buf + s->pending, + s->gzhead->extra + s->gzindex, left); + s->pending += left; + HCRC_UPDATE(beg); + s->gzindex = 0; + } + s->status = NAME_STATE; + } + if (s->status == NAME_STATE) { + if (s->gzhead->name != Z_NULL) { + ulg beg = s->pending; /* start of bytes to update crc */ + int val; + do { + if (s->pending == s->pending_buf_size) { + HCRC_UPDATE(beg); + flush_pending(strm); + if (s->pending != 0) { + s->last_flush = -1; + return Z_OK; + } + beg = 0; + } + val = s->gzhead->name[s->gzindex++]; + put_byte(s, val); + } while (val != 0); + HCRC_UPDATE(beg); + s->gzindex = 0; + } + s->status = COMMENT_STATE; + } + if (s->status == COMMENT_STATE) { + if (s->gzhead->comment != Z_NULL) { + ulg beg = s->pending; /* start of bytes to update crc */ + int val; + do { + if (s->pending == s->pending_buf_size) { + HCRC_UPDATE(beg); + flush_pending(strm); + if (s->pending != 0) { + s->last_flush = -1; + return Z_OK; + } + beg = 0; + } + val = s->gzhead->comment[s->gzindex++]; + put_byte(s, val); + } while (val != 0); + HCRC_UPDATE(beg); + } + s->status = HCRC_STATE; + } + if (s->status == HCRC_STATE) { + if (s->gzhead->hcrc) { + if (s->pending + 2 > s->pending_buf_size) { + flush_pending(strm); + if (s->pending != 0) { + s->last_flush = -1; + return Z_OK; + } + } + put_byte(s, (Byte)(strm->adler & 0xff)); + put_byte(s, (Byte)((strm->adler >> 8) & 0xff)); + strm->adler = crc32(0L, Z_NULL, 0); + } + s->status = BUSY_STATE; + + /* Compression must start with an empty pending buffer */ + flush_pending(strm); + if (s->pending != 0) { + s->last_flush = -1; + return Z_OK; + } + } +#endif + /* Start a new block or continue the current one. */ if (strm->avail_in != 0 || s->lookahead != 0 || (flush != Z_NO_FLUSH && s->status != FINISH_STATE)) { block_state bstate; - bstate = (*(configuration_table[s->level].func))(s, flush); + bstate = s->level == 0 ? deflate_stored(s, flush) : + s->strategy == Z_HUFFMAN_ONLY ? deflate_huff(s, flush) : + s->strategy == Z_RLE ? deflate_rle(s, flush) : + (*(configuration_table[s->level].func))(s, flush); if (bstate == finish_started || bstate == finish_done) { s->status = FINISH_STATE; @@ -808,13 +1021,18 @@ int ZEXPORT deflate (strm, flush) if (bstate == block_done) { if (flush == Z_PARTIAL_FLUSH) { _tr_align(s); - } else { /* FULL_FLUSH or SYNC_FLUSH */ + } else if (flush != Z_BLOCK) { /* FULL_FLUSH or SYNC_FLUSH */ _tr_stored_block(s, (char*)0, 0L, 0); /* For a full flush, this empty block will be recognized * as a special marker by inflate_sync(). */ if (flush == Z_FULL_FLUSH) { CLEAR_HASH(s); /* forget history */ + if (s->lookahead == 0) { + s->strstart = 0; + s->block_start = 0L; + s->insert = 0; + } } } flush_pending(strm); @@ -824,7 +1042,6 @@ int ZEXPORT deflate (strm, flush) } } } - Assert(strm->avail_out > 0, "bug2"); if (flush != Z_FINISH) return Z_OK; if (s->wrap <= 0) return Z_STREAM_END; @@ -861,18 +1078,9 @@ int ZEXPORT deflateEnd (strm) { int status; - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; + if (deflateStateCheck(strm)) return Z_STREAM_ERROR; status = strm->state->status; - if (status != INIT_STATE && - status != EXTRA_STATE && - status != NAME_STATE && - status != COMMENT_STATE && - status != HCRC_STATE && - status != BUSY_STATE && - status != FINISH_STATE) { - return Z_STREAM_ERROR; - } /* Deallocate in reverse order of allocations: */ TRY_FREE(strm, strm->state->pending_buf); @@ -903,18 +1111,18 @@ int ZEXPORT deflateCopy (dest, source) ushf *overlay; - if (source == Z_NULL || dest == Z_NULL || source->state == Z_NULL) { + if (deflateStateCheck(source) || dest == Z_NULL) { return Z_STREAM_ERROR; } ss = source->state; - zmemcpy(dest, source, sizeof(z_stream)); + zmemcpy((voidpf)dest, (voidpf)source, sizeof(z_stream)); ds = (deflate_state *) ZALLOC(dest, 1, sizeof(deflate_state)); if (ds == Z_NULL) return Z_MEM_ERROR; dest->state = (struct internal_state FAR *) ds; - zmemcpy(ds, ss, sizeof(deflate_state)); + zmemcpy((voidpf)ds, (voidpf)ss, sizeof(deflate_state)); ds->strm = dest; ds->window = (Bytef *) ZALLOC(dest, ds->w_size, 2*sizeof(Byte)); @@ -930,8 +1138,8 @@ int ZEXPORT deflateCopy (dest, source) } /* following zmemcpy do not work for 16-bit MSDOS */ zmemcpy(ds->window, ss->window, ds->w_size * 2 * sizeof(Byte)); - zmemcpy(ds->prev, ss->prev, ds->w_size * sizeof(Pos)); - zmemcpy(ds->head, ss->head, ds->hash_size * sizeof(Pos)); + zmemcpy((voidpf)ds->prev, (voidpf)ss->prev, ds->w_size * sizeof(Pos)); + zmemcpy((voidpf)ds->head, (voidpf)ss->head, ds->hash_size * sizeof(Pos)); zmemcpy(ds->pending_buf, ss->pending_buf, (uInt)ds->pending_buf_size); ds->pending_out = ds->pending_buf + (ss->pending_out - ss->pending_buf); @@ -953,7 +1161,7 @@ int ZEXPORT deflateCopy (dest, source) * allocating a large strm->next_in buffer and copying from it. * (See also flush_pending()). */ -local int read_buf(strm, buf, size) +local unsigned read_buf(strm, buf, size) z_streamp strm; Bytef *buf; unsigned size; @@ -965,19 +1173,19 @@ local int read_buf(strm, buf, size) strm->avail_in -= len; + zmemcpy(buf, strm->next_in, len); if (strm->state->wrap == 1) { - strm->adler = adler32(strm->adler, strm->next_in, len); + strm->adler = adler32(strm->adler, buf, len); } #ifdef GZIP else if (strm->state->wrap == 2) { - strm->adler = crc32(strm->adler, strm->next_in, len); + strm->adler = crc32(strm->adler, buf, len); } #endif - zmemcpy(buf, strm->next_in, len); strm->next_in += len; strm->total_in += len; - return (int)len; + return len; } /* =========================================================================== @@ -1000,6 +1208,7 @@ local void lm_init (s) s->strstart = 0; s->block_start = 0L; s->lookahead = 0; + s->insert = 0; s->match_length = s->prev_length = MIN_MATCH-1; s->match_available = 0; s->ins_h = 0; @@ -1030,9 +1239,9 @@ local uInt longest_match(s, cur_match) { unsigned chain_length = s->max_chain_length;/* max hash chain length */ register Bytef *scan = s->window + s->strstart; /* current string */ - register Bytef *match; /* matched string */ + register Bytef *match; /* matched string */ register int len; /* length of current match */ - int best_len = s->prev_length; /* best match length so far */ + int best_len = (int)s->prev_length; /* best match length so far */ int nice_match = s->nice_match; /* stop if match long enough */ IPos limit = s->strstart > (IPos)MAX_DIST(s) ? s->strstart - (IPos)MAX_DIST(s) : NIL; @@ -1067,7 +1276,7 @@ local uInt longest_match(s, cur_match) /* Do not look for matches beyond the end of the input. This is necessary * to make deflate deterministic. */ - if ((uInt)nice_match > s->lookahead) nice_match = s->lookahead; + if ((uInt)nice_match > s->lookahead) nice_match = (int)s->lookahead; Assert((ulg)s->strstart <= s->window_size-MIN_LOOKAHEAD, "need lookahead"); @@ -1167,12 +1376,13 @@ local uInt longest_match(s, cur_match) return s->lookahead; } #endif /* ASMV */ -#endif /* FASTEST */ + +#else /* FASTEST */ /* --------------------------------------------------------------------------- - * Optimized version for level == 1 or strategy == Z_RLE only + * Optimized version for FASTEST only */ -local uInt longest_match_fast(s, cur_match) +local uInt longest_match(s, cur_match) deflate_state *s; IPos cur_match; /* current match */ { @@ -1225,7 +1435,13 @@ local uInt longest_match_fast(s, cur_match) return (uInt)len <= s->lookahead ? (uInt)len : s->lookahead; } -#ifdef DEBUG +#endif /* FASTEST */ + +#ifdef ZLIB_DEBUG + +#define EQUAL 0 +/* result of memcmp for equal strings */ + /* =========================================================================== * Check that the match at match_start is indeed a match. */ @@ -1251,7 +1467,7 @@ local void check_match(s, start, match, length) } #else # define check_match(s, start, match, length) -#endif /* DEBUG */ +#endif /* ZLIB_DEBUG */ /* =========================================================================== * Fill the window when the lookahead becomes insufficient. @@ -1266,11 +1482,12 @@ local void check_match(s, start, match, length) local void fill_window(s) deflate_state *s; { - register unsigned n, m; - register Posf *p; + unsigned n; unsigned more; /* Amount of free space at the end of the window. */ uInt wsize = s->w_size; + Assert(s->lookahead < MIN_LOOKAHEAD, "already enough lookahead"); + do { more = (unsigned)(s->window_size -(ulg)s->lookahead -(ulg)s->strstart); @@ -1292,39 +1509,14 @@ local void fill_window(s) */ if (s->strstart >= wsize+MAX_DIST(s)) { - zmemcpy(s->window, s->window+wsize, (unsigned)wsize); + zmemcpy(s->window, s->window+wsize, (unsigned)wsize - more); s->match_start -= wsize; s->strstart -= wsize; /* we now have strstart >= MAX_DIST */ s->block_start -= (long) wsize; - - /* Slide the hash table (could be avoided with 32 bit values - at the expense of memory usage). We slide even when level == 0 - to keep the hash table consistent if we switch back to level > 0 - later. (Using level 0 permanently is not an optimal usage of - zlib, so we don't care about this pathological case.) - */ - /* %%% avoid this when Z_RLE */ - n = s->hash_size; - p = &s->head[n]; - do { - m = *--p; - *p = (Pos)(m >= wsize ? m-wsize : NIL); - } while (--n); - - n = wsize; -#ifndef FASTEST - p = &s->prev[n]; - do { - m = *--p; - *p = (Pos)(m >= wsize ? m-wsize : NIL); - /* If n is not on any hash chain, prev[n] is garbage but - * its value will never be used. - */ - } while (--n); -#endif + slide_hash(s); more += wsize; } - if (s->strm->avail_in == 0) return; + if (s->strm->avail_in == 0) break; /* If there was no sliding: * strstart <= WSIZE+MAX_DIST-1 && lookahead <= MIN_LOOKAHEAD - 1 && @@ -1343,99 +1535,283 @@ local void fill_window(s) s->lookahead += n; /* Initialize the hash value now that we have some input: */ - if (s->lookahead >= MIN_MATCH) { - s->ins_h = s->window[s->strstart]; - UPDATE_HASH(s, s->ins_h, s->window[s->strstart+1]); + if (s->lookahead + s->insert >= MIN_MATCH) { + uInt str = s->strstart - s->insert; + s->ins_h = s->window[str]; + UPDATE_HASH(s, s->ins_h, s->window[str + 1]); #if MIN_MATCH != 3 Call UPDATE_HASH() MIN_MATCH-3 more times #endif + while (s->insert) { + UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); +#ifndef FASTEST + s->prev[str & s->w_mask] = s->head[s->ins_h]; +#endif + s->head[s->ins_h] = (Pos)str; + str++; + s->insert--; + if (s->lookahead + s->insert < MIN_MATCH) + break; + } } /* If the whole input has less than MIN_MATCH bytes, ins_h is garbage, * but this is not important since only literal bytes will be emitted. */ } while (s->lookahead < MIN_LOOKAHEAD && s->strm->avail_in != 0); + + /* If the WIN_INIT bytes after the end of the current data have never been + * written, then zero those bytes in order to avoid memory check reports of + * the use of uninitialized (or uninitialised as Julian writes) bytes by + * the longest match routines. Update the high water mark for the next + * time through here. WIN_INIT is set to MAX_MATCH since the longest match + * routines allow scanning to strstart + MAX_MATCH, ignoring lookahead. + */ + if (s->high_water < s->window_size) { + ulg curr = s->strstart + (ulg)(s->lookahead); + ulg init; + + if (s->high_water < curr) { + /* Previous high water mark below current data -- zero WIN_INIT + * bytes or up to end of window, whichever is less. + */ + init = s->window_size - curr; + if (init > WIN_INIT) + init = WIN_INIT; + zmemzero(s->window + curr, (unsigned)init); + s->high_water = curr + init; + } + else if (s->high_water < (ulg)curr + WIN_INIT) { + /* High water mark at or above current data, but below current data + * plus WIN_INIT -- zero out to current data plus WIN_INIT, or up + * to end of window, whichever is less. + */ + init = (ulg)curr + WIN_INIT - s->high_water; + if (init > s->window_size - s->high_water) + init = s->window_size - s->high_water; + zmemzero(s->window + s->high_water, (unsigned)init); + s->high_water += init; + } + } + + Assert((ulg)s->strstart <= s->window_size - MIN_LOOKAHEAD, + "not enough room for search"); } /* =========================================================================== * Flush the current block, with given end-of-file flag. * IN assertion: strstart is set to the end of the current match. */ -#define FLUSH_BLOCK_ONLY(s, eof) { \ +#define FLUSH_BLOCK_ONLY(s, last) { \ _tr_flush_block(s, (s->block_start >= 0L ? \ (charf *)&s->window[(unsigned)s->block_start] : \ (charf *)Z_NULL), \ (ulg)((long)s->strstart - s->block_start), \ - (eof)); \ + (last)); \ s->block_start = s->strstart; \ flush_pending(s->strm); \ Tracev((stderr,"[FLUSH]")); \ } /* Same but force premature exit if necessary. */ -#define FLUSH_BLOCK(s, eof) { \ - FLUSH_BLOCK_ONLY(s, eof); \ - if (s->strm->avail_out == 0) return (eof) ? finish_started : need_more; \ +#define FLUSH_BLOCK(s, last) { \ + FLUSH_BLOCK_ONLY(s, last); \ + if (s->strm->avail_out == 0) return (last) ? finish_started : need_more; \ } +/* Maximum stored block length in deflate format (not including header). */ +#define MAX_STORED 65535 + +/* Minimum of a and b. */ +#define MIN(a, b) ((a) > (b) ? (b) : (a)) + /* =========================================================================== * Copy without compression as much as possible from the input stream, return * the current block state. - * This function does not insert new strings in the dictionary since - * uncompressible data is probably not useful. This function is used - * only for the level=0 compression option. - * NOTE: this function should be optimized to avoid extra copying from - * window to pending_buf. + * + * In case deflateParams() is used to later switch to a non-zero compression + * level, s->matches (otherwise unused when storing) keeps track of the number + * of hash table slides to perform. If s->matches is 1, then one hash table + * slide will be done when switching. If s->matches is 2, the maximum value + * allowed here, then the hash table will be cleared, since two or more slides + * is the same as a clear. + * + * deflate_stored() is written to minimize the number of times an input byte is + * copied. It is most efficient with large input and output buffers, which + * maximizes the opportunites to have a single copy from next_in to next_out. */ local block_state deflate_stored(s, flush) deflate_state *s; int flush; { - /* Stored blocks are limited to 0xffff bytes, pending_buf is limited - * to pending_buf_size, and each stored block has a 5 byte header: + /* Smallest worthy block size when not flushing or finishing. By default + * this is 32K. This can be as small as 507 bytes for memLevel == 1. For + * large input and output buffers, the stored block size will be larger. */ - ulg max_block_size = 0xffff; - ulg max_start; + unsigned min_block = MIN(s->pending_buf_size - 5, s->w_size); - if (max_block_size > s->pending_buf_size - 5) { - max_block_size = s->pending_buf_size - 5; - } - - /* Copy as much as possible from input to output: */ - for (;;) { - /* Fill the window as much as possible: */ - if (s->lookahead <= 1) { - - Assert(s->strstart < s->w_size+MAX_DIST(s) || - s->block_start >= (long)s->w_size, "slide too late"); - - fill_window(s); - if (s->lookahead == 0 && flush == Z_NO_FLUSH) return need_more; - - if (s->lookahead == 0) break; /* flush the current block */ - } - Assert(s->block_start >= 0L, "block gone"); - - s->strstart += s->lookahead; - s->lookahead = 0; - - /* Emit a stored block if pending_buf will be full: */ - max_start = s->block_start + max_block_size; - if (s->strstart == 0 || (ulg)s->strstart >= max_start) { - /* strstart == 0 is possible when wraparound on 16-bit machine */ - s->lookahead = (uInt)(s->strstart - max_start); - s->strstart = (uInt)max_start; - FLUSH_BLOCK(s, 0); - } - /* Flush if we may have to slide, otherwise block_start may become - * negative and the data will be gone: + /* Copy as many min_block or larger stored blocks directly to next_out as + * possible. If flushing, copy the remaining available input to next_out as + * stored blocks, if there is enough space. + */ + unsigned len, left, have, last = 0; + unsigned used = s->strm->avail_in; + do { + /* Set len to the maximum size block that we can copy directly with the + * available input data and output space. Set left to how much of that + * would be copied from what's left in the window. */ - if (s->strstart - (uInt)s->block_start >= MAX_DIST(s)) { - FLUSH_BLOCK(s, 0); + len = MAX_STORED; /* maximum deflate stored block length */ + have = (s->bi_valid + 42) >> 3; /* number of header bytes */ + if (s->strm->avail_out < have) /* need room for header */ + break; + /* maximum stored block length that will fit in avail_out: */ + have = s->strm->avail_out - have; + left = s->strstart - s->block_start; /* bytes left in window */ + if (len > (ulg)left + s->strm->avail_in) + len = left + s->strm->avail_in; /* limit len to the input */ + if (len > have) + len = have; /* limit len to the output */ + + /* If the stored block would be less than min_block in length, or if + * unable to copy all of the available input when flushing, then try + * copying to the window and the pending buffer instead. Also don't + * write an empty block when flushing -- deflate() does that. + */ + if (len < min_block && ((len == 0 && flush != Z_FINISH) || + flush == Z_NO_FLUSH || + len != left + s->strm->avail_in)) + break; + + /* Make a dummy stored block in pending to get the header bytes, + * including any pending bits. This also updates the debugging counts. + */ + last = flush == Z_FINISH && len == left + s->strm->avail_in ? 1 : 0; + _tr_stored_block(s, (char *)0, 0L, last); + + /* Replace the lengths in the dummy stored block with len. */ + s->pending_buf[s->pending - 4] = len; + s->pending_buf[s->pending - 3] = len >> 8; + s->pending_buf[s->pending - 2] = ~len; + s->pending_buf[s->pending - 1] = ~len >> 8; + + /* Write the stored block header bytes. */ + flush_pending(s->strm); + +#ifdef ZLIB_DEBUG + /* Update debugging counts for the data about to be copied. */ + s->compressed_len += len << 3; + s->bits_sent += len << 3; +#endif + + /* Copy uncompressed bytes from the window to next_out. */ + if (left) { + if (left > len) + left = len; + zmemcpy(s->strm->next_out, s->window + s->block_start, left); + s->strm->next_out += left; + s->strm->avail_out -= left; + s->strm->total_out += left; + s->block_start += left; + len -= left; } + + /* Copy uncompressed bytes directly from next_in to next_out, updating + * the check value. + */ + if (len) { + read_buf(s->strm, s->strm->next_out, len); + s->strm->next_out += len; + s->strm->avail_out -= len; + s->strm->total_out += len; + } + } while (last == 0); + + /* Update the sliding window with the last s->w_size bytes of the copied + * data, or append all of the copied data to the existing window if less + * than s->w_size bytes were copied. Also update the number of bytes to + * insert in the hash tables, in the event that deflateParams() switches to + * a non-zero compression level. + */ + used -= s->strm->avail_in; /* number of input bytes directly copied */ + if (used) { + /* If any input was used, then no unused input remains in the window, + * therefore s->block_start == s->strstart. + */ + if (used >= s->w_size) { /* supplant the previous history */ + s->matches = 2; /* clear hash */ + zmemcpy(s->window, s->strm->next_in - s->w_size, s->w_size); + s->strstart = s->w_size; + } + else { + if (s->window_size - s->strstart <= used) { + /* Slide the window down. */ + s->strstart -= s->w_size; + zmemcpy(s->window, s->window + s->w_size, s->strstart); + if (s->matches < 2) + s->matches++; /* add a pending slide_hash() */ + } + zmemcpy(s->window + s->strstart, s->strm->next_in - used, used); + s->strstart += used; + } + s->block_start = s->strstart; + s->insert += MIN(used, s->w_size - s->insert); } - FLUSH_BLOCK(s, flush == Z_FINISH); - return flush == Z_FINISH ? finish_done : block_done; + if (s->high_water < s->strstart) + s->high_water = s->strstart; + + /* If the last block was written to next_out, then done. */ + if (last) + return finish_done; + + /* If flushing and all input has been consumed, then done. */ + if (flush != Z_NO_FLUSH && flush != Z_FINISH && + s->strm->avail_in == 0 && (long)s->strstart == s->block_start) + return block_done; + + /* Fill the window with any remaining input. */ + have = s->window_size - s->strstart - 1; + if (s->strm->avail_in > have && s->block_start >= (long)s->w_size) { + /* Slide the window down. */ + s->block_start -= s->w_size; + s->strstart -= s->w_size; + zmemcpy(s->window, s->window + s->w_size, s->strstart); + if (s->matches < 2) + s->matches++; /* add a pending slide_hash() */ + have += s->w_size; /* more space now */ + } + if (have > s->strm->avail_in) + have = s->strm->avail_in; + if (have) { + read_buf(s->strm, s->window + s->strstart, have); + s->strstart += have; + } + if (s->high_water < s->strstart) + s->high_water = s->strstart; + + /* There was not enough avail_out to write a complete worthy or flushed + * stored block to next_out. Write a stored block to pending instead, if we + * have enough input for a worthy block, or if flushing and there is enough + * room for the remaining input as a stored block in the pending buffer. + */ + have = (s->bi_valid + 42) >> 3; /* number of header bytes */ + /* maximum stored block length that will fit in pending: */ + have = MIN(s->pending_buf_size - have, MAX_STORED); + min_block = MIN(have, s->w_size); + left = s->strstart - s->block_start; + if (left >= min_block || + ((left || flush == Z_FINISH) && flush != Z_NO_FLUSH && + s->strm->avail_in == 0 && left <= have)) { + len = MIN(left, have); + last = flush == Z_FINISH && s->strm->avail_in == 0 && + len == left ? 1 : 0; + _tr_stored_block(s, (charf *)s->window + s->block_start, len, last); + s->block_start += len; + flush_pending(s->strm); + } + + /* We've done all we can with the available input and output. */ + return last ? finish_started : need_more; } /* =========================================================================== @@ -1449,7 +1825,7 @@ local block_state deflate_fast(s, flush) deflate_state *s; int flush; { - IPos hash_head = NIL; /* head of the hash chain */ + IPos hash_head; /* head of the hash chain */ int bflush; /* set if current block must be flushed */ for (;;) { @@ -1469,6 +1845,7 @@ local block_state deflate_fast(s, flush) /* Insert the string window[strstart .. strstart+2] in the * dictionary, and set hash_head to the head of the hash chain: */ + hash_head = NIL; if (s->lookahead >= MIN_MATCH) { INSERT_STRING(s, s->strstart, hash_head); } @@ -1481,19 +1858,8 @@ local block_state deflate_fast(s, flush) * of window index 0 (in particular we have to avoid a match * of the string with itself at the start of the input file). */ -#ifdef FASTEST - if ((s->strategy != Z_HUFFMAN_ONLY && s->strategy != Z_RLE) || - (s->strategy == Z_RLE && s->strstart - hash_head == 1)) { - s->match_length = longest_match_fast (s, hash_head); - } -#else - if (s->strategy != Z_HUFFMAN_ONLY && s->strategy != Z_RLE) { - s->match_length = longest_match (s, hash_head); - } else if (s->strategy == Z_RLE && s->strstart - hash_head == 1) { - s->match_length = longest_match_fast (s, hash_head); - } -#endif - /* longest_match() or longest_match_fast() sets match_start */ + s->match_length = longest_match (s, hash_head); + /* longest_match() sets match_start */ } if (s->match_length >= MIN_MATCH) { check_match(s, s->strstart, s->match_start, s->match_length); @@ -1541,8 +1907,14 @@ local block_state deflate_fast(s, flush) } if (bflush) FLUSH_BLOCK(s, 0); } - FLUSH_BLOCK(s, flush == Z_FINISH); - return flush == Z_FINISH ? finish_done : block_done; + s->insert = s->strstart < MIN_MATCH-1 ? s->strstart : MIN_MATCH-1; + if (flush == Z_FINISH) { + FLUSH_BLOCK(s, 1); + return finish_done; + } + if (s->last_lit) + FLUSH_BLOCK(s, 0); + return block_done; } #ifndef FASTEST @@ -1555,7 +1927,7 @@ local block_state deflate_slow(s, flush) deflate_state *s; int flush; { - IPos hash_head = NIL; /* head of hash chain */ + IPos hash_head; /* head of hash chain */ int bflush; /* set if current block must be flushed */ /* Process the input block. */ @@ -1576,6 +1948,7 @@ local block_state deflate_slow(s, flush) /* Insert the string window[strstart .. strstart+2] in the * dictionary, and set hash_head to the head of the hash chain: */ + hash_head = NIL; if (s->lookahead >= MIN_MATCH) { INSERT_STRING(s, s->strstart, hash_head); } @@ -1591,12 +1964,8 @@ local block_state deflate_slow(s, flush) * of window index 0 (in particular we have to avoid a match * of the string with itself at the start of the input file). */ - if (s->strategy != Z_HUFFMAN_ONLY && s->strategy != Z_RLE) { - s->match_length = longest_match (s, hash_head); - } else if (s->strategy == Z_RLE && s->strstart - hash_head == 1) { - s->match_length = longest_match_fast (s, hash_head); - } - /* longest_match() or longest_match_fast() sets match_start */ + s->match_length = longest_match (s, hash_head); + /* longest_match() sets match_start */ if (s->match_length <= 5 && (s->strategy == Z_FILTERED #if TOO_FAR <= 32767 @@ -1669,12 +2038,17 @@ local block_state deflate_slow(s, flush) _tr_tally_lit(s, s->window[s->strstart-1], bflush); s->match_available = 0; } - FLUSH_BLOCK(s, flush == Z_FINISH); - return flush == Z_FINISH ? finish_done : block_done; + s->insert = s->strstart < MIN_MATCH-1 ? s->strstart : MIN_MATCH-1; + if (flush == Z_FINISH) { + FLUSH_BLOCK(s, 1); + return finish_done; + } + if (s->last_lit) + FLUSH_BLOCK(s, 0); + return block_done; } #endif /* FASTEST */ -#if 0 /* =========================================================================== * For Z_RLE, simply look for runs of bytes, generate matches only of distance * one. Do not maintain a hash table. (It will be regenerated if this run of @@ -1684,43 +2058,52 @@ local block_state deflate_rle(s, flush) deflate_state *s; int flush; { - int bflush; /* set if current block must be flushed */ - uInt run; /* length of run */ - uInt max; /* maximum length of run */ - uInt prev; /* byte at distance one to match */ - Bytef *scan; /* scan for end of run */ + int bflush; /* set if current block must be flushed */ + uInt prev; /* byte at distance one to match */ + Bytef *scan, *strend; /* scan goes up to strend for length of run */ for (;;) { /* Make sure that we always have enough lookahead, except * at the end of the input file. We need MAX_MATCH bytes - * for the longest encodable run. + * for the longest run, plus one for the unrolled loop. */ - if (s->lookahead < MAX_MATCH) { + if (s->lookahead <= MAX_MATCH) { fill_window(s); - if (s->lookahead < MAX_MATCH && flush == Z_NO_FLUSH) { + if (s->lookahead <= MAX_MATCH && flush == Z_NO_FLUSH) { return need_more; } if (s->lookahead == 0) break; /* flush the current block */ } /* See how many times the previous byte repeats */ - run = 0; - if (s->strstart > 0) { /* if there is a previous byte, that is */ - max = s->lookahead < MAX_MATCH ? s->lookahead : MAX_MATCH; + s->match_length = 0; + if (s->lookahead >= MIN_MATCH && s->strstart > 0) { scan = s->window + s->strstart - 1; - prev = *scan++; - do { - if (*scan++ != prev) - break; - } while (++run < max); + prev = *scan; + if (prev == *++scan && prev == *++scan && prev == *++scan) { + strend = s->window + s->strstart + MAX_MATCH; + do { + } while (prev == *++scan && prev == *++scan && + prev == *++scan && prev == *++scan && + prev == *++scan && prev == *++scan && + prev == *++scan && prev == *++scan && + scan < strend); + s->match_length = MAX_MATCH - (uInt)(strend - scan); + if (s->match_length > s->lookahead) + s->match_length = s->lookahead; + } + Assert(scan <= s->window+(uInt)(s->window_size-1), "wild scan"); } /* Emit match if have run of MIN_MATCH or longer, else emit literal */ - if (run >= MIN_MATCH) { - check_match(s, s->strstart, s->strstart - 1, run); - _tr_tally_dist(s, 1, run - MIN_MATCH, bflush); - s->lookahead -= run; - s->strstart += run; + if (s->match_length >= MIN_MATCH) { + check_match(s, s->strstart, s->strstart - 1, s->match_length); + + _tr_tally_dist(s, 1, s->match_length - MIN_MATCH, bflush); + + s->lookahead -= s->match_length; + s->strstart += s->match_length; + s->match_length = 0; } else { /* No match, output a literal byte */ Tracevv((stderr,"%c", s->window[s->strstart])); @@ -1730,7 +2113,51 @@ local block_state deflate_rle(s, flush) } if (bflush) FLUSH_BLOCK(s, 0); } - FLUSH_BLOCK(s, flush == Z_FINISH); - return flush == Z_FINISH ? finish_done : block_done; + s->insert = 0; + if (flush == Z_FINISH) { + FLUSH_BLOCK(s, 1); + return finish_done; + } + if (s->last_lit) + FLUSH_BLOCK(s, 0); + return block_done; +} + +/* =========================================================================== + * For Z_HUFFMAN_ONLY, do not look for matches. Do not maintain a hash table. + * (It will be regenerated if this run of deflate switches away from Huffman.) + */ +local block_state deflate_huff(s, flush) + deflate_state *s; + int flush; +{ + int bflush; /* set if current block must be flushed */ + + for (;;) { + /* Make sure that we have a literal to write. */ + if (s->lookahead == 0) { + fill_window(s); + if (s->lookahead == 0) { + if (flush == Z_NO_FLUSH) + return need_more; + break; /* flush the current block */ + } + } + + /* Output a literal byte */ + s->match_length = 0; + Tracevv((stderr,"%c", s->window[s->strstart])); + _tr_tally_lit (s, s->window[s->strstart], bflush); + s->lookahead--; + s->strstart++; + if (bflush) FLUSH_BLOCK(s, 0); + } + s->insert = 0; + if (flush == Z_FINISH) { + FLUSH_BLOCK(s, 1); + return finish_done; + } + if (s->last_lit) + FLUSH_BLOCK(s, 0); + return block_done; } -#endif diff --git a/zlib/deflate.h b/zlib/deflate.h index 222c53e0..a1c7f601 100644 --- a/zlib/deflate.h +++ b/zlib/deflate.h @@ -1,5 +1,5 @@ /* deflate.h -- internal compression state - * Copyright (C) 1995-2004 Jean-loup Gailly + * Copyright (C) 1995-2016 Jean-loup Gailly * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -48,13 +48,19 @@ #define MAX_BITS 15 /* All codes must not exceed MAX_BITS bits */ -#define INIT_STATE 42 -#define EXTRA_STATE 69 -#define NAME_STATE 73 -#define COMMENT_STATE 91 -#define HCRC_STATE 103 -#define BUSY_STATE 113 -#define FINISH_STATE 666 +#define Buf_size 16 +/* size of bit buffer in bi_buf */ + +#define INIT_STATE 42 /* zlib header -> BUSY_STATE */ +#ifdef GZIP +# define GZIP_STATE 57 /* gzip header -> BUSY_STATE | EXTRA_STATE */ +#endif +#define EXTRA_STATE 69 /* gzip extra block -> NAME_STATE */ +#define NAME_STATE 73 /* gzip file name -> COMMENT_STATE */ +#define COMMENT_STATE 91 /* gzip comment -> HCRC_STATE */ +#define HCRC_STATE 103 /* gzip header CRC -> BUSY_STATE */ +#define BUSY_STATE 113 /* deflate -> FINISH_STATE */ +#define FINISH_STATE 666 /* stream complete */ /* Stream status */ @@ -80,7 +86,7 @@ typedef struct static_tree_desc_s static_tree_desc; typedef struct tree_desc_s { ct_data *dyn_tree; /* the dynamic tree */ int max_code; /* largest code with non zero frequency */ - static_tree_desc *stat_desc; /* the corresponding static tree */ + const static_tree_desc *stat_desc; /* the corresponding static tree */ } FAR tree_desc; typedef ush Pos; @@ -97,11 +103,11 @@ typedef struct internal_state { Bytef *pending_buf; /* output still pending */ ulg pending_buf_size; /* size of pending_buf */ Bytef *pending_out; /* next pending byte to output to the stream */ - uInt pending; /* nb of bytes in the pending buffer */ + ulg pending; /* nb of bytes in the pending buffer */ int wrap; /* bit 0 true for zlib, bit 1 true for gzip */ gz_headerp gzhead; /* gzip header information to write */ - uInt gzindex; /* where in extra, name, or comment */ - Byte method; /* STORED (for zip only) or DEFLATED */ + ulg gzindex; /* where in extra, name, or comment */ + Byte method; /* can only be DEFLATED */ int last_flush; /* value of flush param for previous deflate call */ /* used by deflate.c: */ @@ -188,7 +194,7 @@ typedef struct internal_state { int nice_match; /* Stop searching when current match exceeds this */ /* used by trees.c: */ - /* Didn't use ct_data typedef below to supress compiler warning */ + /* Didn't use ct_data typedef below to suppress compiler warning */ struct ct_data_s dyn_ltree[HEAP_SIZE]; /* literal and length tree */ struct ct_data_s dyn_dtree[2*D_CODES+1]; /* distance tree */ struct ct_data_s bl_tree[2*BL_CODES+1]; /* Huffman tree for bit lengths */ @@ -244,9 +250,9 @@ typedef struct internal_state { ulg opt_len; /* bit length of current block with optimal trees */ ulg static_len; /* bit length of current block with static trees */ uInt matches; /* number of string matches in current block */ - int last_eob_len; /* bit length of EOB code for last block */ + uInt insert; /* bytes at end of window left to insert */ -#ifdef DEBUG +#ifdef ZLIB_DEBUG ulg compressed_len; /* total bit length of compressed file mod 2^32 */ ulg bits_sent; /* bit length of compressed data sent mod 2^32 */ #endif @@ -260,12 +266,19 @@ typedef struct internal_state { * are always zero. */ + ulg high_water; + /* High water mark offset in window for initialized bytes -- bytes above + * this are set to zero in order to avoid memory check warnings when + * longest match routines access bytes past the input. This is then + * updated to the new high water mark. + */ + } FAR deflate_state; /* Output a byte on the stream. * IN assertion: there is enough room in pending_buf. */ -#define put_byte(s, c) {s->pending_buf[s->pending++] = (c);} +#define put_byte(s, c) {s->pending_buf[s->pending++] = (Bytef)(c);} #define MIN_LOOKAHEAD (MAX_MATCH+MIN_MATCH+1) @@ -278,14 +291,19 @@ typedef struct internal_state { * distances are limited to MAX_DIST instead of WSIZE. */ +#define WIN_INIT MAX_MATCH +/* Number of bytes after end of data in window to initialize in order to avoid + memory checker errors from longest match routines */ + /* in trees.c */ -void _tr_init OF((deflate_state *s)); -int _tr_tally OF((deflate_state *s, unsigned dist, unsigned lc)); -void _tr_flush_block OF((deflate_state *s, charf *buf, ulg stored_len, - int eof)); -void _tr_align OF((deflate_state *s)); -void _tr_stored_block OF((deflate_state *s, charf *buf, ulg stored_len, - int eof)); +void ZLIB_INTERNAL _tr_init OF((deflate_state *s)); +int ZLIB_INTERNAL _tr_tally OF((deflate_state *s, unsigned dist, unsigned lc)); +void ZLIB_INTERNAL _tr_flush_block OF((deflate_state *s, charf *buf, + ulg stored_len, int last)); +void ZLIB_INTERNAL _tr_flush_bits OF((deflate_state *s)); +void ZLIB_INTERNAL _tr_align OF((deflate_state *s)); +void ZLIB_INTERNAL _tr_stored_block OF((deflate_state *s, charf *buf, + ulg stored_len, int last)); #define d_code(dist) \ ((dist) < 256 ? _dist_code[dist] : _dist_code[256+((dist)>>7)]) @@ -294,15 +312,15 @@ void _tr_stored_block OF((deflate_state *s, charf *buf, ulg stored_len, * used. */ -#ifndef DEBUG +#ifndef ZLIB_DEBUG /* Inline versions of _tr_tally for speed: */ #if defined(GEN_TREES_H) || !defined(STDC) - extern uch _length_code[]; - extern uch _dist_code[]; + extern uch ZLIB_INTERNAL _length_code[]; + extern uch ZLIB_INTERNAL _dist_code[]; #else - extern const uch _length_code[]; - extern const uch _dist_code[]; + extern const uch ZLIB_INTERNAL _length_code[]; + extern const uch ZLIB_INTERNAL _dist_code[]; #endif # define _tr_tally_lit(s, c, flush) \ @@ -313,8 +331,8 @@ void _tr_stored_block OF((deflate_state *s, charf *buf, ulg stored_len, flush = (s->last_lit == s->lit_bufsize-1); \ } # define _tr_tally_dist(s, distance, length, flush) \ - { uch len = (length); \ - ush dist = (distance); \ + { uch len = (uch)(length); \ + ush dist = (ush)(distance); \ s->d_buf[s->last_lit] = dist; \ s->l_buf[s->last_lit++] = len; \ dist--; \ diff --git a/zlib/gzclose.c b/zlib/gzclose.c new file mode 100644 index 00000000..cbf0db66 --- /dev/null +++ b/zlib/gzclose.c @@ -0,0 +1,25 @@ +/* gzclose.c -- zlib gzclose() function + * Copyright (C) 2004, 2010 Mark Adler + * For conditions of distribution and use, see copyright notice in zlib.h + */ + +#include "gzguts.h" + +/* gzclose() is in a separate file so that it is linked in only if it is used. + That way the other gzclose functions can be used instead to avoid linking in + unneeded compression or decompression routines. */ +int ZEXPORT gzclose(file) + gzFile file; +{ +#ifndef NO_GZCOMPRESS + gz_statep state; + + if (file == NULL) + return Z_STREAM_ERROR; + state = (gz_statep)file; + + return state->mode == GZ_READ ? gzclose_r(file) : gzclose_w(file); +#else + return gzclose_r(file); +#endif +} diff --git a/zlib/gzguts.h b/zlib/gzguts.h new file mode 100644 index 00000000..581c6279 --- /dev/null +++ b/zlib/gzguts.h @@ -0,0 +1,218 @@ +/* gzguts.h -- zlib internal header definitions for gz* operations + * Copyright (C) 2004, 2005, 2010, 2011, 2012, 2013, 2016 Mark Adler + * For conditions of distribution and use, see copyright notice in zlib.h + */ + +#ifdef _LARGEFILE64_SOURCE +# ifndef _LARGEFILE_SOURCE +# define _LARGEFILE_SOURCE 1 +# endif +# ifdef _FILE_OFFSET_BITS +# undef _FILE_OFFSET_BITS +# endif +#endif + +#ifdef HAVE_HIDDEN +# define ZLIB_INTERNAL __attribute__((visibility ("hidden"))) +#else +# define ZLIB_INTERNAL +#endif + +#include +#include "zlib.h" +#ifdef STDC +# include +# include +# include +#endif + +#ifndef _POSIX_SOURCE +# define _POSIX_SOURCE +#endif +#include + +#ifdef _WIN32 +# include +#endif + +#if defined(__TURBOC__) || defined(_MSC_VER) || defined(_WIN32) +# include +#endif + +#if defined(_WIN32) || defined(__CYGWIN__) +# define WIDECHAR +#endif + +#ifdef WINAPI_FAMILY +# define open _open +# define read _read +# define write _write +# define close _close +#endif + +#ifdef NO_DEFLATE /* for compatibility with old definition */ +# define NO_GZCOMPRESS +#endif + +#if defined(STDC99) || (defined(__TURBOC__) && __TURBOC__ >= 0x550) +# ifndef HAVE_VSNPRINTF +# define HAVE_VSNPRINTF +# endif +#endif + +#if defined(__CYGWIN__) +# ifndef HAVE_VSNPRINTF +# define HAVE_VSNPRINTF +# endif +#endif + +#if defined(MSDOS) && defined(__BORLANDC__) && (BORLANDC > 0x410) +# ifndef HAVE_VSNPRINTF +# define HAVE_VSNPRINTF +# endif +#endif + +#ifndef HAVE_VSNPRINTF +# ifdef MSDOS +/* vsnprintf may exist on some MS-DOS compilers (DJGPP?), + but for now we just assume it doesn't. */ +# define NO_vsnprintf +# endif +# ifdef __TURBOC__ +# define NO_vsnprintf +# endif +# ifdef WIN32 +/* In Win32, vsnprintf is available as the "non-ANSI" _vsnprintf. */ +# if !defined(vsnprintf) && !defined(NO_vsnprintf) +# if !defined(_MSC_VER) || ( defined(_MSC_VER) && _MSC_VER < 1500 ) +# define vsnprintf _vsnprintf +# endif +# endif +# endif +# ifdef __SASC +# define NO_vsnprintf +# endif +# ifdef VMS +# define NO_vsnprintf +# endif +# ifdef __OS400__ +# define NO_vsnprintf +# endif +# ifdef __MVS__ +# define NO_vsnprintf +# endif +#endif + +/* unlike snprintf (which is required in C99), _snprintf does not guarantee + null termination of the result -- however this is only used in gzlib.c where + the result is assured to fit in the space provided */ +#if defined(_MSC_VER) && _MSC_VER < 1900 +# define snprintf _snprintf +#endif + +#ifndef local +# define local static +#endif +/* since "static" is used to mean two completely different things in C, we + define "local" for the non-static meaning of "static", for readability + (compile with -Dlocal if your debugger can't find static symbols) */ + +/* gz* functions always use library allocation functions */ +#ifndef STDC + extern voidp malloc OF((uInt size)); + extern void free OF((voidpf ptr)); +#endif + +/* get errno and strerror definition */ +#if defined UNDER_CE +# include +# define zstrerror() gz_strwinerror((DWORD)GetLastError()) +#else +# ifndef NO_STRERROR +# include +# define zstrerror() strerror(errno) +# else +# define zstrerror() "stdio error (consult errno)" +# endif +#endif + +/* provide prototypes for these when building zlib without LFS */ +#if !defined(_LARGEFILE64_SOURCE) || _LFS64_LARGEFILE-0 == 0 + ZEXTERN gzFile ZEXPORT gzopen64 OF((const char *, const char *)); + ZEXTERN z_off64_t ZEXPORT gzseek64 OF((gzFile, z_off64_t, int)); + ZEXTERN z_off64_t ZEXPORT gztell64 OF((gzFile)); + ZEXTERN z_off64_t ZEXPORT gzoffset64 OF((gzFile)); +#endif + +/* default memLevel */ +#if MAX_MEM_LEVEL >= 8 +# define DEF_MEM_LEVEL 8 +#else +# define DEF_MEM_LEVEL MAX_MEM_LEVEL +#endif + +/* default i/o buffer size -- double this for output when reading (this and + twice this must be able to fit in an unsigned type) */ +#define GZBUFSIZE 8192 + +/* gzip modes, also provide a little integrity check on the passed structure */ +#define GZ_NONE 0 +#define GZ_READ 7247 +#define GZ_WRITE 31153 +#define GZ_APPEND 1 /* mode set to GZ_WRITE after the file is opened */ + +/* values for gz_state how */ +#define LOOK 0 /* look for a gzip header */ +#define COPY 1 /* copy input directly */ +#define GZIP 2 /* decompress a gzip stream */ + +/* internal gzip file state data structure */ +typedef struct { + /* exposed contents for gzgetc() macro */ + struct gzFile_s x; /* "x" for exposed */ + /* x.have: number of bytes available at x.next */ + /* x.next: next output data to deliver or write */ + /* x.pos: current position in uncompressed data */ + /* used for both reading and writing */ + int mode; /* see gzip modes above */ + int fd; /* file descriptor */ + char *path; /* path or fd for error messages */ + unsigned size; /* buffer size, zero if not allocated yet */ + unsigned want; /* requested buffer size, default is GZBUFSIZE */ + unsigned char *in; /* input buffer (double-sized when writing) */ + unsigned char *out; /* output buffer (double-sized when reading) */ + int direct; /* 0 if processing gzip, 1 if transparent */ + /* just for reading */ + int how; /* 0: get header, 1: copy, 2: decompress */ + z_off64_t start; /* where the gzip data started, for rewinding */ + int eof; /* true if end of input file reached */ + int past; /* true if read requested past end */ + /* just for writing */ + int level; /* compression level */ + int strategy; /* compression strategy */ + /* seek request */ + z_off64_t skip; /* amount to skip (already rewound if backwards) */ + int seek; /* true if seek request pending */ + /* error information */ + int err; /* error code */ + char *msg; /* error message */ + /* zlib inflate or deflate stream */ + z_stream strm; /* stream structure in-place (not a pointer) */ +} gz_state; +typedef gz_state FAR *gz_statep; + +/* shared functions */ +void ZLIB_INTERNAL gz_error OF((gz_statep, int, const char *)); +#if defined UNDER_CE +char ZLIB_INTERNAL *gz_strwinerror OF((DWORD error)); +#endif + +/* GT_OFF(x), where x is an unsigned value, is true if x > maximum z_off64_t + value -- needed when comparing unsigned to z_off64_t, which is signed + (possible z_off64_t types off_t, off64_t, and long are all signed) */ +#ifdef INT_MAX +# define GT_OFF(x) (sizeof(int) == sizeof(z_off64_t) && (x) > INT_MAX) +#else +unsigned ZLIB_INTERNAL gz_intmax OF((void)); +# define GT_OFF(x) (sizeof(int) == sizeof(z_off64_t) && (x) > gz_intmax()) +#endif diff --git a/zlib/gzio.c b/zlib/gzio.c deleted file mode 100644 index 5e20a4aa..00000000 --- a/zlib/gzio.c +++ /dev/null @@ -1,1026 +0,0 @@ -/* gzio.c -- IO on .gz files - * Copyright (C) 1995-2005 Jean-loup Gailly. - * For conditions of distribution and use, see copyright notice in zlib.h - * - * Compile this file with -DNO_GZCOMPRESS to avoid the compression code. - */ - -/* @(#) $Id$ */ - -#include - -#include "zutil.h" - -#ifdef NO_DEFLATE /* for compatibility with old definition */ -# define NO_GZCOMPRESS -#endif - -#ifndef NO_DUMMY_DECL -struct internal_state {int dummy;}; /* for buggy compilers */ -#endif - -#ifndef Z_BUFSIZE -# ifdef MAXSEG_64K -# define Z_BUFSIZE 4096 /* minimize memory usage for 16-bit DOS */ -# else -# define Z_BUFSIZE 16384 -# endif -#endif -#ifndef Z_PRINTF_BUFSIZE -# define Z_PRINTF_BUFSIZE 4096 -#endif - -#ifdef __MVS__ -# pragma map (fdopen , "\174\174FDOPEN") - FILE *fdopen(int, const char *); -#endif - -#ifndef STDC -extern voidp malloc OF((uInt size)); -extern void free OF((voidpf ptr)); -#endif - -#define ALLOC(size) malloc(size) -#define TRYFREE(p) {if (p) free(p);} - -static int const gz_magic[2] = {0x1f, 0x8b}; /* gzip magic header */ - -/* gzip flag byte */ -#define ASCII_FLAG 0x01 /* bit 0 set: file probably ascii text */ -#define HEAD_CRC 0x02 /* bit 1 set: header CRC present */ -#define EXTRA_FIELD 0x04 /* bit 2 set: extra field present */ -#define ORIG_NAME 0x08 /* bit 3 set: original file name present */ -#define COMMENT 0x10 /* bit 4 set: file comment present */ -#define RESERVED 0xE0 /* bits 5..7: reserved */ - -typedef struct gz_stream { - z_stream stream; - int z_err; /* error code for last stream operation */ - int z_eof; /* set if end of input file */ - FILE *file; /* .gz file */ - Byte *inbuf; /* input buffer */ - Byte *outbuf; /* output buffer */ - uLong crc; /* crc32 of uncompressed data */ - char *msg; /* error message */ - char *path; /* path name for debugging only */ - int transparent; /* 1 if input file is not a .gz file */ - char mode; /* 'w' or 'r' */ - z_off_t start; /* start of compressed data in file (header skipped) */ - z_off_t in; /* bytes into deflate or inflate */ - z_off_t out; /* bytes out of deflate or inflate */ - int back; /* one character push-back */ - int last; /* true if push-back is last character */ -} gz_stream; - - -local gzFile gz_open OF((const char *path, const char *mode, int fd)); -local int do_flush OF((gzFile file, int flush)); -local int get_byte OF((gz_stream *s)); -local void check_header OF((gz_stream *s)); -local int destroy OF((gz_stream *s)); -local void putLong OF((FILE *file, uLong x)); -local uLong getLong OF((gz_stream *s)); - -/* =========================================================================== - Opens a gzip (.gz) file for reading or writing. The mode parameter - is as in fopen ("rb" or "wb"). The file is given either by file descriptor - or path name (if fd == -1). - gz_open returns NULL if the file could not be opened or if there was - insufficient memory to allocate the (de)compression state; errno - can be checked to distinguish the two cases (if errno is zero, the - zlib error is Z_MEM_ERROR). -*/ -local gzFile gz_open (path, mode, fd) - const char *path; - const char *mode; - int fd; -{ - int err; - int level = Z_DEFAULT_COMPRESSION; /* compression level */ - int strategy = Z_DEFAULT_STRATEGY; /* compression strategy */ - char *p = (char*)mode; - gz_stream *s; - char fmode[80]; /* copy of mode, without the compression level */ - char *m = fmode; - - if (!path || !mode) return Z_NULL; - - s = (gz_stream *)ALLOC(sizeof(gz_stream)); - if (!s) return Z_NULL; - - s->stream.zalloc = (alloc_func)0; - s->stream.zfree = (free_func)0; - s->stream.opaque = (voidpf)0; - s->stream.next_in = s->inbuf = Z_NULL; - s->stream.next_out = s->outbuf = Z_NULL; - s->stream.avail_in = s->stream.avail_out = 0; - s->file = NULL; - s->z_err = Z_OK; - s->z_eof = 0; - s->in = 0; - s->out = 0; - s->back = EOF; - s->crc = crc32(0L, Z_NULL, 0); - s->msg = NULL; - s->transparent = 0; - - s->path = (char*)ALLOC(strlen(path)+1); - if (s->path == NULL) { - return destroy(s), (gzFile)Z_NULL; - } - strcpy(s->path, path); /* do this early for debugging */ - - s->mode = '\0'; - do { - if (*p == 'r') s->mode = 'r'; - if (*p == 'w' || *p == 'a') s->mode = 'w'; - if (*p >= '0' && *p <= '9') { - level = *p - '0'; - } else if (*p == 'f') { - strategy = Z_FILTERED; - } else if (*p == 'h') { - strategy = Z_HUFFMAN_ONLY; - } else if (*p == 'R') { - strategy = Z_RLE; - } else { - *m++ = *p; /* copy the mode */ - } - } while (*p++ && m != fmode + sizeof(fmode)); - if (s->mode == '\0') return destroy(s), (gzFile)Z_NULL; - - if (s->mode == 'w') { -#ifdef NO_GZCOMPRESS - err = Z_STREAM_ERROR; -#else - err = deflateInit2(&(s->stream), level, - Z_DEFLATED, -MAX_WBITS, DEF_MEM_LEVEL, strategy); - /* windowBits is passed < 0 to suppress zlib header */ - - s->stream.next_out = s->outbuf = (Byte*)ALLOC(Z_BUFSIZE); -#endif - if (err != Z_OK || s->outbuf == Z_NULL) { - return destroy(s), (gzFile)Z_NULL; - } - } else { - s->stream.next_in = s->inbuf = (Byte*)ALLOC(Z_BUFSIZE); - - err = inflateInit2(&(s->stream), -MAX_WBITS); - /* windowBits is passed < 0 to tell that there is no zlib header. - * Note that in this case inflate *requires* an extra "dummy" byte - * after the compressed stream in order to complete decompression and - * return Z_STREAM_END. Here the gzip CRC32 ensures that 4 bytes are - * present after the compressed stream. - */ - if (err != Z_OK || s->inbuf == Z_NULL) { - return destroy(s), (gzFile)Z_NULL; - } - } - s->stream.avail_out = Z_BUFSIZE; - - errno = 0; - s->file = fd < 0 ? F_OPEN(path, fmode) : (FILE*)fdopen(fd, fmode); - - if (s->file == NULL) { - return destroy(s), (gzFile)Z_NULL; - } - if (s->mode == 'w') { - /* Write a very simple .gz header: - */ - fprintf(s->file, "%c%c%c%c%c%c%c%c%c%c", gz_magic[0], gz_magic[1], - Z_DEFLATED, 0 /*flags*/, 0,0,0,0 /*time*/, 0 /*xflags*/, OS_CODE); - s->start = 10L; - /* We use 10L instead of ftell(s->file) to because ftell causes an - * fflush on some systems. This version of the library doesn't use - * start anyway in write mode, so this initialization is not - * necessary. - */ - } else { - check_header(s); /* skip the .gz header */ - s->start = ftell(s->file) - s->stream.avail_in; - } - - return (gzFile)s; -} - -/* =========================================================================== - Opens a gzip (.gz) file for reading or writing. -*/ -gzFile ZEXPORT gzopen (path, mode) - const char *path; - const char *mode; -{ - return gz_open (path, mode, -1); -} - -/* =========================================================================== - Associate a gzFile with the file descriptor fd. fd is not dup'ed here - to mimic the behavio(u)r of fdopen. -*/ -gzFile ZEXPORT gzdopen (fd, mode) - int fd; - const char *mode; -{ - char name[46]; /* allow for up to 128-bit integers */ - - if (fd < 0) return (gzFile)Z_NULL; - sprintf(name, "", fd); /* for debugging */ - - return gz_open (name, mode, fd); -} - -/* =========================================================================== - * Update the compression level and strategy - */ -int ZEXPORT gzsetparams (file, level, strategy) - gzFile file; - int level; - int strategy; -{ - gz_stream *s = (gz_stream*)file; - - if (s == NULL || s->mode != 'w') return Z_STREAM_ERROR; - - /* Make room to allow flushing */ - if (s->stream.avail_out == 0) { - - s->stream.next_out = s->outbuf; - if (fwrite(s->outbuf, 1, Z_BUFSIZE, s->file) != Z_BUFSIZE) { - s->z_err = Z_ERRNO; - } - s->stream.avail_out = Z_BUFSIZE; - } - - return deflateParams (&(s->stream), level, strategy); -} - -/* =========================================================================== - Read a byte from a gz_stream; update next_in and avail_in. Return EOF - for end of file. - IN assertion: the stream s has been sucessfully opened for reading. -*/ -local int get_byte(s) - gz_stream *s; -{ - if (s->z_eof) return EOF; - if (s->stream.avail_in == 0) { - errno = 0; - s->stream.avail_in = (uInt)fread(s->inbuf, 1, Z_BUFSIZE, s->file); - if (s->stream.avail_in == 0) { - s->z_eof = 1; - if (ferror(s->file)) s->z_err = Z_ERRNO; - return EOF; - } - s->stream.next_in = s->inbuf; - } - s->stream.avail_in--; - return *(s->stream.next_in)++; -} - -/* =========================================================================== - Check the gzip header of a gz_stream opened for reading. Set the stream - mode to transparent if the gzip magic header is not present; set s->err - to Z_DATA_ERROR if the magic header is present but the rest of the header - is incorrect. - IN assertion: the stream s has already been created sucessfully; - s->stream.avail_in is zero for the first time, but may be non-zero - for concatenated .gz files. -*/ -local void check_header(s) - gz_stream *s; -{ - int method; /* method byte */ - int flags; /* flags byte */ - uInt len; - int c; - - /* Assure two bytes in the buffer so we can peek ahead -- handle case - where first byte of header is at the end of the buffer after the last - gzip segment */ - len = s->stream.avail_in; - if (len < 2) { - if (len) s->inbuf[0] = s->stream.next_in[0]; - errno = 0; - len = (uInt)fread(s->inbuf + len, 1, Z_BUFSIZE >> len, s->file); - if (len == 0 && ferror(s->file)) s->z_err = Z_ERRNO; - s->stream.avail_in += len; - s->stream.next_in = s->inbuf; - if (s->stream.avail_in < 2) { - s->transparent = s->stream.avail_in; - return; - } - } - - /* Peek ahead to check the gzip magic header */ - if (s->stream.next_in[0] != gz_magic[0] || - s->stream.next_in[1] != gz_magic[1]) { - s->transparent = 1; - return; - } - s->stream.avail_in -= 2; - s->stream.next_in += 2; - - /* Check the rest of the gzip header */ - method = get_byte(s); - flags = get_byte(s); - if (method != Z_DEFLATED || (flags & RESERVED) != 0) { - s->z_err = Z_DATA_ERROR; - return; - } - - /* Discard time, xflags and OS code: */ - for (len = 0; len < 6; len++) (void)get_byte(s); - - if ((flags & EXTRA_FIELD) != 0) { /* skip the extra field */ - len = (uInt)get_byte(s); - len += ((uInt)get_byte(s))<<8; - /* len is garbage if EOF but the loop below will quit anyway */ - while (len-- != 0 && get_byte(s) != EOF) ; - } - if ((flags & ORIG_NAME) != 0) { /* skip the original file name */ - while ((c = get_byte(s)) != 0 && c != EOF) ; - } - if ((flags & COMMENT) != 0) { /* skip the .gz file comment */ - while ((c = get_byte(s)) != 0 && c != EOF) ; - } - if ((flags & HEAD_CRC) != 0) { /* skip the header crc */ - for (len = 0; len < 2; len++) (void)get_byte(s); - } - s->z_err = s->z_eof ? Z_DATA_ERROR : Z_OK; -} - - /* =========================================================================== - * Cleanup then free the given gz_stream. Return a zlib error code. - Try freeing in the reverse order of allocations. - */ -local int destroy (s) - gz_stream *s; -{ - int err = Z_OK; - - if (!s) return Z_STREAM_ERROR; - - TRYFREE(s->msg); - - if (s->stream.state != NULL) { - if (s->mode == 'w') { -#ifdef NO_GZCOMPRESS - err = Z_STREAM_ERROR; -#else - err = deflateEnd(&(s->stream)); -#endif - } else if (s->mode == 'r') { - err = inflateEnd(&(s->stream)); - } - } - if (s->file != NULL && fclose(s->file)) { -#ifdef ESPIPE - if (errno != ESPIPE) /* fclose is broken for pipes in HP/UX */ -#endif - err = Z_ERRNO; - } - if (s->z_err < 0) err = s->z_err; - - TRYFREE(s->inbuf); - TRYFREE(s->outbuf); - TRYFREE(s->path); - TRYFREE(s); - return err; -} - -/* =========================================================================== - Reads the given number of uncompressed bytes from the compressed file. - gzread returns the number of bytes actually read (0 for end of file). -*/ -int ZEXPORT gzread (file, buf, len) - gzFile file; - voidp buf; - unsigned len; -{ - gz_stream *s = (gz_stream*)file; - Bytef *start = (Bytef*)buf; /* starting point for crc computation */ - Byte *next_out; /* == stream.next_out but not forced far (for MSDOS) */ - - if (s == NULL || s->mode != 'r') return Z_STREAM_ERROR; - - if (s->z_err == Z_DATA_ERROR || s->z_err == Z_ERRNO) return -1; - if (s->z_err == Z_STREAM_END) return 0; /* EOF */ - - next_out = (Byte*)buf; - s->stream.next_out = (Bytef*)buf; - s->stream.avail_out = len; - - if (s->stream.avail_out && s->back != EOF) { - *next_out++ = s->back; - s->stream.next_out++; - s->stream.avail_out--; - s->back = EOF; - s->out++; - start++; - if (s->last) { - s->z_err = Z_STREAM_END; - return 1; - } - } - - while (s->stream.avail_out != 0) { - - if (s->transparent) { - /* Copy first the lookahead bytes: */ - uInt n = s->stream.avail_in; - if (n > s->stream.avail_out) n = s->stream.avail_out; - if (n > 0) { - zmemcpy(s->stream.next_out, s->stream.next_in, n); - next_out += n; - s->stream.next_out = next_out; - s->stream.next_in += n; - s->stream.avail_out -= n; - s->stream.avail_in -= n; - } - if (s->stream.avail_out > 0) { - s->stream.avail_out -= - (uInt)fread(next_out, 1, s->stream.avail_out, s->file); - } - len -= s->stream.avail_out; - s->in += len; - s->out += len; - if (len == 0) s->z_eof = 1; - return (int)len; - } - if (s->stream.avail_in == 0 && !s->z_eof) { - - errno = 0; - s->stream.avail_in = (uInt)fread(s->inbuf, 1, Z_BUFSIZE, s->file); - if (s->stream.avail_in == 0) { - s->z_eof = 1; - if (ferror(s->file)) { - s->z_err = Z_ERRNO; - break; - } - } - s->stream.next_in = s->inbuf; - } - s->in += s->stream.avail_in; - s->out += s->stream.avail_out; - s->z_err = inflate(&(s->stream), Z_NO_FLUSH); - s->in -= s->stream.avail_in; - s->out -= s->stream.avail_out; - - if (s->z_err == Z_STREAM_END) { - /* Check CRC and original size */ - s->crc = crc32(s->crc, start, (uInt)(s->stream.next_out - start)); - start = s->stream.next_out; - - if (getLong(s) != s->crc) { - s->z_err = Z_DATA_ERROR; - } else { - (void)getLong(s); - /* The uncompressed length returned by above getlong() may be - * different from s->out in case of concatenated .gz files. - * Check for such files: - */ - check_header(s); - if (s->z_err == Z_OK) { - inflateReset(&(s->stream)); - s->crc = crc32(0L, Z_NULL, 0); - } - } - } - if (s->z_err != Z_OK || s->z_eof) break; - } - s->crc = crc32(s->crc, start, (uInt)(s->stream.next_out - start)); - - if (len == s->stream.avail_out && - (s->z_err == Z_DATA_ERROR || s->z_err == Z_ERRNO)) - return -1; - return (int)(len - s->stream.avail_out); -} - - -/* =========================================================================== - Reads one byte from the compressed file. gzgetc returns this byte - or -1 in case of end of file or error. -*/ -int ZEXPORT gzgetc(file) - gzFile file; -{ - unsigned char c; - - return gzread(file, &c, 1) == 1 ? c : -1; -} - - -/* =========================================================================== - Push one byte back onto the stream. -*/ -int ZEXPORT gzungetc(c, file) - int c; - gzFile file; -{ - gz_stream *s = (gz_stream*)file; - - if (s == NULL || s->mode != 'r' || c == EOF || s->back != EOF) return EOF; - s->back = c; - s->out--; - s->last = (s->z_err == Z_STREAM_END); - if (s->last) s->z_err = Z_OK; - s->z_eof = 0; - return c; -} - - -/* =========================================================================== - Reads bytes from the compressed file until len-1 characters are - read, or a newline character is read and transferred to buf, or an - end-of-file condition is encountered. The string is then terminated - with a null character. - gzgets returns buf, or Z_NULL in case of error. - - The current implementation is not optimized at all. -*/ -char * ZEXPORT gzgets(file, buf, len) - gzFile file; - char *buf; - int len; -{ - char *b = buf; - if (buf == Z_NULL || len <= 0) return Z_NULL; - - while (--len > 0 && gzread(file, buf, 1) == 1 && *buf++ != '\n') ; - *buf = '\0'; - return b == buf && len > 0 ? Z_NULL : b; -} - - -#ifndef NO_GZCOMPRESS -/* =========================================================================== - Writes the given number of uncompressed bytes into the compressed file. - gzwrite returns the number of bytes actually written (0 in case of error). -*/ -int ZEXPORT gzwrite (file, buf, len) - gzFile file; - voidpc buf; - unsigned len; -{ - gz_stream *s = (gz_stream*)file; - - if (s == NULL || s->mode != 'w') return Z_STREAM_ERROR; - - s->stream.next_in = (Bytef*)buf; - s->stream.avail_in = len; - - while (s->stream.avail_in != 0) { - - if (s->stream.avail_out == 0) { - - s->stream.next_out = s->outbuf; - if (fwrite(s->outbuf, 1, Z_BUFSIZE, s->file) != Z_BUFSIZE) { - s->z_err = Z_ERRNO; - break; - } - s->stream.avail_out = Z_BUFSIZE; - } - s->in += s->stream.avail_in; - s->out += s->stream.avail_out; - s->z_err = deflate(&(s->stream), Z_NO_FLUSH); - s->in -= s->stream.avail_in; - s->out -= s->stream.avail_out; - if (s->z_err != Z_OK) break; - } - s->crc = crc32(s->crc, (const Bytef *)buf, len); - - return (int)(len - s->stream.avail_in); -} - - -/* =========================================================================== - Converts, formats, and writes the args to the compressed file under - control of the format string, as in fprintf. gzprintf returns the number of - uncompressed bytes actually written (0 in case of error). -*/ -#ifdef STDC -#include - -int ZEXPORTVA gzprintf (gzFile file, const char *format, /* args */ ...) -{ - char buf[Z_PRINTF_BUFSIZE]; - va_list va; - int len; - - buf[sizeof(buf) - 1] = 0; - va_start(va, format); -#ifdef NO_vsnprintf -# ifdef HAS_vsprintf_void - (void)vsprintf(buf, format, va); - va_end(va); - for (len = 0; len < sizeof(buf); len++) - if (buf[len] == 0) break; -# else - len = vsprintf(buf, format, va); - va_end(va); -# endif -#else -# ifdef HAS_vsnprintf_void - (void)vsnprintf(buf, sizeof(buf), format, va); - va_end(va); - len = strlen(buf); -# else - len = vsnprintf(buf, sizeof(buf), format, va); - va_end(va); -# endif -#endif - if (len <= 0 || len >= (int)sizeof(buf) || buf[sizeof(buf) - 1] != 0) - return 0; - return gzwrite(file, buf, (unsigned)len); -} -#else /* not ANSI C */ - -int ZEXPORTVA gzprintf (file, format, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, - a11, a12, a13, a14, a15, a16, a17, a18, a19, a20) - gzFile file; - const char *format; - int a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, - a11, a12, a13, a14, a15, a16, a17, a18, a19, a20; -{ - char buf[Z_PRINTF_BUFSIZE]; - int len; - - buf[sizeof(buf) - 1] = 0; -#ifdef NO_snprintf -# ifdef HAS_sprintf_void - sprintf(buf, format, a1, a2, a3, a4, a5, a6, a7, a8, - a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20); - for (len = 0; len < sizeof(buf); len++) - if (buf[len] == 0) break; -# else - len = sprintf(buf, format, a1, a2, a3, a4, a5, a6, a7, a8, - a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20); -# endif -#else -# ifdef HAS_snprintf_void - snprintf(buf, sizeof(buf), format, a1, a2, a3, a4, a5, a6, a7, a8, - a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20); - len = strlen(buf); -# else - len = snprintf(buf, sizeof(buf), format, a1, a2, a3, a4, a5, a6, a7, a8, - a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20); -# endif -#endif - if (len <= 0 || len >= sizeof(buf) || buf[sizeof(buf) - 1] != 0) - return 0; - return gzwrite(file, buf, len); -} -#endif - -/* =========================================================================== - Writes c, converted to an unsigned char, into the compressed file. - gzputc returns the value that was written, or -1 in case of error. -*/ -int ZEXPORT gzputc(file, c) - gzFile file; - int c; -{ - unsigned char cc = (unsigned char) c; /* required for big endian systems */ - - return gzwrite(file, &cc, 1) == 1 ? (int)cc : -1; -} - - -/* =========================================================================== - Writes the given null-terminated string to the compressed file, excluding - the terminating null character. - gzputs returns the number of characters written, or -1 in case of error. -*/ -int ZEXPORT gzputs(file, s) - gzFile file; - const char *s; -{ - return gzwrite(file, (char*)s, (unsigned)strlen(s)); -} - - -/* =========================================================================== - Flushes all pending output into the compressed file. The parameter - flush is as in the deflate() function. -*/ -local int do_flush (file, flush) - gzFile file; - int flush; -{ - uInt len; - int done = 0; - gz_stream *s = (gz_stream*)file; - - if (s == NULL || s->mode != 'w') return Z_STREAM_ERROR; - - s->stream.avail_in = 0; /* should be zero already anyway */ - - for (;;) { - len = Z_BUFSIZE - s->stream.avail_out; - - if (len != 0) { - if ((uInt)fwrite(s->outbuf, 1, len, s->file) != len) { - s->z_err = Z_ERRNO; - return Z_ERRNO; - } - s->stream.next_out = s->outbuf; - s->stream.avail_out = Z_BUFSIZE; - } - if (done) break; - s->out += s->stream.avail_out; - s->z_err = deflate(&(s->stream), flush); - s->out -= s->stream.avail_out; - - /* Ignore the second of two consecutive flushes: */ - if (len == 0 && s->z_err == Z_BUF_ERROR) s->z_err = Z_OK; - - /* deflate has finished flushing only when it hasn't used up - * all the available space in the output buffer: - */ - done = (s->stream.avail_out != 0 || s->z_err == Z_STREAM_END); - - if (s->z_err != Z_OK && s->z_err != Z_STREAM_END) break; - } - return s->z_err == Z_STREAM_END ? Z_OK : s->z_err; -} - -int ZEXPORT gzflush (file, flush) - gzFile file; - int flush; -{ - gz_stream *s = (gz_stream*)file; - int err = do_flush (file, flush); - - if (err) return err; - fflush(s->file); - return s->z_err == Z_STREAM_END ? Z_OK : s->z_err; -} -#endif /* NO_GZCOMPRESS */ - -/* =========================================================================== - Sets the starting position for the next gzread or gzwrite on the given - compressed file. The offset represents a number of bytes in the - gzseek returns the resulting offset location as measured in bytes from - the beginning of the uncompressed stream, or -1 in case of error. - SEEK_END is not implemented, returns error. - In this version of the library, gzseek can be extremely slow. -*/ -z_off_t ZEXPORT gzseek (file, offset, whence) - gzFile file; - z_off_t offset; - int whence; -{ - gz_stream *s = (gz_stream*)file; - - if (s == NULL || whence == SEEK_END || - s->z_err == Z_ERRNO || s->z_err == Z_DATA_ERROR) { - return -1L; - } - - if (s->mode == 'w') { -#ifdef NO_GZCOMPRESS - return -1L; -#else - if (whence == SEEK_SET) { - offset -= s->in; - } - if (offset < 0) return -1L; - - /* At this point, offset is the number of zero bytes to write. */ - if (s->inbuf == Z_NULL) { - s->inbuf = (Byte*)ALLOC(Z_BUFSIZE); /* for seeking */ - if (s->inbuf == Z_NULL) return -1L; - zmemzero(s->inbuf, Z_BUFSIZE); - } - while (offset > 0) { - uInt size = Z_BUFSIZE; - if (offset < Z_BUFSIZE) size = (uInt)offset; - - size = gzwrite(file, s->inbuf, size); - if (size == 0) return -1L; - - offset -= size; - } - return s->in; -#endif - } - /* Rest of function is for reading only */ - - /* compute absolute position */ - if (whence == SEEK_CUR) { - offset += s->out; - } - if (offset < 0) return -1L; - - if (s->transparent) { - /* map to fseek */ - s->back = EOF; - s->stream.avail_in = 0; - s->stream.next_in = s->inbuf; - if (fseek(s->file, offset, SEEK_SET) < 0) return -1L; - - s->in = s->out = offset; - return offset; - } - - /* For a negative seek, rewind and use positive seek */ - if (offset >= s->out) { - offset -= s->out; - } else if (gzrewind(file) < 0) { - return -1L; - } - /* offset is now the number of bytes to skip. */ - - if (offset != 0 && s->outbuf == Z_NULL) { - s->outbuf = (Byte*)ALLOC(Z_BUFSIZE); - if (s->outbuf == Z_NULL) return -1L; - } - if (offset && s->back != EOF) { - s->back = EOF; - s->out++; - offset--; - if (s->last) s->z_err = Z_STREAM_END; - } - while (offset > 0) { - int size = Z_BUFSIZE; - if (offset < Z_BUFSIZE) size = (int)offset; - - size = gzread(file, s->outbuf, (uInt)size); - if (size <= 0) return -1L; - offset -= size; - } - return s->out; -} - -/* =========================================================================== - Rewinds input file. -*/ -int ZEXPORT gzrewind (file) - gzFile file; -{ - gz_stream *s = (gz_stream*)file; - - if (s == NULL || s->mode != 'r') return -1; - - s->z_err = Z_OK; - s->z_eof = 0; - s->back = EOF; - s->stream.avail_in = 0; - s->stream.next_in = s->inbuf; - s->crc = crc32(0L, Z_NULL, 0); - if (!s->transparent) (void)inflateReset(&s->stream); - s->in = 0; - s->out = 0; - return fseek(s->file, s->start, SEEK_SET); -} - -/* =========================================================================== - Returns the starting position for the next gzread or gzwrite on the - given compressed file. This position represents a number of bytes in the - uncompressed data stream. -*/ -z_off_t ZEXPORT gztell (file) - gzFile file; -{ - return gzseek(file, 0L, SEEK_CUR); -} - -/* =========================================================================== - Returns 1 when EOF has previously been detected reading the given - input stream, otherwise zero. -*/ -int ZEXPORT gzeof (file) - gzFile file; -{ - gz_stream *s = (gz_stream*)file; - - /* With concatenated compressed files that can have embedded - * crc trailers, z_eof is no longer the only/best indicator of EOF - * on a gz_stream. Handle end-of-stream error explicitly here. - */ - if (s == NULL || s->mode != 'r') return 0; - if (s->z_eof) return 1; - return s->z_err == Z_STREAM_END; -} - -/* =========================================================================== - Returns 1 if reading and doing so transparently, otherwise zero. -*/ -int ZEXPORT gzdirect (file) - gzFile file; -{ - gz_stream *s = (gz_stream*)file; - - if (s == NULL || s->mode != 'r') return 0; - return s->transparent; -} - -/* =========================================================================== - Outputs a long in LSB order to the given file -*/ -local void putLong (file, x) - FILE *file; - uLong x; -{ - int n; - for (n = 0; n < 4; n++) { - fputc((int)(x & 0xff), file); - x >>= 8; - } -} - -/* =========================================================================== - Reads a long in LSB order from the given gz_stream. Sets z_err in case - of error. -*/ -local uLong getLong (s) - gz_stream *s; -{ - uLong x = (uLong)get_byte(s); - int c; - - x += ((uLong)get_byte(s))<<8; - x += ((uLong)get_byte(s))<<16; - c = get_byte(s); - if (c == EOF) s->z_err = Z_DATA_ERROR; - x += ((uLong)c)<<24; - return x; -} - -/* =========================================================================== - Flushes all pending output if necessary, closes the compressed file - and deallocates all the (de)compression state. -*/ -int ZEXPORT gzclose (file) - gzFile file; -{ - gz_stream *s = (gz_stream*)file; - - if (s == NULL) return Z_STREAM_ERROR; - - if (s->mode == 'w') { -#ifdef NO_GZCOMPRESS - return Z_STREAM_ERROR; -#else - if (do_flush (file, Z_FINISH) != Z_OK) - return destroy((gz_stream*)file); - - putLong (s->file, s->crc); - putLong (s->file, (uLong)(s->in & 0xffffffff)); -#endif - } - return destroy((gz_stream*)file); -} - -#ifdef STDC -# define zstrerror(errnum) strerror(errnum) -#else -# define zstrerror(errnum) "" -#endif - -/* =========================================================================== - Returns the error message for the last error which occurred on the - given compressed file. errnum is set to zlib error number. If an - error occurred in the file system and not in the compression library, - errnum is set to Z_ERRNO and the application may consult errno - to get the exact error code. -*/ -const char * ZEXPORT gzerror (file, errnum) - gzFile file; - int *errnum; -{ - char *m; - gz_stream *s = (gz_stream*)file; - - if (s == NULL) { - *errnum = Z_STREAM_ERROR; - return (const char*)ERR_MSG(Z_STREAM_ERROR); - } - *errnum = s->z_err; - if (*errnum == Z_OK) return (const char*)""; - - m = (char*)(*errnum == Z_ERRNO ? zstrerror(errno) : s->stream.msg); - - if (m == NULL || *m == '\0') m = (char*)ERR_MSG(s->z_err); - - TRYFREE(s->msg); - s->msg = (char*)ALLOC(strlen(s->path) + strlen(m) + 3); - if (s->msg == Z_NULL) return (const char*)ERR_MSG(Z_MEM_ERROR); - strcpy(s->msg, s->path); - strcat(s->msg, ": "); - strcat(s->msg, m); - return (const char*)s->msg; -} - -/* =========================================================================== - Clear the error and end-of-file flags, and do the same for the real file. -*/ -void ZEXPORT gzclearerr (file) - gzFile file; -{ - gz_stream *s = (gz_stream*)file; - - if (s == NULL) return; - if (s->z_err != Z_STREAM_END) s->z_err = Z_OK; - s->z_eof = 0; - clearerr(s->file); -} diff --git a/zlib/gzlib.c b/zlib/gzlib.c new file mode 100644 index 00000000..47723601 --- /dev/null +++ b/zlib/gzlib.c @@ -0,0 +1,641 @@ +/* gzlib.c -- zlib functions common to reading and writing gzip files + * Copyright (C) 2004-2017 Mark Adler + * For conditions of distribution and use, see copyright notice in zlib.h + */ + +#include "gzguts.h" + +#ifdef _MSC_VER +#define open _open +#endif + +#if defined(_WIN32) && !defined(__BORLANDC__) && !defined(__MINGW32__) +# define LSEEK _lseeki64 +#else +#if defined(_LARGEFILE64_SOURCE) && _LFS64_LARGEFILE-0 +# define LSEEK lseek64 +#else +# define LSEEK lseek +#endif +#endif + +/* Local functions */ +local void gz_reset OF((gz_statep)); +local gzFile gz_open OF((const void *, int, const char *)); + +#if defined UNDER_CE + +/* Map the Windows error number in ERROR to a locale-dependent error message + string and return a pointer to it. Typically, the values for ERROR come + from GetLastError. + + The string pointed to shall not be modified by the application, but may be + overwritten by a subsequent call to gz_strwinerror + + The gz_strwinerror function does not change the current setting of + GetLastError. */ +char ZLIB_INTERNAL *gz_strwinerror (error) + DWORD error; +{ + static char buf[1024]; + + wchar_t *msgbuf; + DWORD lasterr = GetLastError(); + DWORD chars = FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM + | FORMAT_MESSAGE_ALLOCATE_BUFFER, + NULL, + error, + 0, /* Default language */ + (LPVOID)&msgbuf, + 0, + NULL); + if (chars != 0) { + /* If there is an \r\n appended, zap it. */ + if (chars >= 2 + && msgbuf[chars - 2] == '\r' && msgbuf[chars - 1] == '\n') { + chars -= 2; + msgbuf[chars] = 0; + } + + if (chars > sizeof (buf) - 1) { + chars = sizeof (buf) - 1; + msgbuf[chars] = 0; + } + + wcstombs(buf, msgbuf, chars + 1); + LocalFree(msgbuf); + } + else { + sprintf(buf, "unknown win32 error (%ld)", error); + } + + SetLastError(lasterr); + return buf; +} + +#endif /* UNDER_CE */ + +/* Reset gzip file state */ +local void gz_reset(state) + gz_statep state; +{ + state->x.have = 0; /* no output data available */ + if (state->mode == GZ_READ) { /* for reading ... */ + state->eof = 0; /* not at end of file */ + state->past = 0; /* have not read past end yet */ + state->how = LOOK; /* look for gzip header */ + } + state->seek = 0; /* no seek request pending */ + gz_error(state, Z_OK, NULL); /* clear error */ + state->x.pos = 0; /* no uncompressed data yet */ + state->strm.avail_in = 0; /* no input data yet */ +} + +/* Open a gzip file either by name or file descriptor. */ +local gzFile gz_open(path, fd, mode) + const void *path; + int fd; + const char *mode; +{ + gz_statep state; + z_size_t len; + int oflag; +#ifdef O_CLOEXEC + int cloexec = 0; +#endif +#ifdef O_EXCL + int exclusive = 0; +#endif + + /* check input */ + if (path == NULL) + return NULL; + + /* allocate gzFile structure to return */ + state = (gz_statep)malloc(sizeof(gz_state)); + if (state == NULL) + return NULL; + state->size = 0; /* no buffers allocated yet */ + state->want = GZBUFSIZE; /* requested buffer size */ + state->msg = NULL; /* no error message yet */ + + /* interpret mode */ + state->mode = GZ_NONE; + state->level = Z_DEFAULT_COMPRESSION; + state->strategy = Z_DEFAULT_STRATEGY; + state->direct = 0; + while (*mode) { + if (*mode >= '0' && *mode <= '9') + state->level = *mode - '0'; + else + switch (*mode) { + case 'r': + state->mode = GZ_READ; + break; +#ifndef NO_GZCOMPRESS + case 'w': + state->mode = GZ_WRITE; + break; + case 'a': + state->mode = GZ_APPEND; + break; +#endif + case '+': /* can't read and write at the same time */ + free(state); + return NULL; + case 'b': /* ignore -- will request binary anyway */ + break; +#ifdef O_CLOEXEC + case 'e': + cloexec = 1; + break; +#endif +#ifdef O_EXCL + case 'x': + exclusive = 1; + break; +#endif + case 'f': + state->strategy = Z_FILTERED; + break; + case 'h': + state->strategy = Z_HUFFMAN_ONLY; + break; + case 'R': + state->strategy = Z_RLE; + break; + case 'F': + state->strategy = Z_FIXED; + break; + case 'T': + state->direct = 1; + break; + default: /* could consider as an error, but just ignore */ + ; + } + mode++; + } + + /* must provide an "r", "w", or "a" */ + if (state->mode == GZ_NONE) { + free(state); + return NULL; + } + + /* can't force transparent read */ + if (state->mode == GZ_READ) { + if (state->direct) { + free(state); + return NULL; + } + state->direct = 1; /* for empty file */ + } + + /* save the path name for error messages */ +#ifdef WIDECHAR + if (fd == -2) { + len = wcstombs(NULL, path, 0); + if (len == (z_size_t)-1) + len = 0; + } + else +#endif + len = strlen((const char *)path); + state->path = (char *)malloc(len + 1); + if (state->path == NULL) { + free(state); + return NULL; + } +#ifdef WIDECHAR + if (fd == -2) + if (len) + wcstombs(state->path, path, len + 1); + else + *(state->path) = 0; + else +#endif +#if !defined(NO_snprintf) && !defined(NO_vsnprintf) + (void)snprintf(state->path, len + 1, "%s", (const char *)path); +#else + strcpy(state->path, path); +#endif + + /* compute the flags for open() */ + oflag = +#ifdef O_LARGEFILE + O_LARGEFILE | +#endif +#ifdef O_BINARY + O_BINARY | +#endif +#ifdef O_CLOEXEC + (cloexec ? O_CLOEXEC : 0) | +#endif + (state->mode == GZ_READ ? + O_RDONLY : + (O_WRONLY | O_CREAT | +#ifdef O_EXCL + (exclusive ? O_EXCL : 0) | +#endif + (state->mode == GZ_WRITE ? + O_TRUNC : + O_APPEND))); + + /* open the file with the appropriate flags (or just use fd) */ + state->fd = fd > -1 ? fd : ( +#ifdef WIDECHAR + fd == -2 ? _wopen(path, oflag, 0666) : +#endif + open((const char *)path, oflag, 0666)); + if (state->fd == -1) { + free(state->path); + free(state); + return NULL; + } + if (state->mode == GZ_APPEND) { + LSEEK(state->fd, 0, SEEK_END); /* so gzoffset() is correct */ + state->mode = GZ_WRITE; /* simplify later checks */ + } + + /* save the current position for rewinding (only if reading) */ + if (state->mode == GZ_READ) { + state->start = LSEEK(state->fd, 0, SEEK_CUR); + if (state->start == -1) state->start = 0; + } + + /* initialize stream */ + gz_reset(state); + + /* return stream */ + return (gzFile)state; +} + +/* -- see zlib.h -- */ +gzFile ZEXPORT gzopen(path, mode) + const char *path; + const char *mode; +{ + return gz_open(path, -1, mode); +} + +/* -- see zlib.h -- */ +gzFile ZEXPORT gzopen64(path, mode) + const char *path; + const char *mode; +{ + return gz_open(path, -1, mode); +} + +/* -- see zlib.h -- */ +gzFile ZEXPORT gzdopen(fd, mode) + int fd; + const char *mode; +{ + char *path; /* identifier for error messages */ + gzFile gz; + + if (fd == -1 || (path = (char *)malloc(7 + 3 * sizeof(int))) == NULL) + return NULL; +#if !defined(NO_snprintf) && !defined(NO_vsnprintf) + (void)snprintf(path, 7 + 3 * sizeof(int), "", fd); +#else + sprintf(path, "", fd); /* for debugging */ +#endif + gz = gz_open(path, fd, mode); + free(path); + return gz; +} + +/* -- see zlib.h -- */ +#ifdef WIDECHAR +gzFile ZEXPORT gzopen_w(path, mode) + const wchar_t *path; + const char *mode; +{ + return gz_open(path, -2, mode); +} +#endif + +/* -- see zlib.h -- */ +int ZEXPORT gzbuffer(file, size) + gzFile file; + unsigned size; +{ + gz_statep state; + + /* get internal structure and check integrity */ + if (file == NULL) + return -1; + state = (gz_statep)file; + if (state->mode != GZ_READ && state->mode != GZ_WRITE) + return -1; + + /* make sure we haven't already allocated memory */ + if (state->size != 0) + return -1; + + /* check and set requested size */ + if ((size << 1) < size) + return -1; /* need to be able to double it */ + if (size < 2) + size = 2; /* need two bytes to check magic header */ + state->want = size; + return 0; +} + +/* -- see zlib.h -- */ +int ZEXPORT gzrewind(file) + gzFile file; +{ + gz_statep state; + + /* get internal structure */ + if (file == NULL) + return -1; + state = (gz_statep)file; + + /* check that we're reading and that there's no error */ + if (state->mode != GZ_READ || + (state->err != Z_OK && state->err != Z_BUF_ERROR)) + return -1; + + /* back up and start over */ + if (LSEEK(state->fd, state->start, SEEK_SET) == -1) + return -1; + gz_reset(state); + return 0; +} + +/* -- see zlib.h -- */ +z_off64_t ZEXPORT gzseek64(file, offset, whence) + gzFile file; + z_off64_t offset; + int whence; +{ + unsigned n; + z_off64_t ret; + gz_statep state; + + /* get internal structure and check integrity */ + if (file == NULL) + return -1; + state = (gz_statep)file; + if (state->mode != GZ_READ && state->mode != GZ_WRITE) + return -1; + + /* check that there's no error */ + if (state->err != Z_OK && state->err != Z_BUF_ERROR) + return -1; + + /* can only seek from start or relative to current position */ + if (whence != SEEK_SET && whence != SEEK_CUR) + return -1; + + /* normalize offset to a SEEK_CUR specification */ + if (whence == SEEK_SET) + offset -= state->x.pos; + else if (state->seek) + offset += state->skip; + state->seek = 0; + + /* if within raw area while reading, just go there */ + if (state->mode == GZ_READ && state->how == COPY && + state->x.pos + offset >= 0) { + ret = LSEEK(state->fd, offset - state->x.have, SEEK_CUR); + if (ret == -1) + return -1; + state->x.have = 0; + state->eof = 0; + state->past = 0; + state->seek = 0; + gz_error(state, Z_OK, NULL); + state->strm.avail_in = 0; + state->x.pos += offset; + return state->x.pos; + } + + /* calculate skip amount, rewinding if needed for back seek when reading */ + if (offset < 0) { + if (state->mode != GZ_READ) /* writing -- can't go backwards */ + return -1; + offset += state->x.pos; + if (offset < 0) /* before start of file! */ + return -1; + if (gzrewind(file) == -1) /* rewind, then skip to offset */ + return -1; + } + + /* if reading, skip what's in output buffer (one less gzgetc() check) */ + if (state->mode == GZ_READ) { + n = GT_OFF(state->x.have) || (z_off64_t)state->x.have > offset ? + (unsigned)offset : state->x.have; + state->x.have -= n; + state->x.next += n; + state->x.pos += n; + offset -= n; + } + + /* request skip (if not zero) */ + if (offset) { + state->seek = 1; + state->skip = offset; + } + return state->x.pos + offset; +} + +/* -- see zlib.h -- */ +z_off_t ZEXPORT gzseek(file, offset, whence) + gzFile file; + z_off_t offset; + int whence; +{ + z_off64_t ret; + + ret = gzseek64(file, (z_off64_t)offset, whence); + return ret == (z_off_t)ret ? (z_off_t)ret : -1; +} + +/* -- see zlib.h -- */ +z_off64_t ZEXPORT gztell64(file) + gzFile file; +{ + gz_statep state; + + /* get internal structure and check integrity */ + if (file == NULL) + return -1; + state = (gz_statep)file; + if (state->mode != GZ_READ && state->mode != GZ_WRITE) + return -1; + + /* return position */ + return state->x.pos + (state->seek ? state->skip : 0); +} + +/* -- see zlib.h -- */ +z_off_t ZEXPORT gztell(file) + gzFile file; +{ + z_off64_t ret; + + ret = gztell64(file); + return ret == (z_off_t)ret ? (z_off_t)ret : -1; +} + +/* -- see zlib.h -- */ +z_off64_t ZEXPORT gzoffset64(file) + gzFile file; +{ + z_off64_t offset; + gz_statep state; + + /* get internal structure and check integrity */ + if (file == NULL) + return -1; + state = (gz_statep)file; + if (state->mode != GZ_READ && state->mode != GZ_WRITE) + return -1; + + /* compute and return effective offset in file */ + offset = LSEEK(state->fd, 0, SEEK_CUR); + if (offset == -1) + return -1; + if (state->mode == GZ_READ) /* reading */ + offset -= state->strm.avail_in; /* don't count buffered input */ + return offset; +} + +/* -- see zlib.h -- */ +z_off_t ZEXPORT gzoffset(file) + gzFile file; +{ + z_off64_t ret; + + ret = gzoffset64(file); + return ret == (z_off_t)ret ? (z_off_t)ret : -1; +} + +/* -- see zlib.h -- */ +int ZEXPORT gzeof(file) + gzFile file; +{ + gz_statep state; + + /* get internal structure and check integrity */ + if (file == NULL) + return 0; + state = (gz_statep)file; + if (state->mode != GZ_READ && state->mode != GZ_WRITE) + return 0; + + /* return end-of-file state */ + return state->mode == GZ_READ ? state->past : 0; +} + +/* -- see zlib.h -- */ +const char * ZEXPORT gzerror(file, errnum) + gzFile file; + int *errnum; +{ + gz_statep state; + + /* get internal structure and check integrity */ + if (file == NULL) + return NULL; + state = (gz_statep)file; + if (state->mode != GZ_READ && state->mode != GZ_WRITE) + return NULL; + + /* return error information */ + if (errnum != NULL) + *errnum = state->err; + return state->err == Z_MEM_ERROR ? "out of memory" : + (state->msg == NULL ? "" : state->msg); +} + +/* -- see zlib.h -- */ +void ZEXPORT gzclearerr(file) + gzFile file; +{ + gz_statep state; + + /* get internal structure and check integrity */ + if (file == NULL) + return; + state = (gz_statep)file; + if (state->mode != GZ_READ && state->mode != GZ_WRITE) + return; + + /* clear error and end-of-file */ + if (state->mode == GZ_READ) { + state->eof = 0; + state->past = 0; + } + gz_error(state, Z_OK, NULL); +} + +/* Create an error message in allocated memory and set state->err and + state->msg accordingly. Free any previous error message already there. Do + not try to free or allocate space if the error is Z_MEM_ERROR (out of + memory). Simply save the error message as a static string. If there is an + allocation failure constructing the error message, then convert the error to + out of memory. */ +void ZLIB_INTERNAL gz_error(state, err, msg) + gz_statep state; + int err; + const char *msg; +{ + /* free previously allocated message and clear */ + if (state->msg != NULL) { + if (state->err != Z_MEM_ERROR) + free(state->msg); + state->msg = NULL; + } + + /* if fatal, set state->x.have to 0 so that the gzgetc() macro fails */ + if (err != Z_OK && err != Z_BUF_ERROR) + state->x.have = 0; + + /* set error code, and if no message, then done */ + state->err = err; + if (msg == NULL) + return; + + /* for an out of memory error, return literal string when requested */ + if (err == Z_MEM_ERROR) + return; + + /* construct error message with path */ + if ((state->msg = (char *)malloc(strlen(state->path) + strlen(msg) + 3)) == + NULL) { + state->err = Z_MEM_ERROR; + return; + } +#if !defined(NO_snprintf) && !defined(NO_vsnprintf) + (void)snprintf(state->msg, strlen(state->path) + strlen(msg) + 3, + "%s%s%s", state->path, ": ", msg); +#else + strcpy(state->msg, state->path); + strcat(state->msg, ": "); + strcat(state->msg, msg); +#endif +} + +#ifndef INT_MAX +/* portably return maximum value for an int (when limits.h presumed not + available) -- we need to do this to cover cases where 2's complement not + used, since C standard permits 1's complement and sign-bit representations, + otherwise we could just use ((unsigned)-1) >> 1 */ +unsigned ZLIB_INTERNAL gz_intmax() +{ + unsigned p, q; + + p = 1; + do { + q = p; + p <<= 1; + p++; + } while (p > q); + return q >> 1; +} +#endif diff --git a/zlib/gzread.c b/zlib/gzread.c new file mode 100644 index 00000000..839ca14e --- /dev/null +++ b/zlib/gzread.c @@ -0,0 +1,659 @@ +/* gzread.c -- zlib functions for reading gzip files + * Copyright (C) 2004, 2005, 2010, 2011, 2012, 2013, 2016 Mark Adler + * For conditions of distribution and use, see copyright notice in zlib.h + */ + +#include "gzguts.h" + +#ifdef _MSC_VER +#define close _close +#define read _read +#endif + + /* Local functions */ +local int gz_load OF((gz_statep, unsigned char *, unsigned, unsigned *)); +local int gz_avail OF((gz_statep)); +local int gz_look OF((gz_statep)); +local int gz_decomp OF((gz_statep)); +local int gz_fetch OF((gz_statep)); +local int gz_skip OF((gz_statep, z_off64_t)); +local z_size_t gz_read OF((gz_statep, voidp, z_size_t)); + +/* Use read() to load a buffer -- return -1 on error, otherwise 0. Read from + state->fd, and update state->eof, state->err, and state->msg as appropriate. + This function needs to loop on read(), since read() is not guaranteed to + read the number of bytes requested, depending on the type of descriptor. */ +local int gz_load(state, buf, len, have) + gz_statep state; + unsigned char *buf; + unsigned len; + unsigned *have; +{ + int ret; + unsigned get, max = ((unsigned)-1 >> 2) + 1; + + *have = 0; + do { + get = len - *have; + if (get > max) + get = max; + ret = read(state->fd, buf + *have, get); + if (ret <= 0) + break; + *have += (unsigned)ret; + } while (*have < len); + if (ret < 0) { + gz_error(state, Z_ERRNO, zstrerror()); + return -1; + } + if (ret == 0) + state->eof = 1; + return 0; +} + +/* Load up input buffer and set eof flag if last data loaded -- return -1 on + error, 0 otherwise. Note that the eof flag is set when the end of the input + file is reached, even though there may be unused data in the buffer. Once + that data has been used, no more attempts will be made to read the file. + If strm->avail_in != 0, then the current data is moved to the beginning of + the input buffer, and then the remainder of the buffer is loaded with the + available data from the input file. */ +local int gz_avail(state) + gz_statep state; +{ + unsigned got; + z_streamp strm = &(state->strm); + + if (state->err != Z_OK && state->err != Z_BUF_ERROR) + return -1; + if (state->eof == 0) { + if (strm->avail_in) { /* copy what's there to the start */ + unsigned char *p = state->in; + unsigned const char *q = strm->next_in; + unsigned n = strm->avail_in; + do { + *p++ = *q++; + } while (--n); + } + if (gz_load(state, state->in + strm->avail_in, + state->size - strm->avail_in, &got) == -1) + return -1; + strm->avail_in += got; + strm->next_in = state->in; + } + return 0; +} + +/* Look for gzip header, set up for inflate or copy. state->x.have must be 0. + If this is the first time in, allocate required memory. state->how will be + left unchanged if there is no more input data available, will be set to COPY + if there is no gzip header and direct copying will be performed, or it will + be set to GZIP for decompression. If direct copying, then leftover input + data from the input buffer will be copied to the output buffer. In that + case, all further file reads will be directly to either the output buffer or + a user buffer. If decompressing, the inflate state will be initialized. + gz_look() will return 0 on success or -1 on failure. */ +local int gz_look(state) + gz_statep state; +{ + z_streamp strm = &(state->strm); + + /* allocate read buffers and inflate memory */ + if (state->size == 0) { + /* allocate buffers */ + state->in = (unsigned char *)malloc(state->want); + state->out = (unsigned char *)malloc(state->want << 1); + if (state->in == NULL || state->out == NULL) { + free(state->out); + free(state->in); + gz_error(state, Z_MEM_ERROR, "out of memory"); + return -1; + } + state->size = state->want; + + /* allocate inflate memory */ + state->strm.zalloc = Z_NULL; + state->strm.zfree = Z_NULL; + state->strm.opaque = Z_NULL; + state->strm.avail_in = 0; + state->strm.next_in = Z_NULL; + if (inflateInit2(&(state->strm), 15 + 16) != Z_OK) { /* gunzip */ + free(state->out); + free(state->in); + state->size = 0; + gz_error(state, Z_MEM_ERROR, "out of memory"); + return -1; + } + } + + /* get at least the magic bytes in the input buffer */ + if (strm->avail_in < 2) { + if (gz_avail(state) == -1) + return -1; + if (strm->avail_in == 0) + return 0; + } + + /* look for gzip magic bytes -- if there, do gzip decoding (note: there is + a logical dilemma here when considering the case of a partially written + gzip file, to wit, if a single 31 byte is written, then we cannot tell + whether this is a single-byte file, or just a partially written gzip + file -- for here we assume that if a gzip file is being written, then + the header will be written in a single operation, so that reading a + single byte is sufficient indication that it is not a gzip file) */ + if (strm->avail_in > 1 && + strm->next_in[0] == 31 && strm->next_in[1] == 139) { + inflateReset(strm); + state->how = GZIP; + state->direct = 0; + return 0; + } + + /* no gzip header -- if we were decoding gzip before, then this is trailing + garbage. Ignore the trailing garbage and finish. */ + if (state->direct == 0) { + strm->avail_in = 0; + state->eof = 1; + state->x.have = 0; + return 0; + } + + /* doing raw i/o, copy any leftover input to output -- this assumes that + the output buffer is larger than the input buffer, which also assures + space for gzungetc() */ + state->x.next = state->out; + if (strm->avail_in) { + memcpy(state->x.next, strm->next_in, strm->avail_in); + state->x.have = strm->avail_in; + strm->avail_in = 0; + } + state->how = COPY; + state->direct = 1; + return 0; +} + +/* Decompress from input to the provided next_out and avail_out in the state. + On return, state->x.have and state->x.next point to the just decompressed + data. If the gzip stream completes, state->how is reset to LOOK to look for + the next gzip stream or raw data, once state->x.have is depleted. Returns 0 + on success, -1 on failure. */ +local int gz_decomp(state) + gz_statep state; +{ + int ret = Z_OK; + unsigned had; + z_streamp strm = &(state->strm); + + /* fill output buffer up to end of deflate stream */ + had = strm->avail_out; + do { + /* get more input for inflate() */ + if (strm->avail_in == 0 && gz_avail(state) == -1) + return -1; + if (strm->avail_in == 0) { + gz_error(state, Z_BUF_ERROR, "unexpected end of file"); + break; + } + + /* decompress and handle errors */ + ret = inflate(strm, Z_NO_FLUSH); + if (ret == Z_STREAM_ERROR || ret == Z_NEED_DICT) { + gz_error(state, Z_STREAM_ERROR, + "internal error: inflate stream corrupt"); + return -1; + } + if (ret == Z_MEM_ERROR) { + gz_error(state, Z_MEM_ERROR, "out of memory"); + return -1; + } + if (ret == Z_DATA_ERROR) { /* deflate stream invalid */ + gz_error(state, Z_DATA_ERROR, + strm->msg == NULL ? "compressed data error" : strm->msg); + return -1; + } + } while (strm->avail_out && ret != Z_STREAM_END); + + /* update available output */ + state->x.have = had - strm->avail_out; + state->x.next = strm->next_out - state->x.have; + + /* if the gzip stream completed successfully, look for another */ + if (ret == Z_STREAM_END) + state->how = LOOK; + + /* good decompression */ + return 0; +} + +/* Fetch data and put it in the output buffer. Assumes state->x.have is 0. + Data is either copied from the input file or decompressed from the input + file depending on state->how. If state->how is LOOK, then a gzip header is + looked for to determine whether to copy or decompress. Returns -1 on error, + otherwise 0. gz_fetch() will leave state->how as COPY or GZIP unless the + end of the input file has been reached and all data has been processed. */ +local int gz_fetch(state) + gz_statep state; +{ + z_streamp strm = &(state->strm); + + do { + switch(state->how) { + case LOOK: /* -> LOOK, COPY (only if never GZIP), or GZIP */ + if (gz_look(state) == -1) + return -1; + if (state->how == LOOK) + return 0; + break; + case COPY: /* -> COPY */ + if (gz_load(state, state->out, state->size << 1, &(state->x.have)) + == -1) + return -1; + state->x.next = state->out; + return 0; + case GZIP: /* -> GZIP or LOOK (if end of gzip stream) */ + strm->avail_out = state->size << 1; + strm->next_out = state->out; + if (gz_decomp(state) == -1) + return -1; + } + } while (state->x.have == 0 && (!state->eof || strm->avail_in)); + return 0; +} + +/* Skip len uncompressed bytes of output. Return -1 on error, 0 on success. */ +local int gz_skip(state, len) + gz_statep state; + z_off64_t len; +{ + unsigned n; + + /* skip over len bytes or reach end-of-file, whichever comes first */ + while (len) + /* skip over whatever is in output buffer */ + if (state->x.have) { + n = GT_OFF(state->x.have) || (z_off64_t)state->x.have > len ? + (unsigned)len : state->x.have; + state->x.have -= n; + state->x.next += n; + state->x.pos += n; + len -= n; + } + + /* output buffer empty -- return if we're at the end of the input */ + else if (state->eof && state->strm.avail_in == 0) + break; + + /* need more data to skip -- load up output buffer */ + else { + /* get more output, looking for header if required */ + if (gz_fetch(state) == -1) + return -1; + } + return 0; +} + +/* Read len bytes into buf from file, or less than len up to the end of the + input. Return the number of bytes read. If zero is returned, either the + end of file was reached, or there was an error. state->err must be + consulted in that case to determine which. */ +local z_size_t gz_read(state, buf, len) + gz_statep state; + voidp buf; + z_size_t len; +{ + z_size_t got; + unsigned n; + + /* if len is zero, avoid unnecessary operations */ + if (len == 0) + return 0; + + /* process a skip request */ + if (state->seek) { + state->seek = 0; + if (gz_skip(state, state->skip) == -1) + return 0; + } + + /* get len bytes to buf, or less than len if at the end */ + got = 0; + do { + /* set n to the maximum amount of len that fits in an unsigned int */ + n = -1; + if (n > len) + n = len; + + /* first just try copying data from the output buffer */ + if (state->x.have) { + if (state->x.have < n) + n = state->x.have; + memcpy(buf, state->x.next, n); + state->x.next += n; + state->x.have -= n; + } + + /* output buffer empty -- return if we're at the end of the input */ + else if (state->eof && state->strm.avail_in == 0) { + state->past = 1; /* tried to read past end */ + break; + } + + /* need output data -- for small len or new stream load up our output + buffer */ + else if (state->how == LOOK || n < (state->size << 1)) { + /* get more output, looking for header if required */ + if (gz_fetch(state) == -1) + return 0; + continue; /* no progress yet -- go back to copy above */ + /* the copy above assures that we will leave with space in the + output buffer, allowing at least one gzungetc() to succeed */ + } + + /* large len -- read directly into user buffer */ + else if (state->how == COPY) { /* read directly */ + if (gz_load(state, (unsigned char *)buf, n, &n) == -1) + return 0; + } + + /* large len -- decompress directly into user buffer */ + else { /* state->how == GZIP */ + state->strm.avail_out = n; + state->strm.next_out = (unsigned char *)buf; + if (gz_decomp(state) == -1) + return 0; + n = state->x.have; + state->x.have = 0; + } + + /* update progress */ + len -= n; + buf = (char *)buf + n; + got += n; + state->x.pos += n; + } while (len); + + /* return number of bytes read into user buffer */ + return got; +} + +/* -- see zlib.h -- */ +int ZEXPORT gzread(file, buf, len) + gzFile file; + voidp buf; + unsigned len; +{ + gz_statep state; + + /* get internal structure */ + if (file == NULL) + return -1; + state = (gz_statep)file; + + /* check that we're reading and that there's no (serious) error */ + if (state->mode != GZ_READ || + (state->err != Z_OK && state->err != Z_BUF_ERROR)) + return -1; + + /* since an int is returned, make sure len fits in one, otherwise return + with an error (this avoids a flaw in the interface) */ + if ((int)len < 0) { + gz_error(state, Z_STREAM_ERROR, "request does not fit in an int"); + return -1; + } + + /* read len or fewer bytes to buf */ + len = gz_read(state, buf, len); + + /* check for an error */ + if (len == 0 && state->err != Z_OK && state->err != Z_BUF_ERROR) + return -1; + + /* return the number of bytes read (this is assured to fit in an int) */ + return (int)len; +} + +/* -- see zlib.h -- */ +z_size_t ZEXPORT gzfread(buf, size, nitems, file) + voidp buf; + z_size_t size; + z_size_t nitems; + gzFile file; +{ + z_size_t len; + gz_statep state; + + /* get internal structure */ + if (file == NULL) + return 0; + state = (gz_statep)file; + + /* check that we're reading and that there's no (serious) error */ + if (state->mode != GZ_READ || + (state->err != Z_OK && state->err != Z_BUF_ERROR)) + return 0; + + /* compute bytes to read -- error on overflow */ + len = nitems * size; + if (size && len / size != nitems) { + gz_error(state, Z_STREAM_ERROR, "request does not fit in a size_t"); + return 0; + } + + /* read len or fewer bytes to buf, return the number of full items read */ + return len ? gz_read(state, buf, len) / size : 0; +} + +/* -- see zlib.h -- */ +#ifdef Z_PREFIX_SET +# undef z_gzgetc +#else +# undef gzgetc +#endif +int ZEXPORT gzgetc(file) + gzFile file; +{ + int ret; + unsigned char buf[1]; + gz_statep state; + + /* get internal structure */ + if (file == NULL) + return -1; + state = (gz_statep)file; + + /* check that we're reading and that there's no (serious) error */ + if (state->mode != GZ_READ || + (state->err != Z_OK && state->err != Z_BUF_ERROR)) + return -1; + + /* try output buffer (no need to check for skip request) */ + if (state->x.have) { + state->x.have--; + state->x.pos++; + return *(state->x.next)++; + } + + /* nothing there -- try gz_read() */ + ret = gz_read(state, buf, 1); + return ret < 1 ? -1 : buf[0]; +} + +int ZEXPORT gzgetc_(file) +gzFile file; +{ + return gzgetc(file); +} + +/* -- see zlib.h -- */ +int ZEXPORT gzungetc(c, file) + int c; + gzFile file; +{ + gz_statep state; + + /* get internal structure */ + if (file == NULL) + return -1; + state = (gz_statep)file; + + /* check that we're reading and that there's no (serious) error */ + if (state->mode != GZ_READ || + (state->err != Z_OK && state->err != Z_BUF_ERROR)) + return -1; + + /* process a skip request */ + if (state->seek) { + state->seek = 0; + if (gz_skip(state, state->skip) == -1) + return -1; + } + + /* can't push EOF */ + if (c < 0) + return -1; + + /* if output buffer empty, put byte at end (allows more pushing) */ + if (state->x.have == 0) { + state->x.have = 1; + state->x.next = state->out + (state->size << 1) - 1; + state->x.next[0] = (unsigned char)c; + state->x.pos--; + state->past = 0; + return c; + } + + /* if no room, give up (must have already done a gzungetc()) */ + if (state->x.have == (state->size << 1)) { + gz_error(state, Z_DATA_ERROR, "out of room to push characters"); + return -1; + } + + /* slide output data if needed and insert byte before existing data */ + if (state->x.next == state->out) { + unsigned char *src = state->out + state->x.have; + unsigned char *dest = state->out + (state->size << 1); + while (src > state->out) + *--dest = *--src; + state->x.next = dest; + } + state->x.have++; + state->x.next--; + state->x.next[0] = (unsigned char)c; + state->x.pos--; + state->past = 0; + return c; +} + +/* -- see zlib.h -- */ +char * ZEXPORT gzgets(file, buf, len) + gzFile file; + char *buf; + int len; +{ + unsigned left, n; + char *str; + unsigned char *eol; + gz_statep state; + + /* check parameters and get internal structure */ + if (file == NULL || buf == NULL || len < 1) + return NULL; + state = (gz_statep)file; + + /* check that we're reading and that there's no (serious) error */ + if (state->mode != GZ_READ || + (state->err != Z_OK && state->err != Z_BUF_ERROR)) + return NULL; + + /* process a skip request */ + if (state->seek) { + state->seek = 0; + if (gz_skip(state, state->skip) == -1) + return NULL; + } + + /* copy output bytes up to new line or len - 1, whichever comes first -- + append a terminating zero to the string (we don't check for a zero in + the contents, let the user worry about that) */ + str = buf; + left = (unsigned)len - 1; + if (left) do { + /* assure that something is in the output buffer */ + if (state->x.have == 0 && gz_fetch(state) == -1) + return NULL; /* error */ + if (state->x.have == 0) { /* end of file */ + state->past = 1; /* read past end */ + break; /* return what we have */ + } + + /* look for end-of-line in current output buffer */ + n = state->x.have > left ? left : state->x.have; + eol = (unsigned char *)memchr(state->x.next, '\n', n); + if (eol != NULL) + n = (unsigned)(eol - state->x.next) + 1; + + /* copy through end-of-line, or remainder if not found */ + memcpy(buf, state->x.next, n); + state->x.have -= n; + state->x.next += n; + state->x.pos += n; + left -= n; + buf += n; + } while (left && eol == NULL); + + /* return terminated string, or if nothing, end of file */ + if (buf == str) + return NULL; + buf[0] = 0; + return str; +} + +/* -- see zlib.h -- */ +int ZEXPORT gzdirect(file) + gzFile file; +{ + gz_statep state; + + /* get internal structure */ + if (file == NULL) + return 0; + state = (gz_statep)file; + + /* if the state is not known, but we can find out, then do so (this is + mainly for right after a gzopen() or gzdopen()) */ + if (state->mode == GZ_READ && state->how == LOOK && state->x.have == 0) + (void)gz_look(state); + + /* return 1 if transparent, 0 if processing a gzip stream */ + return state->direct; +} + +/* -- see zlib.h -- */ +int ZEXPORT gzclose_r(file) + gzFile file; +{ + int ret, err; + gz_statep state; + + /* get internal structure */ + if (file == NULL) + return Z_STREAM_ERROR; + state = (gz_statep)file; + + /* check that we're reading */ + if (state->mode != GZ_READ) + return Z_STREAM_ERROR; + + /* free memory and close file */ + if (state->size) { + inflateEnd(&(state->strm)); + free(state->out); + free(state->in); + } + err = state->err == Z_BUF_ERROR ? Z_BUF_ERROR : Z_OK; + gz_error(state, Z_OK, NULL); + free(state->path); + ret = close(state->fd); + free(state); + return ret ? Z_ERRNO : err; +} diff --git a/zlib/gzwrite.c b/zlib/gzwrite.c new file mode 100644 index 00000000..4d22f3c8 --- /dev/null +++ b/zlib/gzwrite.c @@ -0,0 +1,670 @@ +/* gzwrite.c -- zlib functions for writing gzip files + * Copyright (C) 2004-2017 Mark Adler + * For conditions of distribution and use, see copyright notice in zlib.h + */ + +#include "gzguts.h" + +#ifdef _MSC_VER +#define close _close +#define write _write +#endif + +/* Local functions */ +local int gz_init OF((gz_statep)); +local int gz_comp OF((gz_statep, int)); +local int gz_zero OF((gz_statep, z_off64_t)); +local z_size_t gz_write OF((gz_statep, voidpc, z_size_t)); + +/* Initialize state for writing a gzip file. Mark initialization by setting + state->size to non-zero. Return -1 on a memory allocation failure, or 0 on + success. */ +local int gz_init(state) + gz_statep state; +{ + int ret; + z_streamp strm = &(state->strm); + + /* allocate input buffer (double size for gzprintf) */ + state->in = (unsigned char *)malloc(state->want << 1); + if (state->in == NULL) { + gz_error(state, Z_MEM_ERROR, "out of memory"); + return -1; + } + + /* only need output buffer and deflate state if compressing */ + if (!state->direct) { + /* allocate output buffer */ + state->out = (unsigned char *)malloc(state->want); + if (state->out == NULL) { + free(state->in); + gz_error(state, Z_MEM_ERROR, "out of memory"); + return -1; + } + + /* allocate deflate memory, set up for gzip compression */ + strm->zalloc = Z_NULL; + strm->zfree = Z_NULL; + strm->opaque = Z_NULL; + ret = deflateInit2(strm, state->level, Z_DEFLATED, + MAX_WBITS + 16, DEF_MEM_LEVEL, state->strategy); + if (ret != Z_OK) { + free(state->out); + free(state->in); + gz_error(state, Z_MEM_ERROR, "out of memory"); + return -1; + } + strm->next_in = NULL; + } + + /* mark state as initialized */ + state->size = state->want; + + /* initialize write buffer if compressing */ + if (!state->direct) { + strm->avail_out = state->size; + strm->next_out = state->out; + state->x.next = strm->next_out; + } + return 0; +} + +/* Compress whatever is at avail_in and next_in and write to the output file. + Return -1 if there is an error writing to the output file or if gz_init() + fails to allocate memory, otherwise 0. flush is assumed to be a valid + deflate() flush value. If flush is Z_FINISH, then the deflate() state is + reset to start a new gzip stream. If gz->direct is true, then simply write + to the output file without compressing, and ignore flush. */ +local int gz_comp(state, flush) + gz_statep state; + int flush; +{ + int ret, writ; + unsigned have, put, max = ((unsigned)-1 >> 2) + 1; + z_streamp strm = &(state->strm); + + /* allocate memory if this is the first time through */ + if (state->size == 0 && gz_init(state) == -1) + return -1; + + /* write directly if requested */ + if (state->direct) { + while (strm->avail_in) { + put = strm->avail_in > max ? max : strm->avail_in; + writ = write(state->fd, strm->next_in, put); + if (writ < 0) { + gz_error(state, Z_ERRNO, zstrerror()); + return -1; + } + strm->avail_in -= (unsigned)writ; + strm->next_in += writ; + } + return 0; + } + + /* run deflate() on provided input until it produces no more output */ + ret = Z_OK; + do { + /* write out current buffer contents if full, or if flushing, but if + doing Z_FINISH then don't write until we get to Z_STREAM_END */ + if (strm->avail_out == 0 || (flush != Z_NO_FLUSH && + (flush != Z_FINISH || ret == Z_STREAM_END))) { + while (strm->next_out > state->x.next) { + put = strm->next_out - state->x.next > (int)max ? max : + (unsigned)(strm->next_out - state->x.next); + writ = write(state->fd, state->x.next, put); + if (writ < 0) { + gz_error(state, Z_ERRNO, zstrerror()); + return -1; + } + state->x.next += writ; + } + if (strm->avail_out == 0) { + strm->avail_out = state->size; + strm->next_out = state->out; + state->x.next = state->out; + } + } + + /* compress */ + have = strm->avail_out; + ret = deflate(strm, flush); + if (ret == Z_STREAM_ERROR) { + gz_error(state, Z_STREAM_ERROR, + "internal error: deflate stream corrupt"); + return -1; + } + have -= strm->avail_out; + } while (have); + + /* if that completed a deflate stream, allow another to start */ + if (flush == Z_FINISH) + deflateReset(strm); + + /* all done, no errors */ + return 0; +} + +/* Compress len zeros to output. Return -1 on a write error or memory + allocation failure by gz_comp(), or 0 on success. */ +local int gz_zero(state, len) + gz_statep state; + z_off64_t len; +{ + int first; + unsigned n; + z_streamp strm = &(state->strm); + + /* consume whatever's left in the input buffer */ + if (strm->avail_in && gz_comp(state, Z_NO_FLUSH) == -1) + return -1; + + /* compress len zeros (len guaranteed > 0) */ + first = 1; + while (len) { + n = GT_OFF(state->size) || (z_off64_t)state->size > len ? + (unsigned)len : state->size; + if (first) { + memset(state->in, 0, n); + first = 0; + } + strm->avail_in = n; + strm->next_in = state->in; + state->x.pos += n; + if (gz_comp(state, Z_NO_FLUSH) == -1) + return -1; + len -= n; + } + return 0; +} + +/* Write len bytes from buf to file. Return the number of bytes written. If + the returned value is less than len, then there was an error. */ +local z_size_t gz_write(state, buf, len) + gz_statep state; + voidpc buf; + z_size_t len; +{ + z_size_t put = len; + + /* if len is zero, avoid unnecessary operations */ + if (len == 0) + return 0; + + /* allocate memory if this is the first time through */ + if (state->size == 0 && gz_init(state) == -1) + return 0; + + /* check for seek request */ + if (state->seek) { + state->seek = 0; + if (gz_zero(state, state->skip) == -1) + return 0; + } + + /* for small len, copy to input buffer, otherwise compress directly */ + if (len < state->size) { + /* copy to input buffer, compress when full */ + do { + unsigned have, copy; + + if (state->strm.avail_in == 0) + state->strm.next_in = state->in; + have = (unsigned)((state->strm.next_in + state->strm.avail_in) - + state->in); + copy = state->size - have; + if (copy > len) + copy = len; + memcpy(state->in + have, buf, copy); + state->strm.avail_in += copy; + state->x.pos += copy; + buf = (const char *)buf + copy; + len -= copy; + if (len && gz_comp(state, Z_NO_FLUSH) == -1) + return 0; + } while (len); + } + else { + /* consume whatever's left in the input buffer */ + if (state->strm.avail_in && gz_comp(state, Z_NO_FLUSH) == -1) + return 0; + + /* directly compress user buffer to file */ + state->strm.next_in = (z_const Bytef *)buf; + do { + unsigned n = (unsigned)-1; + if (n > len) + n = len; + state->strm.avail_in = n; + state->x.pos += n; + if (gz_comp(state, Z_NO_FLUSH) == -1) + return 0; + len -= n; + } while (len); + } + + /* input was all buffered or compressed */ + return put; +} + +/* -- see zlib.h -- */ +int ZEXPORT gzwrite(file, buf, len) + gzFile file; + voidpc buf; + unsigned len; +{ + gz_statep state; + + /* get internal structure */ + if (file == NULL) + return 0; + state = (gz_statep)file; + + /* check that we're writing and that there's no error */ + if (state->mode != GZ_WRITE || state->err != Z_OK) + return 0; + + /* since an int is returned, make sure len fits in one, otherwise return + with an error (this avoids a flaw in the interface) */ + if ((int)len < 0) { + gz_error(state, Z_DATA_ERROR, "requested length does not fit in int"); + return 0; + } + + /* write len bytes from buf (the return value will fit in an int) */ + return (int)gz_write(state, buf, len); +} + +/* -- see zlib.h -- */ +z_size_t ZEXPORT gzfwrite(buf, size, nitems, file) + voidpc buf; + z_size_t size; + z_size_t nitems; + gzFile file; +{ + z_size_t len; + gz_statep state; + + /* get internal structure */ + if (file == NULL) + return 0; + state = (gz_statep)file; + + /* check that we're writing and that there's no error */ + if (state->mode != GZ_WRITE || state->err != Z_OK) + return 0; + + /* compute bytes to read -- error on overflow */ + len = nitems * size; + if (size && len / size != nitems) { + gz_error(state, Z_STREAM_ERROR, "request does not fit in a size_t"); + return 0; + } + + /* write len bytes to buf, return the number of full items written */ + return len ? gz_write(state, buf, len) / size : 0; +} + +/* -- see zlib.h -- */ +int ZEXPORT gzputc(file, c) + gzFile file; + int c; +{ + unsigned have; + unsigned char buf[1]; + gz_statep state; + z_streamp strm; + + /* get internal structure */ + if (file == NULL) + return -1; + state = (gz_statep)file; + strm = &(state->strm); + + /* check that we're writing and that there's no error */ + if (state->mode != GZ_WRITE || state->err != Z_OK) + return -1; + + /* check for seek request */ + if (state->seek) { + state->seek = 0; + if (gz_zero(state, state->skip) == -1) + return -1; + } + + /* try writing to input buffer for speed (state->size == 0 if buffer not + initialized) */ + if (state->size) { + if (strm->avail_in == 0) + strm->next_in = state->in; + have = (unsigned)((strm->next_in + strm->avail_in) - state->in); + if (have < state->size) { + state->in[have] = (unsigned char)c; + strm->avail_in++; + state->x.pos++; + return c & 0xff; + } + } + + /* no room in buffer or not initialized, use gz_write() */ + buf[0] = (unsigned char)c; + if (gz_write(state, buf, 1) != 1) + return -1; + return c & 0xff; +} + +/* -- see zlib.h -- */ +int ZEXPORT gzputs(file, str) + gzFile file; + const char *str; +{ + int ret; + z_size_t len; + gz_statep state; + + /* get internal structure */ + if (file == NULL) + return -1; + state = (gz_statep)file; + + /* check that we're writing and that there's no error */ + if (state->mode != GZ_WRITE || state->err != Z_OK) + return -1; + + /* write string */ + len = strlen(str); + ret = gz_write(state, str, len); + return ret == 0 && len != 0 ? -1 : ret; +} + +#if defined(STDC) || defined(Z_HAVE_STDARG_H) +#include + +/* -- see zlib.h -- */ +int ZEXPORTVA gzvprintf(gzFile file, const char *format, va_list va) +{ + int len; + unsigned left; + char *next; + gz_statep state; + z_streamp strm; + + /* get internal structure */ + if (file == NULL) + return Z_STREAM_ERROR; + state = (gz_statep)file; + strm = &(state->strm); + + /* check that we're writing and that there's no error */ + if (state->mode != GZ_WRITE || state->err != Z_OK) + return Z_STREAM_ERROR; + + /* make sure we have some buffer space */ + if (state->size == 0 && gz_init(state) == -1) + return state->err; + + /* check for seek request */ + if (state->seek) { + state->seek = 0; + if (gz_zero(state, state->skip) == -1) + return state->err; + } + + /* do the printf() into the input buffer, put length in len -- the input + buffer is double-sized just for this function, so there is guaranteed to + be state->size bytes available after the current contents */ + if (strm->avail_in == 0) + strm->next_in = state->in; + next = (char *)(state->in + (strm->next_in - state->in) + strm->avail_in); + next[state->size - 1] = 0; +#ifdef NO_vsnprintf +# ifdef HAS_vsprintf_void + (void)vsprintf(next, format, va); + for (len = 0; len < state->size; len++) + if (next[len] == 0) break; +# else + len = vsprintf(next, format, va); +# endif +#else +# ifdef HAS_vsnprintf_void + (void)vsnprintf(next, state->size, format, va); + len = strlen(next); +# else + len = vsnprintf(next, state->size, format, va); +# endif +#endif + + /* check that printf() results fit in buffer */ + if (len == 0 || (unsigned)len >= state->size || next[state->size - 1] != 0) + return 0; + + /* update buffer and position, compress first half if past that */ + strm->avail_in += (unsigned)len; + state->x.pos += len; + if (strm->avail_in >= state->size) { + left = strm->avail_in - state->size; + strm->avail_in = state->size; + if (gz_comp(state, Z_NO_FLUSH) == -1) + return state->err; + memcpy(state->in, state->in + state->size, left); + strm->next_in = state->in; + strm->avail_in = left; + } + return len; +} + +int ZEXPORTVA gzprintf(gzFile file, const char *format, ...) +{ + va_list va; + int ret; + + va_start(va, format); + ret = gzvprintf(file, format, va); + va_end(va); + return ret; +} + +#else /* !STDC && !Z_HAVE_STDARG_H */ + +/* -- see zlib.h -- */ +int ZEXPORTVA gzprintf (file, format, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, + a11, a12, a13, a14, a15, a16, a17, a18, a19, a20) + gzFile file; + const char *format; + int a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, + a11, a12, a13, a14, a15, a16, a17, a18, a19, a20; +{ + unsigned len, left; + char *next; + gz_statep state; + z_streamp strm; + + /* get internal structure */ + if (file == NULL) + return Z_STREAM_ERROR; + state = (gz_statep)file; + strm = &(state->strm); + + /* check that can really pass pointer in ints */ + if (sizeof(int) != sizeof(void *)) + return Z_STREAM_ERROR; + + /* check that we're writing and that there's no error */ + if (state->mode != GZ_WRITE || state->err != Z_OK) + return Z_STREAM_ERROR; + + /* make sure we have some buffer space */ + if (state->size == 0 && gz_init(state) == -1) + return state->error; + + /* check for seek request */ + if (state->seek) { + state->seek = 0; + if (gz_zero(state, state->skip) == -1) + return state->error; + } + + /* do the printf() into the input buffer, put length in len -- the input + buffer is double-sized just for this function, so there is guaranteed to + be state->size bytes available after the current contents */ + if (strm->avail_in == 0) + strm->next_in = state->in; + next = (char *)(strm->next_in + strm->avail_in); + next[state->size - 1] = 0; +#ifdef NO_snprintf +# ifdef HAS_sprintf_void + sprintf(next, format, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, + a13, a14, a15, a16, a17, a18, a19, a20); + for (len = 0; len < size; len++) + if (next[len] == 0) + break; +# else + len = sprintf(next, format, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, + a12, a13, a14, a15, a16, a17, a18, a19, a20); +# endif +#else +# ifdef HAS_snprintf_void + snprintf(next, state->size, format, a1, a2, a3, a4, a5, a6, a7, a8, a9, + a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20); + len = strlen(next); +# else + len = snprintf(next, state->size, format, a1, a2, a3, a4, a5, a6, a7, a8, + a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20); +# endif +#endif + + /* check that printf() results fit in buffer */ + if (len == 0 || len >= state->size || next[state->size - 1] != 0) + return 0; + + /* update buffer and position, compress first half if past that */ + strm->avail_in += len; + state->x.pos += len; + if (strm->avail_in >= state->size) { + left = strm->avail_in - state->size; + strm->avail_in = state->size; + if (gz_comp(state, Z_NO_FLUSH) == -1) + return state->err; + memcpy(state->in, state->in + state->size, left); + strm->next_in = state->in; + strm->avail_in = left; + } + return (int)len; +} + +#endif + +/* -- see zlib.h -- */ +int ZEXPORT gzflush(file, flush) + gzFile file; + int flush; +{ + gz_statep state; + + /* get internal structure */ + if (file == NULL) + return Z_STREAM_ERROR; + state = (gz_statep)file; + + /* check that we're writing and that there's no error */ + if (state->mode != GZ_WRITE || state->err != Z_OK) + return Z_STREAM_ERROR; + + /* check flush parameter */ + if (flush < 0 || flush > Z_FINISH) + return Z_STREAM_ERROR; + + /* check for seek request */ + if (state->seek) { + state->seek = 0; + if (gz_zero(state, state->skip) == -1) + return state->err; + } + + /* compress remaining data with requested flush */ + (void)gz_comp(state, flush); + return state->err; +} + +/* -- see zlib.h -- */ +int ZEXPORT gzsetparams(file, level, strategy) + gzFile file; + int level; + int strategy; +{ + gz_statep state; + z_streamp strm; + + /* get internal structure */ + if (file == NULL) + return Z_STREAM_ERROR; + state = (gz_statep)file; + strm = &(state->strm); + + /* check that we're writing and that there's no error */ + if (state->mode != GZ_WRITE || state->err != Z_OK) + return Z_STREAM_ERROR; + + /* if no change is requested, then do nothing */ + if (level == state->level && strategy == state->strategy) + return Z_OK; + + /* check for seek request */ + if (state->seek) { + state->seek = 0; + if (gz_zero(state, state->skip) == -1) + return state->err; + } + + /* change compression parameters for subsequent input */ + if (state->size) { + /* flush previous input with previous parameters before changing */ + if (strm->avail_in && gz_comp(state, Z_BLOCK) == -1) + return state->err; + deflateParams(strm, level, strategy); + } + state->level = level; + state->strategy = strategy; + return Z_OK; +} + +/* -- see zlib.h -- */ +int ZEXPORT gzclose_w(file) + gzFile file; +{ + int ret = Z_OK; + gz_statep state; + + /* get internal structure */ + if (file == NULL) + return Z_STREAM_ERROR; + state = (gz_statep)file; + + /* check that we're writing */ + if (state->mode != GZ_WRITE) + return Z_STREAM_ERROR; + + /* check for seek request */ + if (state->seek) { + state->seek = 0; + if (gz_zero(state, state->skip) == -1) + ret = state->err; + } + + /* flush, free memory, and close file */ + if (gz_comp(state, Z_FINISH) == -1) + ret = state->err; + if (state->size) { + if (!state->direct) { + (void)deflateEnd(&(state->strm)); + free(state->out); + } + free(state->in); + } + gz_error(state, Z_OK, NULL); + free(state->path); + if (close(state->fd) == -1) + ret = Z_ERRNO; + free(state); + return ret; +} diff --git a/zlib/infback.c b/zlib/infback.c index 1e03e1ba..20e73939 100644 --- a/zlib/infback.c +++ b/zlib/infback.c @@ -1,5 +1,5 @@ /* infback.c -- inflate using a call-back interface - * Copyright (C) 1995-2005 Mark Adler + * Copyright (C) 1995-2016 Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -42,20 +42,29 @@ int stream_size; return Z_STREAM_ERROR; strm->msg = Z_NULL; /* in case we return an error */ if (strm->zalloc == (alloc_func)0) { +#ifdef Z_SOLO + return Z_STREAM_ERROR; +#else strm->zalloc = zcalloc; strm->opaque = (voidpf)0; +#endif } - if (strm->zfree == (free_func)0) strm->zfree = zcfree; + if (strm->zfree == (free_func)0) +#ifdef Z_SOLO + return Z_STREAM_ERROR; +#else + strm->zfree = zcfree; +#endif state = (struct inflate_state FAR *)ZALLOC(strm, 1, sizeof(struct inflate_state)); if (state == Z_NULL) return Z_MEM_ERROR; Tracev((stderr, "inflate: allocated\n")); strm->state = (struct internal_state FAR *)state; state->dmax = 32768U; - state->wbits = windowBits; + state->wbits = (uInt)windowBits; state->wsize = 1U << windowBits; state->window = window; - state->write = 0; + state->wnext = 0; state->whave = 0; return Z_OK; } @@ -246,14 +255,14 @@ out_func out; void FAR *out_desc; { struct inflate_state FAR *state; - unsigned char FAR *next; /* next input */ + z_const unsigned char FAR *next; /* next input */ unsigned char FAR *put; /* next output */ unsigned have, left; /* available input and output */ unsigned long hold; /* bit buffer */ unsigned bits; /* bits in bit buffer */ unsigned copy; /* number of stored or match bytes to copy */ unsigned char FAR *from; /* where to copy match bytes from */ - code this; /* current decoding table entry */ + code here; /* current decoding table entry */ code last; /* parent table entry */ unsigned len; /* length to copy for repeats, bits to drop */ int ret; /* return code */ @@ -389,19 +398,18 @@ void FAR *out_desc; state->have = 0; while (state->have < state->nlen + state->ndist) { for (;;) { - this = state->lencode[BITS(state->lenbits)]; - if ((unsigned)(this.bits) <= bits) break; + here = state->lencode[BITS(state->lenbits)]; + if ((unsigned)(here.bits) <= bits) break; PULLBYTE(); } - if (this.val < 16) { - NEEDBITS(this.bits); - DROPBITS(this.bits); - state->lens[state->have++] = this.val; + if (here.val < 16) { + DROPBITS(here.bits); + state->lens[state->have++] = here.val; } else { - if (this.val == 16) { - NEEDBITS(this.bits + 2); - DROPBITS(this.bits); + if (here.val == 16) { + NEEDBITS(here.bits + 2); + DROPBITS(here.bits); if (state->have == 0) { strm->msg = (char *)"invalid bit length repeat"; state->mode = BAD; @@ -411,16 +419,16 @@ void FAR *out_desc; copy = 3 + BITS(2); DROPBITS(2); } - else if (this.val == 17) { - NEEDBITS(this.bits + 3); - DROPBITS(this.bits); + else if (here.val == 17) { + NEEDBITS(here.bits + 3); + DROPBITS(here.bits); len = 0; copy = 3 + BITS(3); DROPBITS(3); } else { - NEEDBITS(this.bits + 7); - DROPBITS(this.bits); + NEEDBITS(here.bits + 7); + DROPBITS(here.bits); len = 0; copy = 11 + BITS(7); DROPBITS(7); @@ -438,7 +446,16 @@ void FAR *out_desc; /* handle error breaks in while */ if (state->mode == BAD) break; - /* build code tables */ + /* check for end-of-block code (better have one) */ + if (state->lens[256] == 0) { + strm->msg = (char *)"invalid code -- missing end-of-block"; + state->mode = BAD; + break; + } + + /* build code tables -- note: do not change the lenbits or distbits + values here (9 and 6) without reading the comments in inftrees.h + concerning the ENOUGH constants, which depend on those values */ state->next = state->codes; state->lencode = (code const FAR *)(state->next); state->lenbits = 9; @@ -474,28 +491,28 @@ void FAR *out_desc; /* get a literal, length, or end-of-block code */ for (;;) { - this = state->lencode[BITS(state->lenbits)]; - if ((unsigned)(this.bits) <= bits) break; + here = state->lencode[BITS(state->lenbits)]; + if ((unsigned)(here.bits) <= bits) break; PULLBYTE(); } - if (this.op && (this.op & 0xf0) == 0) { - last = this; + if (here.op && (here.op & 0xf0) == 0) { + last = here; for (;;) { - this = state->lencode[last.val + + here = state->lencode[last.val + (BITS(last.bits + last.op) >> last.bits)]; - if ((unsigned)(last.bits + this.bits) <= bits) break; + if ((unsigned)(last.bits + here.bits) <= bits) break; PULLBYTE(); } DROPBITS(last.bits); } - DROPBITS(this.bits); - state->length = (unsigned)this.val; + DROPBITS(here.bits); + state->length = (unsigned)here.val; /* process literal */ - if (this.op == 0) { - Tracevv((stderr, this.val >= 0x20 && this.val < 0x7f ? + if (here.op == 0) { + Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ? "inflate: literal '%c'\n" : - "inflate: literal 0x%02x\n", this.val)); + "inflate: literal 0x%02x\n", here.val)); ROOM(); *put++ = (unsigned char)(state->length); left--; @@ -504,21 +521,21 @@ void FAR *out_desc; } /* process end of block */ - if (this.op & 32) { + if (here.op & 32) { Tracevv((stderr, "inflate: end of block\n")); state->mode = TYPE; break; } /* invalid code */ - if (this.op & 64) { + if (here.op & 64) { strm->msg = (char *)"invalid literal/length code"; state->mode = BAD; break; } /* length code -- get extra bits, if any */ - state->extra = (unsigned)(this.op) & 15; + state->extra = (unsigned)(here.op) & 15; if (state->extra != 0) { NEEDBITS(state->extra); state->length += BITS(state->extra); @@ -528,30 +545,30 @@ void FAR *out_desc; /* get distance code */ for (;;) { - this = state->distcode[BITS(state->distbits)]; - if ((unsigned)(this.bits) <= bits) break; + here = state->distcode[BITS(state->distbits)]; + if ((unsigned)(here.bits) <= bits) break; PULLBYTE(); } - if ((this.op & 0xf0) == 0) { - last = this; + if ((here.op & 0xf0) == 0) { + last = here; for (;;) { - this = state->distcode[last.val + + here = state->distcode[last.val + (BITS(last.bits + last.op) >> last.bits)]; - if ((unsigned)(last.bits + this.bits) <= bits) break; + if ((unsigned)(last.bits + here.bits) <= bits) break; PULLBYTE(); } DROPBITS(last.bits); } - DROPBITS(this.bits); - if (this.op & 64) { + DROPBITS(here.bits); + if (here.op & 64) { strm->msg = (char *)"invalid distance code"; state->mode = BAD; break; } - state->offset = (unsigned)this.val; + state->offset = (unsigned)here.val; /* get distance extra bits, if any */ - state->extra = (unsigned)(this.op) & 15; + state->extra = (unsigned)(here.op) & 15; if (state->extra != 0) { NEEDBITS(state->extra); state->offset += BITS(state->extra); diff --git a/zlib/inffast.c b/zlib/inffast.c index fa31cad9..f14174cd 100644 --- a/zlib/inffast.c +++ b/zlib/inffast.c @@ -1,5 +1,5 @@ /* inffast.c -- fast decoding - * Copyright (C) 1995-2004 Mark Adler + * Copyright (C) 1995-2017 Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -8,26 +8,9 @@ #include "inflate.h" #include "inffast.h" -#ifndef ASMINF - -/* Allow machine dependent optimization for post-increment or pre-increment. - Based on testing to date, - Pre-increment preferred for: - - PowerPC G3 (Adler) - - MIPS R5000 (Randers-Pehrson) - Post-increment preferred for: - - none - No measurable difference: - - Pentium III (Anderson) - - M68060 (Nikl) - */ -#ifdef POSTINC -# define OFF 0 -# define PUP(a) *(a)++ +#ifdef ASMINF +# pragma message("Assembler code may have bugs -- use at your own risk") #else -# define OFF 1 -# define PUP(a) *++(a) -#endif /* Decode literal, length, and distance codes and write out the resulting @@ -64,13 +47,13 @@ requires strm->avail_out >= 258 for each loop to avoid checking for output space. */ -void inflate_fast(strm, start) +void ZLIB_INTERNAL inflate_fast(strm, start) z_streamp strm; unsigned start; /* inflate()'s starting value for strm->avail_out */ { struct inflate_state FAR *state; - unsigned char FAR *in; /* local strm->next_in */ - unsigned char FAR *last; /* while in < last, enough input available */ + z_const unsigned char FAR *in; /* local strm->next_in */ + z_const unsigned char FAR *last; /* have enough input while in < last */ unsigned char FAR *out; /* local strm->next_out */ unsigned char FAR *beg; /* inflate()'s initial strm->next_out */ unsigned char FAR *end; /* while out < end, enough space available */ @@ -79,7 +62,7 @@ unsigned start; /* inflate()'s starting value for strm->avail_out */ #endif unsigned wsize; /* window size or zero if not using window */ unsigned whave; /* valid bytes in the window */ - unsigned write; /* window write index */ + unsigned wnext; /* window write index */ unsigned char FAR *window; /* allocated sliding window, if wsize != 0 */ unsigned long hold; /* local strm->hold */ unsigned bits; /* local strm->bits */ @@ -87,7 +70,7 @@ unsigned start; /* inflate()'s starting value for strm->avail_out */ code const FAR *dcode; /* local strm->distcode */ unsigned lmask; /* mask for first level of length codes */ unsigned dmask; /* mask for first level of distance codes */ - code this; /* retrieved table entry */ + code here; /* retrieved table entry */ unsigned op; /* code bits, operation, extra bits, or */ /* window position, window bytes to copy */ unsigned len; /* match length, unused bytes */ @@ -96,9 +79,9 @@ unsigned start; /* inflate()'s starting value for strm->avail_out */ /* copy state to local variables */ state = (struct inflate_state FAR *)strm->state; - in = strm->next_in - OFF; + in = strm->next_in; last = in + (strm->avail_in - 5); - out = strm->next_out - OFF; + out = strm->next_out; beg = out - (start - strm->avail_out); end = out + (strm->avail_out - 257); #ifdef INFLATE_STRICT @@ -106,7 +89,7 @@ unsigned start; /* inflate()'s starting value for strm->avail_out */ #endif wsize = state->wsize; whave = state->whave; - write = state->write; + wnext = state->wnext; window = state->window; hold = state->hold; bits = state->bits; @@ -119,29 +102,29 @@ unsigned start; /* inflate()'s starting value for strm->avail_out */ input data or output space */ do { if (bits < 15) { - hold += (unsigned long)(PUP(in)) << bits; + hold += (unsigned long)(*in++) << bits; bits += 8; - hold += (unsigned long)(PUP(in)) << bits; + hold += (unsigned long)(*in++) << bits; bits += 8; } - this = lcode[hold & lmask]; + here = lcode[hold & lmask]; dolen: - op = (unsigned)(this.bits); + op = (unsigned)(here.bits); hold >>= op; bits -= op; - op = (unsigned)(this.op); + op = (unsigned)(here.op); if (op == 0) { /* literal */ - Tracevv((stderr, this.val >= 0x20 && this.val < 0x7f ? + Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ? "inflate: literal '%c'\n" : - "inflate: literal 0x%02x\n", this.val)); - PUP(out) = (unsigned char)(this.val); + "inflate: literal 0x%02x\n", here.val)); + *out++ = (unsigned char)(here.val); } else if (op & 16) { /* length base */ - len = (unsigned)(this.val); + len = (unsigned)(here.val); op &= 15; /* number of extra bits */ if (op) { if (bits < op) { - hold += (unsigned long)(PUP(in)) << bits; + hold += (unsigned long)(*in++) << bits; bits += 8; } len += (unsigned)hold & ((1U << op) - 1); @@ -150,25 +133,25 @@ unsigned start; /* inflate()'s starting value for strm->avail_out */ } Tracevv((stderr, "inflate: length %u\n", len)); if (bits < 15) { - hold += (unsigned long)(PUP(in)) << bits; + hold += (unsigned long)(*in++) << bits; bits += 8; - hold += (unsigned long)(PUP(in)) << bits; + hold += (unsigned long)(*in++) << bits; bits += 8; } - this = dcode[hold & dmask]; + here = dcode[hold & dmask]; dodist: - op = (unsigned)(this.bits); + op = (unsigned)(here.bits); hold >>= op; bits -= op; - op = (unsigned)(this.op); + op = (unsigned)(here.op); if (op & 16) { /* distance base */ - dist = (unsigned)(this.val); + dist = (unsigned)(here.val); op &= 15; /* number of extra bits */ if (bits < op) { - hold += (unsigned long)(PUP(in)) << bits; + hold += (unsigned long)(*in++) << bits; bits += 8; if (bits < op) { - hold += (unsigned long)(PUP(in)) << bits; + hold += (unsigned long)(*in++) << bits; bits += 8; } } @@ -187,79 +170,101 @@ unsigned start; /* inflate()'s starting value for strm->avail_out */ if (dist > op) { /* see if copy from window */ op = dist - op; /* distance back in window */ if (op > whave) { - strm->msg = (char *)"invalid distance too far back"; - state->mode = BAD; - break; + if (state->sane) { + strm->msg = + (char *)"invalid distance too far back"; + state->mode = BAD; + break; + } +#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR + if (len <= op - whave) { + do { + *out++ = 0; + } while (--len); + continue; + } + len -= op - whave; + do { + *out++ = 0; + } while (--op > whave); + if (op == 0) { + from = out - dist; + do { + *out++ = *from++; + } while (--len); + continue; + } +#endif } - from = window - OFF; - if (write == 0) { /* very common case */ + from = window; + if (wnext == 0) { /* very common case */ from += wsize - op; if (op < len) { /* some from window */ len -= op; do { - PUP(out) = PUP(from); + *out++ = *from++; } while (--op); from = out - dist; /* rest from output */ } } - else if (write < op) { /* wrap around window */ - from += wsize + write - op; - op -= write; + else if (wnext < op) { /* wrap around window */ + from += wsize + wnext - op; + op -= wnext; if (op < len) { /* some from end of window */ len -= op; do { - PUP(out) = PUP(from); + *out++ = *from++; } while (--op); - from = window - OFF; - if (write < len) { /* some from start of window */ - op = write; + from = window; + if (wnext < len) { /* some from start of window */ + op = wnext; len -= op; do { - PUP(out) = PUP(from); + *out++ = *from++; } while (--op); from = out - dist; /* rest from output */ } } } else { /* contiguous in window */ - from += write - op; + from += wnext - op; if (op < len) { /* some from window */ len -= op; do { - PUP(out) = PUP(from); + *out++ = *from++; } while (--op); from = out - dist; /* rest from output */ } } while (len > 2) { - PUP(out) = PUP(from); - PUP(out) = PUP(from); - PUP(out) = PUP(from); + *out++ = *from++; + *out++ = *from++; + *out++ = *from++; len -= 3; } if (len) { - PUP(out) = PUP(from); + *out++ = *from++; if (len > 1) - PUP(out) = PUP(from); + *out++ = *from++; } } else { from = out - dist; /* copy direct from output */ do { /* minimum length is three */ - PUP(out) = PUP(from); - PUP(out) = PUP(from); - PUP(out) = PUP(from); + *out++ = *from++; + *out++ = *from++; + *out++ = *from++; len -= 3; } while (len > 2); if (len) { - PUP(out) = PUP(from); + *out++ = *from++; if (len > 1) - PUP(out) = PUP(from); + *out++ = *from++; } } } else if ((op & 64) == 0) { /* 2nd level distance code */ - this = dcode[this.val + (hold & ((1U << op) - 1))]; + here = dcode[here.val + (hold & ((1U << op) - 1))]; goto dodist; } else { @@ -269,7 +274,7 @@ unsigned start; /* inflate()'s starting value for strm->avail_out */ } } else if ((op & 64) == 0) { /* 2nd level length code */ - this = lcode[this.val + (hold & ((1U << op) - 1))]; + here = lcode[here.val + (hold & ((1U << op) - 1))]; goto dolen; } else if (op & 32) { /* end-of-block */ @@ -291,8 +296,8 @@ unsigned start; /* inflate()'s starting value for strm->avail_out */ hold &= (1U << bits) - 1; /* update state and return */ - strm->next_in = in + OFF; - strm->next_out = out + OFF; + strm->next_in = in; + strm->next_out = out; strm->avail_in = (unsigned)(in < last ? 5 + (last - in) : 5 - (in - last)); strm->avail_out = (unsigned)(out < end ? 257 + (end - out) : 257 - (out - end)); @@ -305,7 +310,7 @@ unsigned start; /* inflate()'s starting value for strm->avail_out */ inflate_fast() speedups that turned out slower (on a PowerPC G3 750CXe): - Using bit fields for code structure - Different op definition to avoid & for extra bits (do & for table bits) - - Three separate decoding do-loops for direct, window, and write == 0 + - Three separate decoding do-loops for direct, window, and wnext == 0 - Special case for distance > 1 copies to do overlapped load and store copy - Explicit branch predictions (based on measured branch probabilities) - Deferring match copy and interspersed it with decoding subsequent codes diff --git a/zlib/inffast.h b/zlib/inffast.h index 614fa787..e1e6db4a 100644 --- a/zlib/inffast.h +++ b/zlib/inffast.h @@ -1,5 +1,5 @@ /* inffast.h -- header to use inffast.c - * Copyright (C) 1995-2003 Mark Adler + * Copyright (C) 1995-2003, 2010 Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -8,4 +8,4 @@ subject to change. Applications should only use zlib.h. */ -void inflate_fast OF((z_streamp strm, unsigned start)); +void ZLIB_INTERNAL inflate_fast OF((z_streamp strm, unsigned start)); diff --git a/zlib/inffixed.h b/zlib/inffixed.h index 423d5c5b..0b29a5ad 100644 --- a/zlib/inffixed.h +++ b/zlib/inffixed.h @@ -2,9 +2,9 @@ * Generated automatically by makefixed(). */ - /* WARNING: this file should *not* be used by applications. It - is part of the implementation of the compression library and - is subject to change. Applications should only use zlib.h. + /* WARNING: this file should *not* be used by applications. + It is part of the implementation of this library and is + subject to change. Applications should only use zlib.h. */ static const code lenfix[512] = { diff --git a/zlib/inflate.c b/zlib/inflate.c index 33ea9029..5c29e06e 100644 --- a/zlib/inflate.c +++ b/zlib/inflate.c @@ -1,5 +1,5 @@ /* inflate.c -- zlib decompression - * Copyright (C) 1995-2005 Mark Adler + * Copyright (C) 1995-2016 Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -45,7 +45,7 @@ * - Rearrange window copies in inflate_fast() for speed and simplification * - Unroll last copy for window match in inflate_fast() * - Use local copies of window variables in inflate_fast() for speed - * - Pull out common write == 0 case for speed in inflate_fast() + * - Pull out common wnext == 0 case for speed in inflate_fast() * - Make op and len in inflate_fast() unsigned for consistency * - Add FAR to lcode and dcode declarations in inflate_fast() * - Simplified bad distance check in inflate_fast() @@ -92,37 +92,156 @@ #endif /* function prototypes */ +local int inflateStateCheck OF((z_streamp strm)); local void fixedtables OF((struct inflate_state FAR *state)); -local int updatewindow OF((z_streamp strm, unsigned out)); +local int updatewindow OF((z_streamp strm, const unsigned char FAR *end, + unsigned copy)); #ifdef BUILDFIXED void makefixed OF((void)); #endif -local unsigned syncsearch OF((unsigned FAR *have, unsigned char FAR *buf, +local unsigned syncsearch OF((unsigned FAR *have, const unsigned char FAR *buf, unsigned len)); +local int inflateStateCheck(strm) +z_streamp strm; +{ + struct inflate_state FAR *state; + if (strm == Z_NULL || + strm->zalloc == (alloc_func)0 || strm->zfree == (free_func)0) + return 1; + state = (struct inflate_state FAR *)strm->state; + if (state == Z_NULL || state->strm != strm || + state->mode < HEAD || state->mode > SYNC) + return 1; + return 0; +} + +int ZEXPORT inflateResetKeep(strm) +z_streamp strm; +{ + struct inflate_state FAR *state; + + if (inflateStateCheck(strm)) return Z_STREAM_ERROR; + state = (struct inflate_state FAR *)strm->state; + strm->total_in = strm->total_out = state->total = 0; + strm->msg = Z_NULL; + if (state->wrap) /* to support ill-conceived Java test suite */ + strm->adler = state->wrap & 1; + state->mode = HEAD; + state->last = 0; + state->havedict = 0; + state->dmax = 32768U; + state->head = Z_NULL; + state->hold = 0; + state->bits = 0; + state->lencode = state->distcode = state->next = state->codes; + state->sane = 1; + state->back = -1; + Tracev((stderr, "inflate: reset\n")); + return Z_OK; +} + int ZEXPORT inflateReset(strm) z_streamp strm; { struct inflate_state FAR *state; - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; + if (inflateStateCheck(strm)) return Z_STREAM_ERROR; state = (struct inflate_state FAR *)strm->state; - strm->total_in = strm->total_out = state->total = 0; - strm->msg = Z_NULL; - strm->adler = 1; /* to support ill-conceived Java test suite */ - state->mode = HEAD; - state->last = 0; - state->havedict = 0; - state->dmax = 32768U; - state->head = Z_NULL; state->wsize = 0; state->whave = 0; - state->write = 0; - state->hold = 0; - state->bits = 0; - state->lencode = state->distcode = state->next = state->codes; - Tracev((stderr, "inflate: reset\n")); - return Z_OK; + state->wnext = 0; + return inflateResetKeep(strm); +} + +int ZEXPORT inflateReset2(strm, windowBits) +z_streamp strm; +int windowBits; +{ + int wrap; + struct inflate_state FAR *state; + + /* get the state */ + if (inflateStateCheck(strm)) return Z_STREAM_ERROR; + state = (struct inflate_state FAR *)strm->state; + + /* extract wrap request from windowBits parameter */ + if (windowBits < 0) { + wrap = 0; + windowBits = -windowBits; + } + else { + wrap = (windowBits >> 4) + 5; +#ifdef GUNZIP + if (windowBits < 48) + windowBits &= 15; +#endif + } + + /* set number of window bits, free window if different */ + if (windowBits && (windowBits < 8 || windowBits > 15)) + return Z_STREAM_ERROR; + if (state->window != Z_NULL && state->wbits != (unsigned)windowBits) { + ZFREE(strm, state->window); + state->window = Z_NULL; + } + + /* update state and reset the rest of it */ + state->wrap = wrap; + state->wbits = (unsigned)windowBits; + return inflateReset(strm); +} + +int ZEXPORT inflateInit2_(strm, windowBits, version, stream_size) +z_streamp strm; +int windowBits; +const char *version; +int stream_size; +{ + int ret; + struct inflate_state FAR *state; + + if (version == Z_NULL || version[0] != ZLIB_VERSION[0] || + stream_size != (int)(sizeof(z_stream))) + return Z_VERSION_ERROR; + if (strm == Z_NULL) return Z_STREAM_ERROR; + strm->msg = Z_NULL; /* in case we return an error */ + if (strm->zalloc == (alloc_func)0) { +#ifdef Z_SOLO + return Z_STREAM_ERROR; +#else + strm->zalloc = zcalloc; + strm->opaque = (voidpf)0; +#endif + } + if (strm->zfree == (free_func)0) +#ifdef Z_SOLO + return Z_STREAM_ERROR; +#else + strm->zfree = zcfree; +#endif + state = (struct inflate_state FAR *) + ZALLOC(strm, 1, sizeof(struct inflate_state)); + if (state == Z_NULL) return Z_MEM_ERROR; + Tracev((stderr, "inflate: allocated\n")); + strm->state = (struct internal_state FAR *)state; + state->strm = strm; + state->window = Z_NULL; + state->mode = HEAD; /* to pass state test in inflateReset2() */ + ret = inflateReset2(strm, windowBits); + if (ret != Z_OK) { + ZFREE(strm, state); + strm->state = Z_NULL; + } + return ret; +} + +int ZEXPORT inflateInit_(strm, version, stream_size) +z_streamp strm; +const char *version; +int stream_size; +{ + return inflateInit2_(strm, DEF_WBITS, version, stream_size); } int ZEXPORT inflatePrime(strm, bits, value) @@ -132,66 +251,20 @@ int value; { struct inflate_state FAR *state; - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; + if (inflateStateCheck(strm)) return Z_STREAM_ERROR; state = (struct inflate_state FAR *)strm->state; - if (bits > 16 || state->bits + bits > 32) return Z_STREAM_ERROR; + if (bits < 0) { + state->hold = 0; + state->bits = 0; + return Z_OK; + } + if (bits > 16 || state->bits + (uInt)bits > 32) return Z_STREAM_ERROR; value &= (1L << bits) - 1; - state->hold += value << state->bits; - state->bits += bits; + state->hold += (unsigned)value << state->bits; + state->bits += (uInt)bits; return Z_OK; } -int ZEXPORT inflateInit2_(strm, windowBits, version, stream_size) -z_streamp strm; -int windowBits; -const char *version; -int stream_size; -{ - struct inflate_state FAR *state; - - if (version == Z_NULL || version[0] != ZLIB_VERSION[0] || - stream_size != (int)(sizeof(z_stream))) - return Z_VERSION_ERROR; - if (strm == Z_NULL) return Z_STREAM_ERROR; - strm->msg = Z_NULL; /* in case we return an error */ - if (strm->zalloc == (alloc_func)0) { - strm->zalloc = zcalloc; - strm->opaque = (voidpf)0; - } - if (strm->zfree == (free_func)0) strm->zfree = zcfree; - state = (struct inflate_state FAR *) - ZALLOC(strm, 1, sizeof(struct inflate_state)); - if (state == Z_NULL) return Z_MEM_ERROR; - Tracev((stderr, "inflate: allocated\n")); - strm->state = (struct internal_state FAR *)state; - if (windowBits < 0) { - state->wrap = 0; - windowBits = -windowBits; - } - else { - state->wrap = (windowBits >> 4) + 1; -#ifdef GUNZIP - if (windowBits < 48) windowBits &= 15; -#endif - } - if (windowBits < 8 || windowBits > 15) { - ZFREE(strm, state); - strm->state = Z_NULL; - return Z_STREAM_ERROR; - } - state->wbits = (unsigned)windowBits; - state->window = Z_NULL; - return inflateReset(strm); -} - -int ZEXPORT inflateInit_(strm, version, stream_size) -z_streamp strm; -const char *version; -int stream_size; -{ - return inflateInit2_(strm, DEF_WBITS, version, stream_size); -} - /* Return state with length and distance decoding tables and index sizes set to fixed code decoding. Normally this returns fixed tables from inffixed.h. @@ -286,8 +359,8 @@ void makefixed() low = 0; for (;;) { if ((low % 7) == 0) printf("\n "); - printf("{%u,%u,%d}", state.lencode[low].op, state.lencode[low].bits, - state.lencode[low].val); + printf("{%u,%u,%d}", (low & 127) == 99 ? 64 : state.lencode[low].op, + state.lencode[low].bits, state.lencode[low].val); if (++low == size) break; putchar(','); } @@ -320,12 +393,13 @@ void makefixed() output will fall in the output data, making match copies simpler and faster. The advantage may be dependent on the size of the processor's data caches. */ -local int updatewindow(strm, out) +local int updatewindow(strm, end, copy) z_streamp strm; -unsigned out; +const Bytef *end; +unsigned copy; { struct inflate_state FAR *state; - unsigned copy, dist; + unsigned dist; state = (struct inflate_state FAR *)strm->state; @@ -340,30 +414,29 @@ unsigned out; /* if window not in use yet, initialize */ if (state->wsize == 0) { state->wsize = 1U << state->wbits; - state->write = 0; + state->wnext = 0; state->whave = 0; } /* copy state->wsize or less output bytes into the circular window */ - copy = out - strm->avail_out; if (copy >= state->wsize) { - zmemcpy(state->window, strm->next_out - state->wsize, state->wsize); - state->write = 0; + zmemcpy(state->window, end - state->wsize, state->wsize); + state->wnext = 0; state->whave = state->wsize; } else { - dist = state->wsize - state->write; + dist = state->wsize - state->wnext; if (dist > copy) dist = copy; - zmemcpy(state->window + state->write, strm->next_out - copy, dist); + zmemcpy(state->window + state->wnext, end - copy, dist); copy -= dist; if (copy) { - zmemcpy(state->window, strm->next_out - copy, copy); - state->write = copy; + zmemcpy(state->window, end - copy, copy); + state->wnext = copy; state->whave = state->wsize; } else { - state->write += dist; - if (state->write == state->wsize) state->write = 0; + state->wnext += dist; + if (state->wnext == state->wsize) state->wnext = 0; if (state->whave < state->wsize) state->whave += dist; } } @@ -464,11 +537,6 @@ unsigned out; bits -= bits & 7; \ } while (0) -/* Reverse the bytes in a 32-bit value */ -#define REVERSE(q) \ - ((((q) >> 24) & 0xff) + (((q) >> 8) & 0xff00) + \ - (((q) & 0xff00) << 8) + (((q) & 0xff) << 24)) - /* inflate() uses a state machine to process as much input data and generate as much output data as possible before returning. The state machine is @@ -556,7 +624,7 @@ z_streamp strm; int flush; { struct inflate_state FAR *state; - unsigned char FAR *next; /* next input */ + z_const unsigned char FAR *next; /* next input */ unsigned char FAR *put; /* next output */ unsigned have, left; /* available input and output */ unsigned long hold; /* bit buffer */ @@ -564,7 +632,7 @@ int flush; unsigned in, out; /* save starting available input and output */ unsigned copy; /* number of stored or match bytes to copy */ unsigned char FAR *from; /* where to copy match bytes from */ - code this; /* current decoding table entry */ + code here; /* current decoding table entry */ code last; /* parent table entry */ unsigned len; /* length to copy for repeats, bits to drop */ int ret; /* return code */ @@ -574,7 +642,7 @@ int flush; static const unsigned short order[19] = /* permutation of code lengths */ {16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15}; - if (strm == Z_NULL || strm->state == Z_NULL || strm->next_out == Z_NULL || + if (inflateStateCheck(strm) || strm->next_out == Z_NULL || (strm->next_in == Z_NULL && strm->avail_in != 0)) return Z_STREAM_ERROR; @@ -594,6 +662,8 @@ int flush; NEEDBITS(16); #ifdef GUNZIP if ((state->wrap & 2) && hold == 0x8b1f) { /* gzip header */ + if (state->wbits == 0) + state->wbits = 15; state->check = crc32(0L, Z_NULL, 0); CRC2(state->check, hold); INITBITS(); @@ -619,7 +689,9 @@ int flush; } DROPBITS(4); len = BITS(4) + 8; - if (len > state->wbits) { + if (state->wbits == 0) + state->wbits = len; + if (len > 15 || len > state->wbits) { strm->msg = (char *)"invalid window size"; state->mode = BAD; break; @@ -646,14 +718,16 @@ int flush; } if (state->head != Z_NULL) state->head->text = (int)((hold >> 8) & 1); - if (state->flags & 0x0200) CRC2(state->check, hold); + if ((state->flags & 0x0200) && (state->wrap & 4)) + CRC2(state->check, hold); INITBITS(); state->mode = TIME; case TIME: NEEDBITS(32); if (state->head != Z_NULL) state->head->time = hold; - if (state->flags & 0x0200) CRC4(state->check, hold); + if ((state->flags & 0x0200) && (state->wrap & 4)) + CRC4(state->check, hold); INITBITS(); state->mode = OS; case OS: @@ -662,7 +736,8 @@ int flush; state->head->xflags = (int)(hold & 0xff); state->head->os = (int)(hold >> 8); } - if (state->flags & 0x0200) CRC2(state->check, hold); + if ((state->flags & 0x0200) && (state->wrap & 4)) + CRC2(state->check, hold); INITBITS(); state->mode = EXLEN; case EXLEN: @@ -671,7 +746,8 @@ int flush; state->length = (unsigned)(hold); if (state->head != Z_NULL) state->head->extra_len = (unsigned)hold; - if (state->flags & 0x0200) CRC2(state->check, hold); + if ((state->flags & 0x0200) && (state->wrap & 4)) + CRC2(state->check, hold); INITBITS(); } else if (state->head != Z_NULL) @@ -689,7 +765,7 @@ int flush; len + copy > state->head->extra_max ? state->head->extra_max - len : copy); } - if (state->flags & 0x0200) + if ((state->flags & 0x0200) && (state->wrap & 4)) state->check = crc32(state->check, next, copy); have -= copy; next += copy; @@ -708,9 +784,9 @@ int flush; if (state->head != Z_NULL && state->head->name != Z_NULL && state->length < state->head->name_max) - state->head->name[state->length++] = len; + state->head->name[state->length++] = (Bytef)len; } while (len && copy < have); - if (state->flags & 0x0200) + if ((state->flags & 0x0200) && (state->wrap & 4)) state->check = crc32(state->check, next, copy); have -= copy; next += copy; @@ -729,9 +805,9 @@ int flush; if (state->head != Z_NULL && state->head->comment != Z_NULL && state->length < state->head->comm_max) - state->head->comment[state->length++] = len; + state->head->comment[state->length++] = (Bytef)len; } while (len && copy < have); - if (state->flags & 0x0200) + if ((state->flags & 0x0200) && (state->wrap & 4)) state->check = crc32(state->check, next, copy); have -= copy; next += copy; @@ -743,7 +819,7 @@ int flush; case HCRC: if (state->flags & 0x0200) { NEEDBITS(16); - if (hold != (state->check & 0xffff)) { + if ((state->wrap & 4) && hold != (state->check & 0xffff)) { strm->msg = (char *)"header crc mismatch"; state->mode = BAD; break; @@ -760,7 +836,7 @@ int flush; #endif case DICTID: NEEDBITS(32); - strm->adler = state->check = REVERSE(hold); + strm->adler = state->check = ZSWAP32(hold); INITBITS(); state->mode = DICT; case DICT: @@ -771,7 +847,7 @@ int flush; strm->adler = state->check = adler32(0L, Z_NULL, 0); state->mode = TYPE; case TYPE: - if (flush == Z_BLOCK) goto inf_leave; + if (flush == Z_BLOCK || flush == Z_TREES) goto inf_leave; case TYPEDO: if (state->last) { BYTEBITS(); @@ -791,7 +867,11 @@ int flush; fixedtables(state); Tracev((stderr, "inflate: fixed codes block%s\n", state->last ? " (last)" : "")); - state->mode = LEN; /* decode codes */ + state->mode = LEN_; /* decode codes */ + if (flush == Z_TREES) { + DROPBITS(2); + goto inf_leave; + } break; case 2: /* dynamic block */ Tracev((stderr, "inflate: dynamic codes block%s\n", @@ -816,6 +896,9 @@ int flush; Tracev((stderr, "inflate: stored length %u\n", state->length)); INITBITS(); + state->mode = COPY_; + if (flush == Z_TREES) goto inf_leave; + case COPY_: state->mode = COPY; case COPY: copy = state->length; @@ -861,7 +944,7 @@ int flush; while (state->have < 19) state->lens[order[state->have++]] = 0; state->next = state->codes; - state->lencode = (code const FAR *)(state->next); + state->lencode = (const code FAR *)(state->next); state->lenbits = 7; ret = inflate_table(CODES, state->lens, 19, &(state->next), &(state->lenbits), state->work); @@ -876,19 +959,18 @@ int flush; case CODELENS: while (state->have < state->nlen + state->ndist) { for (;;) { - this = state->lencode[BITS(state->lenbits)]; - if ((unsigned)(this.bits) <= bits) break; + here = state->lencode[BITS(state->lenbits)]; + if ((unsigned)(here.bits) <= bits) break; PULLBYTE(); } - if (this.val < 16) { - NEEDBITS(this.bits); - DROPBITS(this.bits); - state->lens[state->have++] = this.val; + if (here.val < 16) { + DROPBITS(here.bits); + state->lens[state->have++] = here.val; } else { - if (this.val == 16) { - NEEDBITS(this.bits + 2); - DROPBITS(this.bits); + if (here.val == 16) { + NEEDBITS(here.bits + 2); + DROPBITS(here.bits); if (state->have == 0) { strm->msg = (char *)"invalid bit length repeat"; state->mode = BAD; @@ -898,16 +980,16 @@ int flush; copy = 3 + BITS(2); DROPBITS(2); } - else if (this.val == 17) { - NEEDBITS(this.bits + 3); - DROPBITS(this.bits); + else if (here.val == 17) { + NEEDBITS(here.bits + 3); + DROPBITS(here.bits); len = 0; copy = 3 + BITS(3); DROPBITS(3); } else { - NEEDBITS(this.bits + 7); - DROPBITS(this.bits); + NEEDBITS(here.bits + 7); + DROPBITS(here.bits); len = 0; copy = 11 + BITS(7); DROPBITS(7); @@ -925,9 +1007,18 @@ int flush; /* handle error breaks in while */ if (state->mode == BAD) break; - /* build code tables */ + /* check for end-of-block code (better have one) */ + if (state->lens[256] == 0) { + strm->msg = (char *)"invalid code -- missing end-of-block"; + state->mode = BAD; + break; + } + + /* build code tables -- note: do not change the lenbits or distbits + values here (9 and 6) without reading the comments in inftrees.h + concerning the ENOUGH constants, which depend on those values */ state->next = state->codes; - state->lencode = (code const FAR *)(state->next); + state->lencode = (const code FAR *)(state->next); state->lenbits = 9; ret = inflate_table(LENS, state->lens, state->nlen, &(state->next), &(state->lenbits), state->work); @@ -936,7 +1027,7 @@ int flush; state->mode = BAD; break; } - state->distcode = (code const FAR *)(state->next); + state->distcode = (const code FAR *)(state->next); state->distbits = 6; ret = inflate_table(DISTS, state->lens + state->nlen, state->ndist, &(state->next), &(state->distbits), state->work); @@ -946,88 +1037,102 @@ int flush; break; } Tracev((stderr, "inflate: codes ok\n")); + state->mode = LEN_; + if (flush == Z_TREES) goto inf_leave; + case LEN_: state->mode = LEN; case LEN: if (have >= 6 && left >= 258) { RESTORE(); inflate_fast(strm, out); LOAD(); + if (state->mode == TYPE) + state->back = -1; break; } + state->back = 0; for (;;) { - this = state->lencode[BITS(state->lenbits)]; - if ((unsigned)(this.bits) <= bits) break; + here = state->lencode[BITS(state->lenbits)]; + if ((unsigned)(here.bits) <= bits) break; PULLBYTE(); } - if (this.op && (this.op & 0xf0) == 0) { - last = this; + if (here.op && (here.op & 0xf0) == 0) { + last = here; for (;;) { - this = state->lencode[last.val + + here = state->lencode[last.val + (BITS(last.bits + last.op) >> last.bits)]; - if ((unsigned)(last.bits + this.bits) <= bits) break; + if ((unsigned)(last.bits + here.bits) <= bits) break; PULLBYTE(); } DROPBITS(last.bits); + state->back += last.bits; } - DROPBITS(this.bits); - state->length = (unsigned)this.val; - if ((int)(this.op) == 0) { - Tracevv((stderr, this.val >= 0x20 && this.val < 0x7f ? + DROPBITS(here.bits); + state->back += here.bits; + state->length = (unsigned)here.val; + if ((int)(here.op) == 0) { + Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ? "inflate: literal '%c'\n" : - "inflate: literal 0x%02x\n", this.val)); + "inflate: literal 0x%02x\n", here.val)); state->mode = LIT; break; } - if (this.op & 32) { + if (here.op & 32) { Tracevv((stderr, "inflate: end of block\n")); + state->back = -1; state->mode = TYPE; break; } - if (this.op & 64) { + if (here.op & 64) { strm->msg = (char *)"invalid literal/length code"; state->mode = BAD; break; } - state->extra = (unsigned)(this.op) & 15; + state->extra = (unsigned)(here.op) & 15; state->mode = LENEXT; case LENEXT: if (state->extra) { NEEDBITS(state->extra); state->length += BITS(state->extra); DROPBITS(state->extra); + state->back += state->extra; } Tracevv((stderr, "inflate: length %u\n", state->length)); + state->was = state->length; state->mode = DIST; case DIST: for (;;) { - this = state->distcode[BITS(state->distbits)]; - if ((unsigned)(this.bits) <= bits) break; + here = state->distcode[BITS(state->distbits)]; + if ((unsigned)(here.bits) <= bits) break; PULLBYTE(); } - if ((this.op & 0xf0) == 0) { - last = this; + if ((here.op & 0xf0) == 0) { + last = here; for (;;) { - this = state->distcode[last.val + + here = state->distcode[last.val + (BITS(last.bits + last.op) >> last.bits)]; - if ((unsigned)(last.bits + this.bits) <= bits) break; + if ((unsigned)(last.bits + here.bits) <= bits) break; PULLBYTE(); } DROPBITS(last.bits); + state->back += last.bits; } - DROPBITS(this.bits); - if (this.op & 64) { + DROPBITS(here.bits); + state->back += here.bits; + if (here.op & 64) { strm->msg = (char *)"invalid distance code"; state->mode = BAD; break; } - state->offset = (unsigned)this.val; - state->extra = (unsigned)(this.op) & 15; + state->offset = (unsigned)here.val; + state->extra = (unsigned)(here.op) & 15; state->mode = DISTEXT; case DISTEXT: if (state->extra) { NEEDBITS(state->extra); state->offset += BITS(state->extra); DROPBITS(state->extra); + state->back += state->extra; } #ifdef INFLATE_STRICT if (state->offset > state->dmax) { @@ -1036,11 +1141,6 @@ int flush; break; } #endif - if (state->offset > state->whave + out - left) { - strm->msg = (char *)"invalid distance too far back"; - state->mode = BAD; - break; - } Tracevv((stderr, "inflate: distance %u\n", state->offset)); state->mode = MATCH; case MATCH: @@ -1048,12 +1148,32 @@ int flush; copy = out - left; if (state->offset > copy) { /* copy from window */ copy = state->offset - copy; - if (copy > state->write) { - copy -= state->write; + if (copy > state->whave) { + if (state->sane) { + strm->msg = (char *)"invalid distance too far back"; + state->mode = BAD; + break; + } +#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR + Trace((stderr, "inflate.c too far\n")); + copy -= state->whave; + if (copy > state->length) copy = state->length; + if (copy > left) copy = left; + left -= copy; + state->length -= copy; + do { + *put++ = 0; + } while (--copy); + if (state->length == 0) state->mode = LEN; + break; +#endif + } + if (copy > state->wnext) { + copy -= state->wnext; from = state->window + (state->wsize - copy); } else - from = state->window + (state->write - copy); + from = state->window + (state->wnext - copy); if (copy > state->length) copy = state->length; } else { /* copy from output */ @@ -1080,15 +1200,15 @@ int flush; out -= left; strm->total_out += out; state->total += out; - if (out) + if ((state->wrap & 4) && out) strm->adler = state->check = UPDATE(state->check, put - out, out); out = left; - if (( + if ((state->wrap & 4) && ( #ifdef GUNZIP state->flags ? hold : #endif - REVERSE(hold)) != state->check) { + ZSWAP32(hold)) != state->check) { strm->msg = (char *)"incorrect data check"; state->mode = BAD; break; @@ -1132,8 +1252,9 @@ int flush; */ inf_leave: RESTORE(); - if (state->wsize || (state->mode < CHECK && out != strm->avail_out)) - if (updatewindow(strm, out)) { + if (state->wsize || (out != strm->avail_out && state->mode < BAD && + (state->mode < CHECK || flush != Z_FINISH))) + if (updatewindow(strm, strm->next_out, out - strm->avail_out)) { state->mode = MEM; return Z_MEM_ERROR; } @@ -1142,11 +1263,12 @@ int flush; strm->total_in += in; strm->total_out += out; state->total += out; - if (state->wrap && out) + if ((state->wrap & 4) && out) strm->adler = state->check = UPDATE(state->check, strm->next_out - out, out); - strm->data_type = state->bits + (state->last ? 64 : 0) + - (state->mode == TYPE ? 128 : 0); + strm->data_type = (int)state->bits + (state->last ? 64 : 0) + + (state->mode == TYPE ? 128 : 0) + + (state->mode == LEN_ || state->mode == COPY_ ? 256 : 0); if (((in == 0 && out == 0) || flush == Z_FINISH) && ret == Z_OK) ret = Z_BUF_ERROR; return ret; @@ -1156,7 +1278,7 @@ int ZEXPORT inflateEnd(strm) z_streamp strm; { struct inflate_state FAR *state; - if (strm == Z_NULL || strm->state == Z_NULL || strm->zfree == (free_func)0) + if (inflateStateCheck(strm)) return Z_STREAM_ERROR; state = (struct inflate_state FAR *)strm->state; if (state->window != Z_NULL) ZFREE(strm, state->window); @@ -1166,43 +1288,59 @@ z_streamp strm; return Z_OK; } +int ZEXPORT inflateGetDictionary(strm, dictionary, dictLength) +z_streamp strm; +Bytef *dictionary; +uInt *dictLength; +{ + struct inflate_state FAR *state; + + /* check state */ + if (inflateStateCheck(strm)) return Z_STREAM_ERROR; + state = (struct inflate_state FAR *)strm->state; + + /* copy dictionary */ + if (state->whave && dictionary != Z_NULL) { + zmemcpy(dictionary, state->window + state->wnext, + state->whave - state->wnext); + zmemcpy(dictionary + state->whave - state->wnext, + state->window, state->wnext); + } + if (dictLength != Z_NULL) + *dictLength = state->whave; + return Z_OK; +} + int ZEXPORT inflateSetDictionary(strm, dictionary, dictLength) z_streamp strm; const Bytef *dictionary; uInt dictLength; { struct inflate_state FAR *state; - unsigned long id; + unsigned long dictid; + int ret; /* check state */ - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; + if (inflateStateCheck(strm)) return Z_STREAM_ERROR; state = (struct inflate_state FAR *)strm->state; if (state->wrap != 0 && state->mode != DICT) return Z_STREAM_ERROR; - /* check for correct dictionary id */ + /* check for correct dictionary identifier */ if (state->mode == DICT) { - id = adler32(0L, Z_NULL, 0); - id = adler32(id, dictionary, dictLength); - if (id != state->check) + dictid = adler32(0L, Z_NULL, 0); + dictid = adler32(dictid, dictionary, dictLength); + if (dictid != state->check) return Z_DATA_ERROR; } - /* copy dictionary to window */ - if (updatewindow(strm, strm->avail_out)) { + /* copy dictionary to window using updatewindow(), which will amend the + existing dictionary if appropriate */ + ret = updatewindow(strm, dictionary + dictLength, dictLength); + if (ret) { state->mode = MEM; return Z_MEM_ERROR; } - if (dictLength > state->wsize) { - zmemcpy(state->window, dictionary + dictLength - state->wsize, - state->wsize); - state->whave = state->wsize; - } - else { - zmemcpy(state->window + state->wsize - dictLength, dictionary, - dictLength); - state->whave = dictLength; - } state->havedict = 1; Tracev((stderr, "inflate: dictionary set\n")); return Z_OK; @@ -1215,7 +1353,7 @@ gz_headerp head; struct inflate_state FAR *state; /* check state */ - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; + if (inflateStateCheck(strm)) return Z_STREAM_ERROR; state = (struct inflate_state FAR *)strm->state; if ((state->wrap & 2) == 0) return Z_STREAM_ERROR; @@ -1238,7 +1376,7 @@ gz_headerp head; */ local unsigned syncsearch(have, buf, len) unsigned FAR *have; -unsigned char FAR *buf; +const unsigned char FAR *buf; unsigned len; { unsigned got; @@ -1268,7 +1406,7 @@ z_streamp strm; struct inflate_state FAR *state; /* check parameters */ - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; + if (inflateStateCheck(strm)) return Z_STREAM_ERROR; state = (struct inflate_state FAR *)strm->state; if (strm->avail_in == 0 && state->bits < 8) return Z_BUF_ERROR; @@ -1315,7 +1453,7 @@ z_streamp strm; { struct inflate_state FAR *state; - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; + if (inflateStateCheck(strm)) return Z_STREAM_ERROR; state = (struct inflate_state FAR *)strm->state; return state->mode == STORED && state->bits == 0; } @@ -1330,8 +1468,7 @@ z_streamp source; unsigned wsize; /* check input */ - if (dest == Z_NULL || source == Z_NULL || source->state == Z_NULL || - source->zalloc == (alloc_func)0 || source->zfree == (free_func)0) + if (inflateStateCheck(source) || dest == Z_NULL) return Z_STREAM_ERROR; state = (struct inflate_state FAR *)source->state; @@ -1350,8 +1487,9 @@ z_streamp source; } /* copy state */ - zmemcpy(dest, source, sizeof(z_stream)); - zmemcpy(copy, state, sizeof(struct inflate_state)); + zmemcpy((voidpf)dest, (voidpf)source, sizeof(z_stream)); + zmemcpy((voidpf)copy, (voidpf)state, sizeof(struct inflate_state)); + copy->strm = dest; if (state->lencode >= state->codes && state->lencode <= state->codes + ENOUGH - 1) { copy->lencode = copy->codes + (state->lencode - state->codes); @@ -1366,3 +1504,58 @@ z_streamp source; dest->state = (struct internal_state FAR *)copy; return Z_OK; } + +int ZEXPORT inflateUndermine(strm, subvert) +z_streamp strm; +int subvert; +{ + struct inflate_state FAR *state; + + if (inflateStateCheck(strm)) return Z_STREAM_ERROR; + state = (struct inflate_state FAR *)strm->state; +#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR + state->sane = !subvert; + return Z_OK; +#else + (void)subvert; + state->sane = 1; + return Z_DATA_ERROR; +#endif +} + +int ZEXPORT inflateValidate(strm, check) +z_streamp strm; +int check; +{ + struct inflate_state FAR *state; + + if (inflateStateCheck(strm)) return Z_STREAM_ERROR; + state = (struct inflate_state FAR *)strm->state; + if (check) + state->wrap |= 4; + else + state->wrap &= ~4; + return Z_OK; +} + +long ZEXPORT inflateMark(strm) +z_streamp strm; +{ + struct inflate_state FAR *state; + + if (inflateStateCheck(strm)) + return -(1L << 16); + state = (struct inflate_state FAR *)strm->state; + return (long)(((unsigned long)((long)state->back)) << 16) + + (state->mode == COPY ? state->length : + (state->mode == MATCH ? state->was - state->length : 0)); +} + +unsigned long ZEXPORT inflateCodesUsed(strm) +z_streamp strm; +{ + struct inflate_state FAR *state; + if (inflateStateCheck(strm)) return (unsigned long)-1; + state = (struct inflate_state FAR *)strm->state; + return (unsigned long)(state->next - state->codes); +} diff --git a/zlib/inflate.h b/zlib/inflate.h index fbbc8714..947db39a 100644 --- a/zlib/inflate.h +++ b/zlib/inflate.h @@ -1,5 +1,5 @@ /* inflate.h -- internal inflate state definition - * Copyright (C) 1995-2004 Mark Adler + * Copyright (C) 1995-2016 Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -18,7 +18,7 @@ /* Possible inflate modes between inflate() calls */ typedef enum { - HEAD, /* i: waiting for magic header */ + HEAD = 16180, /* i: waiting for magic header */ FLAGS, /* i: waiting for method and flags (gzip) */ TIME, /* i: waiting for modification time (gzip) */ OS, /* i: waiting for extra flags and operating system (gzip) */ @@ -32,11 +32,13 @@ typedef enum { TYPE, /* i: waiting for type bits, including last-flag bit */ TYPEDO, /* i: same, but skip check to exit inflate on new block */ STORED, /* i: waiting for stored size (length and complement) */ + COPY_, /* i/o: same as COPY below, but only first time in */ COPY, /* i/o: waiting for input or output to copy stored block */ TABLE, /* i: waiting for dynamic block table lengths */ LENLENS, /* i: waiting for code length code lengths */ CODELENS, /* i: waiting for length/lit and distance code lengths */ - LEN, /* i: waiting for length/lit code */ + LEN_, /* i: same as LEN below, but only first time in */ + LEN, /* i: waiting for length/lit/eob code */ LENEXT, /* i: waiting for length extra bits */ DIST, /* i: waiting for distance code */ DISTEXT, /* i: waiting for distance extra bits */ @@ -53,19 +55,21 @@ typedef enum { /* State transitions between above modes - - (most modes can go to the BAD or MEM mode -- not shown for clarity) + (most modes can go to BAD or MEM on error -- not shown for clarity) Process header: - HEAD -> (gzip) or (zlib) - (gzip) -> FLAGS -> TIME -> OS -> EXLEN -> EXTRA -> NAME - NAME -> COMMENT -> HCRC -> TYPE + HEAD -> (gzip) or (zlib) or (raw) + (gzip) -> FLAGS -> TIME -> OS -> EXLEN -> EXTRA -> NAME -> COMMENT -> + HCRC -> TYPE (zlib) -> DICTID or TYPE DICTID -> DICT -> TYPE + (raw) -> TYPEDO Read deflate blocks: - TYPE -> STORED or TABLE or LEN or CHECK - STORED -> COPY -> TYPE - TABLE -> LENLENS -> CODELENS -> LEN - Read deflate codes: + TYPE -> TYPEDO -> STORED or TABLE or LEN_ or CHECK + STORED -> COPY_ -> COPY -> TYPE + TABLE -> LENLENS -> CODELENS -> LEN_ + LEN_ -> LEN + Read deflate codes in fixed or dynamic block: LEN -> LENEXT or LIT or TYPE LENEXT -> DIST -> DISTEXT -> MATCH -> LEN LIT -> LEN @@ -73,11 +77,14 @@ typedef enum { CHECK -> LENGTH -> DONE */ -/* state maintained between inflate() calls. Approximately 7K bytes. */ +/* State maintained between inflate() calls -- approximately 7K bytes, not + including the allocated sliding window, which is up to 32K bytes. */ struct inflate_state { + z_streamp strm; /* pointer back to this zlib stream */ inflate_mode mode; /* current inflate mode */ int last; /* true if processing last block */ - int wrap; /* bit 0 true for zlib, bit 1 true for gzip */ + int wrap; /* bit 0 true for zlib, bit 1 true for gzip, + bit 2 true to validate check value */ int havedict; /* true if dictionary provided */ int flags; /* gzip header method and flags (0 if zlib) */ unsigned dmax; /* zlib header max distance (INFLATE_STRICT) */ @@ -88,7 +95,7 @@ struct inflate_state { unsigned wbits; /* log base 2 of requested window size */ unsigned wsize; /* window size or zero if not using window */ unsigned whave; /* valid bytes in the window */ - unsigned write; /* window write index */ + unsigned wnext; /* window write index */ unsigned char FAR *window; /* allocated sliding window, if needed */ /* bit accumulator */ unsigned long hold; /* input bit accumulator */ @@ -112,4 +119,7 @@ struct inflate_state { unsigned short lens[320]; /* temporary storage for code lengths */ unsigned short work[288]; /* work area for code table building */ code codes[ENOUGH]; /* space for code tables */ + int sane; /* if false, allow invalid distance too far */ + int back; /* bits back of last unprocessed length/lit */ + unsigned was; /* initial length of match */ }; diff --git a/zlib/inftrees.c b/zlib/inftrees.c index 38ded81c..a49e29cb 100644 --- a/zlib/inftrees.c +++ b/zlib/inftrees.c @@ -1,5 +1,5 @@ /* inftrees.c -- generate Huffman trees for efficient decoding - * Copyright (C) 1995-2005 Mark Adler + * Copyright (C) 1995-2017 Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -9,7 +9,7 @@ #define MAXBITS 15 const char inflate_copyright[] = - " inflate 1.2.3 Copyright 1995-2005 Mark Adler "; + " inflate 1.2.11 Copyright 1995-2017 Mark Adler "; /* If you use the zlib library in a product, an acknowledgment is welcome in the documentation of your product. If for some reason you cannot @@ -29,7 +29,7 @@ const char inflate_copyright[] = table index bits. It will differ if the request is greater than the longest code or if it is less than the shortest code. */ -int inflate_table(type, lens, codes, table, bits, work) +int ZLIB_INTERNAL inflate_table(type, lens, codes, table, bits, work) codetype type; unsigned short FAR *lens; unsigned codes; @@ -50,11 +50,11 @@ unsigned short FAR *work; unsigned fill; /* index for replicating entries */ unsigned low; /* low bits for current root entry */ unsigned mask; /* mask for low root bits */ - code this; /* table entry for duplication */ + code here; /* table entry for duplication */ code FAR *next; /* next available space in table */ const unsigned short FAR *base; /* base value table to use */ const unsigned short FAR *extra; /* extra bits table to use */ - int end; /* use base and extra for symbol > end */ + unsigned match; /* use base and extra for symbol >= match */ unsigned short count[MAXBITS+1]; /* number of codes of each length */ unsigned short offs[MAXBITS+1]; /* offsets in table for each length */ static const unsigned short lbase[31] = { /* Length codes 257..285 base */ @@ -62,7 +62,7 @@ unsigned short FAR *work; 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0}; static const unsigned short lext[31] = { /* Length codes 257..285 extra */ 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18, - 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 201, 196}; + 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 77, 202}; static const unsigned short dbase[32] = { /* Distance codes 0..29 base */ 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, @@ -115,15 +115,15 @@ unsigned short FAR *work; if (count[max] != 0) break; if (root > max) root = max; if (max == 0) { /* no symbols to code at all */ - this.op = (unsigned char)64; /* invalid code marker */ - this.bits = (unsigned char)1; - this.val = (unsigned short)0; - *(*table)++ = this; /* make a table to force an error */ - *(*table)++ = this; + here.op = (unsigned char)64; /* invalid code marker */ + here.bits = (unsigned char)1; + here.val = (unsigned short)0; + *(*table)++ = here; /* make a table to force an error */ + *(*table)++ = here; *bits = 1; return 0; /* no symbols, but wait for decoding to report error */ } - for (min = 1; min <= MAXBITS; min++) + for (min = 1; min < max; min++) if (count[min] != 0) break; if (root < min) root = min; @@ -166,11 +166,10 @@ unsigned short FAR *work; entered in the tables. used keeps track of how many table entries have been allocated from the - provided *table space. It is checked when a LENS table is being made - against the space in *table, ENOUGH, minus the maximum space needed by - the worst case distance code, MAXD. This should never happen, but the - sufficiency of ENOUGH has not been proven exhaustively, hence the check. - This assumes that when type == LENS, bits == 9. + provided *table space. It is checked for LENS and DIST tables against + the constants ENOUGH_LENS and ENOUGH_DISTS to guard against changes in + the initial root table size constants. See the comments in inftrees.h + for more information. sym increments through all symbols, and the loop terminates when all codes of length max, i.e. all codes, have been processed. This @@ -182,19 +181,17 @@ unsigned short FAR *work; switch (type) { case CODES: base = extra = work; /* dummy value--not used */ - end = 19; + match = 20; break; case LENS: base = lbase; - base -= 257; extra = lext; - extra -= 257; - end = 256; + match = 257; break; - default: /* DISTS */ + default: /* DISTS */ base = dbase; extra = dext; - end = -1; + match = 0; } /* initialize state for loop */ @@ -209,24 +206,25 @@ unsigned short FAR *work; mask = used - 1; /* mask for comparing low */ /* check available table space */ - if (type == LENS && used >= ENOUGH - MAXD) + if ((type == LENS && used > ENOUGH_LENS) || + (type == DISTS && used > ENOUGH_DISTS)) return 1; /* process all codes and make table entries */ for (;;) { /* create table entry */ - this.bits = (unsigned char)(len - drop); - if ((int)(work[sym]) < end) { - this.op = (unsigned char)0; - this.val = work[sym]; + here.bits = (unsigned char)(len - drop); + if (work[sym] + 1U < match) { + here.op = (unsigned char)0; + here.val = work[sym]; } - else if ((int)(work[sym]) > end) { - this.op = (unsigned char)(extra[work[sym]]); - this.val = base[work[sym]]; + else if (work[sym] >= match) { + here.op = (unsigned char)(extra[work[sym] - match]); + here.val = base[work[sym] - match]; } else { - this.op = (unsigned char)(32 + 64); /* end of block */ - this.val = 0; + here.op = (unsigned char)(32 + 64); /* end of block */ + here.val = 0; } /* replicate for those indices with low len bits equal to huff */ @@ -235,7 +233,7 @@ unsigned short FAR *work; min = fill; /* save offset to next table */ do { fill -= incr; - next[(huff >> drop) + fill] = this; + next[(huff >> drop) + fill] = here; } while (fill != 0); /* backwards increment the len-bit code huff */ @@ -277,7 +275,8 @@ unsigned short FAR *work; /* check for enough space */ used += 1U << curr; - if (type == LENS && used >= ENOUGH - MAXD) + if ((type == LENS && used > ENOUGH_LENS) || + (type == DISTS && used > ENOUGH_DISTS)) return 1; /* point entry in root table to sub-table */ @@ -288,38 +287,14 @@ unsigned short FAR *work; } } - /* - Fill in rest of table for incomplete codes. This loop is similar to the - loop above in incrementing huff for table indices. It is assumed that - len is equal to curr + drop, so there is no loop needed to increment - through high index bits. When the current sub-table is filled, the loop - drops back to the root table to fill in any remaining entries there. - */ - this.op = (unsigned char)64; /* invalid code marker */ - this.bits = (unsigned char)(len - drop); - this.val = (unsigned short)0; - while (huff != 0) { - /* when done with sub-table, drop back to root table */ - if (drop != 0 && (huff & mask) != low) { - drop = 0; - len = root; - next = *table; - this.bits = (unsigned char)len; - } - - /* put invalid code marker in table */ - next[huff >> drop] = this; - - /* backwards increment the len-bit code huff */ - incr = 1U << (len - 1); - while (huff & incr) - incr >>= 1; - if (incr != 0) { - huff &= incr - 1; - huff += incr; - } - else - huff = 0; + /* fill in remaining table entry if code is incomplete (guaranteed to have + at most one remaining entry, since if the code is incomplete, the + maximum code length that was allowed to get this far is one bit) */ + if (huff != 0) { + here.op = (unsigned char)64; /* invalid code marker */ + here.bits = (unsigned char)(len - drop); + here.val = (unsigned short)0; + next[huff] = here; } /* set return parameters */ diff --git a/zlib/inftrees.h b/zlib/inftrees.h index dc0fd567..a685d8c6 100644 --- a/zlib/inftrees.h +++ b/zlib/inftrees.h @@ -1,5 +1,5 @@ /* inftrees.h -- header to use inftrees.c - * Copyright (C) 1995-2005 Mark Adler + * Copyright (C) 1995-2005, 2010 Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -35,21 +35,28 @@ typedef struct { 01000000 - invalid code */ -/* Maximum size of dynamic tree. The maximum found in a long but non- - exhaustive search was 1444 code structures (852 for length/literals - and 592 for distances, the latter actually the result of an - exhaustive search). The true maximum is not known, but the value - below is more than safe. */ -#define ENOUGH 2048 -#define MAXD 592 +/* Maximum size of the dynamic table. The maximum number of code structures is + 1444, which is the sum of 852 for literal/length codes and 592 for distance + codes. These values were found by exhaustive searches using the program + examples/enough.c found in the zlib distribtution. The arguments to that + program are the number of symbols, the initial root table size, and the + maximum bit length of a code. "enough 286 9 15" for literal/length codes + returns returns 852, and "enough 30 6 15" for distance codes returns 592. + The initial root table size (9 or 6) is found in the fifth argument of the + inflate_table() calls in inflate.c and infback.c. If the root table size is + changed, then these maximum sizes would be need to be recalculated and + updated. */ +#define ENOUGH_LENS 852 +#define ENOUGH_DISTS 592 +#define ENOUGH (ENOUGH_LENS+ENOUGH_DISTS) -/* Type of code to build for inftable() */ +/* Type of code to build for inflate_table() */ typedef enum { CODES, LENS, DISTS } codetype; -extern int inflate_table OF((codetype type, unsigned short FAR *lens, +int ZLIB_INTERNAL inflate_table OF((codetype type, unsigned short FAR *lens, unsigned codes, code FAR * FAR *table, unsigned FAR *bits, unsigned short FAR *work)); diff --git a/zlib/trees.c b/zlib/trees.c index 7a048028..075b7172 100644 --- a/zlib/trees.c +++ b/zlib/trees.c @@ -1,5 +1,6 @@ /* trees.c -- output deflated data using Huffman coding - * Copyright (C) 1995-2005 Jean-loup Gailly + * Copyright (C) 1995-2017 Jean-loup Gailly + * detect_data_type() function provided freely by Cosmin Truta, 2006 * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -35,7 +36,7 @@ #include "deflate.h" -#ifdef DEBUG +#ifdef ZLIB_DEBUG # include #endif @@ -73,11 +74,6 @@ local const uch bl_order[BL_CODES] * probability, to avoid transmitting the lengths for unused bit length codes. */ -#define Buf_size (8 * 2*sizeof(char)) -/* Number of bits used within bi_buf. (bi_buf might be implemented on - * more than 16 bits on some systems.) - */ - /* =========================================================================== * Local data. These are initialized only once. */ @@ -126,13 +122,13 @@ struct static_tree_desc_s { int max_length; /* max bit length for the codes */ }; -local static_tree_desc static_l_desc = +local const static_tree_desc static_l_desc = {static_ltree, extra_lbits, LITERALS+1, L_CODES, MAX_BITS}; -local static_tree_desc static_d_desc = +local const static_tree_desc static_d_desc = {static_dtree, extra_dbits, 0, D_CODES, MAX_BITS}; -local static_tree_desc static_bl_desc = +local const static_tree_desc static_bl_desc = {(const ct_data *)0, extra_blbits, 0, BL_CODES, MAX_BL_BITS}; /* =========================================================================== @@ -150,24 +146,22 @@ local void send_tree OF((deflate_state *s, ct_data *tree, int max_code)); local int build_bl_tree OF((deflate_state *s)); local void send_all_trees OF((deflate_state *s, int lcodes, int dcodes, int blcodes)); -local void compress_block OF((deflate_state *s, ct_data *ltree, - ct_data *dtree)); -local void set_data_type OF((deflate_state *s)); +local void compress_block OF((deflate_state *s, const ct_data *ltree, + const ct_data *dtree)); +local int detect_data_type OF((deflate_state *s)); local unsigned bi_reverse OF((unsigned value, int length)); local void bi_windup OF((deflate_state *s)); local void bi_flush OF((deflate_state *s)); -local void copy_block OF((deflate_state *s, charf *buf, unsigned len, - int header)); #ifdef GEN_TREES_H local void gen_trees_header OF((void)); #endif -#ifndef DEBUG +#ifndef ZLIB_DEBUG # define send_code(s, c, tree) send_bits(s, tree[c].Code, tree[c].Len) /* Send a code of the given tree. c and tree must not have side effects */ -#else /* DEBUG */ +#else /* !ZLIB_DEBUG */ # define send_code(s, c, tree) \ { if (z_verbose>2) fprintf(stderr,"\ncd %3d ",(c)); \ send_bits(s, tree[c].Code, tree[c].Len); } @@ -186,7 +180,7 @@ local void gen_trees_header OF((void)); * Send a value on a given number of bits. * IN assertion: length <= 16 and value fits in length bits. */ -#ifdef DEBUG +#ifdef ZLIB_DEBUG local void send_bits OF((deflate_state *s, int value, int length)); local void send_bits(s, value, length) @@ -203,31 +197,31 @@ local void send_bits(s, value, length) * unused bits in value. */ if (s->bi_valid > (int)Buf_size - length) { - s->bi_buf |= (value << s->bi_valid); + s->bi_buf |= (ush)value << s->bi_valid; put_short(s, s->bi_buf); s->bi_buf = (ush)value >> (Buf_size - s->bi_valid); s->bi_valid += length - Buf_size; } else { - s->bi_buf |= value << s->bi_valid; + s->bi_buf |= (ush)value << s->bi_valid; s->bi_valid += length; } } -#else /* !DEBUG */ +#else /* !ZLIB_DEBUG */ #define send_bits(s, value, length) \ { int len = length;\ if (s->bi_valid > (int)Buf_size - len) {\ - int val = value;\ - s->bi_buf |= (val << s->bi_valid);\ + int val = (int)value;\ + s->bi_buf |= (ush)val << s->bi_valid;\ put_short(s, s->bi_buf);\ s->bi_buf = (ush)val >> (Buf_size - s->bi_valid);\ s->bi_valid += len - Buf_size;\ } else {\ - s->bi_buf |= (value) << s->bi_valid;\ + s->bi_buf |= (ush)(value) << s->bi_valid;\ s->bi_valid += len;\ }\ } -#endif /* DEBUG */ +#endif /* ZLIB_DEBUG */ /* the arguments must not have side effects */ @@ -250,11 +244,13 @@ local void tr_static_init() if (static_init_done) return; /* For some embedded targets, global variables are not initialized: */ +#ifdef NO_INIT_GLOBAL_POINTERS static_l_desc.static_tree = static_ltree; static_l_desc.extra_bits = extra_lbits; static_d_desc.static_tree = static_dtree; static_d_desc.extra_bits = extra_dbits; static_bl_desc.extra_bits = extra_blbits; +#endif /* Initialize the mapping length (0..255) -> length code (0..28) */ length = 0; @@ -319,7 +315,7 @@ local void tr_static_init() * Genererate the file trees.h describing the static trees. */ #ifdef GEN_TREES_H -# ifndef DEBUG +# ifndef ZLIB_DEBUG # include # endif @@ -348,13 +344,14 @@ void gen_trees_header() static_dtree[i].Len, SEPARATOR(i, D_CODES-1, 5)); } - fprintf(header, "const uch _dist_code[DIST_CODE_LEN] = {\n"); + fprintf(header, "const uch ZLIB_INTERNAL _dist_code[DIST_CODE_LEN] = {\n"); for (i = 0; i < DIST_CODE_LEN; i++) { fprintf(header, "%2u%s", _dist_code[i], SEPARATOR(i, DIST_CODE_LEN-1, 20)); } - fprintf(header, "const uch _length_code[MAX_MATCH-MIN_MATCH+1]= {\n"); + fprintf(header, + "const uch ZLIB_INTERNAL _length_code[MAX_MATCH-MIN_MATCH+1]= {\n"); for (i = 0; i < MAX_MATCH-MIN_MATCH+1; i++) { fprintf(header, "%2u%s", _length_code[i], SEPARATOR(i, MAX_MATCH-MIN_MATCH, 20)); @@ -379,7 +376,7 @@ void gen_trees_header() /* =========================================================================== * Initialize the tree data structures for a new zlib stream. */ -void _tr_init(s) +void ZLIB_INTERNAL _tr_init(s) deflate_state *s; { tr_static_init(); @@ -395,8 +392,7 @@ void _tr_init(s) s->bi_buf = 0; s->bi_valid = 0; - s->last_eob_len = 8; /* enough lookahead for inflate */ -#ifdef DEBUG +#ifdef ZLIB_DEBUG s->compressed_len = 0L; s->bits_sent = 0L; #endif @@ -524,12 +520,12 @@ local void gen_bitlen(s, desc) xbits = 0; if (n >= base) xbits = extra[n-base]; f = tree[n].Freq; - s->opt_len += (ulg)f * (bits + xbits); - if (stree) s->static_len += (ulg)f * (stree[n].Len + xbits); + s->opt_len += (ulg)f * (unsigned)(bits + xbits); + if (stree) s->static_len += (ulg)f * (unsigned)(stree[n].Len + xbits); } if (overflow == 0) return; - Trace((stderr,"\nbit length overflow\n")); + Tracev((stderr,"\nbit length overflow\n")); /* This happens for example on obj2 and pic of the Calgary corpus */ /* Find the first bit length which could increase: */ @@ -556,9 +552,8 @@ local void gen_bitlen(s, desc) m = s->heap[--h]; if (m > max_code) continue; if ((unsigned) tree[m].Len != (unsigned) bits) { - Trace((stderr,"code %d bits %d->%d\n", m, tree[m].Len, bits)); - s->opt_len += ((long)bits - (long)tree[m].Len) - *(long)tree[m].Freq; + Tracev((stderr,"code %d bits %d->%d\n", m, tree[m].Len, bits)); + s->opt_len += ((ulg)bits - tree[m].Len) * tree[m].Freq; tree[m].Len = (ush)bits; } n--; @@ -580,7 +575,7 @@ local void gen_codes (tree, max_code, bl_count) ushf *bl_count; /* number of codes at each bit length */ { ush next_code[MAX_BITS+1]; /* next code value for each bit length */ - ush code = 0; /* running code value */ + unsigned code = 0; /* running code value */ int bits; /* bit index */ int n; /* code index */ @@ -588,7 +583,8 @@ local void gen_codes (tree, max_code, bl_count) * without bit reversal. */ for (bits = 1; bits <= MAX_BITS; bits++) { - next_code[bits] = code = (code + bl_count[bits-1]) << 1; + code = (code + bl_count[bits-1]) << 1; + next_code[bits] = (ush)code; } /* Check that the bit counts in bl_count are consistent. The last code * must be all ones. @@ -601,7 +597,7 @@ local void gen_codes (tree, max_code, bl_count) int len = tree[n].Len; if (len == 0) continue; /* Now reverse the bits */ - tree[n].Code = bi_reverse(next_code[len]++, len); + tree[n].Code = (ush)bi_reverse(next_code[len]++, len); Tracecv(tree != static_ltree, (stderr,"\nn %3d %c l %2d c %4x (%x) ", n, (isgraph(n) ? n : ' '), len, tree[n].Code, next_code[len]-1)); @@ -823,7 +819,7 @@ local int build_bl_tree(s) if (s->bl_tree[bl_order[max_blindex]].Len != 0) break; } /* Update opt_len to include the bit length tree and counts */ - s->opt_len += 3*(max_blindex+1) + 5+5+4; + s->opt_len += 3*((ulg)max_blindex+1) + 5+5+4; Tracev((stderr, "\ndyn trees: dyn %ld, stat %ld", s->opt_len, s->static_len)); @@ -864,65 +860,59 @@ local void send_all_trees(s, lcodes, dcodes, blcodes) /* =========================================================================== * Send a stored block */ -void _tr_stored_block(s, buf, stored_len, eof) +void ZLIB_INTERNAL _tr_stored_block(s, buf, stored_len, last) deflate_state *s; charf *buf; /* input block */ ulg stored_len; /* length of input block */ - int eof; /* true if this is the last block for a file */ + int last; /* one if this is the last block for a file */ { - send_bits(s, (STORED_BLOCK<<1)+eof, 3); /* send block type */ -#ifdef DEBUG + send_bits(s, (STORED_BLOCK<<1)+last, 3); /* send block type */ + bi_windup(s); /* align on byte boundary */ + put_short(s, (ush)stored_len); + put_short(s, (ush)~stored_len); + zmemcpy(s->pending_buf + s->pending, (Bytef *)buf, stored_len); + s->pending += stored_len; +#ifdef ZLIB_DEBUG s->compressed_len = (s->compressed_len + 3 + 7) & (ulg)~7L; s->compressed_len += (stored_len + 4) << 3; + s->bits_sent += 2*16; + s->bits_sent += stored_len<<3; #endif - copy_block(s, buf, (unsigned)stored_len, 1); /* with header */ +} + +/* =========================================================================== + * Flush the bits in the bit buffer to pending output (leaves at most 7 bits) + */ +void ZLIB_INTERNAL _tr_flush_bits(s) + deflate_state *s; +{ + bi_flush(s); } /* =========================================================================== * Send one empty static block to give enough lookahead for inflate. * This takes 10 bits, of which 7 may remain in the bit buffer. - * The current inflate code requires 9 bits of lookahead. If the - * last two codes for the previous block (real code plus EOB) were coded - * on 5 bits or less, inflate may have only 5+3 bits of lookahead to decode - * the last real code. In this case we send two empty static blocks instead - * of one. (There are no problems if the previous block is stored or fixed.) - * To simplify the code, we assume the worst case of last real code encoded - * on one bit only. */ -void _tr_align(s) +void ZLIB_INTERNAL _tr_align(s) deflate_state *s; { send_bits(s, STATIC_TREES<<1, 3); send_code(s, END_BLOCK, static_ltree); -#ifdef DEBUG +#ifdef ZLIB_DEBUG s->compressed_len += 10L; /* 3 for block type, 7 for EOB */ #endif bi_flush(s); - /* Of the 10 bits for the empty block, we have already sent - * (10 - bi_valid) bits. The lookahead for the last real code (before - * the EOB of the previous block) was thus at least one plus the length - * of the EOB plus what we have just sent of the empty static block. - */ - if (1 + s->last_eob_len + 10 - s->bi_valid < 9) { - send_bits(s, STATIC_TREES<<1, 3); - send_code(s, END_BLOCK, static_ltree); -#ifdef DEBUG - s->compressed_len += 10L; -#endif - bi_flush(s); - } - s->last_eob_len = 7; } /* =========================================================================== * Determine the best encoding for the current block: dynamic trees, static - * trees or store, and output the encoded block to the zip file. + * trees or store, and write out the encoded block. */ -void _tr_flush_block(s, buf, stored_len, eof) +void ZLIB_INTERNAL _tr_flush_block(s, buf, stored_len, last) deflate_state *s; charf *buf; /* input block, or NULL if too old */ ulg stored_len; /* length of input block */ - int eof; /* true if this is the last block for a file */ + int last; /* one if this is the last block for a file */ { ulg opt_lenb, static_lenb; /* opt_len and static_len in bytes */ int max_blindex = 0; /* index of last bit length code of non zero freq */ @@ -931,8 +921,8 @@ void _tr_flush_block(s, buf, stored_len, eof) if (s->level > 0) { /* Check if the file is binary or text */ - if (stored_len > 0 && s->strm->data_type == Z_UNKNOWN) - set_data_type(s); + if (s->strm->data_type == Z_UNKNOWN) + s->strm->data_type = detect_data_type(s); /* Construct the literal and distance trees */ build_tree(s, (tree_desc *)(&(s->l_desc))); @@ -978,24 +968,26 @@ void _tr_flush_block(s, buf, stored_len, eof) * successful. If LIT_BUFSIZE <= WSIZE, it is never too late to * transform a block into a stored block. */ - _tr_stored_block(s, buf, stored_len, eof); + _tr_stored_block(s, buf, stored_len, last); #ifdef FORCE_STATIC } else if (static_lenb >= 0) { /* force static trees */ #else } else if (s->strategy == Z_FIXED || static_lenb == opt_lenb) { #endif - send_bits(s, (STATIC_TREES<<1)+eof, 3); - compress_block(s, (ct_data *)static_ltree, (ct_data *)static_dtree); -#ifdef DEBUG + send_bits(s, (STATIC_TREES<<1)+last, 3); + compress_block(s, (const ct_data *)static_ltree, + (const ct_data *)static_dtree); +#ifdef ZLIB_DEBUG s->compressed_len += 3 + s->static_len; #endif } else { - send_bits(s, (DYN_TREES<<1)+eof, 3); + send_bits(s, (DYN_TREES<<1)+last, 3); send_all_trees(s, s->l_desc.max_code+1, s->d_desc.max_code+1, max_blindex+1); - compress_block(s, (ct_data *)s->dyn_ltree, (ct_data *)s->dyn_dtree); -#ifdef DEBUG + compress_block(s, (const ct_data *)s->dyn_ltree, + (const ct_data *)s->dyn_dtree); +#ifdef ZLIB_DEBUG s->compressed_len += 3 + s->opt_len; #endif } @@ -1005,21 +997,21 @@ void _tr_flush_block(s, buf, stored_len, eof) */ init_block(s); - if (eof) { + if (last) { bi_windup(s); -#ifdef DEBUG +#ifdef ZLIB_DEBUG s->compressed_len += 7; /* align on byte boundary */ #endif } Tracev((stderr,"\ncomprlen %lu(%lu) ", s->compressed_len>>3, - s->compressed_len-7*eof)); + s->compressed_len-7*last)); } /* =========================================================================== * Save the match info and tally the frequency counts. Return true if * the current block must be flushed. */ -int _tr_tally (s, dist, lc) +int ZLIB_INTERNAL _tr_tally (s, dist, lc) deflate_state *s; unsigned dist; /* distance of matched string */ unsigned lc; /* match length-MIN_MATCH or unmatched char (if dist==0) */ @@ -1071,8 +1063,8 @@ int _tr_tally (s, dist, lc) */ local void compress_block(s, ltree, dtree) deflate_state *s; - ct_data *ltree; /* literal tree */ - ct_data *dtree; /* distance tree */ + const ct_data *ltree; /* literal tree */ + const ct_data *dtree; /* distance tree */ { unsigned dist; /* distance of matched string */ int lc; /* match length or unmatched char (if dist == 0) */ @@ -1102,7 +1094,7 @@ local void compress_block(s, ltree, dtree) send_code(s, code, dtree); /* send the distance code */ extra = extra_dbits[code]; if (extra != 0) { - dist -= base_dist[code]; + dist -= (unsigned)base_dist[code]; send_bits(s, dist, extra); /* send the extra distance bits */ } } /* literal or match pair ? */ @@ -1114,28 +1106,48 @@ local void compress_block(s, ltree, dtree) } while (lx < s->last_lit); send_code(s, END_BLOCK, ltree); - s->last_eob_len = ltree[END_BLOCK].Len; } /* =========================================================================== - * Set the data type to BINARY or TEXT, using a crude approximation: - * set it to Z_TEXT if all symbols are either printable characters (33 to 255) - * or white spaces (9 to 13, or 32); or set it to Z_BINARY otherwise. + * Check if the data type is TEXT or BINARY, using the following algorithm: + * - TEXT if the two conditions below are satisfied: + * a) There are no non-portable control characters belonging to the + * "black list" (0..6, 14..25, 28..31). + * b) There is at least one printable character belonging to the + * "white list" (9 {TAB}, 10 {LF}, 13 {CR}, 32..255). + * - BINARY otherwise. + * - The following partially-portable control characters form a + * "gray list" that is ignored in this detection algorithm: + * (7 {BEL}, 8 {BS}, 11 {VT}, 12 {FF}, 26 {SUB}, 27 {ESC}). * IN assertion: the fields Freq of dyn_ltree are set. */ -local void set_data_type(s) +local int detect_data_type(s) deflate_state *s; { + /* black_mask is the bit mask of black-listed bytes + * set bits 0..6, 14..25, and 28..31 + * 0xf3ffc07f = binary 11110011111111111100000001111111 + */ + unsigned long black_mask = 0xf3ffc07fUL; int n; - for (n = 0; n < 9; n++) + /* Check for non-textual ("black-listed") bytes. */ + for (n = 0; n <= 31; n++, black_mask >>= 1) + if ((black_mask & 1) && (s->dyn_ltree[n].Freq != 0)) + return Z_BINARY; + + /* Check for textual ("white-listed") bytes. */ + if (s->dyn_ltree[9].Freq != 0 || s->dyn_ltree[10].Freq != 0 + || s->dyn_ltree[13].Freq != 0) + return Z_TEXT; + for (n = 32; n < LITERALS; n++) if (s->dyn_ltree[n].Freq != 0) - break; - if (n == 9) - for (n = 14; n < 32; n++) - if (s->dyn_ltree[n].Freq != 0) - break; - s->strm->data_type = (n == 32) ? Z_TEXT : Z_BINARY; + return Z_TEXT; + + /* There are no "black-listed" or "white-listed" bytes: + * this stream either is empty or has tolerated ("gray-listed") bytes only. + */ + return Z_BINARY; } /* =========================================================================== @@ -1185,35 +1197,7 @@ local void bi_windup(s) } s->bi_buf = 0; s->bi_valid = 0; -#ifdef DEBUG +#ifdef ZLIB_DEBUG s->bits_sent = (s->bits_sent+7) & ~7; #endif } - -/* =========================================================================== - * Copy a stored block, storing first the length and its - * one's complement if requested. - */ -local void copy_block(s, buf, len, header) - deflate_state *s; - charf *buf; /* the input data */ - unsigned len; /* its length */ - int header; /* true if block header must be written */ -{ - bi_windup(s); /* align on byte boundary */ - s->last_eob_len = 8; /* enough lookahead for inflate */ - - if (header) { - put_short(s, (ush)len); - put_short(s, (ush)~len); -#ifdef DEBUG - s->bits_sent += 2*16; -#endif - } -#ifdef DEBUG - s->bits_sent += (ulg)len<<3; -#endif - while (len--) { - put_byte(s, *buf++); - } -} diff --git a/zlib/trees.h b/zlib/trees.h index 1ca868b8..ce8f6204 100644 --- a/zlib/trees.h +++ b/zlib/trees.h @@ -70,7 +70,7 @@ local const ct_data static_dtree[D_CODES] = { {{19},{ 5}}, {{11},{ 5}}, {{27},{ 5}}, {{ 7},{ 5}}, {{23},{ 5}} }; -const uch _dist_code[DIST_CODE_LEN] = { +const uch ZLIB_INTERNAL _dist_code[DIST_CODE_LEN] = { 0, 1, 2, 3, 4, 4, 5, 5, 6, 6, 6, 6, 7, 7, 7, 7, 8, 8, 8, 8, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, @@ -99,7 +99,7 @@ const uch _dist_code[DIST_CODE_LEN] = { 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29 }; -const uch _length_code[MAX_MATCH-MIN_MATCH+1]= { +const uch ZLIB_INTERNAL _length_code[MAX_MATCH-MIN_MATCH+1]= { 0, 1, 2, 3, 4, 5, 6, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 15, 15, 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, 18, 18, 18, 18, 18, 18, 18, 18, 19, 19, 19, 19, diff --git a/zlib/uncompr.c b/zlib/uncompr.c index ad6db0a6..4eda7862 100644 --- a/zlib/uncompr.c +++ b/zlib/uncompr.c @@ -1,5 +1,5 @@ /* uncompr.c -- decompress a memory buffer - * Copyright (C) 1995-2003 Jean-loup Gailly. + * Copyright (C) 1995-2003, 2010, 2014, 2016 Jean-loup Gailly, Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -9,53 +9,85 @@ #include "zlib.h" /* =========================================================================== - Decompresses the source buffer into the destination buffer. sourceLen is - the byte length of the source buffer. Upon entry, destLen is the total - size of the destination buffer, which must be large enough to hold the - entire uncompressed data. (The size of the uncompressed data must have - been saved previously by the compressor and transmitted to the decompressor - by some mechanism outside the scope of this compression library.) - Upon exit, destLen is the actual size of the compressed buffer. - This function can be used to decompress a whole file at once if the - input file is mmap'ed. + Decompresses the source buffer into the destination buffer. *sourceLen is + the byte length of the source buffer. Upon entry, *destLen is the total size + of the destination buffer, which must be large enough to hold the entire + uncompressed data. (The size of the uncompressed data must have been saved + previously by the compressor and transmitted to the decompressor by some + mechanism outside the scope of this compression library.) Upon exit, + *destLen is the size of the decompressed data and *sourceLen is the number + of source bytes consumed. Upon return, source + *sourceLen points to the + first unused input byte. - uncompress returns Z_OK if success, Z_MEM_ERROR if there was not - enough memory, Z_BUF_ERROR if there was not enough room in the output - buffer, or Z_DATA_ERROR if the input data was corrupted. + uncompress returns Z_OK if success, Z_MEM_ERROR if there was not enough + memory, Z_BUF_ERROR if there was not enough room in the output buffer, or + Z_DATA_ERROR if the input data was corrupted, including if the input data is + an incomplete zlib stream. */ +int ZEXPORT uncompress2 (dest, destLen, source, sourceLen) + Bytef *dest; + uLongf *destLen; + const Bytef *source; + uLong *sourceLen; +{ + z_stream stream; + int err; + const uInt max = (uInt)-1; + uLong len, left; + Byte buf[1]; /* for detection of incomplete stream when *destLen == 0 */ + + len = *sourceLen; + if (*destLen) { + left = *destLen; + *destLen = 0; + } + else { + left = 1; + dest = buf; + } + + stream.next_in = (z_const Bytef *)source; + stream.avail_in = 0; + stream.zalloc = (alloc_func)0; + stream.zfree = (free_func)0; + stream.opaque = (voidpf)0; + + err = inflateInit(&stream); + if (err != Z_OK) return err; + + stream.next_out = dest; + stream.avail_out = 0; + + do { + if (stream.avail_out == 0) { + stream.avail_out = left > (uLong)max ? max : (uInt)left; + left -= stream.avail_out; + } + if (stream.avail_in == 0) { + stream.avail_in = len > (uLong)max ? max : (uInt)len; + len -= stream.avail_in; + } + err = inflate(&stream, Z_NO_FLUSH); + } while (err == Z_OK); + + *sourceLen -= len + stream.avail_in; + if (dest != buf) + *destLen = stream.total_out; + else if (stream.total_out && err == Z_BUF_ERROR) + left = 1; + + inflateEnd(&stream); + return err == Z_STREAM_END ? Z_OK : + err == Z_NEED_DICT ? Z_DATA_ERROR : + err == Z_BUF_ERROR && left + stream.avail_out ? Z_DATA_ERROR : + err; +} + int ZEXPORT uncompress (dest, destLen, source, sourceLen) Bytef *dest; uLongf *destLen; const Bytef *source; uLong sourceLen; { - z_stream stream; - int err; - - stream.next_in = (Bytef*)source; - stream.avail_in = (uInt)sourceLen; - /* Check for source > 64K on 16-bit machine: */ - if ((uLong)stream.avail_in != sourceLen) return Z_BUF_ERROR; - - stream.next_out = dest; - stream.avail_out = (uInt)*destLen; - if ((uLong)stream.avail_out != *destLen) return Z_BUF_ERROR; - - stream.zalloc = (alloc_func)0; - stream.zfree = (free_func)0; - - err = inflateInit(&stream); - if (err != Z_OK) return err; - - err = inflate(&stream, Z_FINISH); - if (err != Z_STREAM_END) { - inflateEnd(&stream); - if (err == Z_NEED_DICT || (err == Z_BUF_ERROR && stream.avail_in == 0)) - return Z_DATA_ERROR; - return err; - } - *destLen = stream.total_out; - - err = inflateEnd(&stream); - return err; + return uncompress2(dest, destLen, source, &sourceLen); } diff --git a/zlib/zconf.h b/zlib/zconf.h index e3b0c962..44d5bef9 100644 --- a/zlib/zconf.h +++ b/zlib/zconf.h @@ -1,5 +1,5 @@ /* zconf.h -- configuration of the zlib compression library - * Copyright (C) 1995-2005 Jean-loup Gailly. + * Copyright (C) 1995-2016 Jean-loup Gailly, Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -11,52 +11,158 @@ /* * If you *really* need a unique prefix for all types and library functions, * compile with -DZ_PREFIX. The "standard" zlib should be compiled without it. + * Even better than compiling with -DZ_PREFIX would be to use configure to set + * this permanently in zconf.h using "./configure --zprefix". */ -#ifdef Z_PREFIX -# define deflateInit_ z_deflateInit_ +#ifdef Z_PREFIX /* may be set to #if 1 by ./configure */ +# define Z_PREFIX_SET + +/* all linked symbols and init macros */ +# define _dist_code z__dist_code +# define _length_code z__length_code +# define _tr_align z__tr_align +# define _tr_flush_bits z__tr_flush_bits +# define _tr_flush_block z__tr_flush_block +# define _tr_init z__tr_init +# define _tr_stored_block z__tr_stored_block +# define _tr_tally z__tr_tally +# define adler32 z_adler32 +# define adler32_combine z_adler32_combine +# define adler32_combine64 z_adler32_combine64 +# define adler32_z z_adler32_z +# ifndef Z_SOLO +# define compress z_compress +# define compress2 z_compress2 +# define compressBound z_compressBound +# endif +# define crc32 z_crc32 +# define crc32_combine z_crc32_combine +# define crc32_combine64 z_crc32_combine64 +# define crc32_z z_crc32_z # define deflate z_deflate -# define deflateEnd z_deflateEnd -# define inflateInit_ z_inflateInit_ -# define inflate z_inflate -# define inflateEnd z_inflateEnd -# define deflateInit2_ z_deflateInit2_ -# define deflateSetDictionary z_deflateSetDictionary -# define deflateCopy z_deflateCopy -# define deflateReset z_deflateReset -# define deflateParams z_deflateParams # define deflateBound z_deflateBound +# define deflateCopy z_deflateCopy +# define deflateEnd z_deflateEnd +# define deflateGetDictionary z_deflateGetDictionary +# define deflateInit z_deflateInit +# define deflateInit2 z_deflateInit2 +# define deflateInit2_ z_deflateInit2_ +# define deflateInit_ z_deflateInit_ +# define deflateParams z_deflateParams +# define deflatePending z_deflatePending # define deflatePrime z_deflatePrime +# define deflateReset z_deflateReset +# define deflateResetKeep z_deflateResetKeep +# define deflateSetDictionary z_deflateSetDictionary +# define deflateSetHeader z_deflateSetHeader +# define deflateTune z_deflateTune +# define deflate_copyright z_deflate_copyright +# define get_crc_table z_get_crc_table +# ifndef Z_SOLO +# define gz_error z_gz_error +# define gz_intmax z_gz_intmax +# define gz_strwinerror z_gz_strwinerror +# define gzbuffer z_gzbuffer +# define gzclearerr z_gzclearerr +# define gzclose z_gzclose +# define gzclose_r z_gzclose_r +# define gzclose_w z_gzclose_w +# define gzdirect z_gzdirect +# define gzdopen z_gzdopen +# define gzeof z_gzeof +# define gzerror z_gzerror +# define gzflush z_gzflush +# define gzfread z_gzfread +# define gzfwrite z_gzfwrite +# define gzgetc z_gzgetc +# define gzgetc_ z_gzgetc_ +# define gzgets z_gzgets +# define gzoffset z_gzoffset +# define gzoffset64 z_gzoffset64 +# define gzopen z_gzopen +# define gzopen64 z_gzopen64 +# ifdef _WIN32 +# define gzopen_w z_gzopen_w +# endif +# define gzprintf z_gzprintf +# define gzputc z_gzputc +# define gzputs z_gzputs +# define gzread z_gzread +# define gzrewind z_gzrewind +# define gzseek z_gzseek +# define gzseek64 z_gzseek64 +# define gzsetparams z_gzsetparams +# define gztell z_gztell +# define gztell64 z_gztell64 +# define gzungetc z_gzungetc +# define gzvprintf z_gzvprintf +# define gzwrite z_gzwrite +# endif +# define inflate z_inflate +# define inflateBack z_inflateBack +# define inflateBackEnd z_inflateBackEnd +# define inflateBackInit z_inflateBackInit +# define inflateBackInit_ z_inflateBackInit_ +# define inflateCodesUsed z_inflateCodesUsed +# define inflateCopy z_inflateCopy +# define inflateEnd z_inflateEnd +# define inflateGetDictionary z_inflateGetDictionary +# define inflateGetHeader z_inflateGetHeader +# define inflateInit z_inflateInit +# define inflateInit2 z_inflateInit2 # define inflateInit2_ z_inflateInit2_ +# define inflateInit_ z_inflateInit_ +# define inflateMark z_inflateMark +# define inflatePrime z_inflatePrime +# define inflateReset z_inflateReset +# define inflateReset2 z_inflateReset2 +# define inflateResetKeep z_inflateResetKeep # define inflateSetDictionary z_inflateSetDictionary # define inflateSync z_inflateSync # define inflateSyncPoint z_inflateSyncPoint -# define inflateCopy z_inflateCopy -# define inflateReset z_inflateReset -# define inflateBack z_inflateBack -# define inflateBackEnd z_inflateBackEnd -# define compress z_compress -# define compress2 z_compress2 -# define compressBound z_compressBound -# define uncompress z_uncompress -# define adler32 z_adler32 -# define crc32 z_crc32 -# define get_crc_table z_get_crc_table +# define inflateUndermine z_inflateUndermine +# define inflateValidate z_inflateValidate +# define inflate_copyright z_inflate_copyright +# define inflate_fast z_inflate_fast +# define inflate_table z_inflate_table +# ifndef Z_SOLO +# define uncompress z_uncompress +# define uncompress2 z_uncompress2 +# endif # define zError z_zError +# ifndef Z_SOLO +# define zcalloc z_zcalloc +# define zcfree z_zcfree +# endif +# define zlibCompileFlags z_zlibCompileFlags +# define zlibVersion z_zlibVersion -# define alloc_func z_alloc_func -# define free_func z_free_func -# define in_func z_in_func -# define out_func z_out_func +/* all zlib typedefs in zlib.h and zconf.h */ # define Byte z_Byte -# define uInt z_uInt -# define uLong z_uLong # define Bytef z_Bytef +# define alloc_func z_alloc_func # define charf z_charf +# define free_func z_free_func +# ifndef Z_SOLO +# define gzFile z_gzFile +# endif +# define gz_header z_gz_header +# define gz_headerp z_gz_headerp +# define in_func z_in_func # define intf z_intf +# define out_func z_out_func +# define uInt z_uInt # define uIntf z_uIntf +# define uLong z_uLong # define uLongf z_uLongf -# define voidpf z_voidpf # define voidp z_voidp +# define voidpc z_voidpc +# define voidpf z_voidpf + +/* all zlib structs in zlib.h and zconf.h */ +# define gz_header_s z_gz_header_s +# define internal_state z_internal_state + #endif #if defined(__MSDOS__) && !defined(MSDOS) @@ -125,9 +231,25 @@ # endif #endif -/* Some Mac compilers merge all .h files incorrectly: */ -#if defined(__MWERKS__)||defined(applec)||defined(THINK_C)||defined(__SC__) -# define NO_DUMMY_DECL +#if defined(ZLIB_CONST) && !defined(z_const) +# define z_const const +#else +# define z_const +#endif + +#ifdef Z_SOLO + typedef unsigned long z_size_t; +#else +# define z_longlong long long +# if defined(NO_SIZE_T) + typedef unsigned NO_SIZE_T z_size_t; +# elif defined(STDC) +# include + typedef size_t z_size_t; +# else + typedef unsigned long z_size_t; +# endif +# undef z_longlong #endif /* Maximum value for memLevel in deflateInit2 */ @@ -157,7 +279,7 @@ Of course this will generally degrade compression (there's no free lunch). The memory requirements for inflate are (in bytes) 1 << windowBits - that is, 32K for windowBits=15 (default value) plus a few kilobytes + that is, 32K for windowBits=15 (default value) plus about 7 kilobytes for small objects. */ @@ -171,6 +293,14 @@ # endif #endif +#ifndef Z_ARG /* function prototypes for stdarg */ +# if defined(STDC) || defined(Z_HAVE_STDARG_H) +# define Z_ARG(args) args +# else +# define Z_ARG(args) () +# endif +#endif + /* The following definitions for FAR are needed only for MSDOS mixed * model programming (small or medium model with some far allocations). * This was tested only with MSC; for other MSDOS compilers you may have @@ -284,49 +414,121 @@ typedef uLong FAR uLongf; typedef Byte *voidp; #endif -#if 0 /* HAVE_UNISTD_H -- this line is updated by ./configure */ -# include /* for off_t */ -# include /* for SEEK_* and off_t */ -# ifdef VMS -# include /* for off_t */ +#if !defined(Z_U4) && !defined(Z_SOLO) && defined(STDC) +# include +# if (UINT_MAX == 0xffffffffUL) +# define Z_U4 unsigned +# elif (ULONG_MAX == 0xffffffffUL) +# define Z_U4 unsigned long +# elif (USHRT_MAX == 0xffffffffUL) +# define Z_U4 unsigned short # endif -# define z_off_t off_t #endif -#ifndef SEEK_SET + +#ifdef Z_U4 + typedef Z_U4 z_crc_t; +#else + typedef unsigned long z_crc_t; +#endif + +#ifdef HAVE_UNISTD_H /* may be set to #if 1 by ./configure */ +# define Z_HAVE_UNISTD_H +#endif + +#ifdef HAVE_STDARG_H /* may be set to #if 1 by ./configure */ +# define Z_HAVE_STDARG_H +#endif + +#ifdef STDC +# ifndef Z_SOLO +# include /* for off_t */ +# endif +#endif + +#if defined(STDC) || defined(Z_HAVE_STDARG_H) +# ifndef Z_SOLO +# include /* for va_list */ +# endif +#endif + +#ifdef _WIN32 +# ifndef Z_SOLO +# include /* for wchar_t */ +# endif +#endif + +/* a little trick to accommodate both "#define _LARGEFILE64_SOURCE" and + * "#define _LARGEFILE64_SOURCE 1" as requesting 64-bit operations, (even + * though the former does not conform to the LFS document), but considering + * both "#undef _LARGEFILE64_SOURCE" and "#define _LARGEFILE64_SOURCE 0" as + * equivalently requesting no 64-bit operations + */ +#if defined(_LARGEFILE64_SOURCE) && -_LARGEFILE64_SOURCE - -1 == 1 +# undef _LARGEFILE64_SOURCE +#endif + +#if defined(__WATCOMC__) && !defined(Z_HAVE_UNISTD_H) +# define Z_HAVE_UNISTD_H +#endif +#ifndef Z_SOLO +# if defined(Z_HAVE_UNISTD_H) || defined(_LARGEFILE64_SOURCE) +# include /* for SEEK_*, off_t, and _LFS64_LARGEFILE */ +# ifdef VMS +# include /* for off_t */ +# endif +# ifndef z_off_t +# define z_off_t off_t +# endif +# endif +#endif + +#if defined(_LFS64_LARGEFILE) && _LFS64_LARGEFILE-0 +# define Z_LFS64 +#endif + +#if defined(_LARGEFILE64_SOURCE) && defined(Z_LFS64) +# define Z_LARGE64 +#endif + +#if defined(_FILE_OFFSET_BITS) && _FILE_OFFSET_BITS-0 == 64 && defined(Z_LFS64) +# define Z_WANT64 +#endif + +#if !defined(SEEK_SET) && !defined(Z_SOLO) # define SEEK_SET 0 /* Seek from beginning of file. */ # define SEEK_CUR 1 /* Seek from current position. */ # define SEEK_END 2 /* Set file pointer to EOF plus "offset" */ #endif + #ifndef z_off_t # define z_off_t long #endif -#if defined(__OS400__) -# define NO_vsnprintf -#endif - -#if defined(__MVS__) -# define NO_vsnprintf -# ifdef FAR -# undef FAR +#if !defined(_WIN32) && defined(Z_LARGE64) +# define z_off64_t off64_t +#else +# if defined(_WIN32) && !defined(__GNUC__) && !defined(Z_SOLO) +# define z_off64_t __int64 +# else +# define z_off64_t z_off_t # endif #endif /* MVS linker does not support external names larger than 8 bytes */ #if defined(__MVS__) -# pragma map(deflateInit_,"DEIN") -# pragma map(deflateInit2_,"DEIN2") -# pragma map(deflateEnd,"DEEND") -# pragma map(deflateBound,"DEBND") -# pragma map(inflateInit_,"ININ") -# pragma map(inflateInit2_,"ININ2") -# pragma map(inflateEnd,"INEND") -# pragma map(inflateSync,"INSY") -# pragma map(inflateSetDictionary,"INSEDI") -# pragma map(compressBound,"CMBND") -# pragma map(inflate_table,"INTABL") -# pragma map(inflate_fast,"INFA") -# pragma map(inflate_copyright,"INCOPY") + #pragma map(deflateInit_,"DEIN") + #pragma map(deflateInit2_,"DEIN2") + #pragma map(deflateEnd,"DEEND") + #pragma map(deflateBound,"DEBND") + #pragma map(inflateInit_,"ININ") + #pragma map(inflateInit2_,"ININ2") + #pragma map(inflateEnd,"INEND") + #pragma map(inflateSync,"INSY") + #pragma map(inflateSetDictionary,"INSEDI") + #pragma map(compressBound,"CMBND") + #pragma map(inflate_table,"INTABL") + #pragma map(inflate_fast,"INFA") + #pragma map(inflate_copyright,"INCOPY") #endif #endif /* ZCONF_H */ diff --git a/zlib/zconf.in.h b/zlib/zconf.in.h deleted file mode 100644 index e3b0c962..00000000 --- a/zlib/zconf.in.h +++ /dev/null @@ -1,332 +0,0 @@ -/* zconf.h -- configuration of the zlib compression library - * Copyright (C) 1995-2005 Jean-loup Gailly. - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* @(#) $Id$ */ - -#ifndef ZCONF_H -#define ZCONF_H - -/* - * If you *really* need a unique prefix for all types and library functions, - * compile with -DZ_PREFIX. The "standard" zlib should be compiled without it. - */ -#ifdef Z_PREFIX -# define deflateInit_ z_deflateInit_ -# define deflate z_deflate -# define deflateEnd z_deflateEnd -# define inflateInit_ z_inflateInit_ -# define inflate z_inflate -# define inflateEnd z_inflateEnd -# define deflateInit2_ z_deflateInit2_ -# define deflateSetDictionary z_deflateSetDictionary -# define deflateCopy z_deflateCopy -# define deflateReset z_deflateReset -# define deflateParams z_deflateParams -# define deflateBound z_deflateBound -# define deflatePrime z_deflatePrime -# define inflateInit2_ z_inflateInit2_ -# define inflateSetDictionary z_inflateSetDictionary -# define inflateSync z_inflateSync -# define inflateSyncPoint z_inflateSyncPoint -# define inflateCopy z_inflateCopy -# define inflateReset z_inflateReset -# define inflateBack z_inflateBack -# define inflateBackEnd z_inflateBackEnd -# define compress z_compress -# define compress2 z_compress2 -# define compressBound z_compressBound -# define uncompress z_uncompress -# define adler32 z_adler32 -# define crc32 z_crc32 -# define get_crc_table z_get_crc_table -# define zError z_zError - -# define alloc_func z_alloc_func -# define free_func z_free_func -# define in_func z_in_func -# define out_func z_out_func -# define Byte z_Byte -# define uInt z_uInt -# define uLong z_uLong -# define Bytef z_Bytef -# define charf z_charf -# define intf z_intf -# define uIntf z_uIntf -# define uLongf z_uLongf -# define voidpf z_voidpf -# define voidp z_voidp -#endif - -#if defined(__MSDOS__) && !defined(MSDOS) -# define MSDOS -#endif -#if (defined(OS_2) || defined(__OS2__)) && !defined(OS2) -# define OS2 -#endif -#if defined(_WINDOWS) && !defined(WINDOWS) -# define WINDOWS -#endif -#if defined(_WIN32) || defined(_WIN32_WCE) || defined(__WIN32__) -# ifndef WIN32 -# define WIN32 -# endif -#endif -#if (defined(MSDOS) || defined(OS2) || defined(WINDOWS)) && !defined(WIN32) -# if !defined(__GNUC__) && !defined(__FLAT__) && !defined(__386__) -# ifndef SYS16BIT -# define SYS16BIT -# endif -# endif -#endif - -/* - * Compile with -DMAXSEG_64K if the alloc function cannot allocate more - * than 64k bytes at a time (needed on systems with 16-bit int). - */ -#ifdef SYS16BIT -# define MAXSEG_64K -#endif -#ifdef MSDOS -# define UNALIGNED_OK -#endif - -#ifdef __STDC_VERSION__ -# ifndef STDC -# define STDC -# endif -# if __STDC_VERSION__ >= 199901L -# ifndef STDC99 -# define STDC99 -# endif -# endif -#endif -#if !defined(STDC) && (defined(__STDC__) || defined(__cplusplus)) -# define STDC -#endif -#if !defined(STDC) && (defined(__GNUC__) || defined(__BORLANDC__)) -# define STDC -#endif -#if !defined(STDC) && (defined(MSDOS) || defined(WINDOWS) || defined(WIN32)) -# define STDC -#endif -#if !defined(STDC) && (defined(OS2) || defined(__HOS_AIX__)) -# define STDC -#endif - -#if defined(__OS400__) && !defined(STDC) /* iSeries (formerly AS/400). */ -# define STDC -#endif - -#ifndef STDC -# ifndef const /* cannot use !defined(STDC) && !defined(const) on Mac */ -# define const /* note: need a more gentle solution here */ -# endif -#endif - -/* Some Mac compilers merge all .h files incorrectly: */ -#if defined(__MWERKS__)||defined(applec)||defined(THINK_C)||defined(__SC__) -# define NO_DUMMY_DECL -#endif - -/* Maximum value for memLevel in deflateInit2 */ -#ifndef MAX_MEM_LEVEL -# ifdef MAXSEG_64K -# define MAX_MEM_LEVEL 8 -# else -# define MAX_MEM_LEVEL 9 -# endif -#endif - -/* Maximum value for windowBits in deflateInit2 and inflateInit2. - * WARNING: reducing MAX_WBITS makes minigzip unable to extract .gz files - * created by gzip. (Files created by minigzip can still be extracted by - * gzip.) - */ -#ifndef MAX_WBITS -# define MAX_WBITS 15 /* 32K LZ77 window */ -#endif - -/* The memory requirements for deflate are (in bytes): - (1 << (windowBits+2)) + (1 << (memLevel+9)) - that is: 128K for windowBits=15 + 128K for memLevel = 8 (default values) - plus a few kilobytes for small objects. For example, if you want to reduce - the default memory requirements from 256K to 128K, compile with - make CFLAGS="-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7" - Of course this will generally degrade compression (there's no free lunch). - - The memory requirements for inflate are (in bytes) 1 << windowBits - that is, 32K for windowBits=15 (default value) plus a few kilobytes - for small objects. -*/ - - /* Type declarations */ - -#ifndef OF /* function prototypes */ -# ifdef STDC -# define OF(args) args -# else -# define OF(args) () -# endif -#endif - -/* The following definitions for FAR are needed only for MSDOS mixed - * model programming (small or medium model with some far allocations). - * This was tested only with MSC; for other MSDOS compilers you may have - * to define NO_MEMCPY in zutil.h. If you don't need the mixed model, - * just define FAR to be empty. - */ -#ifdef SYS16BIT -# if defined(M_I86SM) || defined(M_I86MM) - /* MSC small or medium model */ -# define SMALL_MEDIUM -# ifdef _MSC_VER -# define FAR _far -# else -# define FAR far -# endif -# endif -# if (defined(__SMALL__) || defined(__MEDIUM__)) - /* Turbo C small or medium model */ -# define SMALL_MEDIUM -# ifdef __BORLANDC__ -# define FAR _far -# else -# define FAR far -# endif -# endif -#endif - -#if defined(WINDOWS) || defined(WIN32) - /* If building or using zlib as a DLL, define ZLIB_DLL. - * This is not mandatory, but it offers a little performance increase. - */ -# ifdef ZLIB_DLL -# if defined(WIN32) && (!defined(__BORLANDC__) || (__BORLANDC__ >= 0x500)) -# ifdef ZLIB_INTERNAL -# define ZEXTERN extern __declspec(dllexport) -# else -# define ZEXTERN extern __declspec(dllimport) -# endif -# endif -# endif /* ZLIB_DLL */ - /* If building or using zlib with the WINAPI/WINAPIV calling convention, - * define ZLIB_WINAPI. - * Caution: the standard ZLIB1.DLL is NOT compiled using ZLIB_WINAPI. - */ -# ifdef ZLIB_WINAPI -# ifdef FAR -# undef FAR -# endif -# include - /* No need for _export, use ZLIB.DEF instead. */ - /* For complete Windows compatibility, use WINAPI, not __stdcall. */ -# define ZEXPORT WINAPI -# ifdef WIN32 -# define ZEXPORTVA WINAPIV -# else -# define ZEXPORTVA FAR CDECL -# endif -# endif -#endif - -#if defined (__BEOS__) -# ifdef ZLIB_DLL -# ifdef ZLIB_INTERNAL -# define ZEXPORT __declspec(dllexport) -# define ZEXPORTVA __declspec(dllexport) -# else -# define ZEXPORT __declspec(dllimport) -# define ZEXPORTVA __declspec(dllimport) -# endif -# endif -#endif - -#ifndef ZEXTERN -# define ZEXTERN extern -#endif -#ifndef ZEXPORT -# define ZEXPORT -#endif -#ifndef ZEXPORTVA -# define ZEXPORTVA -#endif - -#ifndef FAR -# define FAR -#endif - -#if !defined(__MACTYPES__) -typedef unsigned char Byte; /* 8 bits */ -#endif -typedef unsigned int uInt; /* 16 bits or more */ -typedef unsigned long uLong; /* 32 bits or more */ - -#ifdef SMALL_MEDIUM - /* Borland C/C++ and some old MSC versions ignore FAR inside typedef */ -# define Bytef Byte FAR -#else - typedef Byte FAR Bytef; -#endif -typedef char FAR charf; -typedef int FAR intf; -typedef uInt FAR uIntf; -typedef uLong FAR uLongf; - -#ifdef STDC - typedef void const *voidpc; - typedef void FAR *voidpf; - typedef void *voidp; -#else - typedef Byte const *voidpc; - typedef Byte FAR *voidpf; - typedef Byte *voidp; -#endif - -#if 0 /* HAVE_UNISTD_H -- this line is updated by ./configure */ -# include /* for off_t */ -# include /* for SEEK_* and off_t */ -# ifdef VMS -# include /* for off_t */ -# endif -# define z_off_t off_t -#endif -#ifndef SEEK_SET -# define SEEK_SET 0 /* Seek from beginning of file. */ -# define SEEK_CUR 1 /* Seek from current position. */ -# define SEEK_END 2 /* Set file pointer to EOF plus "offset" */ -#endif -#ifndef z_off_t -# define z_off_t long -#endif - -#if defined(__OS400__) -# define NO_vsnprintf -#endif - -#if defined(__MVS__) -# define NO_vsnprintf -# ifdef FAR -# undef FAR -# endif -#endif - -/* MVS linker does not support external names larger than 8 bytes */ -#if defined(__MVS__) -# pragma map(deflateInit_,"DEIN") -# pragma map(deflateInit2_,"DEIN2") -# pragma map(deflateEnd,"DEEND") -# pragma map(deflateBound,"DEBND") -# pragma map(inflateInit_,"ININ") -# pragma map(inflateInit2_,"ININ2") -# pragma map(inflateEnd,"INEND") -# pragma map(inflateSync,"INSY") -# pragma map(inflateSetDictionary,"INSEDI") -# pragma map(compressBound,"CMBND") -# pragma map(inflate_table,"INTABL") -# pragma map(inflate_fast,"INFA") -# pragma map(inflate_copyright,"INCOPY") -#endif - -#endif /* ZCONF_H */ diff --git a/zlib/zlib-Express2008.vcproj b/zlib/zlib-Express2008.vcproj index 6292c4f1..970cbc57 100644 --- a/zlib/zlib-Express2008.vcproj +++ b/zlib/zlib-Express2008.vcproj @@ -173,7 +173,23 @@ > + + + + + + + + - - diff --git a/zlib/zlib-Express2010.vcxproj b/zlib/zlib-Express2010.vcxproj index 87265693..e827ecf9 100644 --- a/zlib/zlib-Express2010.vcxproj +++ b/zlib/zlib-Express2010.vcxproj @@ -127,7 +127,10 @@ - + + + + @@ -139,13 +142,13 @@ + - diff --git a/zlib/zlib-Express2010.vcxproj.filters b/zlib/zlib-Express2010.vcxproj.filters index 87bb96b6..e717042c 100644 --- a/zlib/zlib-Express2010.vcxproj.filters +++ b/zlib/zlib-Express2010.vcxproj.filters @@ -19,9 +19,6 @@ Source Files - - Source Files - Source Files @@ -43,6 +40,18 @@ Source Files + + Source Files + + + Source Files + + + Source Files + + + Source Files + @@ -69,15 +78,15 @@ Source Files - - Source Files - Source Files Source Files + + Source Files + diff --git a/zlib/zlib-Express2013.vcxproj b/zlib/zlib-Express2013.vcxproj index 07c74d0c..8185456e 100644 --- a/zlib/zlib-Express2013.vcxproj +++ b/zlib/zlib-Express2013.vcxproj @@ -1,4 +1,4 @@ - + @@ -15,7 +15,10 @@ - + + + + @@ -27,13 +30,13 @@ + - diff --git a/zlib/zlib-Express2013.vcxproj.filters b/zlib/zlib-Express2013.vcxproj.filters index 36bab27a..3a32b479 100644 --- a/zlib/zlib-Express2013.vcxproj.filters +++ b/zlib/zlib-Express2013.vcxproj.filters @@ -1,4 +1,4 @@ - + @@ -13,9 +13,6 @@ Source Files - - Source Files - Source Files @@ -37,6 +34,18 @@ Source Files + + Source Files + + + Source Files + + + Source Files + + + Source Files + @@ -63,15 +72,15 @@ Source Files - - Source Files - Source Files Source Files + + Source Files + diff --git a/zlib/zlib-Express2015.vcxproj b/zlib/zlib-Express2015.vcxproj index a35e3687..e4a28a63 100644 --- a/zlib/zlib-Express2015.vcxproj +++ b/zlib/zlib-Express2015.vcxproj @@ -1,4 +1,4 @@ - + @@ -15,7 +15,10 @@ - + + + + @@ -27,13 +30,13 @@ + - diff --git a/zlib/zlib-Express2015.vcxproj.filters b/zlib/zlib-Express2015.vcxproj.filters index 36bab27a..3a32b479 100644 --- a/zlib/zlib-Express2015.vcxproj.filters +++ b/zlib/zlib-Express2015.vcxproj.filters @@ -1,4 +1,4 @@ - + @@ -13,9 +13,6 @@ Source Files - - Source Files - Source Files @@ -37,6 +34,18 @@ Source Files + + Source Files + + + Source Files + + + Source Files + + + Source Files + @@ -63,15 +72,15 @@ Source Files - - Source Files - Source Files Source Files + + Source Files + diff --git a/zlib/zlib-Express2017.vcxproj b/zlib/zlib-Express2017.vcxproj index 2441c370..e5f63aa1 100644 --- a/zlib/zlib-Express2017.vcxproj +++ b/zlib/zlib-Express2017.vcxproj @@ -15,7 +15,10 @@ - + + + + @@ -27,13 +30,13 @@ + - diff --git a/zlib/zlib-Express2017.vcxproj.filters b/zlib/zlib-Express2017.vcxproj.filters index 61cfae67..55d7477d 100644 --- a/zlib/zlib-Express2017.vcxproj.filters +++ b/zlib/zlib-Express2017.vcxproj.filters @@ -13,9 +13,6 @@ Source Files - - Source Files - Source Files @@ -37,6 +34,18 @@ Source Files + + Source Files + + + Source Files + + + Source Files + + + Source Files + @@ -63,15 +72,15 @@ Source Files - - Source Files - Source Files Source Files + + Source Files + diff --git a/zlib/zlib.h b/zlib/zlib.h index 62d0e467..5fa98b5d 100644 --- a/zlib/zlib.h +++ b/zlib/zlib.h @@ -1,7 +1,7 @@ /* zlib.h -- interface of the 'zlib' general purpose compression library - version 1.2.3, July 18th, 2005 + version 1.2.11, January 15th, 2017 - Copyright (C) 1995-2005 Jean-loup Gailly and Mark Adler + Copyright (C) 1995-2017 Jean-loup Gailly and Mark Adler This software is provided 'as-is', without any express or implied warranty. In no event will the authors be held liable for any damages @@ -24,8 +24,8 @@ The data format used by the zlib library is described by RFCs (Request for - Comments) 1950 to 1952 in the files http://www.ietf.org/rfc/rfc1950.txt - (zlib format), rfc1951.txt (deflate format) and rfc1952.txt (gzip format). + Comments) 1950 to 1952 in the files http://tools.ietf.org/html/rfc1950 + (zlib format), rfc1951 (deflate format) and rfc1952 (gzip format). */ #ifndef ZLIB_H @@ -37,41 +37,45 @@ extern "C" { #endif -#define ZLIB_VERSION "1.2.3" -#define ZLIB_VERNUM 0x1230 +#define ZLIB_VERSION "1.2.11" +#define ZLIB_VERNUM 0x12b0 +#define ZLIB_VER_MAJOR 1 +#define ZLIB_VER_MINOR 2 +#define ZLIB_VER_REVISION 11 +#define ZLIB_VER_SUBREVISION 0 /* - The 'zlib' compression library provides in-memory compression and - decompression functions, including integrity checks of the uncompressed - data. This version of the library supports only one compression method - (deflation) but other algorithms will be added later and will have the same - stream interface. + The 'zlib' compression library provides in-memory compression and + decompression functions, including integrity checks of the uncompressed data. + This version of the library supports only one compression method (deflation) + but other algorithms will be added later and will have the same stream + interface. - Compression can be done in a single step if the buffers are large - enough (for example if an input file is mmap'ed), or can be done by - repeated calls of the compression function. In the latter case, the - application must provide more input and/or consume the output + Compression can be done in a single step if the buffers are large enough, + or can be done by repeated calls of the compression function. In the latter + case, the application must provide more input and/or consume the output (providing more output space) before each call. - The compressed data format used by default by the in-memory functions is + The compressed data format used by default by the in-memory functions is the zlib format, which is a zlib wrapper documented in RFC 1950, wrapped around a deflate stream, which is itself documented in RFC 1951. - The library also supports reading and writing files in gzip (.gz) format + The library also supports reading and writing files in gzip (.gz) format with an interface similar to that of stdio using the functions that start with "gz". The gzip format is different from the zlib format. gzip is a gzip wrapper, documented in RFC 1952, wrapped around a deflate stream. - This library can optionally read and write gzip streams in memory as well. + This library can optionally read and write gzip and raw deflate streams in + memory as well. - The zlib format was designed to be compact and fast for use in memory + The zlib format was designed to be compact and fast for use in memory and on communications channels. The gzip format was designed for single- file compression on file systems, has a larger header than zlib to maintain directory information, and uses a different, slower check method than zlib. - The library does not install any signal handler. The decoder checks - the consistency of the compressed data, so the library should never - crash even in case of corrupted input. + The library does not install any signal handler. The decoder checks + the consistency of the compressed data, so the library should never crash + even in the case of corrupted input. */ typedef voidpf (*alloc_func) OF((voidpf opaque, uInt items, uInt size)); @@ -80,23 +84,24 @@ typedef void (*free_func) OF((voidpf opaque, voidpf address)); struct internal_state; typedef struct z_stream_s { - Bytef *next_in; /* next input byte */ + z_const Bytef *next_in; /* next input byte */ uInt avail_in; /* number of bytes available at next_in */ - uLong total_in; /* total nb of input bytes read so far */ + uLong total_in; /* total number of input bytes read so far */ - Bytef *next_out; /* next output byte should be put there */ + Bytef *next_out; /* next output byte will go here */ uInt avail_out; /* remaining free space at next_out */ - uLong total_out; /* total nb of bytes output so far */ + uLong total_out; /* total number of bytes output so far */ - char *msg; /* last error message, NULL if no error */ + z_const char *msg; /* last error message, NULL if no error */ struct internal_state FAR *state; /* not visible by applications */ alloc_func zalloc; /* used to allocate the internal state */ free_func zfree; /* used to free the internal state */ voidpf opaque; /* private data object passed to zalloc and zfree */ - int data_type; /* best guess about the data type: binary or text */ - uLong adler; /* adler32 value of the uncompressed data */ + int data_type; /* best guess about the data type: binary or text + for deflate, or the decoding state for inflate */ + uLong adler; /* Adler-32 or CRC-32 value of the uncompressed data */ uLong reserved; /* reserved for future use */ } z_stream; @@ -126,45 +131,47 @@ typedef struct gz_header_s { typedef gz_header FAR *gz_headerp; /* - The application must update next_in and avail_in when avail_in has - dropped to zero. It must update next_out and avail_out when avail_out - has dropped to zero. The application must initialize zalloc, zfree and - opaque before calling the init function. All other fields are set by the - compression library and must not be updated by the application. + The application must update next_in and avail_in when avail_in has dropped + to zero. It must update next_out and avail_out when avail_out has dropped + to zero. The application must initialize zalloc, zfree and opaque before + calling the init function. All other fields are set by the compression + library and must not be updated by the application. - The opaque value provided by the application will be passed as the first - parameter for calls of zalloc and zfree. This can be useful for custom - memory management. The compression library attaches no meaning to the + The opaque value provided by the application will be passed as the first + parameter for calls of zalloc and zfree. This can be useful for custom + memory management. The compression library attaches no meaning to the opaque value. - zalloc must return Z_NULL if there is not enough memory for the object. + zalloc must return Z_NULL if there is not enough memory for the object. If zlib is used in a multi-threaded application, zalloc and zfree must be - thread safe. + thread safe. In that case, zlib is thread-safe. When zalloc and zfree are + Z_NULL on entry to the initialization function, they are set to internal + routines that use the standard library functions malloc() and free(). - On 16-bit systems, the functions zalloc and zfree must be able to allocate - exactly 65536 bytes, but will not be required to allocate more than this - if the symbol MAXSEG_64K is defined (see zconf.h). WARNING: On MSDOS, - pointers returned by zalloc for objects of exactly 65536 bytes *must* - have their offset normalized to zero. The default allocation function - provided by this library ensures this (see zutil.c). To reduce memory - requirements and avoid any allocation of 64K objects, at the expense of - compression ratio, compile the library with -DMAX_WBITS=14 (see zconf.h). + On 16-bit systems, the functions zalloc and zfree must be able to allocate + exactly 65536 bytes, but will not be required to allocate more than this if + the symbol MAXSEG_64K is defined (see zconf.h). WARNING: On MSDOS, pointers + returned by zalloc for objects of exactly 65536 bytes *must* have their + offset normalized to zero. The default allocation function provided by this + library ensures this (see zutil.c). To reduce memory requirements and avoid + any allocation of 64K objects, at the expense of compression ratio, compile + the library with -DMAX_WBITS=14 (see zconf.h). - The fields total_in and total_out can be used for statistics or - progress reports. After compression, total_in holds the total size of - the uncompressed data and may be saved for use in the decompressor - (particularly if the decompressor wants to decompress everything in - a single step). + The fields total_in and total_out can be used for statistics or progress + reports. After compression, total_in holds the total size of the + uncompressed data and may be saved for use by the decompressor (particularly + if the decompressor wants to decompress everything in a single step). */ /* constants */ #define Z_NO_FLUSH 0 -#define Z_PARTIAL_FLUSH 1 /* will be removed, use Z_SYNC_FLUSH instead */ +#define Z_PARTIAL_FLUSH 1 #define Z_SYNC_FLUSH 2 #define Z_FULL_FLUSH 3 #define Z_FINISH 4 #define Z_BLOCK 5 +#define Z_TREES 6 /* Allowed flush values; see deflate() and inflate() below for details */ #define Z_OK 0 @@ -176,8 +183,8 @@ typedef gz_header FAR *gz_headerp; #define Z_MEM_ERROR (-4) #define Z_BUF_ERROR (-5) #define Z_VERSION_ERROR (-6) -/* Return codes for the compression/decompression functions. Negative - * values are errors, positive values are used for special but normal events. +/* Return codes for the compression/decompression functions. Negative values + * are errors, positive values are used for special but normal events. */ #define Z_NO_COMPRESSION 0 @@ -197,7 +204,7 @@ typedef gz_header FAR *gz_headerp; #define Z_TEXT 1 #define Z_ASCII Z_TEXT /* for compatibility with 1.2.2 and earlier */ #define Z_UNKNOWN 2 -/* Possible values of the data_type field (though see inflate()) */ +/* Possible values of the data_type field for deflate() */ #define Z_DEFLATED 8 /* The deflate compression method (the only one supported in this version) */ @@ -207,134 +214,162 @@ typedef gz_header FAR *gz_headerp; #define zlib_version zlibVersion() /* for compatibility with versions < 1.0.2 */ + /* basic functions */ ZEXTERN const char * ZEXPORT zlibVersion OF((void)); /* The application can compare zlibVersion and ZLIB_VERSION for consistency. - If the first character differs, the library code actually used is - not compatible with the zlib.h header file used by the application. - This check is automatically made by deflateInit and inflateInit. + If the first character differs, the library code actually used is not + compatible with the zlib.h header file used by the application. This check + is automatically made by deflateInit and inflateInit. */ /* ZEXTERN int ZEXPORT deflateInit OF((z_streamp strm, int level)); - Initializes the internal stream state for compression. The fields - zalloc, zfree and opaque must be initialized before by the caller. - If zalloc and zfree are set to Z_NULL, deflateInit updates them to - use default allocation functions. + Initializes the internal stream state for compression. The fields + zalloc, zfree and opaque must be initialized before by the caller. If + zalloc and zfree are set to Z_NULL, deflateInit updates them to use default + allocation functions. The compression level must be Z_DEFAULT_COMPRESSION, or between 0 and 9: - 1 gives best speed, 9 gives best compression, 0 gives no compression at - all (the input data is simply copied a block at a time). - Z_DEFAULT_COMPRESSION requests a default compromise between speed and - compression (currently equivalent to level 6). + 1 gives best speed, 9 gives best compression, 0 gives no compression at all + (the input data is simply copied a block at a time). Z_DEFAULT_COMPRESSION + requests a default compromise between speed and compression (currently + equivalent to level 6). - deflateInit returns Z_OK if success, Z_MEM_ERROR if there was not - enough memory, Z_STREAM_ERROR if level is not a valid compression level, + deflateInit returns Z_OK if success, Z_MEM_ERROR if there was not enough + memory, Z_STREAM_ERROR if level is not a valid compression level, or Z_VERSION_ERROR if the zlib library version (zlib_version) is incompatible - with the version assumed by the caller (ZLIB_VERSION). - msg is set to null if there is no error message. deflateInit does not - perform any compression: this will be done by deflate(). + with the version assumed by the caller (ZLIB_VERSION). msg is set to null + if there is no error message. deflateInit does not perform any compression: + this will be done by deflate(). */ ZEXTERN int ZEXPORT deflate OF((z_streamp strm, int flush)); /* deflate compresses as much data as possible, and stops when the input - buffer becomes empty or the output buffer becomes full. It may introduce some - output latency (reading input without producing any output) except when + buffer becomes empty or the output buffer becomes full. It may introduce + some output latency (reading input without producing any output) except when forced to flush. - The detailed semantics are as follows. deflate performs one or both of the + The detailed semantics are as follows. deflate performs one or both of the following actions: - Compress more input starting at next_in and update next_in and avail_in - accordingly. If not all input can be processed (because there is not + accordingly. If not all input can be processed (because there is not enough room in the output buffer), next_in and avail_in are updated and processing will resume at this point for the next call of deflate(). - - Provide more output starting at next_out and update next_out and avail_out - accordingly. This action is forced if the parameter flush is non zero. + - Generate more output starting at next_out and update next_out and avail_out + accordingly. This action is forced if the parameter flush is non zero. Forcing flush frequently degrades the compression ratio, so this parameter - should be set only when necessary (in interactive applications). - Some output may be provided even if flush is not set. + should be set only when necessary. Some output may be provided even if + flush is zero. - Before the call of deflate(), the application should ensure that at least - one of the actions is possible, by providing more input and/or consuming - more output, and updating avail_in or avail_out accordingly; avail_out - should never be zero before the call. The application can consume the - compressed output when it wants, for example when the output buffer is full - (avail_out == 0), or after each call of deflate(). If deflate returns Z_OK - and with zero avail_out, it must be called again after making room in the - output buffer because there might be more output pending. + Before the call of deflate(), the application should ensure that at least + one of the actions is possible, by providing more input and/or consuming more + output, and updating avail_in or avail_out accordingly; avail_out should + never be zero before the call. The application can consume the compressed + output when it wants, for example when the output buffer is full (avail_out + == 0), or after each call of deflate(). If deflate returns Z_OK and with + zero avail_out, it must be called again after making room in the output + buffer because there might be more output pending. See deflatePending(), + which can be used if desired to determine whether or not there is more ouput + in that case. Normally the parameter flush is set to Z_NO_FLUSH, which allows deflate to - decide how much data to accumualte before producing output, in order to + decide how much data to accumulate before producing output, in order to maximize compression. If the parameter flush is set to Z_SYNC_FLUSH, all pending output is flushed to the output buffer and the output is aligned on a byte boundary, so - that the decompressor can get all input data available so far. (In particular - avail_in is zero after the call if enough output space has been provided - before the call.) Flushing may degrade compression for some compression - algorithms and so it should be used only when necessary. + that the decompressor can get all input data available so far. (In + particular avail_in is zero after the call if enough output space has been + provided before the call.) Flushing may degrade compression for some + compression algorithms and so it should be used only when necessary. This + completes the current deflate block and follows it with an empty stored block + that is three bits plus filler bits to the next byte, followed by four bytes + (00 00 ff ff). + + If flush is set to Z_PARTIAL_FLUSH, all pending output is flushed to the + output buffer, but the output is not aligned to a byte boundary. All of the + input data so far will be available to the decompressor, as for Z_SYNC_FLUSH. + This completes the current deflate block and follows it with an empty fixed + codes block that is 10 bits long. This assures that enough bytes are output + in order for the decompressor to finish the block before the empty fixed + codes block. + + If flush is set to Z_BLOCK, a deflate block is completed and emitted, as + for Z_SYNC_FLUSH, but the output is not aligned on a byte boundary, and up to + seven bits of the current block are held to be written as the next byte after + the next deflate block is completed. In this case, the decompressor may not + be provided enough bits at this point in order to complete decompression of + the data provided so far to the compressor. It may need to wait for the next + block to be emitted. This is for advanced applications that need to control + the emission of deflate blocks. If flush is set to Z_FULL_FLUSH, all output is flushed as with Z_SYNC_FLUSH, and the compression state is reset so that decompression can restart from this point if previous compressed data has been damaged or if - random access is desired. Using Z_FULL_FLUSH too often can seriously degrade + random access is desired. Using Z_FULL_FLUSH too often can seriously degrade compression. If deflate returns with avail_out == 0, this function must be called again with the same value of the flush parameter and more output space (updated avail_out), until the flush is complete (deflate returns with non-zero - avail_out). In the case of a Z_FULL_FLUSH or Z_SYNC_FLUSH, make sure that + avail_out). In the case of a Z_FULL_FLUSH or Z_SYNC_FLUSH, make sure that avail_out is greater than six to avoid repeated flush markers due to avail_out == 0 on return. If the parameter flush is set to Z_FINISH, pending input is processed, - pending output is flushed and deflate returns with Z_STREAM_END if there - was enough output space; if deflate returns with Z_OK, this function must be - called again with Z_FINISH and more output space (updated avail_out) but no - more input data, until it returns with Z_STREAM_END or an error. After - deflate has returned Z_STREAM_END, the only possible operations on the - stream are deflateReset or deflateEnd. + pending output is flushed and deflate returns with Z_STREAM_END if there was + enough output space. If deflate returns with Z_OK or Z_BUF_ERROR, this + function must be called again with Z_FINISH and more output space (updated + avail_out) but no more input data, until it returns with Z_STREAM_END or an + error. After deflate has returned Z_STREAM_END, the only possible operations + on the stream are deflateReset or deflateEnd. - Z_FINISH can be used immediately after deflateInit if all the compression - is to be done in a single step. In this case, avail_out must be at least - the value returned by deflateBound (see below). If deflate does not return - Z_STREAM_END, then it must be called again as described above. + Z_FINISH can be used in the first deflate call after deflateInit if all the + compression is to be done in a single step. In order to complete in one + call, avail_out must be at least the value returned by deflateBound (see + below). Then deflate is guaranteed to return Z_STREAM_END. If not enough + output space is provided, deflate will not return Z_STREAM_END, and it must + be called again as described above. - deflate() sets strm->adler to the adler32 checksum of all input read - so far (that is, total_in bytes). + deflate() sets strm->adler to the Adler-32 checksum of all input read + so far (that is, total_in bytes). If a gzip stream is being generated, then + strm->adler will be the CRC-32 checksum of the input read so far. (See + deflateInit2 below.) deflate() may update strm->data_type if it can make a good guess about - the input data type (Z_BINARY or Z_TEXT). In doubt, the data is considered - binary. This field is only for information purposes and does not affect - the compression algorithm in any manner. + the input data type (Z_BINARY or Z_TEXT). If in doubt, the data is + considered binary. This field is only for information purposes and does not + affect the compression algorithm in any manner. deflate() returns Z_OK if some progress has been made (more input processed or more output produced), Z_STREAM_END if all input has been consumed and all output has been produced (only when flush is set to Z_FINISH), Z_STREAM_ERROR if the stream state was inconsistent (for example - if next_in or next_out was NULL), Z_BUF_ERROR if no progress is possible - (for example avail_in or avail_out was zero). Note that Z_BUF_ERROR is not - fatal, and deflate() can be called again with more input and more output - space to continue compressing. + if next_in or next_out was Z_NULL or the state was inadvertently written over + by the application), or Z_BUF_ERROR if no progress is possible (for example + avail_in or avail_out was zero). Note that Z_BUF_ERROR is not fatal, and + deflate() can be called again with more input and more output space to + continue compressing. */ ZEXTERN int ZEXPORT deflateEnd OF((z_streamp strm)); /* All dynamically allocated data structures for this stream are freed. - This function discards any unprocessed input and does not flush any - pending output. + This function discards any unprocessed input and does not flush any pending + output. deflateEnd returns Z_OK if success, Z_STREAM_ERROR if the stream state was inconsistent, Z_DATA_ERROR if the stream was freed - prematurely (some input or output was discarded). In the error case, - msg may be set but then points to a static string (which must not be + prematurely (some input or output was discarded). In the error case, msg + may be set but then points to a static string (which must not be deallocated). */ @@ -342,134 +377,157 @@ ZEXTERN int ZEXPORT deflateEnd OF((z_streamp strm)); /* ZEXTERN int ZEXPORT inflateInit OF((z_streamp strm)); - Initializes the internal stream state for decompression. The fields + Initializes the internal stream state for decompression. The fields next_in, avail_in, zalloc, zfree and opaque must be initialized before by - the caller. If next_in is not Z_NULL and avail_in is large enough (the exact - value depends on the compression method), inflateInit determines the - compression method from the zlib header and allocates all data structures - accordingly; otherwise the allocation will be deferred to the first call of - inflate. If zalloc and zfree are set to Z_NULL, inflateInit updates them to - use default allocation functions. + the caller. In the current version of inflate, the provided input is not + read or consumed. The allocation of a sliding window will be deferred to + the first call of inflate (if the decompression does not complete on the + first call). If zalloc and zfree are set to Z_NULL, inflateInit updates + them to use default allocation functions. inflateInit returns Z_OK if success, Z_MEM_ERROR if there was not enough memory, Z_VERSION_ERROR if the zlib library version is incompatible with the - version assumed by the caller. msg is set to null if there is no error - message. inflateInit does not perform any decompression apart from reading - the zlib header if present: this will be done by inflate(). (So next_in and - avail_in may be modified, but next_out and avail_out are unchanged.) + version assumed by the caller, or Z_STREAM_ERROR if the parameters are + invalid, such as a null pointer to the structure. msg is set to null if + there is no error message. inflateInit does not perform any decompression. + Actual decompression will be done by inflate(). So next_in, and avail_in, + next_out, and avail_out are unused and unchanged. The current + implementation of inflateInit() does not process any header information -- + that is deferred until inflate() is called. */ ZEXTERN int ZEXPORT inflate OF((z_streamp strm, int flush)); /* inflate decompresses as much data as possible, and stops when the input - buffer becomes empty or the output buffer becomes full. It may introduce + buffer becomes empty or the output buffer becomes full. It may introduce some output latency (reading input without producing any output) except when forced to flush. - The detailed semantics are as follows. inflate performs one or both of the + The detailed semantics are as follows. inflate performs one or both of the following actions: - Decompress more input starting at next_in and update next_in and avail_in - accordingly. If not all input can be processed (because there is not - enough room in the output buffer), next_in is updated and processing - will resume at this point for the next call of inflate(). + accordingly. If not all input can be processed (because there is not + enough room in the output buffer), then next_in and avail_in are updated + accordingly, and processing will resume at this point for the next call of + inflate(). - - Provide more output starting at next_out and update next_out and avail_out - accordingly. inflate() provides as much output as possible, until there - is no more input data or no more space in the output buffer (see below - about the flush parameter). + - Generate more output starting at next_out and update next_out and avail_out + accordingly. inflate() provides as much output as possible, until there is + no more input data or no more space in the output buffer (see below about + the flush parameter). - Before the call of inflate(), the application should ensure that at least - one of the actions is possible, by providing more input and/or consuming - more output, and updating the next_* and avail_* values accordingly. - The application can consume the uncompressed output when it wants, for - example when the output buffer is full (avail_out == 0), or after each - call of inflate(). If inflate returns Z_OK and with zero avail_out, it - must be called again after making room in the output buffer because there - might be more output pending. + Before the call of inflate(), the application should ensure that at least + one of the actions is possible, by providing more input and/or consuming more + output, and updating the next_* and avail_* values accordingly. If the + caller of inflate() does not provide both available input and available + output space, it is possible that there will be no progress made. The + application can consume the uncompressed output when it wants, for example + when the output buffer is full (avail_out == 0), or after each call of + inflate(). If inflate returns Z_OK and with zero avail_out, it must be + called again after making room in the output buffer because there might be + more output pending. - The flush parameter of inflate() can be Z_NO_FLUSH, Z_SYNC_FLUSH, - Z_FINISH, or Z_BLOCK. Z_SYNC_FLUSH requests that inflate() flush as much - output as possible to the output buffer. Z_BLOCK requests that inflate() stop - if and when it gets to the next deflate block boundary. When decoding the - zlib or gzip format, this will cause inflate() to return immediately after - the header and before the first block. When doing a raw inflate, inflate() - will go ahead and process the first block, and will return when it gets to - the end of that block, or when it runs out of data. + The flush parameter of inflate() can be Z_NO_FLUSH, Z_SYNC_FLUSH, Z_FINISH, + Z_BLOCK, or Z_TREES. Z_SYNC_FLUSH requests that inflate() flush as much + output as possible to the output buffer. Z_BLOCK requests that inflate() + stop if and when it gets to the next deflate block boundary. When decoding + the zlib or gzip format, this will cause inflate() to return immediately + after the header and before the first block. When doing a raw inflate, + inflate() will go ahead and process the first block, and will return when it + gets to the end of that block, or when it runs out of data. The Z_BLOCK option assists in appending to or combining deflate streams. - Also to assist in this, on return inflate() will set strm->data_type to the - number of unused bits in the last byte taken from strm->next_in, plus 64 - if inflate() is currently decoding the last block in the deflate stream, - plus 128 if inflate() returned immediately after decoding an end-of-block - code or decoding the complete header up to just before the first byte of the - deflate stream. The end-of-block will not be indicated until all of the - uncompressed data from that block has been written to strm->next_out. The - number of unused bits may in general be greater than seven, except when - bit 7 of data_type is set, in which case the number of unused bits will be - less than eight. + To assist in this, on return inflate() always sets strm->data_type to the + number of unused bits in the last byte taken from strm->next_in, plus 64 if + inflate() is currently decoding the last block in the deflate stream, plus + 128 if inflate() returned immediately after decoding an end-of-block code or + decoding the complete header up to just before the first byte of the deflate + stream. The end-of-block will not be indicated until all of the uncompressed + data from that block has been written to strm->next_out. The number of + unused bits may in general be greater than seven, except when bit 7 of + data_type is set, in which case the number of unused bits will be less than + eight. data_type is set as noted here every time inflate() returns for all + flush options, and so can be used to determine the amount of currently + consumed input in bits. + + The Z_TREES option behaves as Z_BLOCK does, but it also returns when the + end of each deflate block header is reached, before any actual data in that + block is decoded. This allows the caller to determine the length of the + deflate block header for later use in random access within a deflate block. + 256 is added to the value of strm->data_type when inflate() returns + immediately after reaching the end of the deflate block header. inflate() should normally be called until it returns Z_STREAM_END or an - error. However if all decompression is to be performed in a single step - (a single call of inflate), the parameter flush should be set to - Z_FINISH. In this case all pending input is processed and all pending - output is flushed; avail_out must be large enough to hold all the - uncompressed data. (The size of the uncompressed data may have been saved - by the compressor for this purpose.) The next operation on this stream must - be inflateEnd to deallocate the decompression state. The use of Z_FINISH - is never required, but can be used to inform inflate that a faster approach - may be used for the single inflate() call. + error. However if all decompression is to be performed in a single step (a + single call of inflate), the parameter flush should be set to Z_FINISH. In + this case all pending input is processed and all pending output is flushed; + avail_out must be large enough to hold all of the uncompressed data for the + operation to complete. (The size of the uncompressed data may have been + saved by the compressor for this purpose.) The use of Z_FINISH is not + required to perform an inflation in one step. However it may be used to + inform inflate that a faster approach can be used for the single inflate() + call. Z_FINISH also informs inflate to not maintain a sliding window if the + stream completes, which reduces inflate's memory footprint. If the stream + does not complete, either because not all of the stream is provided or not + enough output space is provided, then a sliding window will be allocated and + inflate() can be called again to continue the operation as if Z_NO_FLUSH had + been used. In this implementation, inflate() always flushes as much output as possible to the output buffer, and always uses the faster approach on the - first call. So the only effect of the flush parameter in this implementation - is on the return value of inflate(), as noted below, or when it returns early - because Z_BLOCK is used. + first call. So the effects of the flush parameter in this implementation are + on the return value of inflate() as noted below, when inflate() returns early + when Z_BLOCK or Z_TREES is used, and when inflate() avoids the allocation of + memory for a sliding window when Z_FINISH is used. If a preset dictionary is needed after this call (see inflateSetDictionary - below), inflate sets strm->adler to the adler32 checksum of the dictionary + below), inflate sets strm->adler to the Adler-32 checksum of the dictionary chosen by the compressor and returns Z_NEED_DICT; otherwise it sets - strm->adler to the adler32 checksum of all output produced so far (that is, + strm->adler to the Adler-32 checksum of all output produced so far (that is, total_out bytes) and returns Z_OK, Z_STREAM_END or an error code as described - below. At the end of the stream, inflate() checks that its computed adler32 + below. At the end of the stream, inflate() checks that its computed Adler-32 checksum is equal to that saved by the compressor and returns Z_STREAM_END only if the checksum is correct. - inflate() will decompress and check either zlib-wrapped or gzip-wrapped - deflate data. The header type is detected automatically. Any information - contained in the gzip header is not retained, so applications that need that - information should instead use raw inflate, see inflateInit2() below, or - inflateBack() and perform their own processing of the gzip header and - trailer. + inflate() can decompress and check either zlib-wrapped or gzip-wrapped + deflate data. The header type is detected automatically, if requested when + initializing with inflateInit2(). Any information contained in the gzip + header is not retained unless inflateGetHeader() is used. When processing + gzip-wrapped deflate data, strm->adler32 is set to the CRC-32 of the output + produced so far. The CRC-32 is checked against the gzip trailer, as is the + uncompressed length, modulo 2^32. inflate() returns Z_OK if some progress has been made (more input processed or more output produced), Z_STREAM_END if the end of the compressed data has been reached and all uncompressed output has been produced, Z_NEED_DICT if a preset dictionary is needed at this point, Z_DATA_ERROR if the input data was corrupted (input stream not conforming to the zlib format or incorrect check - value), Z_STREAM_ERROR if the stream structure was inconsistent (for example - if next_in or next_out was NULL), Z_MEM_ERROR if there was not enough memory, - Z_BUF_ERROR if no progress is possible or if there was not enough room in the - output buffer when Z_FINISH is used. Note that Z_BUF_ERROR is not fatal, and + value, in which case strm->msg points to a string with a more specific + error), Z_STREAM_ERROR if the stream structure was inconsistent (for example + next_in or next_out was Z_NULL, or the state was inadvertently written over + by the application), Z_MEM_ERROR if there was not enough memory, Z_BUF_ERROR + if no progress was possible or if there was not enough room in the output + buffer when Z_FINISH is used. Note that Z_BUF_ERROR is not fatal, and inflate() can be called again with more input and more output space to - continue decompressing. If Z_DATA_ERROR is returned, the application may then - call inflateSync() to look for a good compression block if a partial recovery - of the data is desired. + continue decompressing. If Z_DATA_ERROR is returned, the application may + then call inflateSync() to look for a good compression block if a partial + recovery of the data is to be attempted. */ ZEXTERN int ZEXPORT inflateEnd OF((z_streamp strm)); /* All dynamically allocated data structures for this stream are freed. - This function discards any unprocessed input and does not flush any - pending output. + This function discards any unprocessed input and does not flush any pending + output. - inflateEnd returns Z_OK if success, Z_STREAM_ERROR if the stream state - was inconsistent. In the error case, msg may be set but then points to a - static string (which must not be deallocated). + inflateEnd returns Z_OK if success, or Z_STREAM_ERROR if the stream state + was inconsistent. */ + /* Advanced functions */ /* @@ -484,55 +542,70 @@ ZEXTERN int ZEXPORT deflateInit2 OF((z_streamp strm, int memLevel, int strategy)); - This is another version of deflateInit with more compression options. The - fields next_in, zalloc, zfree and opaque must be initialized before by - the caller. + This is another version of deflateInit with more compression options. The + fields next_in, zalloc, zfree and opaque must be initialized before by the + caller. - The method parameter is the compression method. It must be Z_DEFLATED in + The method parameter is the compression method. It must be Z_DEFLATED in this version of the library. The windowBits parameter is the base two logarithm of the window size - (the size of the history buffer). It should be in the range 8..15 for this - version of the library. Larger values of this parameter result in better - compression at the expense of memory usage. The default value is 15 if + (the size of the history buffer). It should be in the range 8..15 for this + version of the library. Larger values of this parameter result in better + compression at the expense of memory usage. The default value is 15 if deflateInit is used instead. - windowBits can also be -8..-15 for raw deflate. In this case, -windowBits - determines the window size. deflate() will then generate raw deflate data - with no zlib header or trailer, and will not compute an adler32 check value. + For the current implementation of deflate(), a windowBits value of 8 (a + window size of 256 bytes) is not supported. As a result, a request for 8 + will result in 9 (a 512-byte window). In that case, providing 8 to + inflateInit2() will result in an error when the zlib header with 9 is + checked against the initialization of inflate(). The remedy is to not use 8 + with deflateInit2() with this initialization, or at least in that case use 9 + with inflateInit2(). - windowBits can also be greater than 15 for optional gzip encoding. Add + windowBits can also be -8..-15 for raw deflate. In this case, -windowBits + determines the window size. deflate() will then generate raw deflate data + with no zlib header or trailer, and will not compute a check value. + + windowBits can also be greater than 15 for optional gzip encoding. Add 16 to windowBits to write a simple gzip header and trailer around the - compressed data instead of a zlib wrapper. The gzip header will have no - file name, no extra data, no comment, no modification time (set to zero), - no header crc, and the operating system will be set to 255 (unknown). If a - gzip stream is being written, strm->adler is a crc32 instead of an adler32. + compressed data instead of a zlib wrapper. The gzip header will have no + file name, no extra data, no comment, no modification time (set to zero), no + header crc, and the operating system will be set to the appropriate value, + if the operating system was determined at compile time. If a gzip stream is + being written, strm->adler is a CRC-32 instead of an Adler-32. + + For raw deflate or gzip encoding, a request for a 256-byte window is + rejected as invalid, since only the zlib header provides a means of + transmitting the window size to the decompressor. The memLevel parameter specifies how much memory should be allocated - for the internal compression state. memLevel=1 uses minimum memory but - is slow and reduces compression ratio; memLevel=9 uses maximum memory - for optimal speed. The default value is 8. See zconf.h for total memory - usage as a function of windowBits and memLevel. + for the internal compression state. memLevel=1 uses minimum memory but is + slow and reduces compression ratio; memLevel=9 uses maximum memory for + optimal speed. The default value is 8. See zconf.h for total memory usage + as a function of windowBits and memLevel. - The strategy parameter is used to tune the compression algorithm. Use the + The strategy parameter is used to tune the compression algorithm. Use the value Z_DEFAULT_STRATEGY for normal data, Z_FILTERED for data produced by a filter (or predictor), Z_HUFFMAN_ONLY to force Huffman encoding only (no string match), or Z_RLE to limit match distances to one (run-length - encoding). Filtered data consists mostly of small values with a somewhat - random distribution. In this case, the compression algorithm is tuned to - compress them better. The effect of Z_FILTERED is to force more Huffman + encoding). Filtered data consists mostly of small values with a somewhat + random distribution. In this case, the compression algorithm is tuned to + compress them better. The effect of Z_FILTERED is to force more Huffman coding and less string matching; it is somewhat intermediate between - Z_DEFAULT and Z_HUFFMAN_ONLY. Z_RLE is designed to be almost as fast as - Z_HUFFMAN_ONLY, but give better compression for PNG image data. The strategy - parameter only affects the compression ratio but not the correctness of the - compressed output even if it is not set appropriately. Z_FIXED prevents the - use of dynamic Huffman codes, allowing for a simpler decoder for special - applications. + Z_DEFAULT_STRATEGY and Z_HUFFMAN_ONLY. Z_RLE is designed to be almost as + fast as Z_HUFFMAN_ONLY, but give better compression for PNG image data. The + strategy parameter only affects the compression ratio but not the + correctness of the compressed output even if it is not set appropriately. + Z_FIXED prevents the use of dynamic Huffman codes, allowing for a simpler + decoder for special applications. - deflateInit2 returns Z_OK if success, Z_MEM_ERROR if there was not enough - memory, Z_STREAM_ERROR if a parameter is invalid (such as an invalid - method). msg is set to null if there is no error message. deflateInit2 does - not perform any compression: this will be done by deflate(). + deflateInit2 returns Z_OK if success, Z_MEM_ERROR if there was not enough + memory, Z_STREAM_ERROR if any parameter is invalid (such as an invalid + method), or Z_VERSION_ERROR if the zlib library version (zlib_version) is + incompatible with the version assumed by the caller (ZLIB_VERSION). msg is + set to null if there is no error message. deflateInit2 does not perform any + compression: this will be done by deflate(). */ ZEXTERN int ZEXPORT deflateSetDictionary OF((z_streamp strm, @@ -540,38 +613,65 @@ ZEXTERN int ZEXPORT deflateSetDictionary OF((z_streamp strm, uInt dictLength)); /* Initializes the compression dictionary from the given byte sequence - without producing any compressed output. This function must be called - immediately after deflateInit, deflateInit2 or deflateReset, before any - call of deflate. The compressor and decompressor must use exactly the same - dictionary (see inflateSetDictionary). + without producing any compressed output. When using the zlib format, this + function must be called immediately after deflateInit, deflateInit2 or + deflateReset, and before any call of deflate. When doing raw deflate, this + function must be called either before any call of deflate, or immediately + after the completion of a deflate block, i.e. after all input has been + consumed and all output has been delivered when using any of the flush + options Z_BLOCK, Z_PARTIAL_FLUSH, Z_SYNC_FLUSH, or Z_FULL_FLUSH. The + compressor and decompressor must use exactly the same dictionary (see + inflateSetDictionary). The dictionary should consist of strings (byte sequences) that are likely to be encountered later in the data to be compressed, with the most commonly - used strings preferably put towards the end of the dictionary. Using a + used strings preferably put towards the end of the dictionary. Using a dictionary is most useful when the data to be compressed is short and can be predicted with good accuracy; the data can then be compressed better than with the default empty dictionary. Depending on the size of the compression data structures selected by deflateInit or deflateInit2, a part of the dictionary may in effect be - discarded, for example if the dictionary is larger than the window size in - deflate or deflate2. Thus the strings most likely to be useful should be - put at the end of the dictionary, not at the front. In addition, the - current implementation of deflate will use at most the window size minus - 262 bytes of the provided dictionary. + discarded, for example if the dictionary is larger than the window size + provided in deflateInit or deflateInit2. Thus the strings most likely to be + useful should be put at the end of the dictionary, not at the front. In + addition, the current implementation of deflate will use at most the window + size minus 262 bytes of the provided dictionary. - Upon return of this function, strm->adler is set to the adler32 value + Upon return of this function, strm->adler is set to the Adler-32 value of the dictionary; the decompressor may later use this value to determine - which dictionary has been used by the compressor. (The adler32 value + which dictionary has been used by the compressor. (The Adler-32 value applies to the whole dictionary even if only a subset of the dictionary is actually used by the compressor.) If a raw deflate was requested, then the - adler32 value is not computed and strm->adler is not set. + Adler-32 value is not computed and strm->adler is not set. deflateSetDictionary returns Z_OK if success, or Z_STREAM_ERROR if a - parameter is invalid (such as NULL dictionary) or the stream state is + parameter is invalid (e.g. dictionary being Z_NULL) or the stream state is inconsistent (for example if deflate has already been called for this stream - or if the compression method is bsort). deflateSetDictionary does not - perform any compression: this will be done by deflate(). + or if not at a block boundary for raw deflate). deflateSetDictionary does + not perform any compression: this will be done by deflate(). +*/ + +ZEXTERN int ZEXPORT deflateGetDictionary OF((z_streamp strm, + Bytef *dictionary, + uInt *dictLength)); +/* + Returns the sliding dictionary being maintained by deflate. dictLength is + set to the number of bytes in the dictionary, and that many bytes are copied + to dictionary. dictionary must have enough space, where 32768 bytes is + always enough. If deflateGetDictionary() is called with dictionary equal to + Z_NULL, then only the dictionary length is returned, and nothing is copied. + Similary, if dictLength is Z_NULL, then it is not set. + + deflateGetDictionary() may return a length less than the window size, even + when more than the window size in input has been provided. It may return up + to 258 bytes less in that case, due to how zlib's implementation of deflate + manages the sliding window and lookahead for matches, where matches can be + up to 258 bytes long. If the application needs the last window-size bytes of + input, then that would need to be saved by the application outside of zlib. + + deflateGetDictionary returns Z_OK on success, or Z_STREAM_ERROR if the + stream state is inconsistent. */ ZEXTERN int ZEXPORT deflateCopy OF((z_streamp dest, @@ -581,26 +681,26 @@ ZEXTERN int ZEXPORT deflateCopy OF((z_streamp dest, This function can be useful when several compression strategies will be tried, for example when there are several ways of pre-processing the input - data with a filter. The streams that will be discarded should then be freed + data with a filter. The streams that will be discarded should then be freed by calling deflateEnd. Note that deflateCopy duplicates the internal - compression state which can be quite large, so this strategy is slow and - can consume lots of memory. + compression state which can be quite large, so this strategy is slow and can + consume lots of memory. deflateCopy returns Z_OK if success, Z_MEM_ERROR if there was not enough memory, Z_STREAM_ERROR if the source stream state was inconsistent - (such as zalloc being NULL). msg is left unchanged in both source and + (such as zalloc being Z_NULL). msg is left unchanged in both source and destination. */ ZEXTERN int ZEXPORT deflateReset OF((z_streamp strm)); /* - This function is equivalent to deflateEnd followed by deflateInit, - but does not free and reallocate all the internal compression state. - The stream will keep the same compression level and any other attributes - that may have been set by deflateInit2. + This function is equivalent to deflateEnd followed by deflateInit, but + does not free and reallocate the internal compression state. The stream + will leave the compression level and any other attributes that may have been + set unchanged. - deflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source - stream state was inconsistent (such as zalloc or state being NULL). + deflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source + stream state was inconsistent (such as zalloc or state being Z_NULL). */ ZEXTERN int ZEXPORT deflateParams OF((z_streamp strm, @@ -608,20 +708,36 @@ ZEXTERN int ZEXPORT deflateParams OF((z_streamp strm, int strategy)); /* Dynamically update the compression level and compression strategy. The - interpretation of level and strategy is as in deflateInit2. This can be + interpretation of level and strategy is as in deflateInit2(). This can be used to switch between compression and straight copy of the input data, or - to switch to a different kind of input data requiring a different - strategy. If the compression level is changed, the input available so far - is compressed with the old level (and may be flushed); the new level will - take effect only at the next call of deflate(). + to switch to a different kind of input data requiring a different strategy. + If the compression approach (which is a function of the level) or the + strategy is changed, and if any input has been consumed in a previous + deflate() call, then the input available so far is compressed with the old + level and strategy using deflate(strm, Z_BLOCK). There are three approaches + for the compression levels 0, 1..3, and 4..9 respectively. The new level + and strategy will take effect at the next call of deflate(). - Before the call of deflateParams, the stream state must be set as for - a call of deflate(), since the currently available input may have to - be compressed and flushed. In particular, strm->avail_out must be non-zero. + If a deflate(strm, Z_BLOCK) is performed by deflateParams(), and it does + not have enough output space to complete, then the parameter change will not + take effect. In this case, deflateParams() can be called again with the + same parameters and more output space to try again. - deflateParams returns Z_OK if success, Z_STREAM_ERROR if the source - stream state was inconsistent or if a parameter was invalid, Z_BUF_ERROR - if strm->avail_out was zero. + In order to assure a change in the parameters on the first try, the + deflate stream should be flushed using deflate() with Z_BLOCK or other flush + request until strm.avail_out is not zero, before calling deflateParams(). + Then no more input data should be provided before the deflateParams() call. + If this is done, the old level and strategy will be applied to the data + compressed before deflateParams(), and the new level and strategy will be + applied to the the data compressed after deflateParams(). + + deflateParams returns Z_OK on success, Z_STREAM_ERROR if the source stream + state was inconsistent or if a parameter was invalid, or Z_BUF_ERROR if + there was not enough output space to complete the compression of the + available input data before a change in the strategy or approach. Note that + in the case of a Z_BUF_ERROR, the parameters are not changed. A return + value of Z_BUF_ERROR is not fatal, in which case deflateParams() can be + retried with more output space. */ ZEXTERN int ZEXPORT deflateTune OF((z_streamp strm, @@ -645,31 +761,53 @@ ZEXTERN uLong ZEXPORT deflateBound OF((z_streamp strm, uLong sourceLen)); /* deflateBound() returns an upper bound on the compressed size after - deflation of sourceLen bytes. It must be called after deflateInit() - or deflateInit2(). This would be used to allocate an output buffer - for deflation in a single pass, and so would be called before deflate(). + deflation of sourceLen bytes. It must be called after deflateInit() or + deflateInit2(), and after deflateSetHeader(), if used. This would be used + to allocate an output buffer for deflation in a single pass, and so would be + called before deflate(). If that first deflate() call is provided the + sourceLen input bytes, an output buffer allocated to the size returned by + deflateBound(), and the flush value Z_FINISH, then deflate() is guaranteed + to return Z_STREAM_END. Note that it is possible for the compressed size to + be larger than the value returned by deflateBound() if flush options other + than Z_FINISH or Z_NO_FLUSH are used. */ +ZEXTERN int ZEXPORT deflatePending OF((z_streamp strm, + unsigned *pending, + int *bits)); +/* + deflatePending() returns the number of bytes and bits of output that have + been generated, but not yet provided in the available output. The bytes not + provided would be due to the available output space having being consumed. + The number of bits of output not provided are between 0 and 7, where they + await more bits to join them in order to fill out a full byte. If pending + or bits are Z_NULL, then those values are not set. + + deflatePending returns Z_OK if success, or Z_STREAM_ERROR if the source + stream state was inconsistent. + */ + ZEXTERN int ZEXPORT deflatePrime OF((z_streamp strm, int bits, int value)); /* deflatePrime() inserts bits in the deflate output stream. The intent - is that this function is used to start off the deflate output with the - bits leftover from a previous deflate stream when appending to it. As such, - this function can only be used for raw deflate, and must be used before the - first deflate() call after a deflateInit2() or deflateReset(). bits must be - less than or equal to 16, and that many of the least significant bits of - value will be inserted in the output. + is that this function is used to start off the deflate output with the bits + leftover from a previous deflate stream when appending to it. As such, this + function can only be used for raw deflate, and must be used before the first + deflate() call after a deflateInit2() or deflateReset(). bits must be less + than or equal to 16, and that many of the least significant bits of value + will be inserted in the output. - deflatePrime returns Z_OK if success, or Z_STREAM_ERROR if the source - stream state was inconsistent. + deflatePrime returns Z_OK if success, Z_BUF_ERROR if there was not enough + room in the internal buffer to insert the bits, or Z_STREAM_ERROR if the + source stream state was inconsistent. */ ZEXTERN int ZEXPORT deflateSetHeader OF((z_streamp strm, gz_headerp head)); /* - deflateSetHeader() provides gzip header information for when a gzip + deflateSetHeader() provides gzip header information for when a gzip stream is requested by deflateInit2(). deflateSetHeader() may be called after deflateInit2() or deflateReset() and before the first call of deflate(). The text, time, os, extra field, name, and comment information @@ -682,11 +820,11 @@ ZEXTERN int ZEXPORT deflateSetHeader OF((z_streamp strm, 1.3.x) do not support header crc's, and will report that it is a "multi-part gzip file" and give up. - If deflateSetHeader is not used, the default gzip header has text false, + If deflateSetHeader is not used, the default gzip header has text false, the time set to zero, and os set to 255, with no extra, name, or comment fields. The gzip header is returned to the default state by deflateReset(). - deflateSetHeader returns Z_OK if success, or Z_STREAM_ERROR if the source + deflateSetHeader returns Z_OK if success, or Z_STREAM_ERROR if the source stream state was inconsistent. */ @@ -694,43 +832,53 @@ ZEXTERN int ZEXPORT deflateSetHeader OF((z_streamp strm, ZEXTERN int ZEXPORT inflateInit2 OF((z_streamp strm, int windowBits)); - This is another version of inflateInit with an extra parameter. The + This is another version of inflateInit with an extra parameter. The fields next_in, avail_in, zalloc, zfree and opaque must be initialized before by the caller. The windowBits parameter is the base two logarithm of the maximum window size (the size of the history buffer). It should be in the range 8..15 for - this version of the library. The default value is 15 if inflateInit is used - instead. windowBits must be greater than or equal to the windowBits value + this version of the library. The default value is 15 if inflateInit is used + instead. windowBits must be greater than or equal to the windowBits value provided to deflateInit2() while compressing, or it must be equal to 15 if - deflateInit2() was not used. If a compressed stream with a larger window + deflateInit2() was not used. If a compressed stream with a larger window size is given as input, inflate() will return with the error code Z_DATA_ERROR instead of trying to allocate a larger window. - windowBits can also be -8..-15 for raw inflate. In this case, -windowBits - determines the window size. inflate() will then process raw deflate data, + windowBits can also be zero to request that inflate use the window size in + the zlib header of the compressed stream. + + windowBits can also be -8..-15 for raw inflate. In this case, -windowBits + determines the window size. inflate() will then process raw deflate data, not looking for a zlib or gzip header, not generating a check value, and not - looking for any check values for comparison at the end of the stream. This + looking for any check values for comparison at the end of the stream. This is for use with other formats that use the deflate compressed data format - such as zip. Those formats provide their own check values. If a custom + such as zip. Those formats provide their own check values. If a custom format is developed using the raw deflate format for compressed data, it is - recommended that a check value such as an adler32 or a crc32 be applied to + recommended that a check value such as an Adler-32 or a CRC-32 be applied to the uncompressed data as is done in the zlib, gzip, and zip formats. For - most applications, the zlib format should be used as is. Note that comments + most applications, the zlib format should be used as is. Note that comments above on the use in deflateInit2() applies to the magnitude of windowBits. - windowBits can also be greater than 15 for optional gzip decoding. Add + windowBits can also be greater than 15 for optional gzip decoding. Add 32 to windowBits to enable zlib and gzip decoding with automatic header detection, or add 16 to decode only the gzip format (the zlib format will - return a Z_DATA_ERROR). If a gzip stream is being decoded, strm->adler is - a crc32 instead of an adler32. + return a Z_DATA_ERROR). If a gzip stream is being decoded, strm->adler is a + CRC-32 instead of an Adler-32. Unlike the gunzip utility and gzread() (see + below), inflate() will not automatically decode concatenated gzip streams. + inflate() will return Z_STREAM_END at the end of the gzip stream. The state + would need to be reset to continue decoding a subsequent gzip stream. inflateInit2 returns Z_OK if success, Z_MEM_ERROR if there was not enough - memory, Z_STREAM_ERROR if a parameter is invalid (such as a null strm). msg - is set to null if there is no error message. inflateInit2 does not perform - any decompression apart from reading the zlib header if present: this will - be done by inflate(). (So next_in and avail_in may be modified, but next_out - and avail_out are unchanged.) + memory, Z_VERSION_ERROR if the zlib library version is incompatible with the + version assumed by the caller, or Z_STREAM_ERROR if the parameters are + invalid, such as a null pointer to the structure. msg is set to null if + there is no error message. inflateInit2 does not perform any decompression + apart from possibly reading the zlib header if present: actual decompression + will be done by inflate(). (So next_in and avail_in may be modified, but + next_out and avail_out are unused and unchanged.) The current implementation + of inflateInit2() does not process any header information -- that is + deferred until inflate() is called. */ ZEXTERN int ZEXPORT inflateSetDictionary OF((z_streamp strm, @@ -738,36 +886,56 @@ ZEXTERN int ZEXPORT inflateSetDictionary OF((z_streamp strm, uInt dictLength)); /* Initializes the decompression dictionary from the given uncompressed byte - sequence. This function must be called immediately after a call of inflate, - if that call returned Z_NEED_DICT. The dictionary chosen by the compressor - can be determined from the adler32 value returned by that call of inflate. + sequence. This function must be called immediately after a call of inflate, + if that call returned Z_NEED_DICT. The dictionary chosen by the compressor + can be determined from the Adler-32 value returned by that call of inflate. The compressor and decompressor must use exactly the same dictionary (see - deflateSetDictionary). For raw inflate, this function can be called - immediately after inflateInit2() or inflateReset() and before any call of - inflate() to set the dictionary. The application must insure that the - dictionary that was used for compression is provided. + deflateSetDictionary). For raw inflate, this function can be called at any + time to set the dictionary. If the provided dictionary is smaller than the + window and there is already data in the window, then the provided dictionary + will amend what's there. The application must insure that the dictionary + that was used for compression is provided. inflateSetDictionary returns Z_OK if success, Z_STREAM_ERROR if a - parameter is invalid (such as NULL dictionary) or the stream state is + parameter is invalid (e.g. dictionary being Z_NULL) or the stream state is inconsistent, Z_DATA_ERROR if the given dictionary doesn't match the - expected one (incorrect adler32 value). inflateSetDictionary does not + expected one (incorrect Adler-32 value). inflateSetDictionary does not perform any decompression: this will be done by subsequent calls of inflate(). */ +ZEXTERN int ZEXPORT inflateGetDictionary OF((z_streamp strm, + Bytef *dictionary, + uInt *dictLength)); +/* + Returns the sliding dictionary being maintained by inflate. dictLength is + set to the number of bytes in the dictionary, and that many bytes are copied + to dictionary. dictionary must have enough space, where 32768 bytes is + always enough. If inflateGetDictionary() is called with dictionary equal to + Z_NULL, then only the dictionary length is returned, and nothing is copied. + Similary, if dictLength is Z_NULL, then it is not set. + + inflateGetDictionary returns Z_OK on success, or Z_STREAM_ERROR if the + stream state is inconsistent. +*/ + ZEXTERN int ZEXPORT inflateSync OF((z_streamp strm)); /* - Skips invalid compressed data until a full flush point (see above the - description of deflate with Z_FULL_FLUSH) can be found, or until all - available input is skipped. No output is provided. + Skips invalid compressed data until a possible full flush point (see above + for the description of deflate with Z_FULL_FLUSH) can be found, or until all + available input is skipped. No output is provided. - inflateSync returns Z_OK if a full flush point has been found, Z_BUF_ERROR - if no more input was provided, Z_DATA_ERROR if no flush point has been found, - or Z_STREAM_ERROR if the stream structure was inconsistent. In the success - case, the application may save the current current value of total_in which - indicates where valid compressed data was found. In the error case, the - application may repeatedly call inflateSync, providing more input each time, - until success or end of the input data. + inflateSync searches for a 00 00 FF FF pattern in the compressed data. + All full flush points have this pattern, but not all occurrences of this + pattern are full flush points. + + inflateSync returns Z_OK if a possible full flush point has been found, + Z_BUF_ERROR if no more input was provided, Z_DATA_ERROR if no flush point + has been found, or Z_STREAM_ERROR if the stream structure was inconsistent. + In the success case, the application may save the current current value of + total_in which indicates where valid compressed data was found. In the + error case, the application may repeatedly call inflateSync, providing more + input each time, until success or end of the input data. */ ZEXTERN int ZEXPORT inflateCopy OF((z_streamp dest, @@ -782,18 +950,32 @@ ZEXTERN int ZEXPORT inflateCopy OF((z_streamp dest, inflateCopy returns Z_OK if success, Z_MEM_ERROR if there was not enough memory, Z_STREAM_ERROR if the source stream state was inconsistent - (such as zalloc being NULL). msg is left unchanged in both source and + (such as zalloc being Z_NULL). msg is left unchanged in both source and destination. */ ZEXTERN int ZEXPORT inflateReset OF((z_streamp strm)); /* This function is equivalent to inflateEnd followed by inflateInit, - but does not free and reallocate all the internal decompression state. - The stream will keep attributes that may have been set by inflateInit2. + but does not free and reallocate the internal decompression state. The + stream will keep attributes that may have been set by inflateInit2. - inflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source - stream state was inconsistent (such as zalloc or state being NULL). + inflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source + stream state was inconsistent (such as zalloc or state being Z_NULL). +*/ + +ZEXTERN int ZEXPORT inflateReset2 OF((z_streamp strm, + int windowBits)); +/* + This function is the same as inflateReset, but it also permits changing + the wrap and window size requests. The windowBits parameter is interpreted + the same as it is for inflateInit2. If the window size is changed, then the + memory allocated for the window is freed, and the window will be reallocated + by inflate() if needed. + + inflateReset2 returns Z_OK if success, or Z_STREAM_ERROR if the source + stream state was inconsistent (such as zalloc or state being Z_NULL), or if + the windowBits parameter is invalid. */ ZEXTERN int ZEXPORT inflatePrime OF((z_streamp strm, @@ -801,54 +983,87 @@ ZEXTERN int ZEXPORT inflatePrime OF((z_streamp strm, int value)); /* This function inserts bits in the inflate input stream. The intent is - that this function is used to start inflating at a bit position in the - middle of a byte. The provided bits will be used before any bytes are used - from next_in. This function should only be used with raw inflate, and - should be used before the first inflate() call after inflateInit2() or - inflateReset(). bits must be less than or equal to 16, and that many of the - least significant bits of value will be inserted in the input. + that this function is used to start inflating at a bit position in the + middle of a byte. The provided bits will be used before any bytes are used + from next_in. This function should only be used with raw inflate, and + should be used before the first inflate() call after inflateInit2() or + inflateReset(). bits must be less than or equal to 16, and that many of the + least significant bits of value will be inserted in the input. - inflatePrime returns Z_OK if success, or Z_STREAM_ERROR if the source + If bits is negative, then the input stream bit buffer is emptied. Then + inflatePrime() can be called again to put bits in the buffer. This is used + to clear out bits leftover after feeding inflate a block description prior + to feeding inflate codes. + + inflatePrime returns Z_OK if success, or Z_STREAM_ERROR if the source stream state was inconsistent. */ +ZEXTERN long ZEXPORT inflateMark OF((z_streamp strm)); +/* + This function returns two values, one in the lower 16 bits of the return + value, and the other in the remaining upper bits, obtained by shifting the + return value down 16 bits. If the upper value is -1 and the lower value is + zero, then inflate() is currently decoding information outside of a block. + If the upper value is -1 and the lower value is non-zero, then inflate is in + the middle of a stored block, with the lower value equaling the number of + bytes from the input remaining to copy. If the upper value is not -1, then + it is the number of bits back from the current bit position in the input of + the code (literal or length/distance pair) currently being processed. In + that case the lower value is the number of bytes already emitted for that + code. + + A code is being processed if inflate is waiting for more input to complete + decoding of the code, or if it has completed decoding but is waiting for + more output space to write the literal or match data. + + inflateMark() is used to mark locations in the input data for random + access, which may be at bit positions, and to note those cases where the + output of a code may span boundaries of random access blocks. The current + location in the input stream can be determined from avail_in and data_type + as noted in the description for the Z_BLOCK flush parameter for inflate. + + inflateMark returns the value noted above, or -65536 if the provided + source stream state was inconsistent. +*/ + ZEXTERN int ZEXPORT inflateGetHeader OF((z_streamp strm, gz_headerp head)); /* - inflateGetHeader() requests that gzip header information be stored in the + inflateGetHeader() requests that gzip header information be stored in the provided gz_header structure. inflateGetHeader() may be called after inflateInit2() or inflateReset(), and before the first call of inflate(). As inflate() processes the gzip stream, head->done is zero until the header is completed, at which time head->done is set to one. If a zlib stream is being decoded, then head->done is set to -1 to indicate that there will be - no gzip header information forthcoming. Note that Z_BLOCK can be used to - force inflate() to return immediately after header processing is complete - and before any actual data is decompressed. + no gzip header information forthcoming. Note that Z_BLOCK or Z_TREES can be + used to force inflate() to return immediately after header processing is + complete and before any actual data is decompressed. - The text, time, xflags, and os fields are filled in with the gzip header + The text, time, xflags, and os fields are filled in with the gzip header contents. hcrc is set to true if there is a header CRC. (The header CRC - was valid if done is set to one.) If extra is not Z_NULL, then extra_max + was valid if done is set to one.) If extra is not Z_NULL, then extra_max contains the maximum number of bytes to write to extra. Once done is true, extra_len contains the actual extra field length, and extra contains the extra field, or that field truncated if extra_max is less than extra_len. If name is not Z_NULL, then up to name_max characters are written there, terminated with a zero unless the length is greater than name_max. If comment is not Z_NULL, then up to comm_max characters are written there, - terminated with a zero unless the length is greater than comm_max. When - any of extra, name, or comment are not Z_NULL and the respective field is - not present in the header, then that field is set to Z_NULL to signal its + terminated with a zero unless the length is greater than comm_max. When any + of extra, name, or comment are not Z_NULL and the respective field is not + present in the header, then that field is set to Z_NULL to signal its absence. This allows the use of deflateSetHeader() with the returned structure to duplicate the header. However if those fields are set to allocated memory, then the application will need to save those pointers elsewhere so that they can be eventually freed. - If inflateGetHeader is not used, then the header information is simply + If inflateGetHeader is not used, then the header information is simply discarded. The header is always checked for validity, including the header CRC if present. inflateReset() will reset the process to discard the header information. The application would need to call inflateGetHeader() again to retrieve the header from the next gzip stream. - inflateGetHeader returns Z_OK if success, or Z_STREAM_ERROR if the source + inflateGetHeader returns Z_OK if success, or Z_STREAM_ERROR if the source stream state was inconsistent. */ @@ -869,12 +1084,13 @@ ZEXTERN int ZEXPORT inflateBackInit OF((z_streamp strm, int windowBits, See inflateBack() for the usage of these routines. inflateBackInit will return Z_OK on success, Z_STREAM_ERROR if any of - the paramaters are invalid, Z_MEM_ERROR if the internal state could not - be allocated, or Z_VERSION_ERROR if the version of the library does not - match the version of the header file. + the parameters are invalid, Z_MEM_ERROR if the internal state could not be + allocated, or Z_VERSION_ERROR if the version of the library does not match + the version of the header file. */ -typedef unsigned (*in_func) OF((void FAR *, unsigned char FAR * FAR *)); +typedef unsigned (*in_func) OF((void FAR *, + z_const unsigned char FAR * FAR *)); typedef int (*out_func) OF((void FAR *, unsigned char FAR *, unsigned)); ZEXTERN int ZEXPORT inflateBack OF((z_streamp strm, @@ -882,25 +1098,26 @@ ZEXTERN int ZEXPORT inflateBack OF((z_streamp strm, out_func out, void FAR *out_desc)); /* inflateBack() does a raw inflate with a single call using a call-back - interface for input and output. This is more efficient than inflate() for - file i/o applications in that it avoids copying between the output and the - sliding window by simply making the window itself the output buffer. This - function trusts the application to not change the output buffer passed by - the output function, at least until inflateBack() returns. + interface for input and output. This is potentially more efficient than + inflate() for file i/o applications, in that it avoids copying between the + output and the sliding window by simply making the window itself the output + buffer. inflate() can be faster on modern CPUs when used with large + buffers. inflateBack() trusts the application to not change the output + buffer passed by the output function, at least until inflateBack() returns. inflateBackInit() must be called first to allocate the internal state and to initialize the state with the user-provided window buffer. inflateBack() may then be used multiple times to inflate a complete, raw - deflate stream with each call. inflateBackEnd() is then called to free - the allocated state. + deflate stream with each call. inflateBackEnd() is then called to free the + allocated state. A raw deflate stream is one with no zlib or gzip header or trailer. This routine would normally be used in a utility that reads zip or gzip files and writes out uncompressed files. The utility would decode the - header and process the trailer on its own, hence this routine expects - only the raw deflate stream to decompress. This is different from the - normal behavior of inflate(), which expects either a zlib or gzip header and - trailer around the deflate stream. + header and process the trailer on its own, hence this routine expects only + the raw deflate stream to decompress. This is different from the default + behavior of inflate(), which expects a zlib header and trailer around the + deflate stream. inflateBack() uses two subroutines supplied by the caller that are then called by inflateBack() for input and output. inflateBack() calls those @@ -909,12 +1126,12 @@ ZEXTERN int ZEXPORT inflateBack OF((z_streamp strm, parameters and return types are defined above in the in_func and out_func typedefs. inflateBack() will call in(in_desc, &buf) which should return the number of bytes of provided input, and a pointer to that input in buf. If - there is no input available, in() must return zero--buf is ignored in that - case--and inflateBack() will return a buffer error. inflateBack() will call - out(out_desc, buf, len) to write the uncompressed data buf[0..len-1]. out() - should return zero on success, or non-zero on failure. If out() returns - non-zero, inflateBack() will return with an error. Neither in() nor out() - are permitted to change the contents of the window provided to + there is no input available, in() must return zero -- buf is ignored in that + case -- and inflateBack() will return a buffer error. inflateBack() will + call out(out_desc, buf, len) to write the uncompressed data buf[0..len-1]. + out() should return zero on success, or non-zero on failure. If out() + returns non-zero, inflateBack() will return with an error. Neither in() nor + out() are permitted to change the contents of the window provided to inflateBackInit(), which is also the buffer that out() uses to write from. The length written by out() will be at most the window size. Any non-zero amount of input may be provided by in(). @@ -925,7 +1142,7 @@ ZEXTERN int ZEXPORT inflateBack OF((z_streamp strm, calling inflateBack(). If strm->next_in is Z_NULL, then in() will be called immediately for input. If strm->next_in is not Z_NULL, then strm->avail_in must also be initialized, and then if strm->avail_in is not zero, input will - initially be taken from strm->next_in[0 .. strm->avail_in - 1]. + initially be taken from strm->next_in[0 .. strm->avail_in - 1]. The in_desc and out_desc parameters of inflateBack() is passed as the first parameter of in() and out() respectively when they are called. These @@ -935,15 +1152,15 @@ ZEXTERN int ZEXPORT inflateBack OF((z_streamp strm, On return, inflateBack() will set strm->next_in and strm->avail_in to pass back any unused input that was provided by the last in() call. The return values of inflateBack() can be Z_STREAM_END on success, Z_BUF_ERROR - if in() or out() returned an error, Z_DATA_ERROR if there was a format - error in the deflate stream (in which case strm->msg is set to indicate the - nature of the error), or Z_STREAM_ERROR if the stream was not properly - initialized. In the case of Z_BUF_ERROR, an input or output error can be - distinguished using strm->next_in which will be Z_NULL only if in() returned - an error. If strm->next is not Z_NULL, then the Z_BUF_ERROR was due to - out() returning non-zero. (in() will always be called before out(), so - strm->next_in is assured to be defined if out() returns non-zero.) Note - that inflateBack() cannot return Z_OK. + if in() or out() returned an error, Z_DATA_ERROR if there was a format error + in the deflate stream (in which case strm->msg is set to indicate the nature + of the error), or Z_STREAM_ERROR if the stream was not properly initialized. + In the case of Z_BUF_ERROR, an input or output error can be distinguished + using strm->next_in which will be Z_NULL only if in() returned an error. If + strm->next_in is not Z_NULL, then the Z_BUF_ERROR was due to out() returning + non-zero. (in() will always be called before out(), so strm->next_in is + assured to be defined if out() returns non-zero.) Note that inflateBack() + cannot return Z_OK. */ ZEXTERN int ZEXPORT inflateBackEnd OF((z_streamp strm)); @@ -964,7 +1181,7 @@ ZEXTERN uLong ZEXPORT zlibCompileFlags OF((void)); 7.6: size of z_off_t Compiler, assembler, and debug options: - 8: DEBUG + 8: ZLIB_DEBUG 9: ASMV or ASMINF -- use ASM code 10: ZLIB_WINAPI -- exported functions use the WINAPI calling convention 11: 0 (reserved) @@ -995,27 +1212,28 @@ ZEXTERN uLong ZEXPORT zlibCompileFlags OF((void)); 27-31: 0 (reserved) */ +#ifndef Z_SOLO /* utility functions */ /* - The following utility functions are implemented on top of the - basic stream-oriented functions. To simplify the interface, some - default options are assumed (compression level and memory usage, - standard memory allocation functions). The source code of these - utility functions can easily be modified if you need special options. + The following utility functions are implemented on top of the basic + stream-oriented functions. To simplify the interface, some default options + are assumed (compression level and memory usage, standard memory allocation + functions). The source code of these utility functions can be modified if + you need special options. */ ZEXTERN int ZEXPORT compress OF((Bytef *dest, uLongf *destLen, const Bytef *source, uLong sourceLen)); /* Compresses the source buffer into the destination buffer. sourceLen is - the byte length of the source buffer. Upon entry, destLen is the total - size of the destination buffer, which must be at least the value returned - by compressBound(sourceLen). Upon exit, destLen is the actual size of the - compressed buffer. - This function can be used to compress a whole file at once if the - input file is mmap'ed. + the byte length of the source buffer. Upon entry, destLen is the total size + of the destination buffer, which must be at least the value returned by + compressBound(sourceLen). Upon exit, destLen is the actual size of the + compressed data. compress() is equivalent to compress2() with a level + parameter of Z_DEFAULT_COMPRESSION. + compress returns Z_OK if success, Z_MEM_ERROR if there was not enough memory, Z_BUF_ERROR if there was not enough room in the output buffer. @@ -1025,12 +1243,12 @@ ZEXTERN int ZEXPORT compress2 OF((Bytef *dest, uLongf *destLen, const Bytef *source, uLong sourceLen, int level)); /* - Compresses the source buffer into the destination buffer. The level + Compresses the source buffer into the destination buffer. The level parameter has the same meaning as in deflateInit. sourceLen is the byte - length of the source buffer. Upon entry, destLen is the total size of the + length of the source buffer. Upon entry, destLen is the total size of the destination buffer, which must be at least the value returned by - compressBound(sourceLen). Upon exit, destLen is the actual size of the - compressed buffer. + compressBound(sourceLen). Upon exit, destLen is the actual size of the + compressed data. compress2 returns Z_OK if success, Z_MEM_ERROR if there was not enough memory, Z_BUF_ERROR if there was not enough room in the output buffer, @@ -1040,159 +1258,306 @@ ZEXTERN int ZEXPORT compress2 OF((Bytef *dest, uLongf *destLen, ZEXTERN uLong ZEXPORT compressBound OF((uLong sourceLen)); /* compressBound() returns an upper bound on the compressed size after - compress() or compress2() on sourceLen bytes. It would be used before - a compress() or compress2() call to allocate the destination buffer. + compress() or compress2() on sourceLen bytes. It would be used before a + compress() or compress2() call to allocate the destination buffer. */ ZEXTERN int ZEXPORT uncompress OF((Bytef *dest, uLongf *destLen, const Bytef *source, uLong sourceLen)); /* Decompresses the source buffer into the destination buffer. sourceLen is - the byte length of the source buffer. Upon entry, destLen is the total - size of the destination buffer, which must be large enough to hold the - entire uncompressed data. (The size of the uncompressed data must have - been saved previously by the compressor and transmitted to the decompressor - by some mechanism outside the scope of this compression library.) - Upon exit, destLen is the actual size of the compressed buffer. - This function can be used to decompress a whole file at once if the - input file is mmap'ed. + the byte length of the source buffer. Upon entry, destLen is the total size + of the destination buffer, which must be large enough to hold the entire + uncompressed data. (The size of the uncompressed data must have been saved + previously by the compressor and transmitted to the decompressor by some + mechanism outside the scope of this compression library.) Upon exit, destLen + is the actual size of the uncompressed data. uncompress returns Z_OK if success, Z_MEM_ERROR if there was not enough memory, Z_BUF_ERROR if there was not enough room in the output - buffer, or Z_DATA_ERROR if the input data was corrupted or incomplete. + buffer, or Z_DATA_ERROR if the input data was corrupted or incomplete. In + the case where there is not enough room, uncompress() will fill the output + buffer with the uncompressed data up to that point. */ - -typedef voidp gzFile; - -ZEXTERN gzFile ZEXPORT gzopen OF((const char *path, const char *mode)); +ZEXTERN int ZEXPORT uncompress2 OF((Bytef *dest, uLongf *destLen, + const Bytef *source, uLong *sourceLen)); /* - Opens a gzip (.gz) file for reading or writing. The mode parameter - is as in fopen ("rb" or "wb") but can also include a compression level - ("wb9") or a strategy: 'f' for filtered data as in "wb6f", 'h' for - Huffman only compression as in "wb1h", or 'R' for run-length encoding - as in "wb1R". (See the description of deflateInit2 for more information - about the strategy parameter.) + Same as uncompress, except that sourceLen is a pointer, where the + length of the source is *sourceLen. On return, *sourceLen is the number of + source bytes consumed. +*/ + + /* gzip file access functions */ + +/* + This library supports reading and writing files in gzip (.gz) format with + an interface similar to that of stdio, using the functions that start with + "gz". The gzip format is different from the zlib format. gzip is a gzip + wrapper, documented in RFC 1952, wrapped around a deflate stream. +*/ + +typedef struct gzFile_s *gzFile; /* semi-opaque gzip file descriptor */ + +/* +ZEXTERN gzFile ZEXPORT gzopen OF((const char *path, const char *mode)); + + Opens a gzip (.gz) file for reading or writing. The mode parameter is as + in fopen ("rb" or "wb") but can also include a compression level ("wb9") or + a strategy: 'f' for filtered data as in "wb6f", 'h' for Huffman-only + compression as in "wb1h", 'R' for run-length encoding as in "wb1R", or 'F' + for fixed code compression as in "wb9F". (See the description of + deflateInit2 for more information about the strategy parameter.) 'T' will + request transparent writing or appending with no compression and not using + the gzip format. + + "a" can be used instead of "w" to request that the gzip stream that will + be written be appended to the file. "+" will result in an error, since + reading and writing to the same gzip file is not supported. The addition of + "x" when writing will create the file exclusively, which fails if the file + already exists. On systems that support it, the addition of "e" when + reading or writing will set the flag to close the file on an execve() call. + + These functions, as well as gzip, will read and decode a sequence of gzip + streams in a file. The append function of gzopen() can be used to create + such a file. (Also see gzflush() for another way to do this.) When + appending, gzopen does not test whether the file begins with a gzip stream, + nor does it look for the end of the gzip streams to begin appending. gzopen + will simply append a gzip stream to the existing file. gzopen can be used to read a file which is not in gzip format; in this - case gzread will directly read from the file without decompression. + case gzread will directly read from the file without decompression. When + reading, this will be detected automatically by looking for the magic two- + byte gzip header. - gzopen returns NULL if the file could not be opened or if there was - insufficient memory to allocate the (de)compression state; errno - can be checked to distinguish the two cases (if errno is zero, the - zlib error is Z_MEM_ERROR). */ + gzopen returns NULL if the file could not be opened, if there was + insufficient memory to allocate the gzFile state, or if an invalid mode was + specified (an 'r', 'w', or 'a' was not provided, or '+' was provided). + errno can be checked to determine if the reason gzopen failed was that the + file could not be opened. +*/ -ZEXTERN gzFile ZEXPORT gzdopen OF((int fd, const char *mode)); +ZEXTERN gzFile ZEXPORT gzdopen OF((int fd, const char *mode)); /* - gzdopen() associates a gzFile with the file descriptor fd. File - descriptors are obtained from calls like open, dup, creat, pipe or - fileno (in the file has been previously opened with fopen). - The mode parameter is as in gzopen. - The next call of gzclose on the returned gzFile will also close the - file descriptor fd, just like fclose(fdopen(fd), mode) closes the file - descriptor fd. If you want to keep fd open, use gzdopen(dup(fd), mode). - gzdopen returns NULL if there was insufficient memory to allocate - the (de)compression state. + gzdopen associates a gzFile with the file descriptor fd. File descriptors + are obtained from calls like open, dup, creat, pipe or fileno (if the file + has been previously opened with fopen). The mode parameter is as in gzopen. + + The next call of gzclose on the returned gzFile will also close the file + descriptor fd, just like fclose(fdopen(fd, mode)) closes the file descriptor + fd. If you want to keep fd open, use fd = dup(fd_keep); gz = gzdopen(fd, + mode);. The duplicated descriptor should be saved to avoid a leak, since + gzdopen does not close fd if it fails. If you are using fileno() to get the + file descriptor from a FILE *, then you will have to use dup() to avoid + double-close()ing the file descriptor. Both gzclose() and fclose() will + close the associated file descriptor, so they need to have different file + descriptors. + + gzdopen returns NULL if there was insufficient memory to allocate the + gzFile state, if an invalid mode was specified (an 'r', 'w', or 'a' was not + provided, or '+' was provided), or if fd is -1. The file descriptor is not + used until the next gz* read, write, seek, or close operation, so gzdopen + will not detect if fd is invalid (unless fd is -1). +*/ + +ZEXTERN int ZEXPORT gzbuffer OF((gzFile file, unsigned size)); +/* + Set the internal buffer size used by this library's functions. The + default buffer size is 8192 bytes. This function must be called after + gzopen() or gzdopen(), and before any other calls that read or write the + file. The buffer memory allocation is always deferred to the first read or + write. Three times that size in buffer space is allocated. A larger buffer + size of, for example, 64K or 128K bytes will noticeably increase the speed + of decompression (reading). + + The new buffer size also affects the maximum length for gzprintf(). + + gzbuffer() returns 0 on success, or -1 on failure, such as being called + too late. */ ZEXTERN int ZEXPORT gzsetparams OF((gzFile file, int level, int strategy)); /* - Dynamically update the compression level or strategy. See the description - of deflateInit2 for the meaning of these parameters. - gzsetparams returns Z_OK if success, or Z_STREAM_ERROR if the file was not - opened for writing. + Dynamically update the compression level or strategy. See the description + of deflateInit2 for the meaning of these parameters. Previously provided + data is flushed before the parameter change. + + gzsetparams returns Z_OK if success, Z_STREAM_ERROR if the file was not + opened for writing, Z_ERRNO if there is an error writing the flushed data, + or Z_MEM_ERROR if there is a memory allocation error. */ -ZEXTERN int ZEXPORT gzread OF((gzFile file, voidp buf, unsigned len)); +ZEXTERN int ZEXPORT gzread OF((gzFile file, voidp buf, unsigned len)); /* - Reads the given number of uncompressed bytes from the compressed file. - If the input file was not in gzip format, gzread copies the given number - of bytes into the buffer. - gzread returns the number of uncompressed bytes actually read (0 for - end of file, -1 for error). */ + Reads the given number of uncompressed bytes from the compressed file. If + the input file is not in gzip format, gzread copies the given number of + bytes into the buffer directly from the file. -ZEXTERN int ZEXPORT gzwrite OF((gzFile file, - voidpc buf, unsigned len)); + After reaching the end of a gzip stream in the input, gzread will continue + to read, looking for another gzip stream. Any number of gzip streams may be + concatenated in the input file, and will all be decompressed by gzread(). + If something other than a gzip stream is encountered after a gzip stream, + that remaining trailing garbage is ignored (and no error is returned). + + gzread can be used to read a gzip file that is being concurrently written. + Upon reaching the end of the input, gzread will return with the available + data. If the error code returned by gzerror is Z_OK or Z_BUF_ERROR, then + gzclearerr can be used to clear the end of file indicator in order to permit + gzread to be tried again. Z_OK indicates that a gzip stream was completed + on the last gzread. Z_BUF_ERROR indicates that the input file ended in the + middle of a gzip stream. Note that gzread does not return -1 in the event + of an incomplete gzip stream. This error is deferred until gzclose(), which + will return Z_BUF_ERROR if the last gzread ended in the middle of a gzip + stream. Alternatively, gzerror can be used before gzclose to detect this + case. + + gzread returns the number of uncompressed bytes actually read, less than + len for end of file, or -1 for error. If len is too large to fit in an int, + then nothing is read, -1 is returned, and the error state is set to + Z_STREAM_ERROR. +*/ + +ZEXTERN z_size_t ZEXPORT gzfread OF((voidp buf, z_size_t size, z_size_t nitems, + gzFile file)); +/* + Read up to nitems items of size size from file to buf, otherwise operating + as gzread() does. This duplicates the interface of stdio's fread(), with + size_t request and return types. If the library defines size_t, then + z_size_t is identical to size_t. If not, then z_size_t is an unsigned + integer type that can contain a pointer. + + gzfread() returns the number of full items read of size size, or zero if + the end of the file was reached and a full item could not be read, or if + there was an error. gzerror() must be consulted if zero is returned in + order to determine if there was an error. If the multiplication of size and + nitems overflows, i.e. the product does not fit in a z_size_t, then nothing + is read, zero is returned, and the error state is set to Z_STREAM_ERROR. + + In the event that the end of file is reached and only a partial item is + available at the end, i.e. the remaining uncompressed data length is not a + multiple of size, then the final partial item is nevetheless read into buf + and the end-of-file flag is set. The length of the partial item read is not + provided, but could be inferred from the result of gztell(). This behavior + is the same as the behavior of fread() implementations in common libraries, + but it prevents the direct use of gzfread() to read a concurrently written + file, reseting and retrying on end-of-file, when size is not 1. +*/ + +ZEXTERN int ZEXPORT gzwrite OF((gzFile file, + voidpc buf, unsigned len)); /* Writes the given number of uncompressed bytes into the compressed file. - gzwrite returns the number of uncompressed bytes actually written - (0 in case of error). + gzwrite returns the number of uncompressed bytes written or 0 in case of + error. */ -ZEXTERN int ZEXPORTVA gzprintf OF((gzFile file, const char *format, ...)); +ZEXTERN z_size_t ZEXPORT gzfwrite OF((voidpc buf, z_size_t size, + z_size_t nitems, gzFile file)); /* - Converts, formats, and writes the args to the compressed file under - control of the format string, as in fprintf. gzprintf returns the number of - uncompressed bytes actually written (0 in case of error). The number of - uncompressed bytes written is limited to 4095. The caller should assure that - this limit is not exceeded. If it is exceeded, then gzprintf() will return - return an error (0) with nothing written. In this case, there may also be a + gzfwrite() writes nitems items of size size from buf to file, duplicating + the interface of stdio's fwrite(), with size_t request and return types. If + the library defines size_t, then z_size_t is identical to size_t. If not, + then z_size_t is an unsigned integer type that can contain a pointer. + + gzfwrite() returns the number of full items written of size size, or zero + if there was an error. If the multiplication of size and nitems overflows, + i.e. the product does not fit in a z_size_t, then nothing is written, zero + is returned, and the error state is set to Z_STREAM_ERROR. +*/ + +ZEXTERN int ZEXPORTVA gzprintf Z_ARG((gzFile file, const char *format, ...)); +/* + Converts, formats, and writes the arguments to the compressed file under + control of the format string, as in fprintf. gzprintf returns the number of + uncompressed bytes actually written, or a negative zlib error code in case + of error. The number of uncompressed bytes written is limited to 8191, or + one less than the buffer size given to gzbuffer(). The caller should assure + that this limit is not exceeded. If it is exceeded, then gzprintf() will + return an error (0) with nothing written. In this case, there may also be a buffer overflow with unpredictable consequences, which is possible only if zlib was compiled with the insecure functions sprintf() or vsprintf() because the secure snprintf() or vsnprintf() functions were not available. + This can be determined using zlibCompileFlags(). */ ZEXTERN int ZEXPORT gzputs OF((gzFile file, const char *s)); /* - Writes the given null-terminated string to the compressed file, excluding + Writes the given null-terminated string to the compressed file, excluding the terminating null character. - gzputs returns the number of characters written, or -1 in case of error. + + gzputs returns the number of characters written, or -1 in case of error. */ ZEXTERN char * ZEXPORT gzgets OF((gzFile file, char *buf, int len)); /* - Reads bytes from the compressed file until len-1 characters are read, or - a newline character is read and transferred to buf, or an end-of-file - condition is encountered. The string is then terminated with a null - character. - gzgets returns buf, or Z_NULL in case of error. + Reads bytes from the compressed file until len-1 characters are read, or a + newline character is read and transferred to buf, or an end-of-file + condition is encountered. If any characters are read or if len == 1, the + string is terminated with a null character. If no characters are read due + to an end-of-file or len < 1, then the buffer is left untouched. + + gzgets returns buf which is a null-terminated string, or it returns NULL + for end-of-file or in case of error. If there was an error, the contents at + buf are indeterminate. */ -ZEXTERN int ZEXPORT gzputc OF((gzFile file, int c)); +ZEXTERN int ZEXPORT gzputc OF((gzFile file, int c)); /* - Writes c, converted to an unsigned char, into the compressed file. - gzputc returns the value that was written, or -1 in case of error. + Writes c, converted to an unsigned char, into the compressed file. gzputc + returns the value that was written, or -1 in case of error. */ -ZEXTERN int ZEXPORT gzgetc OF((gzFile file)); +ZEXTERN int ZEXPORT gzgetc OF((gzFile file)); /* - Reads one byte from the compressed file. gzgetc returns this byte - or -1 in case of end of file or error. + Reads one byte from the compressed file. gzgetc returns this byte or -1 + in case of end of file or error. This is implemented as a macro for speed. + As such, it does not do all of the checking the other functions do. I.e. + it does not check to see if file is NULL, nor whether the structure file + points to has been clobbered or not. */ -ZEXTERN int ZEXPORT gzungetc OF((int c, gzFile file)); +ZEXTERN int ZEXPORT gzungetc OF((int c, gzFile file)); /* - Push one character back onto the stream to be read again later. - Only one character of push-back is allowed. gzungetc() returns the - character pushed, or -1 on failure. gzungetc() will fail if a - character has been pushed but not read yet, or if c is -1. The pushed - character will be discarded if the stream is repositioned with gzseek() - or gzrewind(). + Push one character back onto the stream to be read as the first character + on the next read. At least one character of push-back is allowed. + gzungetc() returns the character pushed, or -1 on failure. gzungetc() will + fail if c is -1, and may fail if a character has been pushed but not read + yet. If gzungetc is used immediately after gzopen or gzdopen, at least the + output buffer size of pushed characters is allowed. (See gzbuffer above.) + The pushed character will be discarded if the stream is repositioned with + gzseek() or gzrewind(). */ -ZEXTERN int ZEXPORT gzflush OF((gzFile file, int flush)); +ZEXTERN int ZEXPORT gzflush OF((gzFile file, int flush)); /* - Flushes all pending output into the compressed file. The parameter - flush is as in the deflate() function. The return value is the zlib - error number (see function gzerror below). gzflush returns Z_OK if - the flush parameter is Z_FINISH and all output could be flushed. - gzflush should be called only when strictly necessary because it can - degrade compression. + Flushes all pending output into the compressed file. The parameter flush + is as in the deflate() function. The return value is the zlib error number + (see function gzerror below). gzflush is only permitted when writing. + + If the flush parameter is Z_FINISH, the remaining data is written and the + gzip stream is completed in the output. If gzwrite() is called again, a new + gzip stream will be started in the output. gzread() is able to read such + concatenated gzip streams. + + gzflush should be called only when strictly necessary because it will + degrade compression if called too often. */ -ZEXTERN z_off_t ZEXPORT gzseek OF((gzFile file, - z_off_t offset, int whence)); /* - Sets the starting position for the next gzread or gzwrite on the - given compressed file. The offset represents a number of bytes in the - uncompressed data stream. The whence parameter is defined as in lseek(2); +ZEXTERN z_off_t ZEXPORT gzseek OF((gzFile file, + z_off_t offset, int whence)); + + Sets the starting position for the next gzread or gzwrite on the given + compressed file. The offset represents a number of bytes in the + uncompressed data stream. The whence parameter is defined as in lseek(2); the value SEEK_END is not supported. + If the file is opened for reading, this function is emulated but can be - extremely slow. If the file is opened for writing, only forward seeks are + extremely slow. If the file is opened for writing, only forward seeks are supported; gzseek then compresses a sequence of zeroes up to the new starting position. - gzseek returns the resulting offset location as measured in bytes from + gzseek returns the resulting offset location as measured in bytes from the beginning of the uncompressed stream, or -1 in case of error, in particular if the file is opened for writing and the new starting position would be before the current position. @@ -1202,68 +1567,134 @@ ZEXTERN int ZEXPORT gzrewind OF((gzFile file)); /* Rewinds the given file. This function is supported only for reading. - gzrewind(file) is equivalent to (int)gzseek(file, 0L, SEEK_SET) + gzrewind(file) is equivalent to (int)gzseek(file, 0L, SEEK_SET) */ -ZEXTERN z_off_t ZEXPORT gztell OF((gzFile file)); /* - Returns the starting position for the next gzread or gzwrite on the - given compressed file. This position represents a number of bytes in the - uncompressed data stream. +ZEXTERN z_off_t ZEXPORT gztell OF((gzFile file)); - gztell(file) is equivalent to gzseek(file, 0L, SEEK_CUR) + Returns the starting position for the next gzread or gzwrite on the given + compressed file. This position represents a number of bytes in the + uncompressed data stream, and is zero when starting, even if appending or + reading a gzip stream from the middle of a file using gzdopen(). + + gztell(file) is equivalent to gzseek(file, 0L, SEEK_CUR) +*/ + +/* +ZEXTERN z_off_t ZEXPORT gzoffset OF((gzFile file)); + + Returns the current offset in the file being read or written. This offset + includes the count of bytes that precede the gzip stream, for example when + appending or when using gzdopen() for reading. When reading, the offset + does not include as yet unused buffered input. This information can be used + for a progress indicator. On error, gzoffset() returns -1. */ ZEXTERN int ZEXPORT gzeof OF((gzFile file)); /* - Returns 1 when EOF has previously been detected reading the given - input stream, otherwise zero. + Returns true (1) if the end-of-file indicator has been set while reading, + false (0) otherwise. Note that the end-of-file indicator is set only if the + read tried to go past the end of the input, but came up short. Therefore, + just like feof(), gzeof() may return false even if there is no more data to + read, in the event that the last read request was for the exact number of + bytes remaining in the input file. This will happen if the input file size + is an exact multiple of the buffer size. + + If gzeof() returns true, then the read functions will return no more data, + unless the end-of-file indicator is reset by gzclearerr() and the input file + has grown since the previous end of file was detected. */ ZEXTERN int ZEXPORT gzdirect OF((gzFile file)); /* - Returns 1 if file is being read directly without decompression, otherwise - zero. + Returns true (1) if file is being copied directly while reading, or false + (0) if file is a gzip stream being decompressed. + + If the input file is empty, gzdirect() will return true, since the input + does not contain a gzip stream. + + If gzdirect() is used immediately after gzopen() or gzdopen() it will + cause buffers to be allocated to allow reading the file to determine if it + is a gzip file. Therefore if gzbuffer() is used, it should be called before + gzdirect(). + + When writing, gzdirect() returns true (1) if transparent writing was + requested ("wT" for the gzopen() mode), or false (0) otherwise. (Note: + gzdirect() is not needed when writing. Transparent writing must be + explicitly requested, so the application already knows the answer. When + linking statically, using gzdirect() will include all of the zlib code for + gzip file reading and decompression, which may not be desired.) */ ZEXTERN int ZEXPORT gzclose OF((gzFile file)); /* - Flushes all pending output if necessary, closes the compressed file - and deallocates all the (de)compression state. The return value is the zlib - error number (see function gzerror below). + Flushes all pending output if necessary, closes the compressed file and + deallocates the (de)compression state. Note that once file is closed, you + cannot call gzerror with file, since its structures have been deallocated. + gzclose must not be called more than once on the same file, just as free + must not be called more than once on the same allocation. + + gzclose will return Z_STREAM_ERROR if file is not valid, Z_ERRNO on a + file operation error, Z_MEM_ERROR if out of memory, Z_BUF_ERROR if the + last read ended in the middle of a gzip stream, or Z_OK on success. +*/ + +ZEXTERN int ZEXPORT gzclose_r OF((gzFile file)); +ZEXTERN int ZEXPORT gzclose_w OF((gzFile file)); +/* + Same as gzclose(), but gzclose_r() is only for use when reading, and + gzclose_w() is only for use when writing or appending. The advantage to + using these instead of gzclose() is that they avoid linking in zlib + compression or decompression code that is not used when only reading or only + writing respectively. If gzclose() is used, then both compression and + decompression code will be included the application when linking to a static + zlib library. */ ZEXTERN const char * ZEXPORT gzerror OF((gzFile file, int *errnum)); /* - Returns the error message for the last error which occurred on the - given compressed file. errnum is set to zlib error number. If an - error occurred in the file system and not in the compression library, - errnum is set to Z_ERRNO and the application may consult errno - to get the exact error code. + Returns the error message for the last error which occurred on the given + compressed file. errnum is set to zlib error number. If an error occurred + in the file system and not in the compression library, errnum is set to + Z_ERRNO and the application may consult errno to get the exact error code. + + The application must not modify the returned string. Future calls to + this function may invalidate the previously returned string. If file is + closed, then the string previously returned by gzerror will no longer be + available. + + gzerror() should be used to distinguish errors from end-of-file for those + functions above that do not distinguish those cases in their return values. */ ZEXTERN void ZEXPORT gzclearerr OF((gzFile file)); /* - Clears the error and end-of-file flags for file. This is analogous to the - clearerr() function in stdio. This is useful for continuing to read a gzip + Clears the error and end-of-file flags for file. This is analogous to the + clearerr() function in stdio. This is useful for continuing to read a gzip file that is being written concurrently. */ +#endif /* !Z_SOLO */ + /* checksum functions */ /* These functions are not related to compression but are exported - anyway because they might be useful in applications using the - compression library. + anyway because they might be useful in applications using the compression + library. */ ZEXTERN uLong ZEXPORT adler32 OF((uLong adler, const Bytef *buf, uInt len)); /* Update a running Adler-32 checksum with the bytes buf[0..len-1] and - return the updated checksum. If buf is NULL, this function returns - the required initial value for the checksum. - An Adler-32 checksum is almost as reliable as a CRC32 but can be computed - much faster. Usage example: + return the updated checksum. If buf is Z_NULL, this function returns the + required initial value for the checksum. + + An Adler-32 checksum is almost as reliable as a CRC-32 but can be computed + much faster. + + Usage example: uLong adler = adler32(0L, Z_NULL, 0); @@ -1273,21 +1704,31 @@ ZEXTERN uLong ZEXPORT adler32 OF((uLong adler, const Bytef *buf, uInt len)); if (adler != original_adler) error(); */ +ZEXTERN uLong ZEXPORT adler32_z OF((uLong adler, const Bytef *buf, + z_size_t len)); +/* + Same as adler32(), but with a size_t length. +*/ + +/* ZEXTERN uLong ZEXPORT adler32_combine OF((uLong adler1, uLong adler2, z_off_t len2)); -/* + Combine two Adler-32 checksums into one. For two sequences of bytes, seq1 and seq2 with lengths len1 and len2, Adler-32 checksums were calculated for each, adler1 and adler2. adler32_combine() returns the Adler-32 checksum of - seq1 and seq2 concatenated, requiring only adler1, adler2, and len2. + seq1 and seq2 concatenated, requiring only adler1, adler2, and len2. Note + that the z_off_t type (like off_t) is a signed integer. If len2 is + negative, the result has no meaning or utility. */ ZEXTERN uLong ZEXPORT crc32 OF((uLong crc, const Bytef *buf, uInt len)); /* Update a running CRC-32 with the bytes buf[0..len-1] and return the - updated CRC-32. If buf is NULL, this function returns the required initial - value for the for the crc. Pre- and post-conditioning (one's complement) is + updated CRC-32. If buf is Z_NULL, this function returns the required + initial value for the crc. Pre- and post-conditioning (one's complement) is performed within this function so it shouldn't be done by the application. + Usage example: uLong crc = crc32(0L, Z_NULL, 0); @@ -1298,9 +1739,15 @@ ZEXTERN uLong ZEXPORT crc32 OF((uLong crc, const Bytef *buf, uInt len)); if (crc != original_crc) error(); */ -ZEXTERN uLong ZEXPORT crc32_combine OF((uLong crc1, uLong crc2, z_off_t len2)); +ZEXTERN uLong ZEXPORT crc32_z OF((uLong adler, const Bytef *buf, + z_size_t len)); +/* + Same as crc32(), but with a size_t length. +*/ /* +ZEXTERN uLong ZEXPORT crc32_combine OF((uLong crc1, uLong crc2, z_off_t len2)); + Combine two CRC-32 check values into one. For two sequences of bytes, seq1 and seq2 with lengths len1 and len2, CRC-32 check values were calculated for each, crc1 and crc2. crc32_combine() returns the CRC-32 @@ -1328,27 +1775,135 @@ ZEXTERN int ZEXPORT inflateBackInit_ OF((z_streamp strm, int windowBits, unsigned char FAR *window, const char *version, int stream_size)); -#define deflateInit(strm, level) \ - deflateInit_((strm), (level), ZLIB_VERSION, sizeof(z_stream)) -#define inflateInit(strm) \ - inflateInit_((strm), ZLIB_VERSION, sizeof(z_stream)) -#define deflateInit2(strm, level, method, windowBits, memLevel, strategy) \ - deflateInit2_((strm),(level),(method),(windowBits),(memLevel),\ - (strategy), ZLIB_VERSION, sizeof(z_stream)) -#define inflateInit2(strm, windowBits) \ - inflateInit2_((strm), (windowBits), ZLIB_VERSION, sizeof(z_stream)) -#define inflateBackInit(strm, windowBits, window) \ - inflateBackInit_((strm), (windowBits), (window), \ - ZLIB_VERSION, sizeof(z_stream)) - - -#if !defined(ZUTIL_H) && !defined(NO_DUMMY_DECL) - struct internal_state {int dummy;}; /* hack for buggy compilers */ +#ifdef Z_PREFIX_SET +# define z_deflateInit(strm, level) \ + deflateInit_((strm), (level), ZLIB_VERSION, (int)sizeof(z_stream)) +# define z_inflateInit(strm) \ + inflateInit_((strm), ZLIB_VERSION, (int)sizeof(z_stream)) +# define z_deflateInit2(strm, level, method, windowBits, memLevel, strategy) \ + deflateInit2_((strm),(level),(method),(windowBits),(memLevel),\ + (strategy), ZLIB_VERSION, (int)sizeof(z_stream)) +# define z_inflateInit2(strm, windowBits) \ + inflateInit2_((strm), (windowBits), ZLIB_VERSION, \ + (int)sizeof(z_stream)) +# define z_inflateBackInit(strm, windowBits, window) \ + inflateBackInit_((strm), (windowBits), (window), \ + ZLIB_VERSION, (int)sizeof(z_stream)) +#else +# define deflateInit(strm, level) \ + deflateInit_((strm), (level), ZLIB_VERSION, (int)sizeof(z_stream)) +# define inflateInit(strm) \ + inflateInit_((strm), ZLIB_VERSION, (int)sizeof(z_stream)) +# define deflateInit2(strm, level, method, windowBits, memLevel, strategy) \ + deflateInit2_((strm),(level),(method),(windowBits),(memLevel),\ + (strategy), ZLIB_VERSION, (int)sizeof(z_stream)) +# define inflateInit2(strm, windowBits) \ + inflateInit2_((strm), (windowBits), ZLIB_VERSION, \ + (int)sizeof(z_stream)) +# define inflateBackInit(strm, windowBits, window) \ + inflateBackInit_((strm), (windowBits), (window), \ + ZLIB_VERSION, (int)sizeof(z_stream)) #endif +#ifndef Z_SOLO + +/* gzgetc() macro and its supporting function and exposed data structure. Note + * that the real internal state is much larger than the exposed structure. + * This abbreviated structure exposes just enough for the gzgetc() macro. The + * user should not mess with these exposed elements, since their names or + * behavior could change in the future, perhaps even capriciously. They can + * only be used by the gzgetc() macro. You have been warned. + */ +struct gzFile_s { + unsigned have; + unsigned char *next; + z_off64_t pos; +}; +ZEXTERN int ZEXPORT gzgetc_ OF((gzFile file)); /* backward compatibility */ +#ifdef Z_PREFIX_SET +# undef z_gzgetc +# define z_gzgetc(g) \ + ((g)->have ? ((g)->have--, (g)->pos++, *((g)->next)++) : (gzgetc)(g)) +#else +# define gzgetc(g) \ + ((g)->have ? ((g)->have--, (g)->pos++, *((g)->next)++) : (gzgetc)(g)) +#endif + +/* provide 64-bit offset functions if _LARGEFILE64_SOURCE defined, and/or + * change the regular functions to 64 bits if _FILE_OFFSET_BITS is 64 (if + * both are true, the application gets the *64 functions, and the regular + * functions are changed to 64 bits) -- in case these are set on systems + * without large file support, _LFS64_LARGEFILE must also be true + */ +#ifdef Z_LARGE64 + ZEXTERN gzFile ZEXPORT gzopen64 OF((const char *, const char *)); + ZEXTERN z_off64_t ZEXPORT gzseek64 OF((gzFile, z_off64_t, int)); + ZEXTERN z_off64_t ZEXPORT gztell64 OF((gzFile)); + ZEXTERN z_off64_t ZEXPORT gzoffset64 OF((gzFile)); + ZEXTERN uLong ZEXPORT adler32_combine64 OF((uLong, uLong, z_off64_t)); + ZEXTERN uLong ZEXPORT crc32_combine64 OF((uLong, uLong, z_off64_t)); +#endif + +#if !defined(ZLIB_INTERNAL) && defined(Z_WANT64) +# ifdef Z_PREFIX_SET +# define z_gzopen z_gzopen64 +# define z_gzseek z_gzseek64 +# define z_gztell z_gztell64 +# define z_gzoffset z_gzoffset64 +# define z_adler32_combine z_adler32_combine64 +# define z_crc32_combine z_crc32_combine64 +# else +# define gzopen gzopen64 +# define gzseek gzseek64 +# define gztell gztell64 +# define gzoffset gzoffset64 +# define adler32_combine adler32_combine64 +# define crc32_combine crc32_combine64 +# endif +# ifndef Z_LARGE64 + ZEXTERN gzFile ZEXPORT gzopen64 OF((const char *, const char *)); + ZEXTERN z_off_t ZEXPORT gzseek64 OF((gzFile, z_off_t, int)); + ZEXTERN z_off_t ZEXPORT gztell64 OF((gzFile)); + ZEXTERN z_off_t ZEXPORT gzoffset64 OF((gzFile)); + ZEXTERN uLong ZEXPORT adler32_combine64 OF((uLong, uLong, z_off_t)); + ZEXTERN uLong ZEXPORT crc32_combine64 OF((uLong, uLong, z_off_t)); +# endif +#else + ZEXTERN gzFile ZEXPORT gzopen OF((const char *, const char *)); + ZEXTERN z_off_t ZEXPORT gzseek OF((gzFile, z_off_t, int)); + ZEXTERN z_off_t ZEXPORT gztell OF((gzFile)); + ZEXTERN z_off_t ZEXPORT gzoffset OF((gzFile)); + ZEXTERN uLong ZEXPORT adler32_combine OF((uLong, uLong, z_off_t)); + ZEXTERN uLong ZEXPORT crc32_combine OF((uLong, uLong, z_off_t)); +#endif + +#else /* Z_SOLO */ + + ZEXTERN uLong ZEXPORT adler32_combine OF((uLong, uLong, z_off_t)); + ZEXTERN uLong ZEXPORT crc32_combine OF((uLong, uLong, z_off_t)); + +#endif /* !Z_SOLO */ + +/* undocumented functions */ ZEXTERN const char * ZEXPORT zError OF((int)); -ZEXTERN int ZEXPORT inflateSyncPoint OF((z_streamp z)); -ZEXTERN const uLongf * ZEXPORT get_crc_table OF((void)); +ZEXTERN int ZEXPORT inflateSyncPoint OF((z_streamp)); +ZEXTERN const z_crc_t FAR * ZEXPORT get_crc_table OF((void)); +ZEXTERN int ZEXPORT inflateUndermine OF((z_streamp, int)); +ZEXTERN int ZEXPORT inflateValidate OF((z_streamp, int)); +ZEXTERN unsigned long ZEXPORT inflateCodesUsed OF ((z_streamp)); +ZEXTERN int ZEXPORT inflateResetKeep OF((z_streamp)); +ZEXTERN int ZEXPORT deflateResetKeep OF((z_streamp)); +#if (defined(_WIN32) || defined(__CYGWIN__)) && !defined(Z_SOLO) +ZEXTERN gzFile ZEXPORT gzopen_w OF((const wchar_t *path, + const char *mode)); +#endif +#if defined(STDC) || defined(Z_HAVE_STDARG_H) +# ifndef Z_SOLO +ZEXTERN int ZEXPORTVA gzvprintf Z_ARG((gzFile file, + const char *format, + va_list va)); +# endif +#endif #ifdef __cplusplus } diff --git a/zlib/zutil.c b/zlib/zutil.c index 0f4bd787..85fea6d2 100644 --- a/zlib/zutil.c +++ b/zlib/zutil.c @@ -1,27 +1,27 @@ /* zutil.c -- target dependent utility functions for the compression library - * Copyright (C) 1995-2005 Jean-loup Gailly. + * Copyright (C) 1995-2017 Jean-loup Gailly * For conditions of distribution and use, see copyright notice in zlib.h */ /* @(#) $Id$ */ #include "zutil.h" - -#ifndef NO_DUMMY_DECL -struct internal_state {int dummy;}; /* for buggy compilers */ +#ifndef Z_SOLO +# include "gzguts.h" #endif -const char * const z_errmsg[10] = { -"need dictionary", /* Z_NEED_DICT 2 */ -"stream end", /* Z_STREAM_END 1 */ -"", /* Z_OK 0 */ -"file error", /* Z_ERRNO (-1) */ -"stream error", /* Z_STREAM_ERROR (-2) */ -"data error", /* Z_DATA_ERROR (-3) */ -"insufficient memory", /* Z_MEM_ERROR (-4) */ -"buffer error", /* Z_BUF_ERROR (-5) */ -"incompatible version",/* Z_VERSION_ERROR (-6) */ -""}; +z_const char * const z_errmsg[10] = { + (z_const char *)"need dictionary", /* Z_NEED_DICT 2 */ + (z_const char *)"stream end", /* Z_STREAM_END 1 */ + (z_const char *)"", /* Z_OK 0 */ + (z_const char *)"file error", /* Z_ERRNO (-1) */ + (z_const char *)"stream error", /* Z_STREAM_ERROR (-2) */ + (z_const char *)"data error", /* Z_DATA_ERROR (-3) */ + (z_const char *)"insufficient memory", /* Z_MEM_ERROR (-4) */ + (z_const char *)"buffer error", /* Z_BUF_ERROR (-5) */ + (z_const char *)"incompatible version",/* Z_VERSION_ERROR (-6) */ + (z_const char *)"" +}; const char * ZEXPORT zlibVersion() @@ -34,31 +34,31 @@ uLong ZEXPORT zlibCompileFlags() uLong flags; flags = 0; - switch (sizeof(uInt)) { + switch ((int)(sizeof(uInt))) { case 2: break; case 4: flags += 1; break; case 8: flags += 2; break; default: flags += 3; } - switch (sizeof(uLong)) { + switch ((int)(sizeof(uLong))) { case 2: break; case 4: flags += 1 << 2; break; case 8: flags += 2 << 2; break; default: flags += 3 << 2; } - switch (sizeof(voidpf)) { + switch ((int)(sizeof(voidpf))) { case 2: break; case 4: flags += 1 << 4; break; case 8: flags += 2 << 4; break; default: flags += 3 << 4; } - switch (sizeof(z_off_t)) { + switch ((int)(sizeof(z_off_t))) { case 2: break; case 4: flags += 1 << 6; break; case 8: flags += 2 << 6; break; default: flags += 3 << 6; } -#ifdef DEBUG +#ifdef ZLIB_DEBUG flags += 1 << 8; #endif #if defined(ASMV) || defined(ASMINF) @@ -85,41 +85,41 @@ uLong ZEXPORT zlibCompileFlags() #ifdef FASTEST flags += 1L << 21; #endif -#ifdef STDC +#if defined(STDC) || defined(Z_HAVE_STDARG_H) # ifdef NO_vsnprintf - flags += 1L << 25; + flags += 1L << 25; # ifdef HAS_vsprintf_void - flags += 1L << 26; + flags += 1L << 26; # endif # else # ifdef HAS_vsnprintf_void - flags += 1L << 26; + flags += 1L << 26; # endif # endif #else - flags += 1L << 24; + flags += 1L << 24; # ifdef NO_snprintf - flags += 1L << 25; + flags += 1L << 25; # ifdef HAS_sprintf_void - flags += 1L << 26; + flags += 1L << 26; # endif # else # ifdef HAS_snprintf_void - flags += 1L << 26; + flags += 1L << 26; # endif # endif #endif return flags; } -#ifdef DEBUG - +#ifdef ZLIB_DEBUG +#include # ifndef verbose # define verbose 0 # endif -int z_verbose = verbose; +int ZLIB_INTERNAL z_verbose = verbose; -void z_error (m) +void ZLIB_INTERNAL z_error (m) char *m; { fprintf(stderr, "%s\n", m); @@ -146,7 +146,7 @@ const char * ZEXPORT zError(err) #ifndef HAVE_MEMCPY -void zmemcpy(dest, source, len) +void ZLIB_INTERNAL zmemcpy(dest, source, len) Bytef* dest; const Bytef* source; uInt len; @@ -157,7 +157,7 @@ void zmemcpy(dest, source, len) } while (--len != 0); } -int zmemcmp(s1, s2, len) +int ZLIB_INTERNAL zmemcmp(s1, s2, len) const Bytef* s1; const Bytef* s2; uInt len; @@ -170,7 +170,7 @@ int zmemcmp(s1, s2, len) return 0; } -void zmemzero(dest, len) +void ZLIB_INTERNAL zmemzero(dest, len) Bytef* dest; uInt len; { @@ -181,6 +181,7 @@ void zmemzero(dest, len) } #endif +#ifndef Z_SOLO #ifdef SYS16BIT @@ -213,11 +214,13 @@ local ptr_table table[MAX_PTR]; * a protected system like OS/2. Use Microsoft C instead. */ -voidpf zcalloc (voidpf opaque, unsigned items, unsigned size) +voidpf ZLIB_INTERNAL zcalloc (voidpf opaque, unsigned items, unsigned size) { - voidpf buf = opaque; /* just to make some compilers happy */ + voidpf buf; ulg bsize = (ulg)items*size; + (void)opaque; + /* If we allocate less than 65520 bytes, we assume that farmalloc * will return a usable pointer which doesn't have to be normalized. */ @@ -237,9 +240,12 @@ voidpf zcalloc (voidpf opaque, unsigned items, unsigned size) return buf; } -void zcfree (voidpf opaque, voidpf ptr) +void ZLIB_INTERNAL zcfree (voidpf opaque, voidpf ptr) { int n; + + (void)opaque; + if (*(ush*)&ptr != 0) { /* object < 64K */ farfree(ptr); return; @@ -255,7 +261,6 @@ void zcfree (voidpf opaque, voidpf ptr) next_ptr--; return; } - ptr = opaque; /* just to make some compilers happy */ Assert(0, "zcfree: ptr not found"); } @@ -272,15 +277,15 @@ void zcfree (voidpf opaque, voidpf ptr) # define _hfree hfree #endif -voidpf zcalloc (voidpf opaque, unsigned items, unsigned size) +voidpf ZLIB_INTERNAL zcalloc (voidpf opaque, uInt items, uInt size) { - if (opaque) opaque = 0; /* to make compiler happy */ + (void)opaque; return _halloc((long)items, size); } -void zcfree (voidpf opaque, voidpf ptr) +void ZLIB_INTERNAL zcfree (voidpf opaque, voidpf ptr) { - if (opaque) opaque = 0; /* to make compiler happy */ + (void)opaque; _hfree(ptr); } @@ -297,22 +302,24 @@ extern voidp calloc OF((uInt items, uInt size)); extern void free OF((voidpf ptr)); #endif -voidpf zcalloc (opaque, items, size) +voidpf ZLIB_INTERNAL zcalloc (opaque, items, size) voidpf opaque; unsigned items; unsigned size; { - if (opaque) items += size - size; /* make compiler happy */ + (void)opaque; return sizeof(uInt) > 2 ? (voidpf)malloc(items * size) : (voidpf)calloc(items, size); } -void zcfree (opaque, ptr) +void ZLIB_INTERNAL zcfree (opaque, ptr) voidpf opaque; voidpf ptr; { + (void)opaque; free(ptr); - if (opaque) return; /* make compiler happy */ } #endif /* MY_ZCALLOC */ + +#endif /* !Z_SOLO */ diff --git a/zlib/zutil.h b/zlib/zutil.h index 0ba6e020..fdb1b79d 100644 --- a/zlib/zutil.h +++ b/zlib/zutil.h @@ -1,5 +1,5 @@ /* zutil.h -- internal interface and configuration of the compression library - * Copyright (C) 1995-2005 Jean-loup Gailly. + * Copyright (C) 1995-2016 Jean-loup Gailly, Mark Adler * For conditions of distribution and use, see copyright notice in zlib.h */ @@ -13,36 +13,32 @@ #ifndef ZUTIL_H #define ZUTIL_H -#define ZLIB_INTERNAL +#ifdef HAVE_HIDDEN +# define ZLIB_INTERNAL __attribute__((visibility ("hidden"))) +#else +# define ZLIB_INTERNAL +#endif + #include "zlib.h" -#ifdef STDC -# ifndef _WIN32_WCE +#if defined(STDC) && !defined(Z_SOLO) +# if !(defined(_WIN32_WCE) && defined(_MSC_VER)) # include # endif # include # include #endif -#ifdef NO_ERRNO_H -# ifdef _WIN32_WCE - /* The Microsoft C Run-Time Library for Windows CE doesn't have - * errno. We define it as a global variable to simplify porting. - * Its value is always 0 and should not be used. We rename it to - * avoid conflict with other libraries that use the same workaround. - */ -# define errno z_errno -# endif - extern int errno; -#else -# ifndef _WIN32_WCE -# include -# endif + +#ifdef Z_SOLO + typedef long ptrdiff_t; /* guess -- will be caught if guess is wrong */ #endif #ifndef local # define local static #endif -/* compile with -Dlocal if your debugger can't find static symbols */ +/* since "static" is used to mean two completely different things in C, we + define "local" for the non-static meaning of "static", for readability + (compile with -Dlocal if your debugger can't find static symbols) */ typedef unsigned char uch; typedef uch FAR uchf; @@ -50,13 +46,13 @@ typedef unsigned short ush; typedef ush FAR ushf; typedef unsigned long ulg; -extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ +extern z_const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ /* (size given to avoid silly warnings with Visual C++) */ #define ERR_MSG(err) z_errmsg[Z_NEED_DICT-(err)] #define ERR_RETURN(strm,err) \ - return (strm->msg = (char*)ERR_MSG(err), (err)) + return (strm->msg = ERR_MSG(err), (err)) /* To be used only when the state is known to be valid */ /* common constants */ @@ -88,70 +84,90 @@ extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ #if defined(MSDOS) || (defined(WINDOWS) && !defined(WIN32)) # define OS_CODE 0x00 -# if defined(__TURBOC__) || defined(__BORLANDC__) -# if(__STDC__ == 1) && (defined(__LARGE__) || defined(__COMPACT__)) - /* Allow compilation with ANSI keywords only enabled */ - void _Cdecl farfree( void *block ); - void *_Cdecl farmalloc( unsigned long nbytes ); -# else -# include +# ifndef Z_SOLO +# if defined(__TURBOC__) || defined(__BORLANDC__) +# if (__STDC__ == 1) && (defined(__LARGE__) || defined(__COMPACT__)) + /* Allow compilation with ANSI keywords only enabled */ + void _Cdecl farfree( void *block ); + void *_Cdecl farmalloc( unsigned long nbytes ); +# else +# include +# endif +# else /* MSC or DJGPP */ +# include # endif -# else /* MSC or DJGPP */ -# include # endif #endif #ifdef AMIGA -# define OS_CODE 0x01 +# define OS_CODE 1 #endif #if defined(VAXC) || defined(VMS) -# define OS_CODE 0x02 +# define OS_CODE 2 # define F_OPEN(name, mode) \ fopen((name), (mode), "mbc=60", "ctx=stm", "rfm=fix", "mrs=512") #endif +#ifdef __370__ +# if __TARGET_LIB__ < 0x20000000 +# define OS_CODE 4 +# elif __TARGET_LIB__ < 0x40000000 +# define OS_CODE 11 +# else +# define OS_CODE 8 +# endif +#endif + #if defined(ATARI) || defined(atarist) -# define OS_CODE 0x05 +# define OS_CODE 5 #endif #ifdef OS2 -# define OS_CODE 0x06 -# ifdef M_I86 - #include +# define OS_CODE 6 +# if defined(M_I86) && !defined(Z_SOLO) +# include # endif #endif #if defined(MACOS) || defined(TARGET_OS_MAC) -# define OS_CODE 0x07 -# if defined(__MWERKS__) && __dest_os != __be_os && __dest_os != __win32_os -# include /* for fdopen */ -# else -# ifndef fdopen -# define fdopen(fd,mode) NULL /* No fdopen() */ +# define OS_CODE 7 +# ifndef Z_SOLO +# if defined(__MWERKS__) && __dest_os != __be_os && __dest_os != __win32_os +# include /* for fdopen */ +# else +# ifndef fdopen +# define fdopen(fd,mode) NULL /* No fdopen() */ +# endif # endif # endif #endif -#ifdef TOPS20 -# define OS_CODE 0x0a +#ifdef __acorn +# define OS_CODE 13 #endif -#ifdef WIN32 -# ifndef __CYGWIN__ /* Cygwin is Unix, not Win32 */ -# define OS_CODE 0x0b -# endif +#if defined(WIN32) && !defined(__CYGWIN__) +# define OS_CODE 10 #endif -#ifdef __50SERIES /* Prime/PRIMOS */ -# define OS_CODE 0x0f +#ifdef _BEOS_ +# define OS_CODE 16 +#endif + +#ifdef __TOS_OS400__ +# define OS_CODE 18 +#endif + +#ifdef __APPLE__ +# define OS_CODE 19 #endif #if defined(_BEOS_) || defined(RISCOS) # define fdopen(fd,mode) NULL /* No fdopen() */ #endif -#if (defined(_MSC_VER) && (_MSC_VER > 600)) +#if (defined(_MSC_VER) && (_MSC_VER > 600)) && !defined __INTERIX # if defined(_WIN32_WCE) # define fdopen(fd,mode) NULL /* No fdopen() */ # ifndef _PTRDIFF_T_DEFINED @@ -163,10 +179,22 @@ extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ # endif #endif +#if defined(__BORLANDC__) && !defined(MSDOS) + #pragma warn -8004 + #pragma warn -8008 + #pragma warn -8066 +#endif + +/* provide prototypes for these when building zlib without LFS */ +#if !defined(_LARGEFILE64_SOURCE) || _LFS64_LARGEFILE-0 == 0 + ZEXTERN uLong ZEXPORT adler32_combine64 OF((uLong, uLong, z_off_t)); + ZEXTERN uLong ZEXPORT crc32_combine64 OF((uLong, uLong, z_off_t)); +#endif + /* common defaults */ #ifndef OS_CODE -# define OS_CODE 0x03 /* assume Unix */ +# define OS_CODE 3 /* assume Unix */ #endif #ifndef F_OPEN @@ -175,40 +203,7 @@ extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ /* functions */ -#if defined(STDC99) || (defined(__TURBOC__) && __TURBOC__ >= 0x550) -# ifndef HAVE_VSNPRINTF -# define HAVE_VSNPRINTF -# endif -#endif -#if defined(__CYGWIN__) -# ifndef HAVE_VSNPRINTF -# define HAVE_VSNPRINTF -# endif -#endif -#ifndef HAVE_VSNPRINTF -# ifdef MSDOS - /* vsnprintf may exist on some MS-DOS compilers (DJGPP?), - but for now we just assume it doesn't. */ -# define NO_vsnprintf -# endif -# ifdef __TURBOC__ -# define NO_vsnprintf -# endif -# ifdef WIN32 - /* In Win32, vsnprintf is available as the "non-ANSI" _vsnprintf. */ -# if !defined(vsnprintf) && !defined(NO_vsnprintf) -# define vsnprintf _vsnprintf -# endif -# endif -# ifdef __SASC -# define NO_vsnprintf -# endif -#endif -#ifdef VMS -# define NO_vsnprintf -#endif - -#if defined(pyr) +#if defined(pyr) || defined(Z_SOLO) # define NO_MEMCPY #endif #if defined(SMALL_MEDIUM) && !defined(_MSC_VER) && !defined(__SC__) @@ -232,16 +227,16 @@ extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ # define zmemzero(dest, len) memset(dest, 0, len) # endif #else - extern void zmemcpy OF((Bytef* dest, const Bytef* source, uInt len)); - extern int zmemcmp OF((const Bytef* s1, const Bytef* s2, uInt len)); - extern void zmemzero OF((Bytef* dest, uInt len)); + void ZLIB_INTERNAL zmemcpy OF((Bytef* dest, const Bytef* source, uInt len)); + int ZLIB_INTERNAL zmemcmp OF((const Bytef* s1, const Bytef* s2, uInt len)); + void ZLIB_INTERNAL zmemzero OF((Bytef* dest, uInt len)); #endif /* Diagnostic functions */ -#ifdef DEBUG +#ifdef ZLIB_DEBUG # include - extern int z_verbose; - extern void z_error OF((char *m)); + extern int ZLIB_INTERNAL z_verbose; + extern void ZLIB_INTERNAL z_error OF((char *m)); # define Assert(cond,msg) {if(!(cond)) z_error(msg);} # define Trace(x) {if (z_verbose>=0) fprintf x ;} # define Tracev(x) {if (z_verbose>0) fprintf x ;} @@ -257,13 +252,19 @@ extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ # define Tracecv(c,x) #endif - -voidpf zcalloc OF((voidpf opaque, unsigned items, unsigned size)); -void zcfree OF((voidpf opaque, voidpf ptr)); +#ifndef Z_SOLO + voidpf ZLIB_INTERNAL zcalloc OF((voidpf opaque, unsigned items, + unsigned size)); + void ZLIB_INTERNAL zcfree OF((voidpf opaque, voidpf ptr)); +#endif #define ZALLOC(strm, items, size) \ (*((strm)->zalloc))((strm)->opaque, (items), (size)) #define ZFREE(strm, addr) (*((strm)->zfree))((strm)->opaque, (voidpf)(addr)) #define TRY_FREE(s, p) {if (p) ZFREE(s, p);} +/* Reverse the bytes in a 32-bit value */ +#define ZSWAP32(q) ((((q) >> 24) & 0xff) + (((q) >> 8) & 0xff00) + \ + (((q) & 0xff00) << 8) + (((q) & 0xff) << 24)) + #endif /* ZUTIL_H */ From 22ce6f4f5b69f5f0e8071d95d1399c5cd79e6bc0 Mon Sep 17 00:00:00 2001 From: Kelvin Lee Date: Sat, 22 Jul 2017 13:24:20 +1000 Subject: [PATCH 17/64] Added missing resources to follow VS2010/VS2017. --- AppleWinExpress2013.vcxproj | 5 ++++- AppleWinExpress2013.vcxproj.filters | 11 ++++++++++- AppleWinExpress2015.vcxproj | 5 ++++- AppleWinExpress2015.vcxproj.filters | 11 ++++++++++- 4 files changed, 28 insertions(+), 4 deletions(-) diff --git a/AppleWinExpress2013.vcxproj b/AppleWinExpress2013.vcxproj index ef882893..53cf2f1e 100644 --- a/AppleWinExpress2013.vcxproj +++ b/AppleWinExpress2013.vcxproj @@ -1,4 +1,4 @@ - + @@ -236,6 +236,8 @@ + + @@ -283,6 +285,7 @@ + diff --git a/AppleWinExpress2013.vcxproj.filters b/AppleWinExpress2013.vcxproj.filters index f1ac4d2c..c9ec66e6 100644 --- a/AppleWinExpress2013.vcxproj.filters +++ b/AppleWinExpress2013.vcxproj.filters @@ -1,4 +1,4 @@ - + @@ -554,6 +554,9 @@ Resource Files + + Resource Files + @@ -607,6 +610,12 @@ Resource Files + + Resource Files + + + Resource Files + diff --git a/AppleWinExpress2015.vcxproj b/AppleWinExpress2015.vcxproj index 8b40ce47..2fb8c46f 100644 --- a/AppleWinExpress2015.vcxproj +++ b/AppleWinExpress2015.vcxproj @@ -1,4 +1,4 @@ - + @@ -236,6 +236,8 @@ + + @@ -283,6 +285,7 @@ + diff --git a/AppleWinExpress2015.vcxproj.filters b/AppleWinExpress2015.vcxproj.filters index f1ac4d2c..c9ec66e6 100644 --- a/AppleWinExpress2015.vcxproj.filters +++ b/AppleWinExpress2015.vcxproj.filters @@ -1,4 +1,4 @@ - + @@ -554,6 +554,9 @@ Resource Files + + Resource Files + @@ -607,6 +610,12 @@ Resource Files + + Resource Files + + + Resource Files + From e3d8a40cdb0aa2ab98643120cda03d140f7b01e8 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sun, 10 Sep 2017 17:07:18 +0100 Subject: [PATCH 18/64] Restore missing BOMs that got removed during previous cherry-pick --- AppleWinExpress2013.vcxproj | 2 +- AppleWinExpress2013.vcxproj.filters | 2 +- AppleWinExpress2015.vcxproj | 2 +- AppleWinExpress2015.vcxproj.filters | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/AppleWinExpress2013.vcxproj b/AppleWinExpress2013.vcxproj index 53cf2f1e..bedd9492 100644 --- a/AppleWinExpress2013.vcxproj +++ b/AppleWinExpress2013.vcxproj @@ -1,4 +1,4 @@ - + diff --git a/AppleWinExpress2013.vcxproj.filters b/AppleWinExpress2013.vcxproj.filters index c9ec66e6..be9fb2c9 100644 --- a/AppleWinExpress2013.vcxproj.filters +++ b/AppleWinExpress2013.vcxproj.filters @@ -1,4 +1,4 @@ - + diff --git a/AppleWinExpress2015.vcxproj b/AppleWinExpress2015.vcxproj index 2fb8c46f..fc0c6adc 100644 --- a/AppleWinExpress2015.vcxproj +++ b/AppleWinExpress2015.vcxproj @@ -1,4 +1,4 @@ - + diff --git a/AppleWinExpress2015.vcxproj.filters b/AppleWinExpress2015.vcxproj.filters index c9ec66e6..be9fb2c9 100644 --- a/AppleWinExpress2015.vcxproj.filters +++ b/AppleWinExpress2015.vcxproj.filters @@ -1,4 +1,4 @@ - + From c8dc857bbbd9ba1536c17d0d7bd78246dc3d0a0a Mon Sep 17 00:00:00 2001 From: tomcw Date: Sun, 10 Sep 2017 17:25:53 +0100 Subject: [PATCH 19/64] Add .gitattributes file to force line-endings to be CRLF when checking out VS sln/proj files --- .gitattributes | 12 ++++++++++++ 1 file changed, 12 insertions(+) create mode 100644 .gitattributes diff --git a/.gitattributes b/.gitattributes new file mode 100644 index 00000000..2efd4448 --- /dev/null +++ b/.gitattributes @@ -0,0 +1,12 @@ +# ref: https://help.github.com/articles/dealing-with-line-endings/#platform-all + +# Set the default behavior, in case people don't have core.autocrlf set. +# (Check with git config --global --list) +* text=auto + +# Declare files that will always have CRLF line endings on checkout. +*.sln text eol=crlf +*.vcproj text eol=crlf +*.vcxproj text eol=crlf +*.vcxproj.filters text eol=crlf +*.bat text eol=crlf From 72dc573ce1f5e7e42a791a55a8ade244daae3cf2 Mon Sep 17 00:00:00 2001 From: tomcw Date: Fri, 22 Sep 2017 20:43:04 +0100 Subject: [PATCH 20/64] Remove .gitattributes (#487) --- .gitattributes | 12 ------------ 1 file changed, 12 deletions(-) delete mode 100644 .gitattributes diff --git a/.gitattributes b/.gitattributes deleted file mode 100644 index 2efd4448..00000000 --- a/.gitattributes +++ /dev/null @@ -1,12 +0,0 @@ -# ref: https://help.github.com/articles/dealing-with-line-endings/#platform-all - -# Set the default behavior, in case people don't have core.autocrlf set. -# (Check with git config --global --list) -* text=auto - -# Declare files that will always have CRLF line endings on checkout. -*.sln text eol=crlf -*.vcproj text eol=crlf -*.vcxproj text eol=crlf -*.vcxproj.filters text eol=crlf -*.bat text eol=crlf From 3a5bf012f16940860036a28a00a223a65df17f4d Mon Sep 17 00:00:00 2001 From: tomcw Date: Fri, 22 Sep 2017 22:23:13 +0100 Subject: [PATCH 21/64] Save-state: Fix for when SSC's expansion ROM is active and PC is running in this space (GH#486) --- source/Memory.cpp | 19 ++++++++++++++++++- source/Memory.h | 1 + source/SaveState.cpp | 1 + 3 files changed, 20 insertions(+), 1 deletion(-) diff --git a/source/Memory.cpp b/source/Memory.cpp index d5d3a8e1..cde58396 100644 --- a/source/Memory.cpp +++ b/source/Memory.cpp @@ -921,7 +921,8 @@ static void UpdatePaging(BOOL initialize) for (loop = 0xC8; loop < 0xD0; loop++) { const UINT uRomOffset = (loop & 0x0f) * 0x100; - memshadow[loop] = pCxRomInternal+uRomOffset; // C800..CFFF - Internal ROM + memshadow[loop] = (SW_SLOTCXROM && !INTC8ROM) ? pCxRomPeripheral+uRomOffset // C800..CFFF - Peripheral ROM (GH#486) + : pCxRomInternal+uRomOffset; // C800..CFFF - Internal ROM } for (loop = 0xD0; loop < 0xE0; loop++) @@ -1430,6 +1431,21 @@ void MemInitializeIO(void) IoHandlerCardsOut(); } +// Called by: +// . Snapshot_LoadState_v2() +void MemInitializeCardExpansionRomFromSnapshot(void) +{ + const UINT uSlot = g_uPeripheralRomSlot; + + if (ExpansionRom[uSlot] == NULL) + return; + + _ASSERT(g_eExpansionRomType == eExpRomPeripheral); + + memcpy(pCxRomPeripheral+0x800, ExpansionRom[uSlot], FIRMWARE_EXPANSION_SIZE); + // NB. Copied to /mem/ by UpdatePaging(TRUE) +} + inline DWORD getRandomTime() { return rand() ^ timeGetTime(); // We can't use g_nCumulativeCycles as it will be zero on a fresh execution. @@ -1950,6 +1966,7 @@ bool MemLoadSnapshot(YamlLoadHelper& yamlLoadHelper) modechanging = 0; // NB. MemUpdatePaging(TRUE) called at end of Snapshot_LoadState_v2() UpdatePaging(1); // Initialize=1 (Still needed, even with call to MemUpdatePaging() - why?) + // TC-TODO: At this point, the cards haven't been loaded, so the card's expansion ROM is unknown - so pointless(?) calling this now return true; } diff --git a/source/Memory.h b/source/Memory.h index 420b21c5..5f0b9fa0 100644 --- a/source/Memory.h +++ b/source/Memory.h @@ -84,6 +84,7 @@ void MemInitialize (); void MemInitializeROM(void); void MemInitializeCustomF8ROM(void); void MemInitializeIO(void); +void MemInitializeCardExpansionRomFromSnapshot(void); BYTE MemReadFloatingBus(const ULONG uExecutedCycles); BYTE MemReadFloatingBus(const BYTE highbit, const ULONG uExecutedCycles); void MemReset (); diff --git a/source/SaveState.cpp b/source/SaveState.cpp index eb4d71c5..8fc17c0a 100644 --- a/source/SaveState.cpp +++ b/source/SaveState.cpp @@ -523,6 +523,7 @@ static void Snapshot_LoadState_v2(void) MemInitializeROM(); MemInitializeCustomF8ROM(); MemInitializeIO(); + MemInitializeCardExpansionRomFromSnapshot(); MemUpdatePaging(TRUE); } From 6fd125de31b1b319edacef5c4ad421566247109c Mon Sep 17 00:00:00 2001 From: tomcw Date: Sat, 23 Sep 2017 19:29:59 +0100 Subject: [PATCH 22/64] Add more comments about INTC8ROM --- source/Memory.cpp | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/source/Memory.cpp b/source/Memory.cpp index cde58396..64aa3a12 100644 --- a/source/Memory.cpp +++ b/source/Memory.cpp @@ -534,12 +534,16 @@ static bool IsCardInSlot(const UINT uSlot); // 1 0 internal internal // 1 1 internal internal // +// NB. if (INTCXROM || INTC8ROM) == true then internal ROM +// // (*) SLOTCXROM' // ----------- // // INTC8ROM: Unreadable soft switch (UTAIIe:5-28) -// . Set: Access to $C3XX with SLOTC3ROM reset -// . Reset: Access to $CFFF or an MMU reset +// . Set: On access to $C3XX with SLOTC3ROM reset +// - "From this point, $C800-$CFFF will stay assigned to motherboard ROM until +// an access is made to $CFFF or until the MMU detects a system reset." +// . Reset: On access to $CFFF or an MMU reset // static BYTE __stdcall IO_Cxxx(WORD programcounter, WORD address, BYTE write, BYTE value, ULONG nCyclesLeft) From 3cf50d01babec5d4ad32d10c7799598b5cc944aa Mon Sep 17 00:00:00 2001 From: tomcw Date: Fri, 29 Sep 2017 20:33:30 +0100 Subject: [PATCH 23/64] Cmd-line: support new -fs-height= (#488) --- source/Applewin.cpp | 44 +++++++++++++++++++++++ source/Frame.cpp | 86 +++++++++++++++++++++++++++++++++++++++++++++ source/Frame.h | 1 + 3 files changed, 131 insertions(+) diff --git a/source/Applewin.cpp b/source/Applewin.cpp index fddafe1c..7fcea1d5 100644 --- a/source/Applewin.cpp +++ b/source/Applewin.cpp @@ -919,6 +919,8 @@ int APIENTRY WinMain(HINSTANCE passinstance, HINSTANCE, LPSTR lpCmdLine, int) bool bShutdown = false; bool bSetFullScreen = false; bool bBoot = false; + bool bChangedDisplayResolution = false; + UINT bestWidth = 0, bestHeight = 0; LPSTR szImageName_drive1 = NULL; LPSTR szImageName_drive2 = NULL; LPSTR szSnapshotName = NULL; @@ -963,6 +965,30 @@ int APIENTRY WinMain(HINSTANCE passinstance, HINSTANCE, LPSTR lpCmdLine, int) { bSetFullScreen = true; } +#define CMD_FS_HEIGHT "-fs-height=" + else if (strncmp(lpCmdLine, CMD_FS_HEIGHT, sizeof(CMD_FS_HEIGHT)-1) == 0) + { + bSetFullScreen = true; // Implied + + LPSTR lpTmp = lpCmdLine + sizeof(CMD_FS_HEIGHT)-1; + bool bRes = false; + if (strcmp(lpTmp, "best") == 0) + { + bRes = GetBestDisplayResolutionForFullScreen(bestWidth, bestHeight); + } + else + { + UINT userSpecifiedHeight = atoi(lpTmp); + if (userSpecifiedHeight) + bRes = GetBestDisplayResolutionForFullScreen(bestWidth, bestHeight, userSpecifiedHeight); + else + LogFileOutput("Invalid cmd-line parameter for -fs-height=x switch\n"); + } + if (bRes) + LogFileOutput("Best resolution for -fs-height=x switch: Width=%d, Height=%d\n", bestWidth, bestHeight); + else + LogFileOutput("Failed to set parameter for -fs-height=x switch\n"); + } else if (strcmp(lpCmdLine, "-fs8bit") == 0) { SetFullScreen32Bit(false); // Support old v1.24 fullscreen 8-bit palette mode @@ -1299,6 +1325,21 @@ int APIENTRY WinMain(HINSTANCE passinstance, HINSTANCE, LPSTR lpCmdLine, int) { if (bSetFullScreen) { + if (bestWidth && bestHeight) + { + DEVMODE devMode; + memset(&devMode, 0, sizeof(devMode)); + devMode.dmSize = sizeof(devMode); + devMode.dmPelsWidth = bestWidth; + devMode.dmPelsHeight = bestHeight; + devMode.dmFields = DM_PELSWIDTH | DM_PELSHEIGHT; + + DWORD dwFlags = 0; + LONG res = ChangeDisplaySettings(&devMode, dwFlags); + if (res == 0) + bChangedDisplayResolution = true; + } + PostMessage(g_hFrameWindow, WM_USER_FULLSCREEN, 0, 0); bSetFullScreen = false; } @@ -1332,6 +1373,9 @@ int APIENTRY WinMain(HINSTANCE passinstance, HINSTANCE, LPSTR lpCmdLine, int) } while (g_bRestart); + if (bChangedDisplayResolution) + ChangeDisplaySettings(NULL, 0); // restore default + // Release COM SysClk_UninitTimer(); LogFileOutput("Exit: SysClk_UninitTimer()\n"); diff --git a/source/Frame.cpp b/source/Frame.cpp index 387ae8c6..bb69ef19 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -2793,3 +2793,89 @@ void FrameUpdateApple2Type(void) // Draw buttons & call DrawStatusArea(DRAW_BACKGROUND | DRAW_LEDS | DRAW_DISK_STATUS) DrawFrameWindow(); } + +bool GetBestDisplayResolutionForFullScreen(UINT& bestWidth, UINT& bestHeight, UINT userSpecifiedHeight /*= 0*/) +{ + typedef std::vector< std::pair > VEC_PAIR; + VEC_PAIR vecDisplayResolutions; + + for (UINT iModeNum = 0; ; iModeNum++) + { + DEVMODE devMode; + devMode.dmSize = sizeof(DEVMODE); + devMode.dmDriverExtra = 0; + BOOL bValid = EnumDisplaySettings(NULL, iModeNum, &devMode); + if (!bValid) + break; + if (iModeNum == 0) // 0 is the initial "cache info about display device" operation + continue; + + if (devMode.dmBitsPerPel != 32) + continue; + + if (userSpecifiedHeight == 0 || userSpecifiedHeight == devMode.dmPelsHeight) + { + if (vecDisplayResolutions.size() == 0 || vecDisplayResolutions.back() != std::pair(devMode.dmPelsWidth, devMode.dmPelsHeight) ) // Skip duplicate resolutions + { + vecDisplayResolutions.push_back( std::pair(devMode.dmPelsWidth, devMode.dmPelsHeight) ); + LogFileOutput("EnumDisplaySettings(%d) - %d x %d\n", iModeNum, devMode.dmPelsWidth, devMode.dmPelsHeight); + } + } + } + + const int A2_WINDOW_WIDTH = FRAMEBUFFER_BORDERLESS_W; + const int A2_WINDOW_HEIGHT = FRAMEBUFFER_BORDERLESS_H; + + if (userSpecifiedHeight) + { + if (vecDisplayResolutions.size() == 0) + return false; + + // Pick least width (such that it's wide enough to scale) + UINT width = (UINT)-1; + for (VEC_PAIR::iterator it = vecDisplayResolutions.begin(); it!= vecDisplayResolutions.end(); ++it) + { + if (width > it->first) + { + UINT scaleFactor = it->second / A2_WINDOW_HEIGHT; + if (it->first >= (A2_WINDOW_WIDTH * scaleFactor)) + { + width = it->first; + } + } + } + + if (width == (UINT)-1) + return false; + + bestWidth = width; + bestHeight = userSpecifiedHeight; + return true; + } + + // Pick max height that's an exact multiple of A2_WINDOW_HEIGHT + UINT tmpBestWidth = 0; + UINT tmpBestHeight = 0; + for (VEC_PAIR::iterator it = vecDisplayResolutions.begin(); it!= vecDisplayResolutions.end(); ++it) + { + if ((it->second % A2_WINDOW_HEIGHT) == 0) + { + if (it->second > tmpBestHeight) + { + UINT scaleFactor = it->second / A2_WINDOW_HEIGHT; + if (it->first >= (A2_WINDOW_WIDTH * scaleFactor)) + { + tmpBestWidth = it->first; + tmpBestHeight = it->second; + } + } + } + } + + if (tmpBestWidth == 0) + return false; + + bestWidth = tmpBestWidth; + bestHeight = tmpBestHeight; + return true; +} diff --git a/source/Frame.h b/source/Frame.h index 2c68c879..4abb05ac 100644 --- a/source/Frame.h +++ b/source/Frame.h @@ -69,6 +69,7 @@ bool GetFullScreen32Bit(void); void SetFullScreen32Bit(bool b32Bit); void FrameUpdateApple2Type(void); + bool GetBestDisplayResolutionForFullScreen(UINT& bestWidth, UINT& bestHeight, UINT userSpecifiedHeight=0); void FrameDrawDiskLEDS( HDC hdc ); void FrameDrawDiskStatus( HDC hdc ); From 643ba997ae07d8120662c576925fb7dd674ace1a Mon Sep 17 00:00:00 2001 From: tomcw Date: Fri, 29 Sep 2017 22:26:47 +0100 Subject: [PATCH 24/64] Bump to 1.26.3.1 and update History.txt --- bin/History.txt | 19 ++++++++++++++++--- resource/Applewin.rc | 8 ++++---- 2 files changed, 20 insertions(+), 7 deletions(-) diff --git a/bin/History.txt b/bin/History.txt index af3cd02a..75beefd5 100644 --- a/bin/History.txt +++ b/bin/History.txt @@ -9,16 +9,27 @@ https://github.com/AppleWin/AppleWin/issues/new Tom Charlesworth -1.26.3.0 (Experimental) - 4 Aug 2017 +1.26.3.1 (Experimental) - 29 Sep 2017 ------------------------------------ Changes: +. [Bug #488] New -fs-height= switch. + - best: picks the highest resolution where the height is an integer multiple of (192*2) + - nnnn: select a specific resolution with height=nnnn pixels + Use to select a better resolution for full-screen mode. + NB. This changes the display resolution (and restores on exit). . [Bug #428] Input option to use PC Joystick 1 Thumbstick 2 for emulated Joystick 2 . Swapping disks while a drive is on now warns and prompts if you still wish to do this instead of silently failing with no feedback. . [Bug #323] Skip hard disk boot by holding down the Open-Apple key during an Apple II restart +. [PR #441] Update zlib to latest version 1.2.11 Fixes: +. [Bug #486] Peripheral card's expansion ROM ($C800-CFFF, eg. SSC) wasn't being correctly restored from a save-state +. [Bug #460] Debugger: F2 whilst debugger active will immediately stop the drive spinning (allowing disk swap) +. [Bug #456] Fix strange speaker clicks when changing configuration - DirectSound wasn't being uninitialised on a restart . [Bug #452] Fix for unmounted HD now gives "NO DEVICE CONNECTED" (before gave "I/O ERROR") +. [Bug #450] Persist debugger state across an F2 (reset machine state) . [Bug #445] Debugger: BPM cmd: Support trigger on stack access for BRK,JSR,PLn,PHn,RTI,RTS +. [Bug #437] AppleWin.chm blocked from opening - delete the AppleWin.chm:Zone.Identifier ADS . [Bug #423] Full support for INTC8ROM soft switch (fixes transient a2audit.dsk & Bejeweled failures) . [Bug #418] Fix for slot-3 ROM not returning floating bus when Uthernet card is enabled . [Bug #417] Typos in Uthernet documentation @@ -36,9 +47,9 @@ Fixes: - Experimental support for 6551's control bit: DTR via -dtr switch - Experimental support for 6551's status bits: DCD and DSR via -dcd and -dsr switches . [Bug #383] "Enhanced disk speed" is very slow when debugger is active +. [Bug #269] When stepping, ESC no longer exits back to debugger (use F7, Pause keys or Debugger button instead). +. [Bug #250] Debugger: When MODE_STEPPING, fix issue with disk LEDs staying on . [Bug #217] Debugger G(o) command should use normal speed - - When stepping, ESC no longer exits back to debugger (use F7, Pause keys or Debugger button instead). - - Persist F2 (reset machine state) across debug & stepping states . Debugger: Added new gg command: command | run at normal speed? | run at full speed? | video quality | sound quality @@ -46,6 +57,8 @@ Fixes: g | yes | only if disk active, etc | precise | precise gg | no | always | periodic | muted +. [Bug #213] Pause not setting volume to zero + 1.26.1.1 - 17 Feb 2017 ---------------------- diff --git a/resource/Applewin.rc b/resource/Applewin.rc index 63209e84..ee956fe9 100644 --- a/resource/Applewin.rc +++ b/resource/Applewin.rc @@ -251,8 +251,8 @@ DISK_ICON ICON "DISK.ICO" // VS_VERSION_INFO VERSIONINFO - FILEVERSION 1,26,3,0 - PRODUCTVERSION 1,26,3,0 + FILEVERSION 1,26,3,1 + PRODUCTVERSION 1,26,3,1 FILEFLAGSMASK 0x3fL #ifdef _DEBUG FILEFLAGS 0x1L @@ -270,12 +270,12 @@ BEGIN VALUE "Comments", "https://github.com/AppleWin" VALUE "CompanyName", "AppleWin" VALUE "FileDescription", "Apple //e Emulator for Windows" - VALUE "FileVersion", "1, 26, 3, 0" + VALUE "FileVersion", "1, 26, 3, 1" VALUE "InternalName", "APPLEWIN" VALUE "LegalCopyright", " 1994-2017 Michael O'Brien, Oliver Schmidt, Tom Charlesworth, Michael Pohoreski, Nick Westgate, Linards Ticmanis" VALUE "OriginalFilename", "APPLEWIN.EXE" VALUE "ProductName", "Apple //e Emulator" - VALUE "ProductVersion", "1, 26, 3, 0" + VALUE "ProductVersion", "1, 26, 3, 1" END END BLOCK "VarFileInfo" From c5bbf9a2c2a8b03f3c9d3c6a7f93f4354eb9661a Mon Sep 17 00:00:00 2001 From: tomcw Date: Sat, 30 Sep 2017 09:47:48 +0100 Subject: [PATCH 25/64] Cmd-line: Remove old -fs8bit switch --- source/Applewin.cpp | 4 ---- source/Frame.cpp | 10 ---------- source/Frame.h | 2 -- 3 files changed, 16 deletions(-) diff --git a/source/Applewin.cpp b/source/Applewin.cpp index 7fcea1d5..2c56fc02 100644 --- a/source/Applewin.cpp +++ b/source/Applewin.cpp @@ -989,10 +989,6 @@ int APIENTRY WinMain(HINSTANCE passinstance, HINSTANCE, LPSTR lpCmdLine, int) else LogFileOutput("Failed to set parameter for -fs-height=x switch\n"); } - else if (strcmp(lpCmdLine, "-fs8bit") == 0) - { - SetFullScreen32Bit(false); // Support old v1.24 fullscreen 8-bit palette mode - } else if (strcmp(lpCmdLine, "-no-di") == 0) { g_bDisableDirectInput = true; diff --git a/source/Frame.cpp b/source/Frame.cpp index bb69ef19..ab5bdce1 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -2107,16 +2107,6 @@ void CtrlReset() //=========================================================================== -bool GetFullScreen32Bit(void) -{ - return g_bFullScreen32Bit; -} - -void SetFullScreen32Bit(bool b32Bit) -{ - g_bFullScreen32Bit = b32Bit; -} - int GetFullScreenOffsetX(void) { return g_win_fullscreen_offsetx; diff --git a/source/Frame.h b/source/Frame.h index 4abb05ac..387a5ff2 100644 --- a/source/Frame.h +++ b/source/Frame.h @@ -66,8 +66,6 @@ int GetViewportScale(void); int SetViewportScale(int nNewScale, bool bForce = false); void GetViewportCXCY(int& nViewportCX, int& nViewportCY); - bool GetFullScreen32Bit(void); - void SetFullScreen32Bit(bool b32Bit); void FrameUpdateApple2Type(void); bool GetBestDisplayResolutionForFullScreen(UINT& bestWidth, UINT& bestHeight, UINT userSpecifiedHeight=0); From 666b45ff7178e85b487eb8bff996f1bf7a7594a7 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sun, 1 Oct 2017 17:19:18 +0100 Subject: [PATCH 26/64] README.md: Update experimental build version --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index f8365c78..c1962b06 100644 --- a/README.md +++ b/README.md @@ -17,7 +17,7 @@ To compile from source see: Next Version ============ -Experimental build [1.26.2.4](https://github.com/AppleWin/AppleWin/releases/tag/v1.26.2.4) +Experimental build [1.26.3.1](https://github.com/AppleWin/AppleWin/releases/tag/v1.26.3.1) Please report [new issues](https://github.com/AppleWin/AppleWin/issues/new) From 9616df504ebf2e3d03e4b3d18e10f233c4264720 Mon Sep 17 00:00:00 2001 From: tomcw Date: Mon, 2 Oct 2017 22:22:26 +0100 Subject: [PATCH 27/64] Full-screen: Added Config UI checkbox for the display of subunit status (ie. keyboard caps, disk activity, paused/stepping state) - #224 --- resource/Applewin.rc | 31 ++++---- resource/resource.h | 1 + source/Applewin.cpp | 5 +- source/Common.h | 1 + source/Configuration/PageConfig.cpp | 52 +++++++++---- source/Frame.cpp | 109 ++++++++++++++++++---------- source/Frame.h | 5 +- source/Video.cpp | 9 ++- 8 files changed, 139 insertions(+), 74 deletions(-) diff --git a/resource/Applewin.rc b/resource/Applewin.rc index ee956fe9..a06bb3a0 100644 --- a/resource/Applewin.rc +++ b/resource/Applewin.rc @@ -89,25 +89,26 @@ FONT 8, "MS Shell Dlg", 0, 0, 0x0 BEGIN LTEXT "&Model:",IDC_STATIC,5,7,40,8 COMBOBOX IDC_COMPUTER,45,5,95,100,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP - CONTROL "&Confirm reboot",IDC_CHECK_CONFIRM_REBOOT,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,148,8,62,10 - GROUPBOX "Video",IDC_STATIC,5,22,200,43 + CONTROL "Confirm reboot",IDC_CHECK_CONFIRM_REBOOT,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,148,8,62,10 + GROUPBOX "Video",IDC_STATIC,5,22,200,56 LTEXT "Mo&de:",IDC_STATIC,12,33,33,8 COMBOBOX IDC_VIDEOTYPE,45,30,95,100,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP PUSHBUTTON "Monochrome &Color...",IDC_MONOCOLOR,12,46,80,14 - CONTROL "&50% Scan lines",IDC_CHECK_HALF_SCAN_LINES,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,103,48,62,10 - LTEXT "&Serial Port:",IDC_STATIC,5,74,40,8 - COMBOBOX IDC_SERIALPORT,45,72,95,100,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP - PUSHBUTTON "&Ethernet Settings...",IDC_ETHERNET,4,90,80,14 - GROUPBOX "Emulation Speed Control",IDC_STATIC,5,115,200,85 + CONTROL "50% Scan lines",IDC_CHECK_HALF_SCAN_LINES,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,103,48,62,10 + CONTROL "Full-Screen: Show drive/keyboard status",IDC_CHECK_FS_SHOW_SUBUNIT_STATUS,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,12,64,140,10 + LTEXT "&Serial Port:",IDC_STATIC,5,89,40,8 + COMBOBOX IDC_SERIALPORT,45,87,95,100,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP + PUSHBUTTON "&Ethernet Settings...",IDC_ETHERNET,4,105,80,14 + GROUPBOX "Emulation Speed Control",IDC_STATIC,5,130,200,85 CONTROL "Use &Authentic Machine Speed",IDC_AUTHENTIC_SPEED, - "Button",BS_AUTORADIOBUTTON,15,126,115,10 - CONTROL "Select C&ustom Speed (in MHz)",IDC_CUSTOM_SPEED,"Button",BS_AUTORADIOBUTTON,15,138,115,10 - CONTROL "Generic2",IDC_SLIDER_CPU_SPEED,"msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP,25,149,160,15 - CTEXT "0.5",IDC_0_5_MHz,23,165,20,10 - CTEXT "1.0",IDC_1_0_MHz,59,165,20,10 - CTEXT "2.0",IDC_2_0_MHz,96,165,20,10 - RTEXT "Fastest",IDC_MAX_MHz,150,165,29,10 - PUSHBUTTON "&Benchmark Emulator",IDC_BENCHMARK,15,179,85,15 + "Button",BS_AUTORADIOBUTTON,15,141,115,10 + CONTROL "Select C&ustom Speed (in MHz)",IDC_CUSTOM_SPEED,"Button",BS_AUTORADIOBUTTON,15,153,115,10 + CONTROL "Generic2",IDC_SLIDER_CPU_SPEED,"msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP,25,164,160,15 + CTEXT "0.5",IDC_0_5_MHz,23,180,20,10 + CTEXT "1.0",IDC_1_0_MHz,59,180,20,10 + CTEXT "2.0",IDC_2_0_MHz,96,180,20,10 + RTEXT "Fastest",IDC_MAX_MHz,150,180,29,10 + PUSHBUTTON "&Benchmark Emulator",IDC_BENCHMARK,15,194,85,15 END IDD_PROPPAGE_INPUT DIALOGEX 0, 0, 210, 215 diff --git a/resource/resource.h b/resource/resource.h index aa46914a..27f64ebd 100644 --- a/resource/resource.h +++ b/resource/resource.h @@ -113,6 +113,7 @@ #define IDC_COMBO_HDD2 1079 #define IDC_COMBO_DISK1 1080 #define IDC_COMBO_DISK2 1081 +#define IDC_CHECK_FS_SHOW_SUBUNIT_STATUS 1082 #define IDM_EXIT 40001 #define IDM_HELP 40002 #define IDM_ABOUT 40003 diff --git a/source/Applewin.cpp b/source/Applewin.cpp index 2c56fc02..7a504464 100644 --- a/source/Applewin.cpp +++ b/source/Applewin.cpp @@ -596,7 +596,7 @@ void LoadConfiguration(void) } char aySerialPortName[ CSuperSerialCard::SIZEOF_SERIALCHOICE_ITEM ]; - if (RegLoadString( TEXT("Configuration"), + if (RegLoadString( TEXT(REG_CONFIG), TEXT(REGVALUE_SERIAL_PORT_NAME), TRUE, aySerialPortName, @@ -618,6 +618,9 @@ void LoadConfiguration(void) DWORD dwTmp; + if(REGLOAD(TEXT(REGVALUE_FS_SHOW_SUBUNIT_STATUS), &dwTmp)) + SetFullScreenShowSubunitStatus(dwTmp ? true : false); + if(REGLOAD(TEXT(REGVALUE_THE_FREEZES_F8_ROM), &dwTmp)) sg_PropertySheet.SetTheFreezesF8Rom(dwTmp); diff --git a/source/Common.h b/source/Common.h index 9e36136d..b439caac 100644 --- a/source/Common.h +++ b/source/Common.h @@ -75,6 +75,7 @@ enum AppMode_e #define REGVALUE_CPU_TYPE "CPU Type" #define REGVALUE_OLD_APPLE2_TYPE "Computer Emulation" // Deprecated #define REGVALUE_CONFIRM_REBOOT "Confirm Reboot" // Added at 1.24.1 PageConfig +#define REGVALUE_FS_SHOW_SUBUNIT_STATUS "Full-screen show subunit status" #define REGVALUE_SPKR_VOLUME "Speaker Volume" #define REGVALUE_MB_VOLUME "Mockingboard Volume" #define REGVALUE_SAVESTATE_FILENAME "Save State Filename" diff --git a/source/Configuration/PageConfig.cpp b/source/Configuration/PageConfig.cpp index a6834fcb..61c16d13 100644 --- a/source/Configuration/PageConfig.cpp +++ b/source/Configuration/PageConfig.cpp @@ -118,10 +118,8 @@ BOOL CPageConfig::DlgProcInternal(HWND hWnd, UINT message, WPARAM wparam, LPARAM break; case IDC_CHECK_CONFIRM_REBOOT: - g_bConfirmReboot = IsDlgButtonChecked(hWnd, IDC_CHECK_CONFIRM_REBOOT) ? 1 : 0; - break; - case IDC_CHECK_HALF_SCAN_LINES: + case IDC_CHECK_FS_SHOW_SUBUNIT_STATUS: // Checked in DlgOK() break; @@ -189,6 +187,7 @@ BOOL CPageConfig::DlgProcInternal(HWND hWnd, UINT message, WPARAM wparam, LPARAM m_PropertySheetHelper.FillComboBox(hWnd,IDC_VIDEOTYPE,g_aVideoChoices,g_eVideoType); CheckDlgButton(hWnd, IDC_CHECK_HALF_SCAN_LINES, g_uHalfScanLines ? BST_CHECKED : BST_UNCHECKED); + CheckDlgButton(hWnd, IDC_CHECK_FS_SHOW_SUBUNIT_STATUS, GetFullScreenShowSubunitStatus() ? BST_CHECKED : BST_UNCHECKED); m_PropertySheetHelper.FillComboBox(hWnd,IDC_SERIALPORT, sg_SSC.GetSerialPortChoices(), sg_SSC.GetSerialPort()); EnableWindow(GetDlgItem(hWnd, IDC_SERIALPORT), !sg_SSC.IsActive() ? TRUE : FALSE); @@ -245,22 +244,24 @@ void CPageConfig::DlgOK(HWND hWnd) { bool bVideoReinit = false; - const DWORD newvidtype = (DWORD) SendDlgItemMessage(hWnd, IDC_VIDEOTYPE, CB_GETCURSEL, 0, 0); - if (g_eVideoType != newvidtype) + const DWORD uNewVideoType = (DWORD) SendDlgItemMessage(hWnd, IDC_VIDEOTYPE, CB_GETCURSEL, 0, 0); + if (g_eVideoType != uNewVideoType) { - g_eVideoType = newvidtype; + g_eVideoType = uNewVideoType; bVideoReinit = true; } - const DWORD newHalfScanLines = IsDlgButtonChecked(hWnd, IDC_CHECK_HALF_SCAN_LINES) ? 1 : 0; - if (g_uHalfScanLines != newHalfScanLines) + const DWORD uNewHalfScanLines = IsDlgButtonChecked(hWnd, IDC_CHECK_HALF_SCAN_LINES) ? 1 : 0; + if (g_uHalfScanLines != uNewHalfScanLines) { - g_uHalfScanLines = newHalfScanLines; + g_uHalfScanLines = uNewHalfScanLines; bVideoReinit = true; } if (bVideoReinit) { + Config_Save_Video(); + FrameRefreshStatus(DRAW_TITLE, false); VideoReinitialize(); @@ -270,15 +271,38 @@ void CPageConfig::DlgOK(HWND hWnd) } } - REGSAVE(TEXT(REGVALUE_CONFIRM_REBOOT), g_bConfirmReboot); + // - const DWORD newserialport = (DWORD) SendDlgItemMessage(hWnd, IDC_SERIALPORT, CB_GETCURSEL, 0, 0); - sg_SSC.CommSetSerialPort(hWnd, newserialport); + const bool bNewFSSubunitStatus = IsDlgButtonChecked(hWnd, IDC_CHECK_FS_SHOW_SUBUNIT_STATUS) ? true : false; + if (GetFullScreenShowSubunitStatus() != bNewFSSubunitStatus) + { + REGSAVE(TEXT(REGVALUE_FS_SHOW_SUBUNIT_STATUS), bNewFSSubunitStatus ? 1 : 0); + SetFullScreenShowSubunitStatus(bNewFSSubunitStatus); + + if (IsFullScreen()) + FrameRefreshStatus(DRAW_BACKGROUND | DRAW_LEDS | DRAW_DISK_STATUS); + } + + // + + const BOOL bNewConfirmReboot = IsDlgButtonChecked(hWnd, IDC_CHECK_CONFIRM_REBOOT) ? 1 : 0; + if (g_bConfirmReboot != bNewConfirmReboot) + { + REGSAVE(TEXT(REGVALUE_CONFIRM_REBOOT), bNewConfirmReboot); + g_bConfirmReboot = bNewConfirmReboot; + } + + // + + const DWORD uNewSerialPort = (DWORD) SendDlgItemMessage(hWnd, IDC_SERIALPORT, CB_GETCURSEL, 0, 0); + sg_SSC.CommSetSerialPort(hWnd, uNewSerialPort); RegSaveString( TEXT(REG_CONFIG), TEXT(REGVALUE_SERIAL_PORT_NAME), TRUE, sg_SSC.GetSerialPortName() ); - + + // + if (IsDlgButtonChecked(hWnd, IDC_AUTHENTIC_SPEED)) g_dwSpeed = SPEED_NORMAL; else @@ -289,8 +313,6 @@ void CPageConfig::DlgOK(HWND hWnd) REGSAVE(TEXT(REGVALUE_CUSTOM_SPEED), IsDlgButtonChecked(hWnd, IDC_CUSTOM_SPEED)); REGSAVE(TEXT(REGVALUE_EMULATION_SPEED), g_dwSpeed); - Config_Save_Video(); - m_PropertySheetHelper.PostMsgAfterClose(hWnd, m_Page); } diff --git a/source/Frame.cpp b/source/Frame.cpp index ab5bdce1..5df050f0 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -130,7 +130,7 @@ static HDC g_hFrameDC = (HDC)0; static RECT framerect = {0,0,0,0}; HWND g_hFrameWindow = (HWND)0; - BOOL g_bIsFullScreen = 0; +static BOOL g_bIsFullScreen = 0; BOOL g_bConfirmReboot = 1; // saved PageConfig REGSAVE BOOL g_bMultiMon = 0; // OFF = load window position & clamp initial frame to screen, ON = use window position as is @@ -635,11 +635,29 @@ static void DrawFrameWindow () } +//=========================================================================== +static bool g_bFullScreen_ShowSubunitStatus = true; + +bool IsFullScreen(void) +{ + return g_bIsFullScreen ? true : false; +} + +bool GetFullScreenShowSubunitStatus(void) +{ + return g_bFullScreen_ShowSubunitStatus; +} + +void SetFullScreenShowSubunitStatus(bool bShow) +{ + g_bFullScreen_ShowSubunitStatus = bShow; +} + //=========================================================================== void FrameDrawDiskLEDS( HDC passdc ) { - static Disk_Status_e eDrive1Status = DISK_STATUS_OFF; - static Disk_Status_e eDrive2Status = DISK_STATUS_OFF; + Disk_Status_e eDrive1Status; + Disk_Status_e eDrive2Status; DiskGetLightStatus(&eDrive1Status, &eDrive2Status); g_eStatusDrive1 = eDrive1Status; @@ -654,6 +672,9 @@ void FrameDrawDiskLEDS( HDC passdc ) if (g_bIsFullScreen) { + if (!g_bFullScreen_ShowSubunitStatus) + return; + SelectObject(dc,smallfont); SetBkMode(dc,OPAQUE); SetBkColor(dc,RGB(0,0,0)); @@ -772,6 +793,9 @@ void FrameDrawDiskStatus( HDC passdc ) if (g_bIsFullScreen) { + if (!g_bFullScreen_ShowSubunitStatus) + return; + #if _DEBUG && 0 SetBkColor(dc,RGB(255,0,255)); #endif @@ -846,52 +870,61 @@ static void DrawStatusArea (HDC passdc, int drawflags) if (g_bIsFullScreen) { - SelectObject(dc,smallfont); + if (!g_bFullScreen_ShowSubunitStatus) + { + // Erase Config button icon too, as trk/sec is written here - see FrameDrawDiskStatus() + RECT rect = {x,y-BUTTONCY,x+BUTTONCX,y+BUTTONCY}; + FillRect(dc, &rect, (HBRUSH)GetStockObject(BLACK_BRUSH)); + } + else + { + SelectObject(dc,smallfont); - if (drawflags & DRAW_DISK_STATUS) - FrameDrawDiskStatus( dc ); + if (drawflags & DRAW_DISK_STATUS) + FrameDrawDiskStatus( dc ); #if HD_LED - SetTextColor(dc, g_aDiskFullScreenColorsLED[ eHardDriveStatus ] ); - TextOut(dc,x+23,y+2,TEXT("H"),1); + SetTextColor(dc, g_aDiskFullScreenColorsLED[ eHardDriveStatus ] ); + TextOut(dc,x+23,y+2,TEXT("H"),1); #endif - // Feature Request #3581 ] drive lights in full screen mode - // This has been in for a while, at least since 1.12.7.1 + // Feature Request #3581 ] drive lights in full screen mode + // This has been in for a while, at least since 1.12.7.1 - // Full Screen Drive LED - // Note: Made redundant with above code - // RECT rect = {0,0,8,8}; - // CONST int DriveLedY = 12; // 8 in windowed mode - // DrawBitmapRect(dc,x+12,y+DriveLedY,&rect,g_hDiskFullScreenLED[ eDrive1Status ]); - // DrawBitmapRect(dc,x+30,y+DriveLedY,&rect,g_hDiskFullScreenLED[ eDrive2Status ]); - // SetTextColor(dc, g_aDiskFullScreenColors[ eDrive1Status ] ); - // TextOut(dc,x+ 10,y+2,TEXT("*"),1); - // SetTextColor(dc, g_aDiskFullScreenColors[ eDrive2Status ] ); - // TextOut(dc,x+ 20,y+2,TEXT("*"),1); + // Full Screen Drive LED + // Note: Made redundant with above code + // RECT rect = {0,0,8,8}; + // CONST int DriveLedY = 12; // 8 in windowed mode + // DrawBitmapRect(dc,x+12,y+DriveLedY,&rect,g_hDiskFullScreenLED[ eDrive1Status ]); + // DrawBitmapRect(dc,x+30,y+DriveLedY,&rect,g_hDiskFullScreenLED[ eDrive2Status ]); + // SetTextColor(dc, g_aDiskFullScreenColors[ eDrive1Status ] ); + // TextOut(dc,x+ 10,y+2,TEXT("*"),1); + // SetTextColor(dc, g_aDiskFullScreenColors[ eDrive2Status ] ); + // TextOut(dc,x+ 20,y+2,TEXT("*"),1); - if (!IS_APPLE2) - { - SetTextAlign(dc,TA_RIGHT | TA_TOP); - SetTextColor(dc,(bCaps - ? RGB(128,128,128) - : RGB( 0, 0, 0) )); + if (!IS_APPLE2) + { + SetTextAlign(dc,TA_RIGHT | TA_TOP); + SetTextColor(dc,(bCaps + ? RGB(128,128,128) + : RGB( 0, 0, 0) )); -// const TCHAR sCapsStatus[] = TEXT("Caps"); // Caps or A -// const int nCapsLen = sizeof(sCapsStatus) / sizeof(TCHAR); -// TextOut(dc,x+BUTTONCX,y+2,"Caps",4); // sCapsStatus,nCapsLen - 1); +// const TCHAR sCapsStatus[] = TEXT("Caps"); // Caps or A +// const int nCapsLen = sizeof(sCapsStatus) / sizeof(TCHAR); +// TextOut(dc,x+BUTTONCX,y+2,"Caps",4); // sCapsStatus,nCapsLen - 1); - TextOut(dc,x+BUTTONCX,y+2,TEXT("A"),1); // NB. Caps Lock indicator is already flush right! + TextOut(dc,x+BUTTONCX,y+2,TEXT("A"),1); // NB. Caps Lock indicator is already flush right! + } + SetTextAlign(dc,TA_CENTER | TA_TOP); + SetTextColor(dc,(g_nAppMode == MODE_PAUSED || g_nAppMode == MODE_STEPPING + ? RGB(255,255,255) + : RGB( 0, 0, 0))); + TextOut(dc,x+BUTTONCX/2,y+13,(g_nAppMode == MODE_PAUSED + ? TITLE_PAUSED + : TITLE_STEPPING) ,8); } - SetTextAlign(dc,TA_CENTER | TA_TOP); - SetTextColor(dc,(g_nAppMode == MODE_PAUSED || g_nAppMode == MODE_STEPPING - ? RGB(255,255,255) - : RGB( 0, 0, 0))); - TextOut(dc,x+BUTTONCX/2,y+13,(g_nAppMode == MODE_PAUSED - ? TITLE_PAUSED - : TITLE_STEPPING) ,8); } - else // g_bIsFullScreen + else // !g_bIsFullScreen { if (drawflags & DRAW_BACKGROUND) { diff --git a/source/Frame.h b/source/Frame.h index 387a5ff2..fcae0f26 100644 --- a/source/Frame.h +++ b/source/Frame.h @@ -38,7 +38,6 @@ // Win32 extern HWND g_hFrameWindow; - extern BOOL g_bIsFullScreen; extern int g_nViewportCX; extern int g_nViewportCY; extern BOOL g_bConfirmReboot; // saved PageConfig REGSAVE @@ -69,6 +68,10 @@ void FrameUpdateApple2Type(void); bool GetBestDisplayResolutionForFullScreen(UINT& bestWidth, UINT& bestHeight, UINT userSpecifiedHeight=0); + bool IsFullScreen(void); + bool GetFullScreenShowSubunitStatus(void); + void SetFullScreenShowSubunitStatus(bool bShow); + void FrameDrawDiskLEDS( HDC hdc ); void FrameDrawDiskStatus( HDC hdc ); diff --git a/source/Video.cpp b/source/Video.cpp index 96e493d6..694c7ae9 100644 --- a/source/Video.cpp +++ b/source/Video.cpp @@ -444,7 +444,7 @@ void VideoDisplayLogo () nLogoX = (g_nViewportCX - scale*bm.bmWidth )/2; nLogoY = (g_nViewportCY - scale*bm.bmHeight)/2; - if( g_bIsFullScreen ) + if( IsFullScreen() ) { #if 0 // Draw Logo at top of screen so when the Apple display is refreshed it will automagically clear it @@ -455,6 +455,7 @@ void VideoDisplayLogo () nLogoY += GetFullScreenOffsetY(); #endif } + VideoDrawLogoBitmap( hFrameDC, nLogoX, nLogoY, bm.bmWidth, bm.bmHeight, scale ); } } @@ -666,8 +667,8 @@ void VideoRefreshScreen ( uint32_t uRedrawWholeScreenVideoMode /* =0*/, bool bRe #define H g_nViewportCY #else // Stretch // Stretch - doesn't preserve 1:1 aspect ratio - #define W g_bIsFullScreen ? g_nDDFullScreenW : g_nViewportCX - #define H g_bIsFullScreen ? g_nDDFullScreenH : g_nViewportCY + #define W IsFullScreen() ? g_nDDFullScreenW : g_nViewportCX + #define H IsFullScreen() ? g_nDDFullScreenH : g_nViewportCY #endif if (hFrameDC) @@ -676,7 +677,7 @@ void VideoRefreshScreen ( uint32_t uRedrawWholeScreenVideoMode /* =0*/, bool bRe int xDst = 0; int yDst = 0; - if (g_bIsFullScreen) + if ( IsFullScreen() ) { // Why the need to set the mid-position here, but not for (full-screen) LOGO or DEBUG modes? xDst = (g_nDDFullScreenW-W)/2 - VIEWPORTX*2; From 0bf2ae677a063734341cb14bc4f9c96400d18de0 Mon Sep 17 00:00:00 2001 From: TomCh Date: Thu, 5 Oct 2017 22:06:53 +0100 Subject: [PATCH 28/64] Full-screen and 2x tweaks for Status Area (#492) Status Area tweaks: . Full-screen: Correctly erase the PAUSED or STEPPING text status . 2x windowed mode: draw the the correct size 3d rect --- source/Frame.cpp | 71 ++++++++++++++++++++++++------------------------ 1 file changed, 35 insertions(+), 36 deletions(-) diff --git a/source/Frame.cpp b/source/Frame.cpp index 5df050f0..e67614f2 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -612,8 +612,7 @@ static void DrawFrameWindow () int x = buttonx + 1; int y = buttony + BUTTONS*BUTTONCY + 36; // 36 = height of StatusArea RECT rect = {x, y, x+45, y+BUTTONS*BUTTONCY+22}; - HBRUSH hbr = (HBRUSH) GetStockObject(WHITE_BRUSH); - int res = FillRect(dc, &rect, hbr); + int res = FillRect(dc, &rect, btnfacebrush); } } @@ -702,6 +701,9 @@ void FrameDrawDiskStatus( HDC passdc ) if (mem == NULL) return; + if (g_nAppMode == MODE_LOGO) + return; + // We use the actual drive since probing from memory doesn't tell us anything we don't already know. // DOS3.3 ProDOS // Drive $B7EA $BE3D @@ -793,12 +795,11 @@ void FrameDrawDiskStatus( HDC passdc ) if (g_bIsFullScreen) { + // GH#57 - drive lights in full screen mode + if (!g_bFullScreen_ShowSubunitStatus) return; -#if _DEBUG && 0 - SetBkColor(dc,RGB(255,0,255)); -#endif SetTextColor(dc, g_aDiskFullScreenColorsLED[ g_eStatusDrive1 ] ); TextOut(dc,x+ 3,y+2,TEXT("1"),1); @@ -822,11 +823,7 @@ void FrameDrawDiskStatus( HDC passdc ) // Erase background SelectObject(dc,GetStockObject(NULL_PEN)); -#if _DEBUG && 0 - SelectObject( dc, CreateSolidBrush( RGB(255,0,255) ) ); -#else SelectObject(dc,btnfacebrush); -#endif Rectangle(dc,x+4,y+32,x+BUTTONCX+1,y+56); // y+35 -> 44 -> 56 SetTextColor(dc,RGB(0,0,0)); @@ -873,7 +870,7 @@ static void DrawStatusArea (HDC passdc, int drawflags) if (!g_bFullScreen_ShowSubunitStatus) { // Erase Config button icon too, as trk/sec is written here - see FrameDrawDiskStatus() - RECT rect = {x,y-BUTTONCY,x+BUTTONCX,y+BUTTONCY}; + RECT rect = {x-2,y-BUTTONCY,x+BUTTONCX+2,y+BUTTONCY}; // Extend rect's width by +/-2 as the TITLE_PAUSED text is wider than an icon button FillRect(dc, &rect, (HBRUSH)GetStockObject(BLACK_BRUSH)); } else @@ -884,24 +881,11 @@ static void DrawStatusArea (HDC passdc, int drawflags) FrameDrawDiskStatus( dc ); #if HD_LED + SetTextAlign(dc, TA_RIGHT | TA_TOP); SetTextColor(dc, g_aDiskFullScreenColorsLED[ eHardDriveStatus ] ); TextOut(dc,x+23,y+2,TEXT("H"),1); #endif - // Feature Request #3581 ] drive lights in full screen mode - // This has been in for a while, at least since 1.12.7.1 - - // Full Screen Drive LED - // Note: Made redundant with above code - // RECT rect = {0,0,8,8}; - // CONST int DriveLedY = 12; // 8 in windowed mode - // DrawBitmapRect(dc,x+12,y+DriveLedY,&rect,g_hDiskFullScreenLED[ eDrive1Status ]); - // DrawBitmapRect(dc,x+30,y+DriveLedY,&rect,g_hDiskFullScreenLED[ eDrive2Status ]); - // SetTextColor(dc, g_aDiskFullScreenColors[ eDrive1Status ] ); - // TextOut(dc,x+ 10,y+2,TEXT("*"),1); - // SetTextColor(dc, g_aDiskFullScreenColors[ eDrive2Status ] ); - // TextOut(dc,x+ 20,y+2,TEXT("*"),1); - if (!IS_APPLE2) { SetTextAlign(dc,TA_RIGHT | TA_TOP); @@ -909,19 +893,34 @@ static void DrawStatusArea (HDC passdc, int drawflags) ? RGB(128,128,128) : RGB( 0, 0, 0) )); -// const TCHAR sCapsStatus[] = TEXT("Caps"); // Caps or A -// const int nCapsLen = sizeof(sCapsStatus) / sizeof(TCHAR); -// TextOut(dc,x+BUTTONCX,y+2,"Caps",4); // sCapsStatus,nCapsLen - 1); - TextOut(dc,x+BUTTONCX,y+2,TEXT("A"),1); // NB. Caps Lock indicator is already flush right! } - SetTextAlign(dc,TA_CENTER | TA_TOP); - SetTextColor(dc,(g_nAppMode == MODE_PAUSED || g_nAppMode == MODE_STEPPING - ? RGB(255,255,255) - : RGB( 0, 0, 0))); - TextOut(dc,x+BUTTONCX/2,y+13,(g_nAppMode == MODE_PAUSED + + // + + static const char* pCurrentAppModeText = NULL; + + const char* const pNewAppModeText = (g_nAppMode == MODE_PAUSED) ? TITLE_PAUSED - : TITLE_STEPPING) ,8); + : (g_nAppMode == MODE_STEPPING) + ? TITLE_STEPPING + : NULL; + + SetTextAlign(dc, TA_CENTER | TA_TOP); + + if (pCurrentAppModeText && pNewAppModeText != pCurrentAppModeText) + { + SetTextColor(dc, RGB(0,0,0)); + TextOut(dc, x+BUTTONCX/2, y+13, pCurrentAppModeText, strlen(pCurrentAppModeText)); + pCurrentAppModeText = NULL; + } + + if (pNewAppModeText) + { + SetTextColor(dc, RGB(255,255,255)); + TextOut(dc, x+BUTTONCX/2, y+13, pNewAppModeText, strlen(pNewAppModeText)); + pCurrentAppModeText = pNewAppModeText; + } } } else // !g_bIsFullScreen @@ -930,8 +929,8 @@ static void DrawStatusArea (HDC passdc, int drawflags) { SelectObject(dc,GetStockObject(NULL_PEN)); SelectObject(dc,btnfacebrush); - Rectangle(dc,x,y,x+BUTTONCX+2,y+60); // y+35 --> 48 --> 60 - Draw3dRect(dc,x+1,y+3,x+BUTTONCX,y+56,0); // y+31 --> 44 --> 56 + Rectangle(dc,x,y,x+BUTTONCX+2,y+34); + Draw3dRect(dc,x+1,y+3,x+BUTTONCX,y+30,0); SelectObject(dc,smallfont); SetTextAlign(dc,TA_CENTER | TA_TOP); From 3ad68739ee7216af6217910ea7251bc0367bbe3d Mon Sep 17 00:00:00 2001 From: tomcw Date: Fri, 6 Oct 2017 21:17:31 +0100 Subject: [PATCH 29/64] Update History.txt and help for new switches (fixes #469) --- bin/History.txt | 1 + help/CommandLine.html | 9 +++++++++ 2 files changed, 10 insertions(+) diff --git a/bin/History.txt b/bin/History.txt index 75beefd5..ce0af9c5 100644 --- a/bin/History.txt +++ b/bin/History.txt @@ -12,6 +12,7 @@ Tom Charlesworth 1.26.3.1 (Experimental) - 29 Sep 2017 ------------------------------------ Changes: +. [Bug #469] New -no-printscreen-key switch to prevent the PrintScreen key from being registered. . [Bug #488] New -fs-height= switch. - best: picks the highest resolution where the height is an integer multiple of (192*2) - nnnn: select a specific resolution with height=nnnn pixels diff --git a/help/CommandLine.html b/help/CommandLine.html index 940e9e7b..192c918f 100644 --- a/help/CommandLine.html +++ b/help/CommandLine.html @@ -17,12 +17,21 @@ Start with a disk in drive-2

-f
Start in full-screen mode

+ -fs-height=<best|nnnn>
+ Use to select a better resolution for full-screen mode.
+

+ NB. This changes the display resolution (and restores on exit).

-r <number of pages>
Emulate a RAMworks III card with 1 to 127 pages (each page is 64K, giving a max of 8MB)

-f8rom <rom-file>
Use custom 2K ROM at [$F800..$FFFF]. <rom-file> must be 2048 bytes long

-printscreen
Enable the dialog box to display the last file saved to

+ -no-printscreen-key
+ Prevent the PrintScreen key from being registered

-use-real-printer
Enables Advanced configuration control to allow dumping to a real printer

-noreg
From b1dfd57502869bcddfb979e7230256a2b3ffffaa Mon Sep 17 00:00:00 2001 From: tomcw Date: Tue, 10 Oct 2017 22:05:03 +0100 Subject: [PATCH 30/64] Tidy-up in Frame.cpp: unused prototypes, dead code; consolidate some full-screen constants --- source/Frame.cpp | 35 +++++++++++++---------------------- source/Frame.h | 6 ------ source/Video.cpp | 10 ---------- 3 files changed, 13 insertions(+), 38 deletions(-) diff --git a/source/Frame.cpp b/source/Frame.cpp index e67614f2..9202fcab 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -143,14 +143,14 @@ static int viewportx = VIEWPORTX; // Default to Normal (non-FullScreen static int viewporty = VIEWPORTY; // Default to Normal (non-FullScreen) mode // Direct Draw -- For Full Screen - LPDIRECTDRAW g_pDD = (LPDIRECTDRAW)0; +// LPDIRECTDRAW g_pDD = (LPDIRECTDRAW)0; LPDIRECTDRAWSURFACE g_pDDPrimarySurface = (LPDIRECTDRAWSURFACE)0; #if DIRECTX_PAGE_FLIP LPDIRECTDRAWSURFACE g_pDDBackSurface = (LPDIRECTDRAWSURFACE)0; #endif HDC g_hDDdc = 0; - int g_nDDFullScreenW = 640; - int g_nDDFullScreenH = 480; +// int g_nDDFullScreenW = 640; +// int g_nDDFullScreenH = 480; static bool g_bShowingCursor = true; static bool g_bLastCursorInAppleViewport = false; @@ -184,12 +184,9 @@ static int g_win_fullscreen_offsety = 0; // __ Prototypes __________________________________________________________________________________ static void DrawCrosshairs (int x, int y); - static void FrameSetCursorPosByMousePos(int x, int y, int dx, int dy, bool bLeavingAppleScreen); - static void DrawCrosshairsMouse(); static void UpdateMouseInAppleViewport(int iOutOfBoundsX, int iOutOfBoundsY, int x=0, int y=0); static void ScreenWindowResize(const bool bCtrlKey); static void FrameResizeWindow(int nNewScale); - static void GetWidthHeight(int& nWidth, int& nHeight); TCHAR g_pAppleWindowTitle[ 128 ] = ""; @@ -2161,9 +2158,6 @@ void SetFullScreenMode () FULLSCREEN_SCALE_TYPE width, height, scalex, scaley; int top, left; - const int A2_WINDOW_WIDTH = FRAMEBUFFER_BORDERLESS_W; - const int A2_WINDOW_HEIGHT = FRAMEBUFFER_BORDERLESS_H; - buttonover = -1; #if 0 // FS: 640x480 @@ -2188,12 +2182,12 @@ void SetFullScreenMode () width = (FULLSCREEN_SCALE_TYPE)(monitor_info.rcMonitor.right - monitor_info.rcMonitor.left); height = (FULLSCREEN_SCALE_TYPE)(monitor_info.rcMonitor.bottom - monitor_info.rcMonitor.top ); - scalex = width / A2_WINDOW_WIDTH; - scaley = height / A2_WINDOW_HEIGHT; + scalex = width / FRAMEBUFFER_BORDERLESS_W; + scaley = height / FRAMEBUFFER_BORDERLESS_H; g_win_fullscreen_scale = (scalex <= scaley) ? scalex : scaley; - g_win_fullscreen_offsetx = ((int)width - (int)(g_win_fullscreen_scale * A2_WINDOW_WIDTH )) / 2; - g_win_fullscreen_offsety = ((int)height - (int)(g_win_fullscreen_scale * A2_WINDOW_HEIGHT)) / 2; + g_win_fullscreen_offsetx = ((int)width - (int)(g_win_fullscreen_scale * FRAMEBUFFER_BORDERLESS_W)) / 2; + g_win_fullscreen_offsety = ((int)height - (int)(g_win_fullscreen_scale * FRAMEBUFFER_BORDERLESS_H)) / 2; SetWindowPos(g_hFrameWindow, NULL, left, top, (int)width, (int)height, SWP_NOZORDER | SWP_NOACTIVATE | SWP_FRAMECHANGED); g_bIsFullScreen = true; @@ -2845,9 +2839,6 @@ bool GetBestDisplayResolutionForFullScreen(UINT& bestWidth, UINT& bestHeight, UI } } - const int A2_WINDOW_WIDTH = FRAMEBUFFER_BORDERLESS_W; - const int A2_WINDOW_HEIGHT = FRAMEBUFFER_BORDERLESS_H; - if (userSpecifiedHeight) { if (vecDisplayResolutions.size() == 0) @@ -2859,8 +2850,8 @@ bool GetBestDisplayResolutionForFullScreen(UINT& bestWidth, UINT& bestHeight, UI { if (width > it->first) { - UINT scaleFactor = it->second / A2_WINDOW_HEIGHT; - if (it->first >= (A2_WINDOW_WIDTH * scaleFactor)) + UINT scaleFactor = it->second / FRAMEBUFFER_BORDERLESS_H; + if (it->first >= (FRAMEBUFFER_BORDERLESS_W * scaleFactor)) { width = it->first; } @@ -2875,17 +2866,17 @@ bool GetBestDisplayResolutionForFullScreen(UINT& bestWidth, UINT& bestHeight, UI return true; } - // Pick max height that's an exact multiple of A2_WINDOW_HEIGHT + // Pick max height that's an exact multiple of FRAMEBUFFER_BORDERLESS_H UINT tmpBestWidth = 0; UINT tmpBestHeight = 0; for (VEC_PAIR::iterator it = vecDisplayResolutions.begin(); it!= vecDisplayResolutions.end(); ++it) { - if ((it->second % A2_WINDOW_HEIGHT) == 0) + if ((it->second % FRAMEBUFFER_BORDERLESS_H) == 0) { if (it->second > tmpBestHeight) { - UINT scaleFactor = it->second / A2_WINDOW_HEIGHT; - if (it->first >= (A2_WINDOW_WIDTH * scaleFactor)) + UINT scaleFactor = it->second / FRAMEBUFFER_BORDERLESS_H; + if (it->first >= (FRAMEBUFFER_BORDERLESS_W * scaleFactor)) { tmpBestWidth = it->first; tmpBestHeight = it->second; diff --git a/source/Frame.h b/source/Frame.h index fcae0f26..92da9608 100644 --- a/source/Frame.h +++ b/source/Frame.h @@ -30,12 +30,6 @@ #endif // NTSC_END -// Direct Draw -- For Full Screen - extern LPDIRECTDRAW g_pDD; - extern LPDIRECTDRAWSURFACE g_pDDPrimarySurface; - extern int g_nDDFullScreenW; - extern int g_nDDFullScreenH; - // Win32 extern HWND g_hFrameWindow; extern int g_nViewportCX; diff --git a/source/Video.cpp b/source/Video.cpp index 694c7ae9..501546fe 100644 --- a/source/Video.cpp +++ b/source/Video.cpp @@ -674,16 +674,6 @@ void VideoRefreshScreen ( uint32_t uRedrawWholeScreenVideoMode /* =0*/, bool bRe if (hFrameDC) { { - int xDst = 0; - int yDst = 0; - - if ( IsFullScreen() ) - { - // Why the need to set the mid-position here, but not for (full-screen) LOGO or DEBUG modes? - xDst = (g_nDDFullScreenW-W)/2 - VIEWPORTX*2; - yDst = (g_nDDFullScreenH-H)/2; - } - int xSrc = BORDER_W; int ySrc = BORDER_H; VideoFrameBufferAdjust(xSrc, ySrc); // TC: Hacky-fix for GH#341 From 03b4e889e5ee7c6f9b9c0e189f7d6560b8d0f67d Mon Sep 17 00:00:00 2001 From: tomcw Date: Tue, 10 Oct 2017 22:11:36 +0100 Subject: [PATCH 31/64] Stop ASSERT when 'mouse entering Apple screen area' (#464) --- source/Frame.cpp | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/source/Frame.cpp b/source/Frame.cpp index 9202fcab..920ba6c9 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -2699,8 +2699,11 @@ static void FrameSetCursorPosByMousePos(int x, int y, int dx, int dy, bool bLeav else // Mouse entering Apple screen area { // sprintf(szDbg, "[MOUSE_ENTERING] x=%d, y=%d\n", x, y); OutputDebugString(szDbg); - x -= (viewportx+2-MAGICX); if (x < 0) x = 0; - y -= (viewporty+2-MAGICY); if (y < 0) y = 0; + if (!g_bIsFullScreen) // GH#464 + { + x -= (viewportx+2-MAGICX); if (x < 0) x = 0; + y -= (viewporty+2-MAGICY); if (y < 0) y = 0; + } _ASSERT(x <= g_nViewportCX); _ASSERT(y <= g_nViewportCY); From 018e338612dc518ce2aaed8004e8f4868614d640 Mon Sep 17 00:00:00 2001 From: tomcw Date: Wed, 11 Oct 2017 17:38:36 +0100 Subject: [PATCH 32/64] Frame.cpp: move header constants into Frame.cpp and expose with accessor functions --- source/Applewin.cpp | 2 +- source/Debugger/Debug.cpp | 15 +++- source/Debugger/Debugger_Display.cpp | 8 +- source/Frame.cpp | 110 +++++++++++++++++++++------ source/Frame.h | 32 +++----- source/NTSC.cpp | 10 ++- source/Video.cpp | 46 +++++------ 7 files changed, 143 insertions(+), 80 deletions(-) diff --git a/source/Applewin.cpp b/source/Applewin.cpp index 7a504464..71444265 100644 --- a/source/Applewin.cpp +++ b/source/Applewin.cpp @@ -60,7 +60,7 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA static UINT16 g_AppleWinVersion[4] = {0}; char VERSIONSTRING[16] = "xx.yy.zz.ww"; -TCHAR *g_pAppTitle = TITLE_APPLE_2E_ENHANCED; +TCHAR *g_pAppTitle = NULL; eApple2Type g_Apple2Type = A2TYPE_APPLE2EENHANCED; diff --git a/source/Debugger/Debug.cpp b/source/Debugger/Debug.cpp index b6fc94d8..d1592c3c 100644 --- a/source/Debugger/Debug.cpp +++ b/source/Debugger/Debug.cpp @@ -9687,9 +9687,18 @@ void DebuggerMouseClick( int x, int y ) // do picking - int cx = (x - VIEWPORTX) / nFontWidth; - int cy = (y - VIEWPORTY) / nFontHeight; - + const int nOffsetX = IsFullScreen() ? GetFullScreenOffsetX() : Get3DBorderWidth(); + const int nOffsetY = IsFullScreen() ? GetFullScreenOffsetY() : Get3DBorderHeight(); + + const int nOffsetInScreenX = x - nOffsetX; + const int nOffsetInScreenY = y - nOffsetY; + + if (nOffsetInScreenX < 0 || nOffsetInScreenY < 0) + return; + + int cx = nOffsetInScreenX / nFontWidth; + int cy = nOffsetInScreenY / nFontHeight; + #if _DEBUG char sText[ CONSOLE_WIDTH ]; sprintf( sText, "x:%d y:%d cx:%d cy:%d", x, y, cx, cy ); diff --git a/source/Debugger/Debugger_Display.cpp b/source/Debugger/Debugger_Display.cpp index 3df95596..51db89af 100644 --- a/source/Debugger/Debugger_Display.cpp +++ b/source/Debugger/Debugger_Display.cpp @@ -539,7 +539,7 @@ HDC GetDebuggerMemDC(void) { HDC hFrameDC = FrameGetDC(); g_hDebuggerMemDC = CreateCompatibleDC(hFrameDC); - g_hDebuggerMemBM = CreateCompatibleBitmap(hFrameDC, FRAMEBUFFER_W, FRAMEBUFFER_H); + g_hDebuggerMemBM = CreateCompatibleBitmap(hFrameDC, GetFrameBufferWidth(), GetFrameBufferHeight()); SelectObject(g_hDebuggerMemDC, g_hDebuggerMemBM); } @@ -563,8 +563,8 @@ void StretchBltMemToFrameDC(void) int nViewportCX, nViewportCY; GetViewportCXCY(nViewportCX, nViewportCY); - int xdest = GetFullScreenOffsetX(); - int ydest = GetFullScreenOffsetY(); + int xdest = IsFullScreen() ? GetFullScreenOffsetX() : 0; + int ydest = IsFullScreen() ? GetFullScreenOffsetY() : 0; int wdest = nViewportCX; int hdest = nViewportCY; @@ -574,7 +574,7 @@ void StretchBltMemToFrameDC(void) wdest, hdest, // int nWidthDest, int nHeightDest, GetDebuggerMemDC(), // HDC hdcSrc, 0, 0, // int nXOriginSrc, int nYOriginSrc, - FRAMEBUFFER_BORDERLESS_W, FRAMEBUFFER_BORDERLESS_H, // int nWidthSrc, int nHeightSrc, + GetFrameBufferBorderlessWidth(), GetFrameBufferBorderlessHeight(), // int nWidthSrc, int nHeightSrc, SRCCOPY // DWORD dwRop ); } diff --git a/source/Frame.cpp b/source/Frame.cpp index 920ba6c9..753b91b4 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -56,17 +56,19 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA #include "Configuration\PropertySheet.h" #include "Debugger\Debug.h" -#define DIRECTX_PAGE_FLIP 1 - //#define ENABLE_MENU 0 // Magic numbers (used by FrameCreateWindow to calc width/height): #define MAGICX 5 // 3D border between Apple window & Emulator's RHS buttons #define MAGICY 5 // 3D border between Apple window & Title bar +// 3D border around the 560x384 Apple II display +#define VIEWPORTX 5 +#define VIEWPORTY 5 + static const int kDEFAULT_VIEWPORT_SCALE = 2; - int g_nViewportCX = FRAMEBUFFER_BORDERLESS_W * kDEFAULT_VIEWPORT_SCALE; - int g_nViewportCY = FRAMEBUFFER_BORDERLESS_H * kDEFAULT_VIEWPORT_SCALE; + int g_nViewportCX = GetFrameBufferBorderlessWidth() * kDEFAULT_VIEWPORT_SCALE; + int g_nViewportCY = GetFrameBufferBorderlessHeight() * kDEFAULT_VIEWPORT_SCALE; static int g_nViewportScale = kDEFAULT_VIEWPORT_SCALE; // saved REGSAVE static int g_nMaxViewportScale = kDEFAULT_VIEWPORT_SCALE; // Max scale in Windowed mode with borders, buttons etc (full-screen may be +1) @@ -75,10 +77,10 @@ static int g_nMaxViewportScale = kDEFAULT_VIEWPORT_SCALE; // Max scale in Window #define BUTTONCX 45 #define BUTTONCY 45 // NB. FSxxx = FullScreen xxx -#define FSVIEWPORTX (640-BUTTONCX-MAGICX-g_nViewportCX) -#define FSVIEWPORTY ((480-g_nViewportCY)/2) -#define FSBUTTONX (640-BUTTONCX) -#define FSBUTTONY (((480-g_nViewportCY)/2)-1) +//#define FSVIEWPORTX (640-BUTTONCX-MAGICX-g_nViewportCX) +//#define FSVIEWPORTY ((480-g_nViewportCY)/2) +//#define FSBUTTONX (640-BUTTONCX) +//#define FSBUTTONY (((480-g_nViewportCY)/2)-1) #define BUTTONS 8 static HBITMAP g_hCapsLockBitmap[2]; @@ -130,7 +132,7 @@ static HDC g_hFrameDC = (HDC)0; static RECT framerect = {0,0,0,0}; HWND g_hFrameWindow = (HWND)0; -static BOOL g_bIsFullScreen = 0; +static bool g_bIsFullScreen = false; BOOL g_bConfirmReboot = 1; // saved PageConfig REGSAVE BOOL g_bMultiMon = 0; // OFF = load window position & clamp initial frame to screen, ON = use window position as is @@ -142,15 +144,18 @@ static BOOL g_bUsingCursor = 0; // 1=AppleWin is using (hiding) the mouse-cu static int viewportx = VIEWPORTX; // Default to Normal (non-FullScreen) mode static int viewporty = VIEWPORTY; // Default to Normal (non-FullScreen) mode +#if 0 // TC: Redundant // Direct Draw -- For Full Screen // LPDIRECTDRAW g_pDD = (LPDIRECTDRAW)0; - LPDIRECTDRAWSURFACE g_pDDPrimarySurface = (LPDIRECTDRAWSURFACE)0; +// LPDIRECTDRAWSURFACE g_pDDPrimarySurface = (LPDIRECTDRAWSURFACE)0; +#define DIRECTX_PAGE_FLIP 1 #if DIRECTX_PAGE_FLIP - LPDIRECTDRAWSURFACE g_pDDBackSurface = (LPDIRECTDRAWSURFACE)0; +// LPDIRECTDRAWSURFACE g_pDDBackSurface = (LPDIRECTDRAWSURFACE)0; #endif - HDC g_hDDdc = 0; +// HDC g_hDDdc = 0; // int g_nDDFullScreenW = 640; // int g_nDDFullScreenH = 480; +#endif static bool g_bShowingCursor = true; static bool g_bLastCursorInAppleViewport = false; @@ -189,12 +194,72 @@ static int g_win_fullscreen_offsety = 0; static void FrameResizeWindow(int nNewScale); - TCHAR g_pAppleWindowTitle[ 128 ] = ""; +// ========================================================================== -// Updates g_pAppTitle -// ==================================================================== +// Display construction: +// . Apple II video gets rendered to the framebuffer (maybe with some preliminary/final NTSC data in the border areas) +// . The *borderless* framebuffer is stretchblt() copied to the frame DC, in VideoRefreshScreen() +// . Draw cross-hairs (if using mouse as either a mouse or joystick) to frame DC +// . In Windowed mode: +// - Draw 3D border, 8x buttons, status area (disk LEDs, caps) to frame DC +// . In Fullscreen mode: +// - Optional: Draw status area to frame DC +// + +#define FRAMEBUFFER_BORDERLESS_W 560 // 560 = Double Hi-Res +#define FRAMEBUFFER_BORDERLESS_H 384 // 384 = Double Scan Line + +// NB. This border area is not visible (... and this border area is unrelated to the 3D border below) +#define BORDER_W 20 +#define BORDER_H 18 + +UINT GetFrameBufferBorderlessWidth(void) +{ + return FRAMEBUFFER_BORDERLESS_W; +} + +UINT GetFrameBufferBorderlessHeight(void) +{ + return FRAMEBUFFER_BORDERLESS_H; +} + +UINT GetFrameBufferBorderWidth(void) +{ + return BORDER_W; +} + +UINT GetFrameBufferBorderHeight(void) +{ + return BORDER_H; +} + +UINT GetFrameBufferWidth(void) +{ + return GetFrameBufferBorderlessWidth() + 2*GetFrameBufferBorderWidth(); +} + +UINT GetFrameBufferHeight(void) +{ + return GetFrameBufferBorderlessHeight() + 2*GetFrameBufferBorderHeight(); +} + +// + +UINT Get3DBorderWidth(void) +{ + return IsFullScreen() ? 0 : VIEWPORTX; +} + +UINT Get3DBorderHeight(void) +{ + return IsFullScreen() ? 0 : VIEWPORTY; +} + +// ========================================================================== static void GetAppleWindowTitle() { + static TCHAR g_pAppleWindowTitle[ 128 ] = ""; + g_pAppTitle = g_pAppleWindowTitle; switch (g_Apple2Type) @@ -236,8 +301,6 @@ static void GetAppleWindowTitle() case MODE_PAUSED : _tcscat(g_pAppleWindowTitle,TEXT(" [")); _tcscat(g_pAppleWindowTitle,TITLE_PAUSED ); _tcscat(g_pAppleWindowTitle,TEXT("]")); break; case MODE_STEPPING: _tcscat(g_pAppleWindowTitle,TEXT(" [")); _tcscat(g_pAppleWindowTitle,TITLE_STEPPING); _tcscat(g_pAppleWindowTitle,TEXT("]")); break; } - - g_pAppTitle = g_pAppleWindowTitle; } //=========================================================================== @@ -636,7 +699,7 @@ static bool g_bFullScreen_ShowSubunitStatus = true; bool IsFullScreen(void) { - return g_bIsFullScreen ? true : false; + return g_bIsFullScreen; } bool GetFullScreenShowSubunitStatus(void) @@ -2197,8 +2260,8 @@ void SetFullScreenMode () buttonx = GetFullScreenOffsetX() + g_nViewportCX + VIEWPORTX*2; buttony = GetFullScreenOffsetY(); - viewportx = VIEWPORTX; - viewporty = g_bIsFullScreen ? 0 : VIEWPORTY; // GH#464 + viewportx = VIEWPORTX; // TC-TODO: Should be zero too? (Since there's no 3D border in full-screen) + viewporty = 0; // GH#464 #endif // GetWindowRect(g_hFrameWindow,&framerect); @@ -2236,7 +2299,6 @@ void SetFullScreenMode () //=========================================================================== void SetNormalMode () { -// g_bIsFullScreen = false; buttonover = -1; buttonx = BUTTONX; buttony = BUTTONY; @@ -2513,6 +2575,7 @@ HDC FrameGetVideoDC (LPBYTE *pAddr_, LONG *pPitch_) { HDC hDC = 0; +#if 0 // TC: just wrapping existing "if (false)" code in "#if 0" to make it clear that it's dead code // ASSERT( pAddr_ ); // ASSERT( pPitch_ ); if (false) // TODO: ... @@ -2544,9 +2607,10 @@ HDC FrameGetVideoDC (LPBYTE *pAddr_, LONG *pPitch_) hDC = 0; } else +#endif { *pAddr_ = g_pFramebufferbits; - *pPitch_ = FRAMEBUFFER_W; + *pPitch_ = GetFrameBufferWidth(); hDC = FrameGetDC(); } @@ -2592,6 +2656,7 @@ void FrameReleaseDC () { //=========================================================================== void FrameReleaseVideoDC () { +#if 0 // TC: just wrapping existing "if (false)" code in "#if 0" to make it clear that it's dead code if (false) // TODO: ... //if (g_bIsFullScreen && g_bAppActive && !g_bPaintingWindow) { @@ -2616,6 +2681,7 @@ void FrameReleaseVideoDC () g_pDDPrimarySurface->ReleaseDC( g_hDDdc ); // NTSC Full Screen g_hDDdc = 0; } +#endif } //=========================================================================== diff --git a/source/Frame.h b/source/Frame.h index 92da9608..7d5cfe1f 100644 --- a/source/Frame.h +++ b/source/Frame.h @@ -6,29 +6,6 @@ // Keyboard -- keystroke type enum {NOT_ASCII=0, ASCII}; -// 3D Border - #define VIEWPORTX 5 - #define VIEWPORTY 5 - - // 560 = Double Hi-Res - // 384 = Double Scan Line - #define FRAMEBUFFER_BORDERLESS_W 560 - #define FRAMEBUFFER_BORDERLESS_H 384 -// NTSC_BEGIN -#if 0 - // TC: No good as NTSC render code writes to border area: - // . NTSC.cpp: updateVideoScannerHorzEOL(): "NOTE: This writes out-of-bounds for a 560x384 framebuffer" - #define BORDER_W 0 - #define BORDER_H 0 - #define FRAMEBUFFER_W FRAMEBUFFER_BORDERLESS_W - #define FRAMEBUFFER_H FRAMEBUFFER_BORDERLESS_H -#else - #define BORDER_W 20 - #define BORDER_H 18 - #define FRAMEBUFFER_W (FRAMEBUFFER_BORDERLESS_W + BORDER_W*2) - #define FRAMEBUFFER_H (FRAMEBUFFER_BORDERLESS_H + BORDER_H*2) -#endif -// NTSC_END // Win32 extern HWND g_hFrameWindow; @@ -77,3 +54,12 @@ int GetFullScreenOffsetX(void); int GetFullScreenOffsetY(void); + + UINT GetFrameBufferBorderlessWidth(void); + UINT GetFrameBufferBorderlessHeight(void); + UINT GetFrameBufferBorderWidth(void); + UINT GetFrameBufferBorderHeight(void); + UINT GetFrameBufferWidth(void); + UINT GetFrameBufferHeight(void); + UINT Get3DBorderWidth(void); + UINT Get3DBorderHeight(void); diff --git a/source/NTSC.cpp b/source/NTSC.cpp index cc3a4258..92e3f738 100644 --- a/source/NTSC.cpp +++ b/source/NTSC.cpp @@ -134,6 +134,8 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA static bgra_t *g_pVideoAddress = 0; static bgra_t *g_pScanLines[VIDEO_SCANNER_Y_DISPLAY*2]; // To maintain the 280x192 aspect ratio for 560px width, we double every scan line -> 560x384 + static const UINT g_kFrameBufferWidth = GetFrameBufferWidth(); + static unsigned (*g_pHorzClockOffset)[VIDEO_SCANNER_MAX_HORZ] = 0; typedef void (*UpdateScreenFunc_t)(long); @@ -486,19 +488,19 @@ inline uint32_t getScanlineColor( const uint16_t signal, const bgra_t *pTable ) //=========================================================================== inline uint32_t* getScanlineNext1Address() { - return (uint32_t*) (g_pVideoAddress - 1*FRAMEBUFFER_W); + return (uint32_t*) (g_pVideoAddress - 1*g_kFrameBufferWidth); } //=========================================================================== inline uint32_t* getScanlinePrev1Address() { - return (uint32_t*) (g_pVideoAddress + 1*FRAMEBUFFER_W); + return (uint32_t*) (g_pVideoAddress + 1*g_kFrameBufferWidth); } //=========================================================================== inline uint32_t* getScanlinePrev2Address() { - return (uint32_t*) (g_pVideoAddress + 2*FRAMEBUFFER_W); + return (uint32_t*) (g_pVideoAddress + 2*g_kFrameBufferWidth); } //=========================================================================== @@ -1616,7 +1618,7 @@ void NTSC_VideoInit( uint8_t* pFramebuffer ) // wsVideoInit updateMonochromeTables( 0xFF, 0xFF, 0xFF ); for (int y = 0; y < (VIDEO_SCANNER_Y_DISPLAY*2); y++) - g_pScanLines[y] = (bgra_t*)(g_pFramebufferbits + sizeof(bgra_t) * FRAMEBUFFER_W * ((FRAMEBUFFER_H - 1) - y - BORDER_H) + (sizeof(bgra_t) * BORDER_W)); + g_pScanLines[y] = (bgra_t*)(g_pFramebufferbits + sizeof(bgra_t) * GetFrameBufferWidth() * ((GetFrameBufferHeight() - 1) - y - GetFrameBufferBorderHeight()) + (sizeof(bgra_t) * GetFrameBufferBorderWidth())); g_pVideoAddress = g_pScanLines[0]; diff --git a/source/Video.cpp b/source/Video.cpp index 501546fe..34d56e92 100644 --- a/source/Video.cpp +++ b/source/Video.cpp @@ -148,8 +148,8 @@ void VideoInitialize () ZeroMemory(g_pFramebufferinfo,sizeof(BITMAPINFOHEADER)+256*sizeof(RGBQUAD)); g_pFramebufferinfo->bmiHeader.biSize = sizeof(BITMAPINFOHEADER); - g_pFramebufferinfo->bmiHeader.biWidth = FRAMEBUFFER_W; - g_pFramebufferinfo->bmiHeader.biHeight = FRAMEBUFFER_H; + g_pFramebufferinfo->bmiHeader.biWidth = GetFrameBufferWidth(); + g_pFramebufferinfo->bmiHeader.biHeight = GetFrameBufferHeight(); g_pFramebufferinfo->bmiHeader.biPlanes = 1; g_pFramebufferinfo->bmiHeader.biBitCount = 32; g_pFramebufferinfo->bmiHeader.biCompression = BI_RGB; @@ -674,12 +674,12 @@ void VideoRefreshScreen ( uint32_t uRedrawWholeScreenVideoMode /* =0*/, bool bRe if (hFrameDC) { { - int xSrc = BORDER_W; - int ySrc = BORDER_H; + int xSrc = GetFrameBufferBorderWidth(); + int ySrc = GetFrameBufferBorderHeight(); VideoFrameBufferAdjust(xSrc, ySrc); // TC: Hacky-fix for GH#341 - int xdest = GetFullScreenOffsetX(); - int ydest = GetFullScreenOffsetY(); + int xdest = IsFullScreen() ? GetFullScreenOffsetX() : 0; + int ydest = IsFullScreen() ? GetFullScreenOffsetY() : 0; int wdest = g_nViewportCX; int hdest = g_nViewportCY; @@ -690,7 +690,7 @@ void VideoRefreshScreen ( uint32_t uRedrawWholeScreenVideoMode /* =0*/, bool bRe wdest, hdest, g_hDeviceDC, xSrc, ySrc, - FRAMEBUFFER_BORDERLESS_W, FRAMEBUFFER_BORDERLESS_H, + GetFrameBufferBorderlessWidth(), GetFrameBufferBorderlessHeight(), SRCCOPY); } } @@ -1122,8 +1122,8 @@ static void Video_MakeScreenShot(FILE *pFile, const VideoScreenShot_e ScreenShot Video_SetBitmapHeader( pBmp, - ScreenShotType == SCREENSHOT_280x192 ? FRAMEBUFFER_BORDERLESS_W/2 : FRAMEBUFFER_BORDERLESS_W, - ScreenShotType == SCREENSHOT_280x192 ? FRAMEBUFFER_BORDERLESS_H/2 : FRAMEBUFFER_BORDERLESS_H, + ScreenShotType == SCREENSHOT_280x192 ? GetFrameBufferBorderlessWidth()/2 : GetFrameBufferBorderlessWidth(), + ScreenShotType == SCREENSHOT_280x192 ? GetFrameBufferBorderlessHeight()/2 : GetFrameBufferBorderlessHeight(), 32 ); @@ -1153,17 +1153,17 @@ static void Video_MakeScreenShot(FILE *pFile, const VideoScreenShot_e ScreenShot // @reference: "Storing an Image" http://msdn.microsoft.com/en-us/library/ms532340(VS.85).aspx pSrc = (uint32_t*) g_pFramebufferbits; - int xSrc = BORDER_W; - int ySrc = BORDER_H; + int xSrc = GetFrameBufferBorderWidth(); + int ySrc = GetFrameBufferBorderHeight(); VideoFrameBufferAdjust(xSrc, ySrc, true); // TC: Hacky-fix for GH#341 & GH#356 // Lines stored in reverse, so invert the y-adjust value - pSrc += xSrc; // Skip left border - pSrc += ySrc * FRAMEBUFFER_W; // Skip top border + pSrc += xSrc; // Skip left border + pSrc += ySrc * GetFrameBufferWidth(); // Skip top border if( ScreenShotType == SCREENSHOT_280x192 ) { - pSrc += FRAMEBUFFER_W; // Start on odd scanline (otherwise for 50% scanline mode get an all black image!) + pSrc += GetFrameBufferWidth(); // Start on odd scanline (otherwise for 50% scanline mode get an all black image!) uint32_t aScanLine[ 280 ]; uint32_t *pDst; @@ -1171,25 +1171,25 @@ static void Video_MakeScreenShot(FILE *pFile, const VideoScreenShot_e ScreenShot // 50% Half Scan Line clears every odd scanline. // SHIFT+PrintScreen saves only the even rows. // NOTE: Keep in sync with _Video_RedrawScreen() & Video_MakeScreenShot() - for( int y = 0; y < FRAMEBUFFER_BORDERLESS_H/2; y++ ) + for( UINT y = 0; y < GetFrameBufferBorderlessHeight()/2; y++ ) { pDst = aScanLine; - for( int x = 0; x < FRAMEBUFFER_BORDERLESS_W/2; x++ ) + for( UINT x = 0; x < GetFrameBufferBorderlessWidth()/2; x++ ) { *pDst++ = pSrc[1]; // correction for left edge loss of scaled scanline [Bill Buckel, B#18928] pSrc += 2; // skip odd pixels } - fwrite( aScanLine, sizeof(uint32_t), FRAMEBUFFER_BORDERLESS_W/2, pFile ); - pSrc += FRAMEBUFFER_W; // scan lines doubled - skip odd ones - pSrc += BORDER_W*2; // Skip right border & next line's left border + fwrite( aScanLine, sizeof(uint32_t), GetFrameBufferBorderlessWidth()/2, pFile ); + pSrc += GetFrameBufferWidth(); // scan lines doubled - skip odd ones + pSrc += GetFrameBufferBorderWidth()*2; // Skip right border & next line's left border } } else { - for( int y = 0; y < FRAMEBUFFER_BORDERLESS_H; y++ ) + for( UINT y = 0; y < GetFrameBufferBorderlessHeight(); y++ ) { - fwrite( pSrc, sizeof(uint32_t), FRAMEBUFFER_BORDERLESS_W, pFile ); - pSrc += FRAMEBUFFER_W; + fwrite( pSrc, sizeof(uint32_t), GetFrameBufferBorderlessWidth(), pFile ); + pSrc += GetFrameBufferWidth(); } } #endif // SCREENSHOT_BMP @@ -1268,7 +1268,7 @@ static void videoCreateDIBSection() // CREATE THE OFFSET TABLE FOR EACH SCAN LINE IN THE FRAME BUFFER // DRAW THE SOURCE IMAGE INTO THE SOURCE BIT BUFFER - ZeroMemory( g_pFramebufferbits, FRAMEBUFFER_W*FRAMEBUFFER_H*4 ); + ZeroMemory( g_pFramebufferbits, GetFrameBufferWidth()*GetFrameBufferHeight()*sizeof(bgra_t) ); NTSC_VideoInit( g_pFramebufferbits ); } From 32ffe0e1acb775aed775a47c8f2304d59962f599 Mon Sep 17 00:00:00 2001 From: tomcw Date: Wed, 11 Oct 2017 17:55:10 +0100 Subject: [PATCH 33/64] Frame.cpp: internalise the FRAMEBUFFER_BORDERLESS_W|H constants as static vars --- source/Frame.cpp | 48 +++++++++++++++++++++++------------------------- 1 file changed, 23 insertions(+), 25 deletions(-) diff --git a/source/Frame.cpp b/source/Frame.cpp index 753b91b4..58a0f4e6 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -206,31 +206,29 @@ static int g_win_fullscreen_offsety = 0; // - Optional: Draw status area to frame DC // -#define FRAMEBUFFER_BORDERLESS_W 560 // 560 = Double Hi-Res -#define FRAMEBUFFER_BORDERLESS_H 384 // 384 = Double Scan Line - -// NB. This border area is not visible (... and this border area is unrelated to the 3D border below) -#define BORDER_W 20 -#define BORDER_H 18 - UINT GetFrameBufferBorderlessWidth(void) { - return FRAMEBUFFER_BORDERLESS_W; + static UINT uFrameBufferBorderlessW = 560; // 560 = Double Hi-Res + return uFrameBufferBorderlessW; } UINT GetFrameBufferBorderlessHeight(void) { - return FRAMEBUFFER_BORDERLESS_H; + static UINT uFrameBufferBorderlessH = 384; // 384 = Double Scan Line + return uFrameBufferBorderlessH; } +// NB. These border areas are not visible (... and these border areas are unrelated to the 3D border below) UINT GetFrameBufferBorderWidth(void) { - return BORDER_W; + static UINT uBorderW = 20; + return uBorderW; } UINT GetFrameBufferBorderHeight(void) { - return BORDER_H; + static UINT uBorderH = 18; + return uBorderH; } UINT GetFrameBufferWidth(void) @@ -2245,12 +2243,12 @@ void SetFullScreenMode () width = (FULLSCREEN_SCALE_TYPE)(monitor_info.rcMonitor.right - monitor_info.rcMonitor.left); height = (FULLSCREEN_SCALE_TYPE)(monitor_info.rcMonitor.bottom - monitor_info.rcMonitor.top ); - scalex = width / FRAMEBUFFER_BORDERLESS_W; - scaley = height / FRAMEBUFFER_BORDERLESS_H; + scalex = width / GetFrameBufferBorderlessWidth(); + scaley = height / GetFrameBufferBorderlessHeight(); g_win_fullscreen_scale = (scalex <= scaley) ? scalex : scaley; - g_win_fullscreen_offsetx = ((int)width - (int)(g_win_fullscreen_scale * FRAMEBUFFER_BORDERLESS_W)) / 2; - g_win_fullscreen_offsety = ((int)height - (int)(g_win_fullscreen_scale * FRAMEBUFFER_BORDERLESS_H)) / 2; + g_win_fullscreen_offsetx = ((int)width - (int)(g_win_fullscreen_scale * GetFrameBufferBorderlessWidth())) / 2; + g_win_fullscreen_offsety = ((int)height - (int)(g_win_fullscreen_scale * GetFrameBufferBorderlessHeight())) / 2; SetWindowPos(g_hFrameWindow, NULL, left, top, (int)width, (int)height, SWP_NOZORDER | SWP_NOACTIVATE | SWP_FRAMECHANGED); g_bIsFullScreen = true; @@ -2381,8 +2379,8 @@ int SetViewportScale(int nNewScale, bool bForce /*=false*/) nNewScale = g_nMaxViewportScale; g_nViewportScale = nNewScale; - g_nViewportCX = g_nViewportScale * FRAMEBUFFER_BORDERLESS_W; - g_nViewportCY = g_nViewportScale * FRAMEBUFFER_BORDERLESS_H; + g_nViewportCX = g_nViewportScale * GetFrameBufferBorderlessWidth(); + g_nViewportCY = g_nViewportScale * GetFrameBufferBorderlessHeight(); return nNewScale; } @@ -2481,8 +2479,8 @@ void FrameCreateWindow(void) int nOldViewportCX = g_nViewportCX; int nOldViewportCY = g_nViewportCY; - g_nViewportCX = FRAMEBUFFER_BORDERLESS_W * 2; - g_nViewportCY = FRAMEBUFFER_BORDERLESS_H * 2; + g_nViewportCX = GetFrameBufferBorderlessWidth() * 2; + g_nViewportCY = GetFrameBufferBorderlessHeight() * 2; GetWidthHeight(nWidth, nHeight); // Probe with 2x dimensions g_nViewportCX = nOldViewportCX; @@ -2919,8 +2917,8 @@ bool GetBestDisplayResolutionForFullScreen(UINT& bestWidth, UINT& bestHeight, UI { if (width > it->first) { - UINT scaleFactor = it->second / FRAMEBUFFER_BORDERLESS_H; - if (it->first >= (FRAMEBUFFER_BORDERLESS_W * scaleFactor)) + UINT scaleFactor = it->second / GetFrameBufferBorderlessHeight(); + if (it->first >= (GetFrameBufferBorderlessWidth() * scaleFactor)) { width = it->first; } @@ -2935,17 +2933,17 @@ bool GetBestDisplayResolutionForFullScreen(UINT& bestWidth, UINT& bestHeight, UI return true; } - // Pick max height that's an exact multiple of FRAMEBUFFER_BORDERLESS_H + // Pick max height that's an exact multiple of GetFrameBufferBorderlessHeight() UINT tmpBestWidth = 0; UINT tmpBestHeight = 0; for (VEC_PAIR::iterator it = vecDisplayResolutions.begin(); it!= vecDisplayResolutions.end(); ++it) { - if ((it->second % FRAMEBUFFER_BORDERLESS_H) == 0) + if ((it->second % GetFrameBufferBorderlessHeight()) == 0) { if (it->second > tmpBestHeight) { - UINT scaleFactor = it->second / FRAMEBUFFER_BORDERLESS_H; - if (it->first >= (FRAMEBUFFER_BORDERLESS_W * scaleFactor)) + UINT scaleFactor = it->second / GetFrameBufferBorderlessHeight(); + if (it->first >= (GetFrameBufferBorderlessWidth() * scaleFactor)) { tmpBestWidth = it->first; tmpBestHeight = it->second; From 670ca20057343a3b49353598ffb986346e829845 Mon Sep 17 00:00:00 2001 From: tomcw Date: Wed, 11 Oct 2017 19:18:53 +0100 Subject: [PATCH 34/64] Frame.cpp: Remove redundant, commented out and if 0 code, mostly relating to the old full-screen implementation --- source/Frame.cpp | 189 +++-------------------------------------------- source/Frame.h | 4 +- source/Video.cpp | 60 +++++---------- 3 files changed, 28 insertions(+), 225 deletions(-) diff --git a/source/Frame.cpp b/source/Frame.cpp index 58a0f4e6..2e061d9e 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -76,11 +76,6 @@ static int g_nMaxViewportScale = kDEFAULT_VIEWPORT_SCALE; // Max scale in Window #define BUTTONY 0 #define BUTTONCX 45 #define BUTTONCY 45 -// NB. FSxxx = FullScreen xxx -//#define FSVIEWPORTX (640-BUTTONCX-MAGICX-g_nViewportCX) -//#define FSVIEWPORTY ((480-g_nViewportCY)/2) -//#define FSBUTTONX (640-BUTTONCX) -//#define FSBUTTONY (((480-g_nViewportCY)/2)-1) #define BUTTONS 8 static HBITMAP g_hCapsLockBitmap[2]; @@ -144,19 +139,6 @@ static BOOL g_bUsingCursor = 0; // 1=AppleWin is using (hiding) the mouse-cu static int viewportx = VIEWPORTX; // Default to Normal (non-FullScreen) mode static int viewporty = VIEWPORTY; // Default to Normal (non-FullScreen) mode -#if 0 // TC: Redundant -// Direct Draw -- For Full Screen -// LPDIRECTDRAW g_pDD = (LPDIRECTDRAW)0; -// LPDIRECTDRAWSURFACE g_pDDPrimarySurface = (LPDIRECTDRAWSURFACE)0; -#define DIRECTX_PAGE_FLIP 1 -#if DIRECTX_PAGE_FLIP -// LPDIRECTDRAWSURFACE g_pDDBackSurface = (LPDIRECTDRAWSURFACE)0; -#endif -// HDC g_hDDdc = 0; -// int g_nDDFullScreenW = 640; -// int g_nDDFullScreenH = 480; -#endif - static bool g_bShowingCursor = true; static bool g_bLastCursorInAppleViewport = false; @@ -208,26 +190,26 @@ static int g_win_fullscreen_offsety = 0; UINT GetFrameBufferBorderlessWidth(void) { - static UINT uFrameBufferBorderlessW = 560; // 560 = Double Hi-Res + static const UINT uFrameBufferBorderlessW = 560; // 560 = Double Hi-Res return uFrameBufferBorderlessW; } UINT GetFrameBufferBorderlessHeight(void) { - static UINT uFrameBufferBorderlessH = 384; // 384 = Double Scan Line + static const UINT uFrameBufferBorderlessH = 384; // 384 = Double Scan Line return uFrameBufferBorderlessH; } // NB. These border areas are not visible (... and these border areas are unrelated to the 3D border below) UINT GetFrameBufferBorderWidth(void) { - static UINT uBorderW = 20; + static const UINT uBorderW = 20; return uBorderW; } UINT GetFrameBufferBorderHeight(void) { - static UINT uBorderH = 18; + static const UINT uBorderH = 18; return uBorderH; } @@ -530,22 +512,6 @@ static void DrawCrosshairs (int x, int y) { // ERASE THE OLD CROSSHAIRS if (lastx && lasty) -#if 0 - if (g_bIsFullScreen) { - int loop = 4; - while (loop--) { - RECT rect = {0,0,5,5}; - switch (loop) { - case 0: OffsetRect(&rect,lastx-2,FSVIEWPORTY-5); break; - case 1: OffsetRect(&rect,lastx-2,FSVIEWPORTY+g_nViewportCY); break; - case 2: OffsetRect(&rect,FSVIEWPORTX-5,lasty-2); break; - case 3: OffsetRect(&rect,FSVIEWPORTX+g_nViewportCX,lasty-2); break; - } - FillRect(dc,&rect,(HBRUSH)GetStockObject(BLACK_BRUSH)); - } - } - else -#else if (g_bIsFullScreen) { int loop = 4; @@ -561,7 +527,6 @@ static void DrawCrosshairs (int x, int y) { } } else -#endif { int loop = 5; while (loop--) { @@ -2220,13 +2185,6 @@ void SetFullScreenMode () int top, left; buttonover = -1; -#if 0 - // FS: 640x480 - buttonx = FSBUTTONX; - buttony = FSBUTTONY; - viewportx = FSVIEWPORTX; - viewporty = FSVIEWPORTY; -#endif g_main_window_saved_style = GetWindowLong(g_hFrameWindow, GWL_STYLE); g_main_window_saved_exstyle = GetWindowLong(g_hFrameWindow, GWL_EXSTYLE); @@ -2252,42 +2210,12 @@ void SetFullScreenMode () SetWindowPos(g_hFrameWindow, NULL, left, top, (int)width, (int)height, SWP_NOZORDER | SWP_NOACTIVATE | SWP_FRAMECHANGED); g_bIsFullScreen = true; -#if 1 - // FS: desktop SetViewportScale(g_win_fullscreen_scale, true); buttonx = GetFullScreenOffsetX() + g_nViewportCX + VIEWPORTX*2; buttony = GetFullScreenOffsetY(); viewportx = VIEWPORTX; // TC-TODO: Should be zero too? (Since there's no 3D border in full-screen) viewporty = 0; // GH#464 -#endif - - // GetWindowRect(g_hFrameWindow,&framerect); -// SetWindowLong(g_hFrameWindow,GWL_STYLE,WS_POPUP | WS_SYSMENU | WS_VISIBLE); -// -// DDSURFACEDESC ddsd; -// ddsd.dwSize = sizeof(ddsd); -// ddsd.dwFlags = DDSD_CAPS | DDSD_BACKBUFFERCOUNT; -// ddsd.ddsCaps.dwCaps = DDSCAPS_PRIMARYSURFACE | DDSCAPS_FLIP | DDSCAPS_COMPLEX; -// ddsd.dwBackBufferCount = 1; -// -// DDSCAPS ddscaps; -// ddscaps.dwCaps = DDSCAPS_BACKBUFFER; -// -// if ( 0 -// || DD_OK != DirectDrawCreate(NULL,&g_pDD,NULL) -// || DD_OK != g_pDD->SetCooperativeLevel(g_hFrameWindow,DDSCL_EXCLUSIVE | DDSCL_FULLSCREEN) -// || DD_OK != g_pDD->SetDisplayMode(g_nDDFullScreenW,g_nDDFullScreenH,32) -// || DD_OK != g_pDD->CreateSurface(&ddsd,&g_pDDPrimarySurface,NULL) -//#if DIRECTX_PAGE_FLIP -// || DD_OK != g_pDDPrimarySurface->GetAttachedSurface( &ddscaps, &g_pDDBackSurface) -//#endif -// ) -// { -// g_pDDPrimarySurface = NULL; -// SetNormalMode(); -// return; -// } InvalidateRect(g_hFrameWindow,NULL,1); @@ -2315,25 +2243,6 @@ void SetNormalMode () g_main_window_saved_rect.bottom - g_main_window_saved_rect.top, SWP_SHOWWINDOW); g_bIsFullScreen = false; - - //g_pDD->RestoreDisplayMode(); - //g_pDD->SetCooperativeLevel(NULL,DDSCL_NORMAL); - //SetWindowLong(g_hFrameWindow,GWL_STYLE, - // WS_OVERLAPPED | WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX | - // WS_VISIBLE); - //SetWindowPos(g_hFrameWindow,0,framerect.left, - // framerect.top, - // framerect.right - framerect.left, - // framerect.bottom - framerect.top, - // SWP_NOZORDER | SWP_FRAMECHANGED); - //if (g_pDDPrimarySurface) - //{ - // g_pDDPrimarySurface->Release(); - // g_pDDPrimarySurface = (LPDIRECTDRAWSURFACE)0; - //} - - //g_pDD->Release(); - //g_pDD = (LPDIRECTDRAW)0; } //=========================================================================== @@ -2569,50 +2478,12 @@ HDC FrameGetDC () { } //=========================================================================== -HDC FrameGetVideoDC (LPBYTE *pAddr_, LONG *pPitch_) -{ - HDC hDC = 0; - -#if 0 // TC: just wrapping existing "if (false)" code in "#if 0" to make it clear that it's dead code - // ASSERT( pAddr_ ); - // ASSERT( pPitch_ ); - if (false) // TODO: ... - //if (g_bIsFullScreen && g_bAppActive && !g_bPaintingWindow) - { - // Reference: http://archive.gamedev.net/archive/reference/articles/article608.html - // NTSC TODO: Are these coordinates correct?? Coordinates don't seem to matter on Win7 fullscreen!? - // g_nViewportCX = FRAMEBUFFER_W * kDEFAULT_VIEWPORT_SCALE; - RECT rect = { - FSVIEWPORTX, - FSVIEWPORTY, - FSVIEWPORTX+g_nViewportCX, - FSVIEWPORTY+g_nViewportCY - }; - DDSURFACEDESC surfacedesc; - surfacedesc.dwSize = sizeof(surfacedesc); - // TC: Use DDLOCK_WAIT - see Bug #13425 - if (g_pDDPrimarySurface->Lock(&rect,&surfacedesc,DDLOCK_WAIT,NULL) == DDERR_SURFACELOST) - { - g_pDDPrimarySurface->Restore(); - g_pDDPrimarySurface->Lock(&rect,&surfacedesc,DDLOCK_WAIT,NULL); - } - *pAddr_ = (LPBYTE)surfacedesc.lpSurface + (g_nViewportCY-1) * surfacedesc.lPitch; - *pPitch_ = -surfacedesc.lPitch; - - if( g_pDDPrimarySurface->GetDC( &hDC ) == DD_OK ) - g_hDDdc = hDC; // intentional "null" copy - else - hDC = 0; - } - else -#endif - { - *pAddr_ = g_pFramebufferbits; - *pPitch_ = GetFrameBufferWidth(); - hDC = FrameGetDC(); - } - - return hDC; +void FrameReleaseDC () { + if (g_hFrameDC) { + SetViewportOrgEx(g_hFrameDC,0,0,NULL); + ReleaseDC(g_hFrameWindow,g_hFrameDC); + g_hFrameDC = (HDC)0; + } } //=========================================================================== @@ -2642,46 +2513,6 @@ void FrameRegisterClass () { RegisterClassEx(&wndclass); } -//=========================================================================== -void FrameReleaseDC () { - if (g_hFrameDC) { - SetViewportOrgEx(g_hFrameDC,0,0,NULL); - ReleaseDC(g_hFrameWindow,g_hFrameDC); - g_hFrameDC = (HDC)0; - } -} - -//=========================================================================== -void FrameReleaseVideoDC () -{ -#if 0 // TC: just wrapping existing "if (false)" code in "#if 0" to make it clear that it's dead code - if (false) // TODO: ... - //if (g_bIsFullScreen && g_bAppActive && !g_bPaintingWindow) - { - // THIS IS CORRECT ACCORDING TO THE DIRECTDRAW DOCS - RECT rect = { - FSVIEWPORTX, - FSVIEWPORTY, - FSVIEWPORTX+g_nViewportCX, - FSVIEWPORTY+g_nViewportCY - }; - - //g_pDDBackSurface->BltFast( 0, 0, g_pDDPrimarySurface, &rcRect,DDBLTFAST_NOCOLORKEY | DDBLTFAST_WAIT); -#if DIRECTX_PAGE_FLIP - g_pDDBackSurface->Flip( g_pDDPrimarySurface, 0 ); -#endif - - g_pDDPrimarySurface->Unlock(&rect); - - // BUT THIS SEEMS TO BE WORKING - g_pDDPrimarySurface->Unlock(NULL); - - g_pDDPrimarySurface->ReleaseDC( g_hDDdc ); // NTSC Full Screen - g_hDDdc = 0; - } -#endif -} - //=========================================================================== // TODO: FIXME: Util_TestFileExists() static bool FileExists(std::string strFilename) diff --git a/source/Frame.h b/source/Frame.h index 7d5cfe1f..0528bfe5 100644 --- a/source/Frame.h +++ b/source/Frame.h @@ -27,11 +27,9 @@ void FrameCreateWindow(void); HDC FrameGetDC (); - HDC FrameGetVideoDC (LPBYTE *,LONG *); + void FrameReleaseDC (); void FrameRefreshStatus (int, bool bUpdateDiskStatus = true ); void FrameRegisterClass (); - void FrameReleaseDC (); - void FrameReleaseVideoDC (); void FrameSetCursorPosByMousePos(); int GetViewportScale(void); int SetViewportScale(int nNewScale, bool bForce = false); diff --git a/source/Video.cpp b/source/Video.cpp index 34d56e92..6516192b 100644 --- a/source/Video.cpp +++ b/source/Video.cpp @@ -446,14 +446,8 @@ void VideoDisplayLogo () if( IsFullScreen() ) { -#if 0 - // Draw Logo at top of screen so when the Apple display is refreshed it will automagically clear it - nLogoX = 0; - nLogoY = 0; -#else nLogoX += GetFullScreenOffsetX(); nLogoY += GetFullScreenOffsetY(); -#endif } VideoDrawLogoBitmap( hFrameDC, nLogoX, nLogoY, bm.bmWidth, bm.bmHeight, scale ); @@ -500,8 +494,6 @@ void VideoDisplayLogo () #undef DRAWVERSION - FrameReleaseVideoDC(); - DeleteObject(font); } @@ -656,49 +648,31 @@ void VideoRefreshScreen ( uint32_t uRedrawWholeScreenVideoMode /* =0*/, bool bRe NTSC_VideoRedrawWholeScreen(); } -// NTSC_BEGIN - LPBYTE pDstFrameBufferBits = 0; - LONG pitch = 0; - HDC hFrameDC = FrameGetVideoDC(&pDstFrameBufferBits,&pitch); - -#if 1 // Keep Aspect Ratio - // Need to clear full screen logo to black - #define W g_nViewportCX - #define H g_nViewportCY -#else // Stretch - // Stretch - doesn't preserve 1:1 aspect ratio - #define W IsFullScreen() ? g_nDDFullScreenW : g_nViewportCX - #define H IsFullScreen() ? g_nDDFullScreenH : g_nViewportCY -#endif + HDC hFrameDC = FrameGetDC(); if (hFrameDC) { - { - int xSrc = GetFrameBufferBorderWidth(); - int ySrc = GetFrameBufferBorderHeight(); - VideoFrameBufferAdjust(xSrc, ySrc); // TC: Hacky-fix for GH#341 + int xSrc = GetFrameBufferBorderWidth(); + int ySrc = GetFrameBufferBorderHeight(); + VideoFrameBufferAdjust(xSrc, ySrc); // TC: Hacky-fix for GH#341 - int xdest = IsFullScreen() ? GetFullScreenOffsetX() : 0; - int ydest = IsFullScreen() ? GetFullScreenOffsetY() : 0; - int wdest = g_nViewportCX; - int hdest = g_nViewportCY; + int xdest = IsFullScreen() ? GetFullScreenOffsetX() : 0; + int ydest = IsFullScreen() ? GetFullScreenOffsetY() : 0; + int wdest = g_nViewportCX; + int hdest = g_nViewportCY; - SetStretchBltMode(hFrameDC, COLORONCOLOR); - StretchBlt( - hFrameDC, - xdest, ydest, - wdest, hdest, - g_hDeviceDC, - xSrc, ySrc, - GetFrameBufferBorderlessWidth(), GetFrameBufferBorderlessHeight(), - SRCCOPY); - } + SetStretchBltMode(hFrameDC, COLORONCOLOR); + StretchBlt( + hFrameDC, + xdest, ydest, + wdest, hdest, + g_hDeviceDC, + xSrc, ySrc, + GetFrameBufferBorderlessWidth(), GetFrameBufferBorderlessHeight(), + SRCCOPY); } GdiFlush(); - - FrameReleaseVideoDC(); -// NTSC_END } //=========================================================================== From ba6a38d32532d7c4aa1744eeb98c310922884ef9 Mon Sep 17 00:00:00 2001 From: tomcw Date: Thu, 12 Oct 2017 22:11:10 +0100 Subject: [PATCH 35/64] Frame.cpp: Get rid of the MAGICX/Y constants! Get the correct system-metric: SM_CXFIXEDFRAME (not SM_CXBORDER). Remove more commented out old code. --- source/Frame.cpp | 38 ++++++++++++-------------------------- 1 file changed, 12 insertions(+), 26 deletions(-) diff --git a/source/Frame.cpp b/source/Frame.cpp index 2e061d9e..09bcf2db 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -58,10 +58,6 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA //#define ENABLE_MENU 0 -// Magic numbers (used by FrameCreateWindow to calc width/height): -#define MAGICX 5 // 3D border between Apple window & Emulator's RHS buttons -#define MAGICY 5 // 3D border between Apple window & Title bar - // 3D border around the 560x384 Apple II display #define VIEWPORTX 5 #define VIEWPORTY 5 @@ -88,7 +84,6 @@ static int g_nMaxViewportScale = kDEFAULT_VIEWPORT_SCALE; // Max scale in Window //=========================== static HBITMAP g_hDiskWindowedLED[ NUM_DISK_STATUS ]; -//static HBITMAP g_hDiskFullScreenLED[ NUM_DISK_STATUS ]; static int g_nTrackDrive1 = -1; static int g_nTrackDrive2 = -1; static int g_nSectorDrive1 = -1; @@ -388,12 +383,6 @@ static void CreateGdiObjects(void) g_hDiskWindowedLED[ DISK_STATUS_WRITE] = (HBITMAP)LOADBUTTONBITMAP(TEXT("DISKWRITE_BITMAP")); g_hDiskWindowedLED[ DISK_STATUS_PROT ] = (HBITMAP)LOADBUTTONBITMAP(TEXT("DISKPROT_BITMAP")); - // Full Screen Drive LED - // g_hDiskFullScreenLED[ DISK_STATUS_OFF ] = (HBITMAP)LOADBUTTONBITMAP(TEXT("DISK_FULLSCREEN_O")); // Full Screen Off - // g_hDiskFullScreenLED[ DISK_STATUS_READ ] = (HBITMAP)LOADBUTTONBITMAP(TEXT("DISK_FULLSCREEN_R")); // Full Screen Read Only - // g_hDiskFullScreenLED[ DISK_STATUS_WRITE] = (HBITMAP)LOADBUTTONBITMAP(TEXT("DISK_FULLSCREEN_W")); // Full Screen Write - // g_hDiskFullScreenLED[ DISK_STATUS_PROT ] = (HBITMAP)LOADBUTTONBITMAP(TEXT("DISK_FULLSCREEN_P")); // Full Screen Write Protected - btnfacebrush = CreateSolidBrush(GetSysColor(COLOR_BTNFACE)); btnfacepen = CreatePen(PS_SOLID,1,GetSysColor(COLOR_BTNFACE)); btnhighlightpen = CreatePen(PS_SOLID,1,GetSysColor(COLOR_BTNHIGHLIGHT)); @@ -420,7 +409,6 @@ static void DeleteGdiObjects(void) for (int loop = 0; loop < NUM_DISK_STATUS; loop++) { _ASSERT(DeleteObject(g_hDiskWindowedLED[loop])); - //_ASSERT(DeleteObject(g_hDiskFullScreenLED[loop])); } _ASSERT(DeleteObject(btnfacebrush)); @@ -2319,13 +2307,11 @@ static void SetupTooltipControls(void) static void GetWidthHeight(int& nWidth, int& nHeight) { nWidth = g_nViewportCX + VIEWPORTX*2 - + BUTTONCX - + (GetSystemMetrics(SM_CXBORDER) + GetSystemMetrics(SM_CXPADDEDBORDER)) * 2 - + MAGICX; + + BUTTONCX + + (GetSystemMetrics(SM_CYFIXEDFRAME) + GetSystemMetrics(SM_CXPADDEDBORDER)) * 2; nHeight = g_nViewportCY + VIEWPORTY*2 - + (GetSystemMetrics(SM_CYBORDER) + GetSystemMetrics(SM_CXPADDEDBORDER)) * 2 - + GetSystemMetrics(SM_CYCAPTION) - + MAGICY; + + (GetSystemMetrics(SM_CYFIXEDFRAME) + GetSystemMetrics(SM_CXPADDEDBORDER)) * 2 // NB. No SM_CYPADDEDBORDER + + GetSystemMetrics(SM_CYCAPTION); } static void FrameResizeWindow(int nNewScale) @@ -2449,7 +2435,7 @@ void FrameCreateWindow(void) // NB. g_hFrameWindow also set by WM_CREATE - NB. CreateWindow() must synchronously send WM_CREATE g_hFrameWindow = CreateWindow( TEXT("APPLE2FRAME"), - g_pAppTitle, // SetWindowText() // WindowTitle + g_pAppTitle, WS_OVERLAPPED | WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX | WS_VISIBLE, nXPos, nYPos, nWidth, nHeight, @@ -2544,13 +2530,13 @@ void FrameSetCursorPosByMousePos() POINT Point = {viewportx+2, viewporty+2}; // top-left ClientToScreen(g_hFrameWindow, &Point); - SetCursorPos(Point.x+iWindowX-MAGICX, Point.y+iWindowY-MAGICY); + SetCursorPos(Point.x+iWindowX-VIEWPORTX, Point.y+iWindowY-VIEWPORTY); -#if defined(_DEBUG) && 0 +#if defined(_DEBUG) && 0 // OutputDebugString() when cursor position changes since last time static int OldX=0, OldY=0; char szDbg[200]; - int X=Point.x+iWindowX-MAGICX; - int Y=Point.y+iWindowY-MAGICY; + int X=Point.x+iWindowX-VIEWPORTX; + int Y=Point.y+iWindowY-VIEWPORTY; if (X != OldX || Y != OldY) { sprintf(szDbg, "[FrameSetCursorPosByMousePos] x,y=%d,%d (MaxX,Y=%d,%d)\n", X,Y, iMaxX,iMaxY); OutputDebugString(szDbg); @@ -2588,7 +2574,7 @@ static void FrameSetCursorPosByMousePos(int x, int y, int dx, int dy, bool bLeav POINT Point = {viewportx+2, viewporty+2}; // top-left ClientToScreen(g_hFrameWindow, &Point); - SetCursorPos(Point.x+iWindowX-MAGICX, Point.y+iWindowY-MAGICY); + SetCursorPos(Point.x+iWindowX-VIEWPORTX, Point.y+iWindowY-VIEWPORTY); // sprintf(szDbg, "[MOUSE_LEAVING ] x=%d, y=%d (Scale: x,y=%f,%f; iX,iY=%d,%d)\n", iWindowX, iWindowY, fScaleX, fScaleY, iX, iY); OutputDebugString(szDbg); } else // Mouse entering Apple screen area @@ -2596,8 +2582,8 @@ static void FrameSetCursorPosByMousePos(int x, int y, int dx, int dy, bool bLeav // sprintf(szDbg, "[MOUSE_ENTERING] x=%d, y=%d\n", x, y); OutputDebugString(szDbg); if (!g_bIsFullScreen) // GH#464 { - x -= (viewportx+2-MAGICX); if (x < 0) x = 0; - y -= (viewporty+2-MAGICY); if (y < 0) y = 0; + x -= (viewportx+2-VIEWPORTX); if (x < 0) x = 0; + y -= (viewporty+2-VIEWPORTY); if (y < 0) y = 0; } _ASSERT(x <= g_nViewportCX); From 1cb5c6868da3daea813ee077b2727a720a321b8f Mon Sep 17 00:00:00 2001 From: tomcw Date: Tue, 17 Oct 2017 14:46:55 -0700 Subject: [PATCH 36/64] UpdatePaging(): Clear memdirty flag for $Cx pages (#495) . STA $CFFF will set memdirty[0xCF] flag . The loop at the end of UpdatePaging() would copy a page of zeros over pCxRomInternal[0xF00] (ie. $CF00-CFFF) --- source/Memory.cpp | 2 ++ 1 file changed, 2 insertions(+) diff --git a/source/Memory.cpp b/source/Memory.cpp index 64aa3a12..06ee705b 100644 --- a/source/Memory.cpp +++ b/source/Memory.cpp @@ -913,6 +913,7 @@ static void UpdatePaging(BOOL initialize) for (loop = 0xC0; loop < 0xC8; loop++) { + memdirty[loop] = 0; // ROM can't be dirty const UINT uSlotOffset = (loop & 0x0f) * 0x100; if (loop == 0xC3) memshadow[loop] = (SW_SLOTC3ROM && SW_SLOTCXROM) ? pCxRomPeripheral+uSlotOffset // C300..C3FF - Slot 3 ROM (all 0x00's) @@ -924,6 +925,7 @@ static void UpdatePaging(BOOL initialize) for (loop = 0xC8; loop < 0xD0; loop++) { + memdirty[loop] = 0; // ROM can't be dirty (but STA $CFFF will set the dirty flag) const UINT uRomOffset = (loop & 0x0f) * 0x100; memshadow[loop] = (SW_SLOTCXROM && !INTC8ROM) ? pCxRomPeripheral+uRomOffset // C800..CFFF - Peripheral ROM (GH#486) : pCxRomInternal+uRomOffset; // C800..CFFF - Internal ROM From c49d68f2b56ffdee6f18f77fc8fca608b3cc7677 Mon Sep 17 00:00:00 2001 From: tomcw Date: Thu, 19 Oct 2017 22:49:10 -0700 Subject: [PATCH 37/64] Flush current track (if dirty) before 'Send to CiderPress' (fix #499) --- source/Disk.cpp | 18 ++++++++++++------ source/Disk.h | 1 + source/Frame.cpp | 2 ++ 3 files changed, 15 insertions(+), 6 deletions(-) diff --git a/source/Disk.cpp b/source/Disk.cpp index 1539167c..c3751a65 100644 --- a/source/Disk.cpp +++ b/source/Disk.cpp @@ -320,14 +320,23 @@ static void ReadTrack(const int iDrive) //=========================================================================== +void DiskFlushCurrentTrack(const int iDrive) +{ + Disk_t *pFloppy = &g_aFloppyDisk[iDrive]; + + if (pFloppy->trackimage && pFloppy->trackimagedirty) + WriteTrack(iDrive); +} + +//=========================================================================== + static void RemoveDisk(const int iDrive) { Disk_t *pFloppy = &g_aFloppyDisk[iDrive]; if (pFloppy->imagehandle) { - if (pFloppy->trackimage && pFloppy->trackimagedirty) - WriteTrack( iDrive); + DiskFlushCurrentTrack(iDrive); ImageClose(pFloppy->imagehandle); pFloppy->imagehandle = NULL; @@ -442,10 +451,7 @@ static void __stdcall DiskControlStepper(WORD, WORD address, BYTE, BYTE, ULONG u : MIN(nNumTracksInImage-1, fptr->phase >> 1); // (round half tracks down) if (newtrack != fptr->track) { - if (fptr->trackimage && fptr->trackimagedirty) - { - WriteTrack(currdrive); - } + DiskFlushCurrentTrack(currdrive); fptr->track = newtrack; fptr->trackimagedata = 0; } diff --git a/source/Disk.h b/source/Disk.h index 95d8f7e2..b803e24f 100644 --- a/source/Disk.h +++ b/source/Disk.h @@ -47,6 +47,7 @@ void DiskDestroy(void); // no, doesn't "destroy" the disk image. DiskIIManag void DiskBoot(void); void DiskEject(const int iDrive); +void DiskFlushCurrentTrack(const int iDrive); LPCTSTR DiskGetFullName(const int iDrive); LPCTSTR DiskGetFullDiskFilename(const int iDrive); diff --git a/source/Frame.cpp b/source/Frame.cpp index 09bcf2db..74e60576 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -2040,6 +2040,8 @@ void ProcessDiskPopupMenu(HWND hwnd, POINT pt, const int iDrive) "Please install CiderPress.\n" "Otherwise set the path to CiderPress from Configuration->Disk."; + DiskFlushCurrentTrack(iDrive); + //if(!filename1.compare("\"\"") == false) //Do not use this, for some reason it does not work!!! if(!filename1.compare(sFileNameEmpty) ) { From 297cea7d2aec892b13522f74e271c6a965409e96 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sat, 21 Oct 2017 18:47:22 +0100 Subject: [PATCH 38/64] Support polling of Mockingboard's & Phasor's 6522 IFR.Timer1 (#496) . Extended save-state (Mockingboard & Phasor: version 2) to support 6522 timer being active --- source/AY8910.cpp | 1 - source/CPU.cpp | 1 + source/Mockingboard.cpp | 130 ++++++++++++++++++++++++++-------------- source/Mockingboard.h | 5 -- 4 files changed, 85 insertions(+), 52 deletions(-) diff --git a/source/AY8910.cpp b/source/AY8910.cpp index e7f21f7d..701a958a 100644 --- a/source/AY8910.cpp +++ b/source/AY8910.cpp @@ -32,7 +32,6 @@ #include "AY8910.h" #include "Applewin.h" // For g_fh -#include "Mockingboard.h" // For g_uTimer1IrqCount #include "YamlHelper.h" /* The AY white noise RNG algorithm is based on info from MAME's ay8910.c - diff --git a/source/CPU.cpp b/source/CPU.cpp index 402ca743..f6bdc0fd 100644 --- a/source/CPU.cpp +++ b/source/CPU.cpp @@ -539,6 +539,7 @@ DWORD CpuExecute(const DWORD uCycles, const bool bVideoUpdate) const DWORD uExecutedCycles = InternalCpuExecute(uCycles, bVideoUpdate); MB_UpdateCycles(uExecutedCycles); // Update 6522s (NB. Do this before updating g_nCumulativeCycles below) + // NB. Ensures that 6522 regs are up-to-date for any potential save-state UpdateEmulationTime(uExecutedCycles); // diff --git a/source/Mockingboard.cpp b/source/Mockingboard.cpp index 4571f6cf..928b593d 100644 --- a/source/Mockingboard.cpp +++ b/source/Mockingboard.cpp @@ -122,7 +122,8 @@ struct SY6522_AY8910 SY6522 sy6522; BYTE nAY8910Number; BYTE nAYCurrentRegister; - BYTE nTimerStatus; + bool bTimer1Active; + bool bTimer2Active; SSI263A SpeechChip; }; @@ -203,13 +204,7 @@ static DWORD g_dwMaxPhonemeLen = 0; // When 6522 IRQ is *not* active use 60Hz update freq for MB voices static const double g_f6522TimerPeriod_NoIRQ = CLK_6502 / 60.0; // Constant whatever the CLK is set to -//--------------------------------------------------------------------------- - -// External global vars: -bool g_bMBTimerIrqActive = false; -#ifdef _DEBUG -UINT32 g_uTimer1IrqCount = 0; // DEBUG -#endif +static bool g_bMBTimerIrqActive = false; //--------------------------------------------------------------------------- @@ -219,33 +214,41 @@ static void Votrax_Write(BYTE nDevice, BYTE nValue); //--------------------------------------------------------------------------- -static void StartTimer(SY6522_AY8910* pMB) +static void StartTimer1(SY6522_AY8910* pMB) { -// if((pMB->nAY8910Number & 1) != SY6522_DEVICE_A) -// return; - - if((pMB->sy6522.IER & IxR_TIMER1) == 0x00) - return; - - USHORT nPeriod = pMB->sy6522.TIMER1_LATCH.w; - -// if(nPeriod <= 0xff) // Timer1L value has been written (but TIMER1H hasn't) -// return; - - pMB->nTimerStatus = 1; + pMB->bTimer1Active = true; // 6522 CLK runs at same speed as 6502 CLK - g_n6522TimerPeriod = nPeriod; + g_n6522TimerPeriod = pMB->sy6522.TIMER1_LATCH.w; + + if (pMB->sy6522.IER & IxR_TIMER1) + g_bMBTimerIrqActive = true; + + g_nMBTimerDevice = pMB->nAY8910Number; +} + +// The assumption was that timer1 was only active if IER.TIMER1=1 +// . Not true, since IFR can be polled (with IER.TIMER1=0) +static void StartTimer1_LoadStateV1(SY6522_AY8910* pMB) +{ + if ((pMB->sy6522.IER & IxR_TIMER1) == 0x00) + return; + + pMB->bTimer1Active = true; + + // 6522 CLK runs at same speed as 6502 CLK + g_n6522TimerPeriod = pMB->sy6522.TIMER1_LATCH.w; g_bMBTimerIrqActive = true; + g_nMBTimerDevice = pMB->nAY8910Number; } //----------------------------------------------------------------------------- -static void StopTimer(SY6522_AY8910* pMB) +static void StopTimer1(SY6522_AY8910* pMB) { - pMB->nTimerStatus = 0; + pMB->bTimer1Active = false; g_bMBTimerIrqActive = false; g_nMBTimerDevice = TIMERDEVICE_INVALID; } @@ -256,8 +259,8 @@ static void ResetSY6522(SY6522_AY8910* pMB) { memset(&pMB->sy6522,0,sizeof(SY6522)); - if(pMB->nTimerStatus) - StopTimer(pMB); + if (pMB->bTimer1Active) + StopTimer1(pMB); pMB->nAYCurrentRegister = 0; } @@ -398,7 +401,7 @@ static void SY6522_Write(BYTE nDevice, BYTE nReg, BYTE nValue) pMB->sy6522.TIMER1_LATCH.h = nValue; pMB->sy6522.TIMER1_COUNTER.w = pMB->sy6522.TIMER1_LATCH.w; - StartTimer(pMB); + StartTimer1(pMB); break; case 0x07: // TIMER1H_LATCH // Clear Timer1 Interrupt Flag. @@ -445,11 +448,11 @@ static void SY6522_Write(BYTE nDevice, BYTE nReg, BYTE nValue) if(pMB->sy6522.IER & IxR_TIMER1) break; - if(pMB->nTimerStatus == 0) + if (pMB->bTimer1Active == false) break; // Stop timer - StopTimer(pMB); + StopTimer1(pMB); } else { @@ -457,7 +460,7 @@ static void SY6522_Write(BYTE nDevice, BYTE nReg, BYTE nValue) nValue &= 0x7F; pMB->sy6522.IER |= nValue; UpdateIFR(pMB); - StartTimer(pMB); + StartTimer1(pMB); } break; case 0x0f: // ORA_NO_HS @@ -1656,7 +1659,10 @@ void MB_EndOfVideoFrame() //----------------------------------------------------------------------------- -// Called by CpuExecute() after every N opcodes (N = ~1000 @ 1MHz) +// Called by: +// . CpuExecute() every ~1000 @ 1MHz +// . CheckInterruptSources() every 128 cycles +// . MB_Read() / MB_Write() void MB_UpdateCycles(ULONG uExecutedCycles) { if(g_SoundcardType == CT_Empty) @@ -1682,12 +1688,8 @@ void MB_UpdateCycles(ULONG uExecutedCycles) bool bTimer1Underflow = (!(OldTimer1 & 0x8000) && (pMB->sy6522.TIMER1_COUNTER.w & 0x8000)); bool bTimer2Underflow = (!(OldTimer2 & 0x8000) && (pMB->sy6522.TIMER2_COUNTER.w & 0x8000)); - if( bTimer1Underflow && (g_nMBTimerDevice == i) && g_bMBTimerIrqActive ) + if ( bTimer1Underflow && (g_nMBTimerDevice == i) ) { -#ifdef _DEBUG - g_uTimer1IrqCount++; // DEBUG -#endif - pMB->sy6522.IFR |= IxR_TIMER1; UpdateIFR(pMB); @@ -1696,20 +1698,20 @@ void MB_UpdateCycles(ULONG uExecutedCycles) // One-shot mode // - Phasor's playback code uses one-shot mode // - Willy Byte sets to one-shot to stop the timer IRQ - StopTimer(pMB); + StopTimer1(pMB); } else { // Free-running mode // - Ultima4/5 change ACCESS_TIMER1 after a couple of IRQs into tune pMB->sy6522.TIMER1_COUNTER.w = pMB->sy6522.TIMER1_LATCH.w; - StartTimer(pMB); + StartTimer1(pMB); } MB_Update(); } else if ( bTimer1Underflow - && !g_bMBTimerIrqActive // StopTimer() has been called + && !g_bMBTimerIrqActive // StopTimer1() has been called && (pMB->sy6522.IFR & IxR_TIMER1) // IRQ && ((pMB->sy6522.ACR & RUNMODE) == RM_ONESHOT) ) // One-shot mode { @@ -1826,7 +1828,7 @@ int MB_SetSnapshot_v1(const SS_CARD_MOCKINGBOARD_v1* const pSS, const DWORD /*dw memcpy(&pMB->SpeechChip, &pSS->Unit[i].RegsSSI263, sizeof(SSI263A)); pMB->nAYCurrentRegister = pSS->Unit[i].nAYCurrentRegister; - StartTimer(pMB); // Attempt to start timer + StartTimer1_LoadStateV1(pMB); // Attempt to start timer // @@ -1919,6 +1921,8 @@ const UINT NUM_PHASOR_UNITS = 2; #define SS_YAML_KEY_TIMER1_IRQ "Timer1 IRQ Pending" #define SS_YAML_KEY_TIMER2_IRQ "Timer2 IRQ Pending" #define SS_YAML_KEY_SPEECH_IRQ "Speech IRQ Pending" +#define SS_YAML_KEY_TIMER1_ACTIVE "Timer1 Active" +#define SS_YAML_KEY_TIMER2_ACTIVE "Timer2 Active" #define SS_YAML_KEY_PHASOR_UNIT "Unit" #define SS_YAML_KEY_PHASOR_CLOCK_SCALE_FACTOR "Clock Scale Factor" @@ -1974,7 +1978,8 @@ void MB_SaveSnapshot(YamlSaveHelper& yamlSaveHelper, const UINT uSlot) UINT nDeviceNum = nMbCardNum*2; SY6522_AY8910* pMB = &g_MB[nDeviceNum]; - YamlSaveHelper::Slot slot(yamlSaveHelper, MB_GetSnapshotCardName(), uSlot, 1); // fixme: object should be just 1 Mockingboard card & it will know its slot + const UINT version = 2; + YamlSaveHelper::Slot slot(yamlSaveHelper, MB_GetSnapshotCardName(), uSlot, version); // fixme: object should be just 1 Mockingboard card & it will know its slot YamlSaveHelper::Label state(yamlSaveHelper, "%s:\n", SS_YAML_KEY_STATE); @@ -1990,6 +1995,8 @@ void MB_SaveSnapshot(YamlSaveHelper& yamlSaveHelper, const UINT uSlot) yamlSaveHelper.Save("%s: %s # Not supported\n", SS_YAML_KEY_TIMER1_IRQ, "false"); yamlSaveHelper.Save("%s: %s # Not supported\n", SS_YAML_KEY_TIMER2_IRQ, "false"); yamlSaveHelper.Save("%s: %s # Not supported\n", SS_YAML_KEY_SPEECH_IRQ, "false"); + yamlSaveHelper.SaveBool(SS_YAML_KEY_TIMER1_ACTIVE, pMB->bTimer1Active); + yamlSaveHelper.SaveBool(SS_YAML_KEY_TIMER2_ACTIVE, pMB->bTimer2Active); nDeviceNum++; pMB++; @@ -2039,7 +2046,7 @@ bool MB_LoadSnapshot(YamlLoadHelper& yamlLoadHelper, UINT slot, UINT version) if (slot != 4 && slot != 5) // fixme throw std::string("Card: wrong slot"); - if (version != 1) + if (version < 1 || version > 2) throw std::string("Card: wrong version"); AY8910UpdateSetCycles(); @@ -2067,11 +2074,25 @@ bool MB_LoadSnapshot(YamlLoadHelper& yamlLoadHelper, UINT slot, UINT version) yamlLoadHelper.LoadBool(SS_YAML_KEY_TIMER2_IRQ); // Consume yamlLoadHelper.LoadBool(SS_YAML_KEY_SPEECH_IRQ); // Consume + if (version >= 2) + { + pMB->bTimer1Active = yamlLoadHelper.LoadBool(SS_YAML_KEY_TIMER1_ACTIVE); + pMB->bTimer2Active = yamlLoadHelper.LoadBool(SS_YAML_KEY_TIMER2_ACTIVE); + } + yamlLoadHelper.PopMap(); // - StartTimer(pMB); // Attempt to start timer + if (version == 1) + { + StartTimer1_LoadStateV1(pMB); // Attempt to start timer + } + else // version >= 2 + { + if (pMB->bTimer1Active) + StartTimer1(pMB); // Attempt to start timer + } // Crude - currently only support a single speech chip // FIX THIS: @@ -2110,7 +2131,8 @@ void Phasor_SaveSnapshot(YamlSaveHelper& yamlSaveHelper, const UINT uSlot) UINT nDeviceNum = 0; SY6522_AY8910* pMB = &g_MB[0]; // fixme: Phasor uses MB's slot4(2x6522), slot4(2xSSI263), but slot4+5(4xAY8910) - YamlSaveHelper::Slot slot(yamlSaveHelper, Phasor_GetSnapshotCardName(), uSlot, 1); // fixme: object should be just 1 Mockingboard card & it will know its slot + const UINT version = 2; + YamlSaveHelper::Slot slot(yamlSaveHelper, Phasor_GetSnapshotCardName(), uSlot, version); // fixme: object should be just 1 Mockingboard card & it will know its slot YamlSaveHelper::Label state(yamlSaveHelper, "%s:\n", SS_YAML_KEY_STATE); @@ -2130,6 +2152,8 @@ void Phasor_SaveSnapshot(YamlSaveHelper& yamlSaveHelper, const UINT uSlot) yamlSaveHelper.Save("%s: %s # Not supported\n", SS_YAML_KEY_TIMER1_IRQ, "false"); yamlSaveHelper.Save("%s: %s # Not supported\n", SS_YAML_KEY_TIMER2_IRQ, "false"); yamlSaveHelper.Save("%s: %s # Not supported\n", SS_YAML_KEY_SPEECH_IRQ, "false"); + yamlSaveHelper.SaveBool(SS_YAML_KEY_TIMER1_ACTIVE, pMB->bTimer1Active); + yamlSaveHelper.SaveBool(SS_YAML_KEY_TIMER2_ACTIVE, pMB->bTimer2Active); nDeviceNum += 2; pMB++; @@ -2141,7 +2165,7 @@ bool Phasor_LoadSnapshot(YamlLoadHelper& yamlLoadHelper, UINT slot, UINT version if (slot != 4) // fixme throw std::string("Card: wrong slot"); - if (version != 1) + if (version < 1 || version > 2) throw std::string("Card: wrong version"); g_PhasorClockScaleFactor = yamlLoadHelper.LoadUint(SS_YAML_KEY_PHASOR_CLOCK_SCALE_FACTOR); @@ -2172,11 +2196,25 @@ bool Phasor_LoadSnapshot(YamlLoadHelper& yamlLoadHelper, UINT slot, UINT version yamlLoadHelper.LoadBool(SS_YAML_KEY_TIMER2_IRQ); // Consume yamlLoadHelper.LoadBool(SS_YAML_KEY_SPEECH_IRQ); // Consume + if (version >= 2) + { + pMB->bTimer1Active = yamlLoadHelper.LoadBool(SS_YAML_KEY_TIMER1_ACTIVE); + pMB->bTimer2Active = yamlLoadHelper.LoadBool(SS_YAML_KEY_TIMER2_ACTIVE); + } + yamlLoadHelper.PopMap(); // - StartTimer(pMB); // Attempt to start timer + if (version == 1) + { + StartTimer1_LoadStateV1(pMB); // Attempt to start timer + } + else // version >= 2 + { + if (pMB->bTimer1Active) + StartTimer1(pMB); // Attempt to start timer + } // Crude - currently only support a single speech chip // FIX THIS: diff --git a/source/Mockingboard.h b/source/Mockingboard.h index 901a9e41..0c33bc8b 100644 --- a/source/Mockingboard.h +++ b/source/Mockingboard.h @@ -1,10 +1,5 @@ #pragma once -extern bool g_bMBTimerIrqActive; -#ifdef _DEBUG -extern UINT32 g_uTimer1IrqCount; // DEBUG -#endif - void MB_Initialize(); void MB_Reinitialize(); void MB_Destroy(); From 86f56a9a49d72587ade14eec5d44e4c5f4440333 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sat, 21 Oct 2017 21:02:38 +0100 Subject: [PATCH 39/64] Bump to 1.26.3.2 and update History.txt --- bin/History.txt | 8 ++++++-- resource/Applewin.rc | 8 ++++---- 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/bin/History.txt b/bin/History.txt index ce0af9c5..6d6a53d9 100644 --- a/bin/History.txt +++ b/bin/History.txt @@ -9,8 +9,8 @@ https://github.com/AppleWin/AppleWin/issues/new Tom Charlesworth -1.26.3.1 (Experimental) - 29 Sep 2017 ------------------------------------- +1.26.3.2 (Experimental) - 21 Oct 2017 +------------------------------------- Changes: . [Bug #469] New -no-printscreen-key switch to prevent the PrintScreen key from being registered. . [Bug #488] New -fs-height= switch. @@ -24,7 +24,11 @@ Changes: . [PR #441] Update zlib to latest version 1.2.11 Fixes: +. [Bug #499] Flush current track (if dirty) before 'Send to CiderPress' +. [Bug #496] Support polling of Mockingboard's & Phasor's 6522 IFR.Timer1 +. [Bug #492] UI fixes for full-screen & 2x windowed-mode . [Bug #486] Peripheral card's expansion ROM ($C800-CFFF, eg. SSC) wasn't being correctly restored from a save-state +. [Bug #464] Fix for full-screen: bottom line missing when vertical resolution is 768 . [Bug #460] Debugger: F2 whilst debugger active will immediately stop the drive spinning (allowing disk swap) . [Bug #456] Fix strange speaker clicks when changing configuration - DirectSound wasn't being uninitialised on a restart . [Bug #452] Fix for unmounted HD now gives "NO DEVICE CONNECTED" (before gave "I/O ERROR") diff --git a/resource/Applewin.rc b/resource/Applewin.rc index a06bb3a0..721e4b94 100644 --- a/resource/Applewin.rc +++ b/resource/Applewin.rc @@ -252,8 +252,8 @@ DISK_ICON ICON "DISK.ICO" // VS_VERSION_INFO VERSIONINFO - FILEVERSION 1,26,3,1 - PRODUCTVERSION 1,26,3,1 + FILEVERSION 1,26,3,2 + PRODUCTVERSION 1,26,3,2 FILEFLAGSMASK 0x3fL #ifdef _DEBUG FILEFLAGS 0x1L @@ -271,12 +271,12 @@ BEGIN VALUE "Comments", "https://github.com/AppleWin" VALUE "CompanyName", "AppleWin" VALUE "FileDescription", "Apple //e Emulator for Windows" - VALUE "FileVersion", "1, 26, 3, 1" + VALUE "FileVersion", "1, 26, 3, 2" VALUE "InternalName", "APPLEWIN" VALUE "LegalCopyright", " 1994-2017 Michael O'Brien, Oliver Schmidt, Tom Charlesworth, Michael Pohoreski, Nick Westgate, Linards Ticmanis" VALUE "OriginalFilename", "APPLEWIN.EXE" VALUE "ProductName", "Apple //e Emulator" - VALUE "ProductVersion", "1, 26, 3, 1" + VALUE "ProductVersion", "1, 26, 3, 2" END END BLOCK "VarFileInfo" From 49465d018228406aff51c6c04f1dd86f3e3ae562 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sat, 21 Oct 2017 21:59:21 +0100 Subject: [PATCH 40/64] Fix position of disk status in 2x Windowed-mode --- source/Frame.cpp | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/source/Frame.cpp b/source/Frame.cpp index 74e60576..b41bcebc 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -795,7 +795,7 @@ void FrameDrawDiskStatus( HDC passdc ) HDC dc = (passdc ? passdc : GetDC(g_hFrameWindow)); int x = buttonx; - int y = buttony+BUTTONS*BUTTONCY+1; + int y = buttony+BUTTONS*BUTTONCY+4; SelectObject(dc,smallfont); SetBkMode(dc,OPAQUE); @@ -841,12 +841,12 @@ void FrameDrawDiskStatus( HDC passdc ) SetBkMode(dc,TRANSPARENT); sprintf( text, "T%s", g_sTrackDrive1 ); - TextOut(dc,x+6 ,y+32,text, strlen(text) ); + TextOut(dc,x+6, y+32, text, strlen(text) ); sprintf( text, "S%s", g_sSectorDrive1 ); - TextOut(dc,x+ 6,y+42, text, strlen(text) ); + TextOut(dc,x+6, y+42, text, strlen(text) ); sprintf( text, "T%s", g_sTrackDrive2 ); - TextOut(dc,x+26,y+32,text, strlen(text) ); + TextOut(dc,x+26,y+32, text, strlen(text) ); sprintf( text, "S%s", g_sSectorDrive2 ); TextOut(dc,x+26,y+42, text, strlen(text) ); } From 66321febbaea46625defb974fd2aa3689484bde6 Mon Sep 17 00:00:00 2001 From: TomCh Date: Tue, 24 Oct 2017 22:28:22 +0100 Subject: [PATCH 41/64] Support Mockingboard/Phasor when polling IFR.Timer1 (#496) * Support precise AY8910 sound-buffer filling when polling 6522 IFR.Timer1 (ACR=Free Running mode) - same as if using 6522 IER.Timer1 interrupt * Support 6522's Timer2 and some code refactoring * Bump version: 1.26.3.4 --- resource/Applewin.rc | 8 +-- source/Mockingboard.cpp | 150 +++++++++++++++++++++++++++------------- source/Mockingboard.h | 1 - 3 files changed, 106 insertions(+), 53 deletions(-) diff --git a/resource/Applewin.rc b/resource/Applewin.rc index 721e4b94..bb9da64c 100644 --- a/resource/Applewin.rc +++ b/resource/Applewin.rc @@ -252,8 +252,8 @@ DISK_ICON ICON "DISK.ICO" // VS_VERSION_INFO VERSIONINFO - FILEVERSION 1,26,3,2 - PRODUCTVERSION 1,26,3,2 + FILEVERSION 1,26,3,4 + PRODUCTVERSION 1,26,3,4 FILEFLAGSMASK 0x3fL #ifdef _DEBUG FILEFLAGS 0x1L @@ -271,12 +271,12 @@ BEGIN VALUE "Comments", "https://github.com/AppleWin" VALUE "CompanyName", "AppleWin" VALUE "FileDescription", "Apple //e Emulator for Windows" - VALUE "FileVersion", "1, 26, 3, 2" + VALUE "FileVersion", "1, 26, 3, 4" VALUE "InternalName", "APPLEWIN" VALUE "LegalCopyright", " 1994-2017 Michael O'Brien, Oliver Schmidt, Tom Charlesworth, Michael Pohoreski, Nick Westgate, Linards Ticmanis" VALUE "OriginalFilename", "APPLEWIN.EXE" VALUE "ProductName", "Apple //e Emulator" - VALUE "ProductVersion", "1, 26, 3, 2" + VALUE "ProductVersion", "1, 26, 3, 4" END END BLOCK "VarFileInfo" diff --git a/source/Mockingboard.cpp b/source/Mockingboard.cpp index 928b593d..92fd4502 100644 --- a/source/Mockingboard.cpp +++ b/source/Mockingboard.cpp @@ -153,8 +153,8 @@ static SY6522_AY8910 g_MB[NUM_AY8910]; // Timer vars static ULONG g_n6522TimerPeriod = 0; -static const UINT TIMERDEVICE_INVALID = -1; -static UINT g_nMBTimerDevice = TIMERDEVICE_INVALID; // SY6522 device# which is generating timer IRQ +static const UINT kTIMERDEVICE_INVALID = -1; +static UINT g_nMBTimerDevice = kTIMERDEVICE_INVALID; // SY6522 device# which is generating timer IRQ static UINT64 g_uLastCumulativeCycles = 0; // SSI263 vars: @@ -204,13 +204,12 @@ static DWORD g_dwMaxPhonemeLen = 0; // When 6522 IRQ is *not* active use 60Hz update freq for MB voices static const double g_f6522TimerPeriod_NoIRQ = CLK_6502 / 60.0; // Constant whatever the CLK is set to -static bool g_bMBTimerIrqActive = false; - //--------------------------------------------------------------------------- // Forward refs: static DWORD WINAPI SSI263Thread(LPVOID); static void Votrax_Write(BYTE nDevice, BYTE nValue); +static double MB_GetFramePeriod(void); //--------------------------------------------------------------------------- @@ -221,10 +220,10 @@ static void StartTimer1(SY6522_AY8910* pMB) // 6522 CLK runs at same speed as 6502 CLK g_n6522TimerPeriod = pMB->sy6522.TIMER1_LATCH.w; - if (pMB->sy6522.IER & IxR_TIMER1) - g_bMBTimerIrqActive = true; - - g_nMBTimerDevice = pMB->nAY8910Number; + if (pMB->sy6522.IER & IxR_TIMER1) // Using 6522 interrupt + g_nMBTimerDevice = pMB->nAY8910Number; + else if (pMB->sy6522.ACR & RM_FREERUNNING) // Polling 6522 IFR + g_nMBTimerDevice = pMB->nAY8910Number; } // The assumption was that timer1 was only active if IER.TIMER1=1 @@ -239,18 +238,28 @@ static void StartTimer1_LoadStateV1(SY6522_AY8910* pMB) // 6522 CLK runs at same speed as 6502 CLK g_n6522TimerPeriod = pMB->sy6522.TIMER1_LATCH.w; - g_bMBTimerIrqActive = true; - g_nMBTimerDevice = pMB->nAY8910Number; } -//----------------------------------------------------------------------------- - static void StopTimer1(SY6522_AY8910* pMB) { pMB->bTimer1Active = false; - g_bMBTimerIrqActive = false; - g_nMBTimerDevice = TIMERDEVICE_INVALID; + g_nMBTimerDevice = kTIMERDEVICE_INVALID; +} + +//----------------------------------------------------------------------------- + +static void StartTimer2(SY6522_AY8910* pMB) +{ + pMB->bTimer2Active = true; + + // NB. Can't mimic StartTimer1() as that would stomp on global state + // TODO: Switch to per-device state +} + +static void StopTimer2(SY6522_AY8910* pMB) +{ + pMB->bTimer2Active = false; } //----------------------------------------------------------------------------- @@ -259,8 +268,8 @@ static void ResetSY6522(SY6522_AY8910* pMB) { memset(&pMB->sy6522,0,sizeof(SY6522)); - if (pMB->bTimer1Active) - StopTimer1(pMB); + StopTimer1(pMB); + StopTimer2(pMB); pMB->nAYCurrentRegister = 0; } @@ -272,7 +281,7 @@ static void AY8910_Write(BYTE nDevice, BYTE nReg, BYTE nValue, BYTE nAYDevice) g_bMB_RegAccessedFlag = true; SY6522_AY8910* pMB = &g_MB[nDevice]; - if((nValue & 4) == 0) + if ((nValue & 4) == 0) { // RESET: Reset AY8910 only AY8910_reset(nDevice+2*nAYDevice); @@ -287,7 +296,7 @@ static void AY8910_Write(BYTE nDevice, BYTE nReg, BYTE nValue, BYTE nAYDevice) int nAYFunc = (nBDIR<<2) | (nBC2<<1) | nBC1; enum {AY_NOP0, AY_NOP1, AY_INACTIVE, AY_READ, AY_NOP4, AY_NOP5, AY_WRITE, AY_LATCH}; - switch(nAYFunc) + switch (nAYFunc) { case AY_INACTIVE: // 4: INACTIVE break; @@ -312,17 +321,20 @@ static void AY8910_Write(BYTE nDevice, BYTE nReg, BYTE nValue, BYTE nAYDevice) } } +// TODO: Fix data-race: main thread & SSI263Thread accessing IFR +// . extend this func to take an or_mask & and_mask +// . then do the mods inside a critical section static void UpdateIFR(SY6522_AY8910* pMB) { pMB->sy6522.IFR &= 0x7F; - if(pMB->sy6522.IFR & pMB->sy6522.IER & 0x7F) + if (pMB->sy6522.IFR & pMB->sy6522.IER & 0x7F) pMB->sy6522.IFR |= 0x80; // Now update the IRQ signal from all 6522s // . OR-sum of all active TIMER1, TIMER2 & SPEECH sources (from all 6522s) UINT bIRQ = 0; - for(UINT i=0; isy6522.TIMER2_LATCH.h = nValue; pMB->sy6522.TIMER2_COUNTER.w = pMB->sy6522.TIMER2_LATCH.w; + + StartTimer2(pMB); break; case 0x0a: // SERIAL_SHIFT break; @@ -444,15 +458,12 @@ static void SY6522_Write(BYTE nDevice, BYTE nReg, BYTE nValue) pMB->sy6522.IER &= nValue; UpdateIFR(pMB); - // Check if timer has been disabled. - if(pMB->sy6522.IER & IxR_TIMER1) - break; + // Check if active timer has been disabled: + if (((pMB->sy6522.IER & IxR_TIMER1) == 0) && pMB->bTimer1Active) + StopTimer1(pMB); - if (pMB->bTimer1Active == false) - break; - - // Stop timer - StopTimer1(pMB); + if (((pMB->sy6522.IER & IxR_TIMER2) == 0) && pMB->bTimer2Active) + StopTimer2(pMB); } else { @@ -460,7 +471,13 @@ static void SY6522_Write(BYTE nDevice, BYTE nReg, BYTE nValue) nValue &= 0x7F; pMB->sy6522.IER |= nValue; UpdateIFR(pMB); - StartTimer1(pMB); + + // Check if active timer changed from non-interrupt (polling IFR) to interrupt: + if ((pMB->sy6522.IER & IxR_TIMER1) && pMB->bTimer1Active) + StartTimer1(pMB); + + if ((pMB->sy6522.IER & IxR_TIMER2) && pMB->bTimer2Active) + StartTimer2(pMB); } break; case 0x0f: // ORA_NO_HS @@ -742,6 +759,9 @@ static void Votrax_Write(BYTE nDevice, BYTE nValue) //=========================================================================== +// Called by: +// . MB_UpdateCycles() - when g_nMBTimerDevice == {0,1,2,3} +// . MB_EndOfVideoFrame() - when g_nMBTimerDevice == kTIMERDEVICE_INVALID static void MB_Update() { //char szDbg[200]; @@ -1408,7 +1428,7 @@ void MB_Destroy() static void ResetState() { g_n6522TimerPeriod = 0; - g_nMBTimerDevice = TIMERDEVICE_INVALID; + g_nMBTimerDevice = kTIMERDEVICE_INVALID; g_uLastCumulativeCycles = 0; g_nSSI263Device = 0; @@ -1650,10 +1670,10 @@ void MB_StartOfCpuExecute() // Called by ContinueExecution() at the end of every video frame void MB_EndOfVideoFrame() { - if(g_SoundcardType == CT_Empty) + if (g_SoundcardType == CT_Empty) return; - if(!g_bMBTimerIrqActive) + if (g_nMBTimerDevice == kTIMERDEVICE_INVALID) MB_Update(); } @@ -1688,11 +1708,28 @@ void MB_UpdateCycles(ULONG uExecutedCycles) bool bTimer1Underflow = (!(OldTimer1 & 0x8000) && (pMB->sy6522.TIMER1_COUNTER.w & 0x8000)); bool bTimer2Underflow = (!(OldTimer2 & 0x8000) && (pMB->sy6522.TIMER2_COUNTER.w & 0x8000)); - if ( bTimer1Underflow && (g_nMBTimerDevice == i) ) + if (!pMB->bTimer1Active && bTimer1Underflow) + { + if ( (g_nMBTimerDevice == kTIMERDEVICE_INVALID) // StopTimer1() has been called + && (pMB->sy6522.IFR & IxR_TIMER1) // Counter underflowed + && ((pMB->sy6522.ACR & RUNMODE) == RM_ONESHOT) ) // One-shot mode + { + // Fix for Willy Byte - need to confirm that 6522 really does this! + // . It never accesses IER/IFR/TIMER1 regs to clear IRQ + pMB->sy6522.IFR &= ~IxR_TIMER1; // Deassert the TIMER IRQ + UpdateIFR(pMB); + } + } + + if (pMB->bTimer1Active && bTimer1Underflow) { pMB->sy6522.IFR |= IxR_TIMER1; UpdateIFR(pMB); + // Do MB_Update() before StopTimer1() + if (g_nMBTimerDevice == i) + MB_Update(); + if((pMB->sy6522.ACR & RUNMODE) == RM_ONESHOT) { // One-shot mode @@ -1707,18 +1744,21 @@ void MB_UpdateCycles(ULONG uExecutedCycles) pMB->sy6522.TIMER1_COUNTER.w = pMB->sy6522.TIMER1_LATCH.w; StartTimer1(pMB); } - - MB_Update(); } - else if ( bTimer1Underflow - && !g_bMBTimerIrqActive // StopTimer1() has been called - && (pMB->sy6522.IFR & IxR_TIMER1) // IRQ - && ((pMB->sy6522.ACR & RUNMODE) == RM_ONESHOT) ) // One-shot mode + else if (pMB->bTimer2Active && bTimer2Underflow) { - // Fix for Willy Byte - need to confirm that 6522 really does this! - // . It never accesses IER/IFR/TIMER1 regs to clear IRQ - pMB->sy6522.IFR &= ~IxR_TIMER1; // Deassert the TIMER IRQ + pMB->sy6522.IFR |= IxR_TIMER2; UpdateIFR(pMB); + + if((pMB->sy6522.ACR & RUNMODE) == RM_ONESHOT) + { + StopTimer2(pMB); + } + else + { + pMB->sy6522.TIMER2_COUNTER.w = pMB->sy6522.TIMER2_LATCH.w; + StartTimer2(pMB); + } } } } @@ -1732,7 +1772,6 @@ SS_CARDTYPE MB_GetSoundcardType() void MB_SetSoundcardType(SS_CARDTYPE NewSoundcardType) { -// if ((NewSoundcardType == SC_UNINIT) || (g_SoundcardType == NewSoundcardType)) if (g_SoundcardType == NewSoundcardType) return; @@ -1746,18 +1785,33 @@ void MB_SetSoundcardType(SS_CARDTYPE NewSoundcardType) //----------------------------------------------------------------------------- -double MB_GetFramePeriod() +static double MB_GetFramePeriod(void) { - return (g_bMBTimerIrqActive||(g_MB[0].sy6522.IFR & IxR_TIMER1)) ? (double)g_n6522TimerPeriod : g_f6522TimerPeriod_NoIRQ; + // TODO: Ideally remove this (slot-4) Phasor-IFR check: [*1] + // . It's for Phasor music player, which runs in one-shot mode: + // . MB_UpdateCycles() + // -> Timer1 underflows & StopTimer1() is called, which sets g_nMBTimerDevice == kTIMERDEVICE_INVALID + // . MB_EndOfVideoFrame(), and g_nMBTimerDevice == kTIMERDEVICE_INVALID + // -> MB_Update() + // -> MB_GetFramePeriod() + // NB. Removing this Phasor-IFR check means the occasional 'g_f6522TimerPeriod_NoIRQ' gets returned. + + if ((g_nMBTimerDevice != kTIMERDEVICE_INVALID) || + (g_bPhasorEnable && (g_MB[0].sy6522.IFR & IxR_TIMER1))) // [*1] + { + return (double)g_n6522TimerPeriod; + } + else + { + return g_f6522TimerPeriod_NoIRQ; + } } bool MB_IsActive() { - if(!MockingboardVoice.bActive) + if (!MockingboardVoice.bActive) return false; - // Ignore /g_bMBTimerIrqActive/ as timer's irq handler will access 6522 regs affecting /g_bMB_Active/ - return g_bMB_Active; } diff --git a/source/Mockingboard.h b/source/Mockingboard.h index 0c33bc8b..96e1bcf5 100644 --- a/source/Mockingboard.h +++ b/source/Mockingboard.h @@ -13,7 +13,6 @@ void MB_CheckIRQ(); void MB_UpdateCycles(ULONG uExecutedCycles); SS_CARDTYPE MB_GetSoundcardType(); void MB_SetSoundcardType(SS_CARDTYPE NewSoundcardType); -double MB_GetFramePeriod(); bool MB_IsActive(); DWORD MB_GetVolume(); void MB_SetVolume(DWORD dwVolume, DWORD dwVolumeMax); From 74ac2a4f2265e4d75f5a7abd5d6139c87448bd08 Mon Sep 17 00:00:00 2001 From: tomcw Date: Fri, 27 Oct 2017 11:10:15 +0100 Subject: [PATCH 42/64] Mockingboard/Phasor unit functions only work from an inactive state (#320) - Extended save-state (MB/Phasor v3) to support 'Unit state' --- source/Mockingboard.cpp | 73 +++++++++++++++++++++++++++-------------- 1 file changed, 48 insertions(+), 25 deletions(-) diff --git a/source/Mockingboard.cpp b/source/Mockingboard.cpp index 92fd4502..3db4cfb6 100644 --- a/source/Mockingboard.cpp +++ b/source/Mockingboard.cpp @@ -117,6 +117,8 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA #define Phasor_SY6522A_Offset (1<nAYCurrentRegister = 0; + pMB->state = AY_INACTIVE; } //----------------------------------------------------------------------------- @@ -293,31 +297,35 @@ static void AY8910_Write(BYTE nDevice, BYTE nReg, BYTE nValue, BYTE nAYDevice) const int nBC2 = 1; // Hardwired to +5V int nBC1 = nValue & 1; - int nAYFunc = (nBDIR<<2) | (nBC2<<1) | nBC1; - enum {AY_NOP0, AY_NOP1, AY_INACTIVE, AY_READ, AY_NOP4, AY_NOP5, AY_WRITE, AY_LATCH}; + MockingboardUnitState_e nAYFunc = (MockingboardUnitState_e) ((nBDIR<<2) | (nBC2<<1) | nBC1); - switch (nAYFunc) + if (pMB->state == AY_INACTIVE) // GH#320: functions only work from inactive state { - case AY_INACTIVE: // 4: INACTIVE - break; + switch (nAYFunc) + { + case AY_INACTIVE: // 4: INACTIVE + break; - case AY_READ: // 5: READ FROM PSG (need to set DDRA to input) - break; + case AY_READ: // 5: READ FROM PSG (need to set DDRA to input) + break; - case AY_WRITE: // 6: WRITE TO PSG - _AYWriteReg(nDevice+2*nAYDevice, pMB->nAYCurrentRegister, pMB->sy6522.ORA); - break; + case AY_WRITE: // 6: WRITE TO PSG + _AYWriteReg(nDevice+2*nAYDevice, pMB->nAYCurrentRegister, pMB->sy6522.ORA); + break; - case AY_LATCH: // 7: LATCH ADDRESS - // http://www.worldofspectrum.org/forums/showthread.php?t=23327 - // Selecting an unused register number above 0x0f puts the AY into a state where - // any values written to the data/address bus are ignored, but can be read back - // within a few tens of thousands of cycles before they decay to zero. - if(pMB->sy6522.ORA <= 0x0F) - pMB->nAYCurrentRegister = pMB->sy6522.ORA & 0x0F; - // else Pro-Mockingboard (clone from HK) - break; + case AY_LATCH: // 7: LATCH ADDRESS + // http://www.worldofspectrum.org/forums/showthread.php?t=23327 + // Selecting an unused register number above 0x0f puts the AY into a state where + // any values written to the data/address bus are ignored, but can be read back + // within a few tens of thousands of cycles before they decay to zero. + if(pMB->sy6522.ORA <= 0x0F) + pMB->nAYCurrentRegister = pMB->sy6522.ORA & 0x0F; + // else Pro-Mockingboard (clone from HK) + break; + } } + + pMB->state = nAYFunc; } } @@ -1881,6 +1889,7 @@ int MB_SetSnapshot_v1(const SS_CARD_MOCKINGBOARD_v1* const pSS, const DWORD /*dw memcpy(AY8910_GetRegsPtr(nDeviceNum), &pSS->Unit[i].RegsAY8910, 16); memcpy(&pMB->SpeechChip, &pSS->Unit[i].RegsSSI263, sizeof(SSI263A)); pMB->nAYCurrentRegister = pSS->Unit[i].nAYCurrentRegister; + pMB->state = AY_INACTIVE; StartTimer1_LoadStateV1(pMB); // Attempt to start timer @@ -1946,6 +1955,11 @@ static UINT DoReadFile(const HANDLE hFile, void* const pData, const UINT Length) //=========================================================================== +// Unit version history: +// 2: Added: Timer1 & Timer2 active +// 3: Added: Unit state +const UINT kUNIT_VERSION = 3; + const UINT NUM_MB_UNITS = 2; const UINT NUM_PHASOR_UNITS = 2; @@ -1972,6 +1986,7 @@ const UINT NUM_PHASOR_UNITS = 2; #define SS_YAML_KEY_SSI263_REG_FILTER_FREQ "Filter Frequency" #define SS_YAML_KEY_SSI263_REG_CURRENT_MODE "Current Mode" #define SS_YAML_KEY_AY_CURR_REG "AY Current Register" +#define SS_YAML_KEY_MB_UNIT_STATE "Unit State" #define SS_YAML_KEY_TIMER1_IRQ "Timer1 IRQ Pending" #define SS_YAML_KEY_TIMER2_IRQ "Timer2 IRQ Pending" #define SS_YAML_KEY_SPEECH_IRQ "Speech IRQ Pending" @@ -2032,8 +2047,7 @@ void MB_SaveSnapshot(YamlSaveHelper& yamlSaveHelper, const UINT uSlot) UINT nDeviceNum = nMbCardNum*2; SY6522_AY8910* pMB = &g_MB[nDeviceNum]; - const UINT version = 2; - YamlSaveHelper::Slot slot(yamlSaveHelper, MB_GetSnapshotCardName(), uSlot, version); // fixme: object should be just 1 Mockingboard card & it will know its slot + YamlSaveHelper::Slot slot(yamlSaveHelper, MB_GetSnapshotCardName(), uSlot, kUNIT_VERSION); // fixme: object should be just 1 Mockingboard card & it will know its slot YamlSaveHelper::Label state(yamlSaveHelper, "%s:\n", SS_YAML_KEY_STATE); @@ -2045,6 +2059,7 @@ void MB_SaveSnapshot(YamlSaveHelper& yamlSaveHelper, const UINT uSlot) AY8910_SaveSnapshot(yamlSaveHelper, nDeviceNum, std::string("")); SaveSnapshotSSI263(yamlSaveHelper, pMB->SpeechChip); + yamlSaveHelper.SaveHexUint4(SS_YAML_KEY_MB_UNIT_STATE, pMB->state); yamlSaveHelper.SaveHexUint4(SS_YAML_KEY_AY_CURR_REG, pMB->nAYCurrentRegister); yamlSaveHelper.Save("%s: %s # Not supported\n", SS_YAML_KEY_TIMER1_IRQ, "false"); yamlSaveHelper.Save("%s: %s # Not supported\n", SS_YAML_KEY_TIMER2_IRQ, "false"); @@ -2100,7 +2115,7 @@ bool MB_LoadSnapshot(YamlLoadHelper& yamlLoadHelper, UINT slot, UINT version) if (slot != 4 && slot != 5) // fixme throw std::string("Card: wrong slot"); - if (version < 1 || version > 2) + if (version < 1 || version > kUNIT_VERSION) throw std::string("Card: wrong version"); AY8910UpdateSetCycles(); @@ -2134,6 +2149,10 @@ bool MB_LoadSnapshot(YamlLoadHelper& yamlLoadHelper, UINT slot, UINT version) pMB->bTimer2Active = yamlLoadHelper.LoadBool(SS_YAML_KEY_TIMER2_ACTIVE); } + pMB->state = AY_INACTIVE; + if (version >= 3) + pMB->state = (MockingboardUnitState_e) (yamlLoadHelper.LoadUint(SS_YAML_KEY_MB_UNIT_STATE) & 7); + yamlLoadHelper.PopMap(); // @@ -2185,8 +2204,7 @@ void Phasor_SaveSnapshot(YamlSaveHelper& yamlSaveHelper, const UINT uSlot) UINT nDeviceNum = 0; SY6522_AY8910* pMB = &g_MB[0]; // fixme: Phasor uses MB's slot4(2x6522), slot4(2xSSI263), but slot4+5(4xAY8910) - const UINT version = 2; - YamlSaveHelper::Slot slot(yamlSaveHelper, Phasor_GetSnapshotCardName(), uSlot, version); // fixme: object should be just 1 Mockingboard card & it will know its slot + YamlSaveHelper::Slot slot(yamlSaveHelper, Phasor_GetSnapshotCardName(), uSlot, kUNIT_VERSION); // fixme: object should be just 1 Mockingboard card & it will know its slot YamlSaveHelper::Label state(yamlSaveHelper, "%s:\n", SS_YAML_KEY_STATE); @@ -2202,6 +2220,7 @@ void Phasor_SaveSnapshot(YamlSaveHelper& yamlSaveHelper, const UINT uSlot) AY8910_SaveSnapshot(yamlSaveHelper, nDeviceNum+1, std::string("-B")); SaveSnapshotSSI263(yamlSaveHelper, pMB->SpeechChip); + yamlSaveHelper.SaveHexUint4(SS_YAML_KEY_MB_UNIT_STATE, pMB->state); yamlSaveHelper.SaveHexUint4(SS_YAML_KEY_AY_CURR_REG, pMB->nAYCurrentRegister); yamlSaveHelper.Save("%s: %s # Not supported\n", SS_YAML_KEY_TIMER1_IRQ, "false"); yamlSaveHelper.Save("%s: %s # Not supported\n", SS_YAML_KEY_TIMER2_IRQ, "false"); @@ -2219,7 +2238,7 @@ bool Phasor_LoadSnapshot(YamlLoadHelper& yamlLoadHelper, UINT slot, UINT version if (slot != 4) // fixme throw std::string("Card: wrong slot"); - if (version < 1 || version > 2) + if (version < 1 || version > kUNIT_VERSION) throw std::string("Card: wrong version"); g_PhasorClockScaleFactor = yamlLoadHelper.LoadUint(SS_YAML_KEY_PHASOR_CLOCK_SCALE_FACTOR); @@ -2256,6 +2275,10 @@ bool Phasor_LoadSnapshot(YamlLoadHelper& yamlLoadHelper, UINT slot, UINT version pMB->bTimer2Active = yamlLoadHelper.LoadBool(SS_YAML_KEY_TIMER2_ACTIVE); } + pMB->state = AY_INACTIVE; + if (version >= 3) + pMB->state = (MockingboardUnitState_e) (yamlLoadHelper.LoadUint(SS_YAML_KEY_MB_UNIT_STATE) & 7); + yamlLoadHelper.PopMap(); // From e2b515de3300683617bc98ee1c1fe99329735854 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sat, 28 Oct 2017 18:39:45 +0100 Subject: [PATCH 43/64] MB/Phasor: Wrap 6522.IFR changes inside a critical section to avoid a potential 2 thread data-race --- source/Mockingboard.cpp | 128 ++++++++++++++-------------------------- 1 file changed, 45 insertions(+), 83 deletions(-) diff --git a/source/Mockingboard.cpp b/source/Mockingboard.cpp index 3db4cfb6..13217884 100644 --- a/source/Mockingboard.cpp +++ b/source/Mockingboard.cpp @@ -207,6 +207,9 @@ static DWORD g_dwMaxPhonemeLen = 0; // When 6522 IRQ is *not* active use 60Hz update freq for MB voices static const double g_f6522TimerPeriod_NoIRQ = CLK_6502 / 60.0; // Constant whatever the CLK is set to +static bool g_bCritSectionValid = false; // Deleting CritialSection when not valid causes crash on Win98 +static CRITICAL_SECTION g_CriticalSection; // To guard 6522's IFR + //--------------------------------------------------------------------------- // Forward refs: @@ -329,15 +332,22 @@ static void AY8910_Write(BYTE nDevice, BYTE nReg, BYTE nValue, BYTE nAYDevice) } } -// TODO: Fix data-race: main thread & SSI263Thread accessing IFR -// . extend this func to take an or_mask & and_mask -// . then do the mods inside a critical section -static void UpdateIFR(SY6522_AY8910* pMB) +static void UpdateIFR(SY6522_AY8910* pMB, BYTE clr_ifr, BYTE set_ifr=0) { - pMB->sy6522.IFR &= 0x7F; + // Need critical section to avoid data-race: main thread & SSI263Thread can both access IFR + // . NB. Loading a save-state just directly writes into 6522.IFR (which is fine) + _ASSERT(g_bCritSectionValid); + if (g_bCritSectionValid) EnterCriticalSection(&g_CriticalSection); + { + pMB->sy6522.IFR &= ~clr_ifr; + pMB->sy6522.IFR |= set_ifr; - if (pMB->sy6522.IFR & pMB->sy6522.IER & 0x7F) - pMB->sy6522.IFR |= 0x80; + if (pMB->sy6522.IFR & pMB->sy6522.IER & 0x7F) + pMB->sy6522.IFR |= 0x80; + else + pMB->sy6522.IFR &= 0x7F; + } + if (g_bCritSectionValid) LeaveCriticalSection(&g_CriticalSection); // Now update the IRQ signal from all 6522s // . OR-sum of all active TIMER1, TIMER2 & SPEECH sources (from all 6522s) @@ -352,13 +362,9 @@ static void UpdateIFR(SY6522_AY8910* pMB) // . I assume Phasor's 6522s just generate 6502 IRQs (not NMIs) if (bIRQ) - { CpuIrqAssert(IS_6522); - } else - { CpuIrqDeassert(IS_6522); - } } static void SY6522_Write(BYTE nDevice, BYTE nReg, BYTE nValue) @@ -415,8 +421,7 @@ static void SY6522_Write(BYTE nDevice, BYTE nReg, BYTE nValue) /* Initiates timer1 & clears time-out of timer1 */ // Clear Timer Interrupt Flag. - pMB->sy6522.IFR &= ~IxR_TIMER1; - UpdateIFR(pMB); + UpdateIFR(pMB, IxR_TIMER1); pMB->sy6522.TIMER1_LATCH.h = nValue; pMB->sy6522.TIMER1_COUNTER.w = pMB->sy6522.TIMER1_LATCH.w; @@ -425,17 +430,15 @@ static void SY6522_Write(BYTE nDevice, BYTE nReg, BYTE nValue) break; case 0x07: // TIMER1H_LATCH // Clear Timer1 Interrupt Flag. + UpdateIFR(pMB, IxR_TIMER1); pMB->sy6522.TIMER1_LATCH.h = nValue; - pMB->sy6522.IFR &= ~IxR_TIMER1; - UpdateIFR(pMB); break; case 0x08: // TIMER2L pMB->sy6522.TIMER2_LATCH.l = nValue; break; case 0x09: // TIMER2H // Clear Timer2 Interrupt Flag. - pMB->sy6522.IFR &= ~IxR_TIMER2; - UpdateIFR(pMB); + UpdateIFR(pMB, IxR_TIMER2); pMB->sy6522.TIMER2_LATCH.h = nValue; pMB->sy6522.TIMER2_COUNTER.w = pMB->sy6522.TIMER2_LATCH.w; @@ -453,10 +456,7 @@ static void SY6522_Write(BYTE nDevice, BYTE nReg, BYTE nValue) case 0x0d: // IFR // - Clear those bits which are set in the lower 7 bits. // - Can't clear bit 7 directly. - nValue |= 0x80; // Set high bit - nValue ^= 0x7F; // Make mask - pMB->sy6522.IFR &= nValue; - UpdateIFR(pMB); + UpdateIFR(pMB, nValue); break; case 0x0e: // IER if(!(nValue & 0x80)) @@ -464,7 +464,7 @@ static void SY6522_Write(BYTE nDevice, BYTE nReg, BYTE nValue) // Clear those bits which are set in the lower 7 bits. nValue ^= 0x7F; pMB->sy6522.IER &= nValue; - UpdateIFR(pMB); + UpdateIFR(pMB, 0); // Check if active timer has been disabled: if (((pMB->sy6522.IER & IxR_TIMER1) == 0) && pMB->bTimer1Active) @@ -478,7 +478,7 @@ static void SY6522_Write(BYTE nDevice, BYTE nReg, BYTE nValue) // Set those bits which are set in the lower 7 bits. nValue &= 0x7F; pMB->sy6522.IER |= nValue; - UpdateIFR(pMB); + UpdateIFR(pMB, 0); // Check if active timer changed from non-interrupt (polling IFR) to interrupt: if ((pMB->sy6522.IER & IxR_TIMER1) && pMB->bTimer1Active) @@ -519,8 +519,7 @@ static BYTE SY6522_Read(BYTE nDevice, BYTE nReg) break; case 0x04: // TIMER1L_COUNTER nValue = pMB->sy6522.TIMER1_COUNTER.l; - pMB->sy6522.IFR &= ~IxR_TIMER1; // Also clears Timer1 Interrupt Flag - UpdateIFR(pMB); + UpdateIFR(pMB, IxR_TIMER1); break; case 0x05: // TIMER1H_COUNTER nValue = pMB->sy6522.TIMER1_COUNTER.h; @@ -533,8 +532,7 @@ static BYTE SY6522_Read(BYTE nDevice, BYTE nReg) break; case 0x08: // TIMER2L nValue = pMB->sy6522.TIMER2_COUNTER.l; - pMB->sy6522.IFR &= ~IxR_TIMER2; // Also clears Timer2 Interrupt Flag - UpdateIFR(pMB); + UpdateIFR(pMB, IxR_TIMER2); break; case 0x09: // TIMER2H nValue = pMB->sy6522.TIMER2_COUNTER.h; @@ -627,8 +625,7 @@ static void SSI263_Write(BYTE nDevice, BYTE nReg, BYTE nValue) } else { - pMB->sy6522.IFR &= ~IxR_PERIPHERAL; - UpdateIFR(pMB); + UpdateIFR(pMB, IxR_PERIPHERAL); } pMB->SpeechChip.CurrentMode &= ~1; // Clear SSI263's D7 pin @@ -757,8 +754,7 @@ static void Votrax_Write(BYTE nDevice, BYTE nValue) // !A/R: Acknowledge receipt of phoneme data (signal goes from high to low) SY6522_AY8910* pMB = &g_MB[nDevice]; - pMB->sy6522.IFR &= ~IxR_VOTRAX; - UpdateIFR(pMB); + UpdateIFR(pMB, IxR_VOTRAX); g_nSSI263Device = nDevice; @@ -1008,8 +1004,7 @@ static DWORD WINAPI SSI263Thread(LPVOID lpParameter) { if((pMB->SpeechChip.CurrentMode != MODE_IRQ_DISABLED) && (pMB->sy6522.PCR == 0x0C)) { - pMB->sy6522.IFR |= IxR_PERIPHERAL; - UpdateIFR(pMB); + UpdateIFR(pMB, 0, IxR_PERIPHERAL); pMB->SpeechChip.CurrentMode |= 1; // Set SSI263's D7 pin } } @@ -1020,8 +1015,7 @@ static DWORD WINAPI SSI263Thread(LPVOID lpParameter) { // !A/R: Time-out of old phoneme (signal goes from low to high) - pMB->sy6522.IFR |= IxR_VOTRAX; - UpdateIFR(pMB); + UpdateIFR(pMB, 0, IxR_VOTRAX); g_bVotraxPhoneme = false; } @@ -1410,6 +1404,9 @@ void MB_Initialize() MB_Reset(); LogFileOutput("MB_Initialize: MB_Reset()\n"); } + + InitializeCriticalSection(&g_CriticalSection); + g_bCritSectionValid = true; } //----------------------------------------------------------------------------- @@ -1427,8 +1424,14 @@ void MB_Destroy() { MB_DSUninit(); - for(int i=0; isy6522.IFR &= ~IxR_TIMER1; // Deassert the TIMER IRQ - UpdateIFR(pMB); + UpdateIFR(pMB, IxR_TIMER1); // Deassert the TIMER IRQ } } if (pMB->bTimer1Active && bTimer1Underflow) { - pMB->sy6522.IFR |= IxR_TIMER1; - UpdateIFR(pMB); + UpdateIFR(pMB, 0, IxR_TIMER1); // Do MB_Update() before StopTimer1() if (g_nMBTimerDevice == i) @@ -1755,8 +1756,7 @@ void MB_UpdateCycles(ULONG uExecutedCycles) } else if (pMB->bTimer2Active && bTimer2Underflow) { - pMB->sy6522.IFR |= IxR_TIMER2; - UpdateIFR(pMB); + UpdateIFR(pMB, 0, IxR_TIMER2); if((pMB->sy6522.ACR & RUNMODE) == RM_ONESHOT) { @@ -1905,8 +1905,7 @@ int MB_SetSnapshot_v1(const SS_CARD_MOCKINGBOARD_v1* const pSS, const DWORD /*dw if((pMB->SpeechChip.CurrentMode != MODE_IRQ_DISABLED) && (pMB->sy6522.PCR == 0x0C) && (pMB->sy6522.IER & IxR_PERIPHERAL)) { - pMB->sy6522.IFR |= IxR_PERIPHERAL; - UpdateIFR(pMB); + UpdateIFR(pMB, 0, IxR_PERIPHERAL); pMB->SpeechChip.CurrentMode |= 1; // Set SSI263's D7 pin } } @@ -1920,41 +1919,6 @@ int MB_SetSnapshot_v1(const SS_CARD_MOCKINGBOARD_v1* const pSS, const DWORD /*dw //=========================================================================== -static UINT DoWriteFile(const HANDLE hFile, const void* const pData, const UINT Length) -{ - DWORD dwBytesWritten; - BOOL bRes = WriteFile( hFile, - pData, - Length, - &dwBytesWritten, - NULL); - - if(!bRes || (dwBytesWritten != Length)) - { - //dwError = GetLastError(); - throw std::string("Card: save error"); - } - - return dwBytesWritten; -} - -static UINT DoReadFile(const HANDLE hFile, void* const pData, const UINT Length) -{ - DWORD dwBytesRead; - BOOL bRes = ReadFile( hFile, - pData, - Length, - &dwBytesRead, - NULL); - - if (dwBytesRead != Length) - throw std::string("Card: file corrupt"); - - return dwBytesRead; -} - -//=========================================================================== - // Unit version history: // 2: Added: Timer1 & Timer2 active // 3: Added: Unit state @@ -2177,8 +2141,7 @@ bool MB_LoadSnapshot(YamlLoadHelper& yamlLoadHelper, UINT slot, UINT version) if((pMB->SpeechChip.CurrentMode != MODE_IRQ_DISABLED) && (pMB->sy6522.PCR == 0x0C) && (pMB->sy6522.IER & IxR_PERIPHERAL)) { - pMB->sy6522.IFR |= IxR_PERIPHERAL; - UpdateIFR(pMB); + UpdateIFR(pMB, 0, IxR_PERIPHERAL); pMB->SpeechChip.CurrentMode |= 1; // Set SSI263's D7 pin } } @@ -2303,8 +2266,7 @@ bool Phasor_LoadSnapshot(YamlLoadHelper& yamlLoadHelper, UINT slot, UINT version if((pMB->SpeechChip.CurrentMode != MODE_IRQ_DISABLED) && (pMB->sy6522.PCR == 0x0C) && (pMB->sy6522.IER & IxR_PERIPHERAL)) { - pMB->sy6522.IFR |= IxR_PERIPHERAL; - UpdateIFR(pMB); + UpdateIFR(pMB, 0, IxR_PERIPHERAL); pMB->SpeechChip.CurrentMode |= 1; // Set SSI263's D7 pin } } From e5dbdb169649331f00bae59dfeb2f087b0f70411 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sat, 28 Oct 2017 21:59:48 +0100 Subject: [PATCH 44/64] Full-screen: Hide mouse cursor after 2s of inactivity (#504) --- source/Common.h | 2 + source/Frame.cpp | 101 +++++++++++++++++++++++++++++--------- source/MouseInterface.cpp | 1 + source/MouseInterface.h | 2 - 4 files changed, 82 insertions(+), 24 deletions(-) diff --git a/source/Common.h b/source/Common.h index b439caac..c78af713 100644 --- a/source/Common.h +++ b/source/Common.h @@ -212,3 +212,5 @@ inline bool IsOriginal2E(void) enum eBUTTON {BUTTON0=0, BUTTON1}; enum eBUTTONSTATE {BUTTON_UP=0, BUTTON_DOWN}; + +enum {IDEVENT_TIMER_MOUSE=1, IDEVENT_TIMER_100MSEC}; diff --git a/source/Frame.cpp b/source/Frame.cpp index b41bcebc..6f70315e 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -117,7 +117,6 @@ static int buttondown = -1; static int buttonover = -1; static int buttonx = BUTTONX; static int buttony = BUTTONY; -static HRGN clipregion = (HRGN)0; static HDC g_hFrameDC = (HDC)0; static RECT framerect = {0,0,0,0}; @@ -130,10 +129,13 @@ static BOOL helpquit = 0; static BOOL g_bPaintingWindow = 0; static HFONT smallfont = (HFONT)0; static HWND tooltipwindow = (HWND)0; -static BOOL g_bUsingCursor = 0; // 1=AppleWin is using (hiding) the mouse-cursor +static BOOL g_bUsingCursor = FALSE; // TRUE = AppleWin is using (hiding) the mouse-cursor && restricting cursor to window - see SetUsingCursor() static int viewportx = VIEWPORTX; // Default to Normal (non-FullScreen) mode static int viewporty = VIEWPORTY; // Default to Normal (non-FullScreen) mode +static UINT_PTR g_TimerIDEvent_100msec = 0; +static UINT g_uCount100msec = 0; + static bool g_bShowingCursor = true; static bool g_bLastCursorInAppleViewport = false; @@ -144,7 +146,7 @@ void RelayEvent (UINT message, WPARAM wparam, LPARAM lparam); void ResetMachineState (); void SetFullScreenMode (); void SetNormalMode (); -void SetUsingCursor (BOOL); +static void SetUsingCursor(BOOL); static bool FileExists(std::string strFilename); bool g_bScrollLock_FullSpeed = false; @@ -164,11 +166,13 @@ static FULLSCREEN_SCALE_TYPE g_win_fullscreen_scale = 1; static int g_win_fullscreen_offsetx = 0; static int g_win_fullscreen_offsety = 0; +static bool g_bShowingConfigDlg = false; + // __ Prototypes __________________________________________________________________________________ - static void DrawCrosshairs (int x, int y); - static void UpdateMouseInAppleViewport(int iOutOfBoundsX, int iOutOfBoundsY, int x=0, int y=0); - static void ScreenWindowResize(const bool bCtrlKey); - static void FrameResizeWindow(int nNewScale); +void DrawCrosshairs (int x, int y); +void UpdateMouseInAppleViewport(int iOutOfBoundsX, int iOutOfBoundsY, int x=0, int y=0); +void ScreenWindowResize(const bool bCtrlKey); +void FrameResizeWindow(int nNewScale); // ========================================================================== @@ -326,6 +330,25 @@ static void RevealCursor() g_bLastCursorInAppleViewport = false; } +// Called when: +// . WM_MOUSEMOVE event +// . Switch from full-screen to normal (windowed) mode +// . AppleWin's main window is deactivated +static void FullScreenRevealCursor(void) +{ + if (!g_bIsFullScreen) + return; + + if (sg_Mouse.IsActive()) + return; + + if (!g_bUsingCursor && !g_bShowingCursor) + { + FrameShowCursor(TRUE); + g_uCount100msec = 0; + } +} + //=========================================================================== #define LOADBUTTONBITMAP(bitmapname) LoadImage(g_hInstance,bitmapname, \ @@ -1025,8 +1048,9 @@ LRESULT CALLBACK FrameWndProc ( case WM_ACTIVATE: // Sent when window is activated/deactivated. wParam indicates WA_ACTIVE, WA_INACTIVE, etc // Eg. Deactivate when Config dialog is active, AppleWin app loses focus, etc JoyReset(); - SetUsingCursor(0); + SetUsingCursor(FALSE); RevealCursor(); + FullScreenRevealCursor(); break; case WM_ACTIVATEAPP: // Sent when different app's window is activated/deactivated. @@ -1045,11 +1069,17 @@ LRESULT CALLBACK FrameWndProc ( RegSaveValue(TEXT(REG_PREFS), TEXT(REGVALUE_PREF_WINDOW_X_POS), 1, framerect.left); RegSaveValue(TEXT(REG_PREFS), TEXT(REGVALUE_PREF_WINDOW_Y_POS), 1, framerect.top); FrameReleaseDC(); - SetUsingCursor(0); + SetUsingCursor(FALSE); if (helpquit) { helpquit = 0; HtmlHelp(NULL,NULL,HH_CLOSE_ALL,0); } + if (g_TimerIDEvent_100msec) + { + BOOL bRes = KillTimer(g_hFrameWindow, g_TimerIDEvent_100msec); + LogFileOutput("KillTimer(g_TimerIDEvent_100msec), res=%d\n", bRes ? 1 : 0); + g_TimerIDEvent_100msec = 0; + } LogFileOutput("WM_CLOSE (done)\n"); break; @@ -1233,7 +1263,7 @@ LRESULT CALLBACK FrameWndProc ( // Process is done in WM_KEYUP: VK_F1 VK_F2 VK_F3 VK_F4 VK_F5 VK_F6 VK_F7 VK_F8 if ((wparam >= VK_F1) && (wparam <= VK_F8) && (buttondown == -1)) { - SetUsingCursor(0); + SetUsingCursor(FALSE); buttondown = wparam-VK_F1; if (g_bIsFullScreen && (buttonover != -1)) { if (buttonover != buttondown) @@ -1312,7 +1342,7 @@ LRESULT CALLBACK FrameWndProc ( } else if (wparam == VK_PAUSE) { - SetUsingCursor(0); + SetUsingCursor(FALSE); switch (g_nAppMode) { case MODE_RUNNING: @@ -1362,8 +1392,7 @@ LRESULT CALLBACK FrameWndProc ( } else { - SetUsingCursor(0); - return 0; // TC: Why return early? + SetUsingCursor(FALSE); } } break; @@ -1407,7 +1436,7 @@ LRESULT CALLBACK FrameWndProc ( { if (wparam & (MK_CONTROL | MK_SHIFT)) { - SetUsingCursor(0); + SetUsingCursor(FALSE); } else { @@ -1416,7 +1445,7 @@ LRESULT CALLBACK FrameWndProc ( } else if ( ((x < buttonx) && JoyUsingMouse() && ((g_nAppMode == MODE_RUNNING) || (g_nAppMode == MODE_STEPPING))) ) { - SetUsingCursor(1); + SetUsingCursor(TRUE); } else if (sg_Mouse.IsActive()) { @@ -1525,6 +1554,8 @@ LRESULT CALLBACK FrameWndProc ( UpdateMouseInAppleViewport(iOutOfBoundsX, iOutOfBoundsY, x, y); } + FullScreenRevealCursor(); + RelayEvent(WM_MOUSEMOVE,wparam,lparam); break; } @@ -1549,6 +1580,21 @@ LRESULT CALLBACK FrameWndProc ( UpdateMouseInAppleViewport(iOutOfBoundsX, iOutOfBoundsY); } } + else if (wparam == IDEVENT_TIMER_100MSEC) // GH#504 + { + if (g_bIsFullScreen + && !sg_Mouse.IsActive() // Don't interfere if there's a mousecard present! + && !g_bUsingCursor // Using mouse for joystick emulation (or mousecard restricted to window) + && g_bShowingCursor + && !g_bShowingConfigDlg) + { + g_uCount100msec++; + if (g_uCount100msec > 20) // Hide every 2sec of mouse inactivity + { + FrameShowCursor(FALSE); + } + } + } break; // VSCROLL @@ -1644,13 +1690,12 @@ LRESULT CALLBACK FrameWndProc ( } } } - if (g_bUsingCursor) - { - if (sg_Mouse.IsActive()) - sg_Mouse.SetButton(BUTTON1, (message == WM_RBUTTONDOWN) ? BUTTON_DOWN : BUTTON_UP); - else - JoySetButton(BUTTON1, (message == WM_RBUTTONDOWN) ? BUTTON_DOWN : BUTTON_UP); - } + + if (g_bUsingCursor && !sg_Mouse.IsActive()) + JoySetButton(BUTTON1, (message == WM_RBUTTONDOWN) ? BUTTON_DOWN : BUTTON_UP); + else if (sg_Mouse.IsActive()) + sg_Mouse.SetButton(BUTTON1, (message == WM_RBUTTONDOWN) ? BUTTON_DOWN : BUTTON_UP); + RelayEvent(message,wparam,lparam); break; @@ -1952,7 +1997,9 @@ static void ProcessButtonClick(int button, bool bFromButtonUI /*=false*/) case BTN_SETUP: { + g_bShowingConfigDlg = true; sg_PropertySheet.Init(); + g_bShowingConfigDlg = false; } break; @@ -2215,6 +2262,8 @@ void SetFullScreenMode () //=========================================================================== void SetNormalMode () { + FullScreenRevealCursor(); // Do before clearing g_bIsFullScreen flag + buttonover = -1; buttonx = BUTTONX; buttony = BUTTONY; @@ -2242,8 +2291,12 @@ void SetUsingCursor (BOOL bNewValue) return; g_bUsingCursor = bNewValue; + if (g_bUsingCursor) { + // Set TRUE when: + // . Using mouse for joystick emulation + // . Using mousecard and mouse is restricted to window SetCapture(g_hFrameWindow); RECT rect = { viewportx+2, // left viewporty+2, // top @@ -2454,6 +2507,10 @@ void FrameCreateWindow(void) g_hInstance,NULL ); SetupTooltipControls(); + + _ASSERT(g_TimerIDEvent_100msec == 0); + g_TimerIDEvent_100msec = SetTimer(g_hFrameWindow, IDEVENT_TIMER_100MSEC, 100, NULL); + LogFileOutput("FrameCreateWindow: SetTimer(), id=0x%08X\n", g_TimerIDEvent_100msec); } //=========================================================================== diff --git a/source/MouseInterface.cpp b/source/MouseInterface.cpp index 9be5d279..2c4be60f 100644 --- a/source/MouseInterface.cpp +++ b/source/MouseInterface.cpp @@ -889,6 +889,7 @@ namespace DIMouse return hr; // Setup timer to read mouse position + _ASSERT(g_TimerIDEvent == 0); g_TimerIDEvent = SetTimer(hDlg, IDEVENT_TIMER_MOUSE, 8, NULL); // 120Hz timer LogFileOutput("DirectInputInit: SetTimer(), id=0x%08X\n", g_TimerIDEvent); if (g_TimerIDEvent == 0) diff --git a/source/MouseInterface.h b/source/MouseInterface.h index 2b48f0f0..4d63b81b 100644 --- a/source/MouseInterface.h +++ b/source/MouseInterface.h @@ -101,8 +101,6 @@ protected: UINT m_uSlot; }; -#define IDEVENT_TIMER_MOUSE 1 - namespace DIMouse { HRESULT DirectInputInit( HWND hDlg ); From 146b6ebad3ac3f11cb146a0917bbacd3b9366ba6 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sat, 28 Oct 2017 22:13:05 +0100 Subject: [PATCH 45/64] Opening any dialog will deactivate the main frame - so don't hide the mouse cursor --- source/Frame.cpp | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/source/Frame.cpp b/source/Frame.cpp index 6f70315e..062c7ab7 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -166,7 +166,7 @@ static FULLSCREEN_SCALE_TYPE g_win_fullscreen_scale = 1; static int g_win_fullscreen_offsetx = 0; static int g_win_fullscreen_offsety = 0; -static bool g_bShowingConfigDlg = false; +static bool g_bFrameActive = false; // __ Prototypes __________________________________________________________________________________ void DrawCrosshairs (int x, int y); @@ -311,7 +311,7 @@ static void FrameShowCursor(BOOL bShow) // Called when: // . Ctrl-Left mouse button // . PAUSE pressed (when MODE_RUNNING) -// . AppleWin's main window is deactivated +// . AppleWin's main window is activated/deactivated static void RevealCursor() { if (!sg_Mouse.IsActiveAndEnabled()) @@ -333,7 +333,7 @@ static void RevealCursor() // Called when: // . WM_MOUSEMOVE event // . Switch from full-screen to normal (windowed) mode -// . AppleWin's main window is deactivated +// . AppleWin's main window is activated/deactivated static void FullScreenRevealCursor(void) { if (!g_bIsFullScreen) @@ -1051,6 +1051,7 @@ LRESULT CALLBACK FrameWndProc ( SetUsingCursor(FALSE); RevealCursor(); FullScreenRevealCursor(); + g_bFrameActive = (wparam != WA_INACTIVE); break; case WM_ACTIVATEAPP: // Sent when different app's window is activated/deactivated. @@ -1586,7 +1587,7 @@ LRESULT CALLBACK FrameWndProc ( && !sg_Mouse.IsActive() // Don't interfere if there's a mousecard present! && !g_bUsingCursor // Using mouse for joystick emulation (or mousecard restricted to window) && g_bShowingCursor - && !g_bShowingConfigDlg) + && g_bFrameActive) // Frame inactive when eg. Config or 'Select Disk Image' dialogs are opened { g_uCount100msec++; if (g_uCount100msec > 20) // Hide every 2sec of mouse inactivity @@ -1997,9 +1998,7 @@ static void ProcessButtonClick(int button, bool bFromButtonUI /*=false*/) case BTN_SETUP: { - g_bShowingConfigDlg = true; sg_PropertySheet.Init(); - g_bShowingConfigDlg = false; } break; From 77cbfbec99eb4383aebaafb9b45205c74ba545f7 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sun, 29 Oct 2017 10:50:08 +0000 Subject: [PATCH 46/64] Remove stale/unused key buffering code --- source/Keyboard.cpp | 94 +-------------------------------------------- 1 file changed, 2 insertions(+), 92 deletions(-) diff --git a/source/Keyboard.cpp b/source/Keyboard.cpp index 47f1687d..d403dbe6 100644 --- a/source/Keyboard.cpp +++ b/source/Keyboard.cpp @@ -36,10 +36,6 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA #include "YamlHelper.h" #include "Video.h" // Needed by TK3000 //e, to refresh the frame at each |Mode| change -static bool g_bKeybBufferEnable = false; - -#define KEY_OLD - static BYTE asciicode[2][10] = { {0x08,0x0D,0x15,0x2F,0x00,0x00,0x00,0x00,0x00,0x00}, {0x08,0x0B,0x15,0x0A,0x00,0x00,0x00,0x00,0x00,0x7F} @@ -56,26 +52,7 @@ static bool g_bP8CapsLock = true; //Caps lock key of Pravets 8A/C static int lastvirtkey = 0; // Current PC keycode static BYTE keycode = 0; // Current Apple keycode -#ifdef KEY_OLD -// Original static BOOL keywaiting = 0; -#else -// Buffered key input: -// - Needed on faster PCs where aliasing occurs during short/fast bursts of 6502 code. -// - Keyboard only sampled during 6502 execution, so if it's run too fast then key presses will be missed. -const int KEY_BUFFER_MIN_SIZE = 1; -const int KEY_BUFFER_MAX_SIZE = 2; -static int g_nKeyBufferSize = KEY_BUFFER_MAX_SIZE; // Circ key buffer size -static int g_nNextInIdx = 0; -static int g_nNextOutIdx = 0; -static int g_nKeyBufferCnt = 0; - -static struct -{ - int nVirtKey; - BYTE nAppleKey; -} g_nKeyBuffer[KEY_BUFFER_MAX_SIZE]; -#endif static BYTE g_nLastKey = 0x00; @@ -87,34 +64,9 @@ static BYTE g_nLastKey = 0x00; void KeybReset() { -#ifdef KEY_OLD keywaiting = 0; -#else - g_nNextInIdx = 0; - g_nNextOutIdx = 0; - g_nKeyBufferCnt = 0; - g_nLastKey = 0x00; - - g_nKeyBufferSize = g_bKeybBufferEnable ? KEY_BUFFER_MAX_SIZE : KEY_BUFFER_MIN_SIZE; -#endif } -//=========================================================================== - -//void KeybSetBufferMode(bool bNewKeybBufferEnable) -//{ -// if(g_bKeybBufferEnable == bNewKeybBufferEnable) -// return; -// -// g_bKeybBufferEnable = bNewKeybBufferEnable; -// KeybReset(); -//} -// -//bool KeybGetBufferMode() -//{ -// return g_bKeybBufferEnable; -//} - //=========================================================================== bool KeybGetAltStatus () { @@ -329,9 +281,6 @@ void KeybQueueKeypress (int key, BOOL bASCII) // Note: VK_CANCEL is Control-Break if ((key == VK_CANCEL) && (GetKeyState(VK_CONTROL) < 0)) { -#ifndef KEY_OLD - g_nNextInIdx = g_nNextOutIdx = g_nKeyBufferCnt = 0; -#endif g_bFreshReset = true; CtrlReset(); return; @@ -360,23 +309,8 @@ void KeybQueueKeypress (int key, BOOL bASCII) keycode = asciicode[IS_APPLE2 ? 0 : 1][key - VK_LEFT]; // Convert to Apple arrow keycode lastvirtkey = key; } -#ifdef KEY_OLD + keywaiting = 1; -#else - bool bOverflow = false; - - if(g_nKeyBufferCnt < g_nKeyBufferSize) - g_nKeyBufferCnt++; - else - bOverflow = true; - - g_nKeyBuffer[g_nNextInIdx].nVirtKey = lastvirtkey; - g_nKeyBuffer[g_nNextInIdx].nAppleKey = keycode; - g_nNextInIdx = (g_nNextInIdx + 1) % g_nKeyBufferSize; - - if(bOverflow) - g_nNextOutIdx = (g_nNextOutIdx + 1) % g_nKeyBufferSize; -#endif } //=========================================================================== @@ -472,21 +406,7 @@ BYTE __stdcall KeybReadData (WORD, WORD, BYTE, BYTE, ULONG) // -#ifdef KEY_OLD return keycode | (keywaiting ? 0x80 : 0); -#else - BYTE nKey = g_nKeyBufferCnt ? 0x80 : 0; - if(g_nKeyBufferCnt) - { - nKey |= g_nKeyBuffer[g_nNextOutIdx].nAppleKey; - g_nLastKey = g_nKeyBuffer[g_nNextOutIdx].nAppleKey; - } - else - { - nKey |= g_nLastKey; - } - return nKey; -#endif } //=========================================================================== @@ -506,19 +426,9 @@ BYTE __stdcall KeybReadFlag (WORD, WORD, BYTE, BYTE, ULONG) // -#ifdef KEY_OLD keywaiting = 0; + return keycode | ((GetKeyState(lastvirtkey) < 0) ? 0x80 : 0); -#else - BYTE nKey = (GetKeyState(g_nKeyBuffer[g_nNextOutIdx].nVirtKey) < 0) ? 0x80 : 0; - nKey |= g_nKeyBuffer[g_nNextOutIdx].nAppleKey; - if(g_nKeyBufferCnt) - { - g_nKeyBufferCnt--; - g_nNextOutIdx = (g_nNextOutIdx + 1) % g_nKeyBufferSize; - } - return nKey; -#endif } //=========================================================================== From 64d8675a88dac05c91b76726e841f25978b1f439 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sun, 29 Oct 2017 19:55:53 +0000 Subject: [PATCH 47/64] AppleWin.chm: updates for main Config prop page --- help/CommandLine.html | 2 +- help/cfg-config.html | 126 ++++++++++++++++++++--------------------- help/img/config.png | Bin 37119 -> 37273 bytes help/img/dbgscreen.gif | Bin 12447 -> 0 bytes 4 files changed, 63 insertions(+), 65 deletions(-) delete mode 100644 help/img/dbgscreen.gif diff --git a/help/CommandLine.html b/help/CommandLine.html index 192c918f..ed148db3 100644 --- a/help/CommandLine.html +++ b/help/CommandLine.html @@ -67,7 +67,7 @@

Debug arguments:

- -l
+ -l or -log
Enable logging. Creates an AppleWin.log file

-m
Disable DirectSound support

diff --git a/help/cfg-config.html b/help/cfg-config.html index d9b7b2ab..4723fe25 100644 --- a/help/cfg-config.html +++ b/help/cfg-config.html @@ -9,85 +9,83 @@

Configuration Settings


Configuration settingsModel:
+ hspace="5" vspace="5"> + + Model:
This describes the mode of emulation.  You have the option of emulating the predecessors of the Apple //e: the Apple ][ and Apple ][+. Besides running with a different Apple system ROM, some differences are discussed below.
    -
  • - Apple ][ : Non-autobooting, 64K machine, no lower-case, no 80-column, 6502 CPU -
  • - Apple ][+ : Autobooting version of the Apple ][ -
  • - Apple //e : 128K machine, lower-case, 80-column, 6502 CPU
  • -
  • - Enhanced Apple //e : 128K machine, lower-case, 80-column, 65C02 CPU
  • -
  • - Clone (specific model selectable from Advanced page)
  • +
  • Apple ][ : Non-autobooting, 64K machine, no lower-case, no 80-column, 6502 CPU +
  • Apple ][+ : Autobooting version of the Apple ][ +
  • Apple //e : 128K machine, lower-case, 80-column, 6502 CPU
  • +
  • Enhanced Apple //e : 128K machine, lower-case, 80-column, 65C02 CPU
  • +
  • Clone (specific model selectable from Advanced page)
+ + Confirm reboot:
+ Show "Confirm reboot" message box when F2 is pressed.
+
+ Video:
AppleWin can display Apple video in a variety of modes. The display can also be run in a standard window or full-screen. This option describes the type of video emulation to be used for the emulator. The differences are discussed below.
    -
  • - Monochrome (custom) : This mode emulates a monochrome +
  • Monochrome (custom) : This mode emulates a monochrome monitor. You can choose your monochrome color from the Monochrome Color button described below. -
  • - Color Monitor : This mode emulates a standard color monitor. -
  • - B&W TV : This mode emulates an NTSC black and white TV. -
  • - Color TV : This mode emulates an NTSC color TV. -
  • - Monochrome (Amber/Green/White) : Monochrome with specified color. -
  • -
  • 50% Scan line : Only draw alternate scanline (for better monitor - authenticity).
  • +
  • Color Monitor : This mode emulates a standard color monitor. +
  • B&W TV : This mode emulates an NTSC black and white TV. +
  • Color TV : This mode emulates an NTSC color TV. +
  • Monochrome (Amber/Green/White) : Monochrome with specified color.
-
  • Boot the Apple II to AppleSoft (ie. power on and hit Ctrl-Reset) and type IN#2. -
  • -
  • From a Windows DOS box, start AGS with "localhost 1977 apple2e". This will boot the emulated Apple II from AGS.
  • -
  • Nb. Only Enhanced Apple //e is working at the moment. -
    - -
    - Ethernet Settings...:
    -
    - This allows to choose which network interface card (NIC) you want to - use with the Uthernet card.

    Monochrome Color:
    - This is the color to use when you choose a monochrome video mode.
    -
    - Emulation Speed Control:
    - This option let's you control the processor speed of the emulated system. You - may choose to use an authentic speed (matching the speed of the original - processor from the system) or you can underclock or overclock the emulated - processor speed from half-speed to as fast as your PC can emulate.
    -
    - Confirm reboot:
    - Show "Confirm reboot" message box when F2 is pressed.
    -
    - Benchmark Emulator:
    - This will run a benchmark test that will show how fast your PC can emulate an - Apple //e system with this emulator.  In order to run the benchmark, the - emulated machine must be reset and you will lose any unsaved work. You will be - prompted before you continue this action. The results given are:
    -

    + + Monochrome Color:
    + This is the color to use when you choose a monochrome video mode.
    +
    + + 50% Scan line:
    + Only draw alternate scanline (for better monitor authenticity).
    +
    + + Full-Screen: Show drive/keyboard status:
    + When in full-screen mode, show floppy (activity and track) and harddisk status (activity); keyboard caps-lock status and if emulation is paused.
    +
    + + Serial Port:
    + This option will remap the emulated Apple's serial port to your PC's + serial port (or TCP port 1977). The Apple Super Serial Card (SSC) is emulated in slot-2.
    + The TCP interface to the Apple SSC can be used by the Apple // Game Server. + For details see the notes that comes with AGS:
    +
  • Boot the Apple II to AppleSoft (ie. power on and hit Ctrl-Reset) and type IN#2. +
  • From a Windows DOS box, start AGS with "localhost 1977 apple2e". This will boot the emulated Apple II from AGS. +
  • Nb. Only Enhanced Apple //e is working at the moment. +
    +
    + + Ethernet Settings...:
    + This allows to choose which network interface card (NIC) you want to + use with the Uthernet card.
    +
    + + Emulation Speed Control:
    + This option let's you control the processor speed of the emulated system. You + may choose to use an authentic speed (matching the speed of the original + processor from the system) or you can underclock or overclock the emulated + processor speed from half-speed to as fast as your PC can emulate.
    +
    + + Benchmark Emulator:
    + This will run a benchmark test that will show how fast your PC can emulate an + Apple //e system with this emulator. In order to run the benchmark, the + emulated machine must be reset and you will lose any unsaved work. You will be + prompted before you continue this action. The results given are:
      -
    • - Pure Video FPS -
    • - Pure CPU MHz -
    • - Expected average video game performance (in FPS)
    • +
    • Pure Video FPS +
    • Pure CPU MHz +
    • Expected average video game performance (in FPS)
  • diff --git a/help/img/config.png b/help/img/config.png index d29d2cfd71f185462ef06e0ba2a09c785ed79fd4..7b14c9e65214135720b46efa74a15a5693f0df9d 100644 GIT binary patch literal 37273 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%0D5cXiKz{`fBy{B*v8ZtFR^ToPi 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 literal 37119 zcmX`Sby!pX|31#fMt6*X#AuMw-Ca_O0wWy_q9WZeM)wGnZctx0<|AR;27HZ;&NCn5qk-L4@r;O#d^ zA=#$e6Tr`0UyJDdF#G211;|~~M3ac9A%pVD5qx`1{=&f8kBEq-=YI=;_kQa_M1;vP z)X{tt?6BKGim<@Xo_36c6dx6yhJ8~sQx%kylni8aE~j^v>Fb5q?!X|})Axy}QXZJe zW=9NoCmCk41J+GWW(!L-+)4U7C>c_J+P0Tx?e*QEt$Xo~qx8*o)HAp5`FS6v7QG_p zoBsQqu`vH{+I5&~spJfQQgO3C{4?s}o0r=~2{po^_M_zo0b7gOvWva$SC@|`BTc?V z)m8nd%k%nSGt(a>O}II_x6poBViWmygJ$XKJOY1numYl%TJ0denT(t)x%n^?B^QR5 z7g{}8DB1qK7Z5>uHGuIx_-A;cy&u$n?aXndG1san5Pn4J7k<Hh;`9j53$F(-C0ONvnwlm zobs-$#Eks>sjtMRjmlEa_t7ONdth5z?RBu0M#}+!W{tQt{fIPbeTVdql$(h=HhV9@ zw3AEWJxLH-$Hn!7nl29g_u;fE=-|n(=@pip>Y>b^7==%wC$?zuXMrTjmw`Sf*B(1; z*d7J-goDV1{>vz;;^mtpqb@-)udvql*OLLe?%6=~685vc^-_n2=*~jO6?1T?!QLi! zgj?)M9_wt-RO`Q{pHZq|*C<6t;*EIfLPj}{=VzD@`XzWGd#l8g>F&2HDdqa`B+kz= zBs&Dib~Aj~)A|Z}8tk4C+fbaerkdR!#@||N;A@?^vsENDMp~#8!W_D_)%>nz0yhyZ zU434?=Dq$}@uANYJZcbN-E`gb8|3ocx(&dgVdDF!-zo2xto&jC!NTwFWw-N>IQ^QG zbPHxqi#CGLP}Vs9QT*MZzFy4RPJe0N_-|Ft_-_;DT`xD^S+FkW__4m*7!!V-DDGZq zrz^NHV9=VEd2C;;xip#Ao|)%QT@)%S{r8^RR!g4nYpI7%q#k-nO$@tMTQFL=Ru&nW zwIM>0#(Uy-#Uof=Sp>Il-P15wFS+^o#oXNE-}LkKo2!i9(c8{}IhFvHc4vB!$l9T0 z-$vcNfyYI;dj+4oP0ZD%#XU`aMw%_Uy!5xHI^=(|BGG)WUo$@-I zM@5_hD=LD*baziuXAO7hKlp`A(wvg*2d+N*#`{r}lJsHiQ{pxsht|j%LviaCUDssp zdp!PRlHBxska(9EW)klB#tpFR2=zQwF-vR-QZJ8aE3FB7ztOE0kW)&oBh~e=3&fLc zl z5Ck2+ASZ0H5mlb~mxEG-H9M+FzF`U4$gv~?L3&uEjZO_lItaV64l!q24ZZkAr^Mwfi`fP-?y@FWt9x*uHx1Imc9B;Bx|)M3)irbwKgn> zw>L;{%RzT$F$BFli{E+F6mD|(WAc;t!!_}$etYAjdc!33*9?z~fRy)YjZIaw?H)do z+WIyEU^M#a8skUtZ7N=GJXh-|p(V8AU*KHhk$m{-p=JL@ooT6^(7urvnSroffellx zB~y+Ad!Yk+R@pD)YH2FZOJZpX;)$e*QLiLo^Rjnnq8IlxH4fFHkks0=p(f^>NspljO z<$baWP6`1R#-0fVhJWz#Xxgs06n~V!B*R0w5%OtJ@vkpFua-#mjmgZ2_`MoYytkI@ z>7*HeZsf_hg_N%~f@1s1r@bM)RPnh^raJ0mLT*LOWbdtyM{_ z^{!g0l-z~!Q~!{s{?7QW;!9|Z}Rb@-oFzkn^4x>StmEbzs z>H(uoUGiMhT^coEY^4WTgRT}g>cO$tSB@k#WqNt~Ih>T!eD_B&@B|?~y-uq|jA90e zqa*^ufH6gR{}c-I8t*RrAdMFk9_BQxpobhRbrHEZO#W=*y}*?^UtEYgeu~a5)$Fxl zrSk;={71pPmvm~W4hs*$5^==k9PY7wWU}z}f%5FNyI_cOcw4F_0wq}s!xF@BKs03@ z)9pUji@gm3Og$7nMUN;Y9pbJ;VVxX$k!+UmRA2_ou}`Q4A%W@6!~naK8;~QtK76$r z4p;yglE;-H*!6Bd69c>&C@`AJG!z-jbe4nz$APtpopl5vo#t`nNlitnK;e=+ z>*hN9zY>>4=y6uO=z3jHf*9g%583!np1BLM=Lt~lf0r4pJQ{r*} zf-c)nA@JME*)x5Hk6b46K5)-BtGz{-ieIrD`fIqk453AmfV{Ot=N5CWhMIIyst7nqo;g8)pDL zLQqmo2`P1G2%zVca18+B>8zT?T?=jCdrm;-Y95s%31jYhP%0(05{ARgTf8FHMV82G ztV5SWPedkhd>({*niw5TOx!!l{Ok)LEOUfeA_?1tMIUJ0frw->T_9H^0;w^;`668R zmxP+Akt8WN8d(d%!g}aXx@2*>OL+zqn;yCfynR;#-VhxcUdg^heo17aa929=Q~?I= z2KK{tJixQAx>AadqARbPMbrRl)_-?f$Fzqb5Kfw7RR%&>&Y26{g+InS1mo?B z@wUM1&6LV+#Dt53&K;-@JD8gD^B+ShV>ZMd{R+R+ou=tX)5zs)lHR zxB;t3|KYMvb+^&LVKVCjcl~+LydWs;Yv%Sx^xIcu@UYJ72kz@dL(?@19EC=yNsP-f zi(%<+%=ZKq15{jDnxkY~1^vcpws#rW6;bCst5D(Yd7 zR3v!J%vAMaG>D7eX5MG0gcd_9-_n~y8J`jHm9ZvCrI7njaI=&Dr%bZ<_2VQL^8hTJ*Y(5Qd_$=)kOMsJZfp@zN?ZH#kUP^}BSg2sMD`kZjS_TE$ zq*X%K<}A>C__ga+v;A!v$vBZ*Y7HoyOgMA}K$!}^7}hvV01UwOC@506DS0}r>13%$ zU@5|ICw;NLT&LqkM56G3&v%e}P;6hYnFM#7)gegyd{iKwIXl9@MYD&3J-(D4!uJU! zIbi&Sidoq0d?nKeP2~bwpU}h~B&T@J8Bu+LDs4nDYNE}0;DZP$j&|aR<@K2^?ufg7 zekm%iUj~cL?R}`7^qS$`b4}=2NDpn}I1Lmz3RM2J8`zJp>vs42Ff!gm;NOUNg^qC> zihjk)OvZvpu5^6<{cF{Rm6&SF`0mcVmV2wxBCm^1tOLKg&lr}t;=|`N&OULS1gaBu zBfI7zZYWL%v>cX8tM9ni~@;PZcb`P4FF?Oe%wNk%9C%o zE2Jf{Y)~g6VUJQxhJSf)MtB9%3)M<6_Ly9Iq7w3g6~D*bZcbTH!Hg4-9SalBmIRY4d5Rwol*3tgpM5B0)Kp@2K+b zdOx%SEK-PZi;DAzq0<4AI!{0_Hk?B|42@v@OjE(L}RK%3=9}1PNs~C0`tfl8Yk6w8An{ zBJ@Xs3cN64aLgnXJ`DvSB_&HYbolz*vtwYjXXsST&O%PKzWl)_fglD@cXG%I@rEu{ zzS;0gF&^w~qL&lsQ=Ij1&{!P^2;$@Xs&5Q?+gRL*`Ggq&8fqdnM`Dbv4QUXyS%#Ww zK2%wf#4(h@ov;}C(s&SM7pRyn?&fC9IxJ5b_jz`a@#Sate^OC|8ufc)&e0b4^Yq;?mZ4!=iLfQ~OdO>fi+FxV)Y#Ctt~9M^eu)3U(3+83v7OS<UKo2ZCsFHhm&q2A>>2444o+s>qENI=<4XIOkESY7YGwy|q9( z^5l+hGnMPxpmL-3FwaoXs~wg5ABcyJTy6bnO&-@j%YicwdR;z2`cih0Jz!9JSdsTR z#H-sWO>d3OOtHK)7EraE^U4{b={V`W;u8yRl;0KMeZ@c}5AB0_9gcdv$!wi~q~k~6 zal)|z4EH6<9fdMIvMAWgUhyz76tf$;fiz#hlt1z+pjE;=WjcNfFa&lf7$mE8p{Nq2 zkV6bPHblIc76)PNXPUAx_-Qy8Xw} zubJnJy4>HkFpDhO__I+hmzo~$5&y7XrQ;%x#QbRrm#!KV-g?S$RQC0EZXBD*p6eZ9 z6Ct%1XFUZ}ai4;9ND|N)&YnoAeaA9Vj>*b+{~zHWU~zqHGV?IJB~8B({vnEGtiXs@ z?p5u#yA-D4WCp_tC}2G2ANn~KfB;%<>*L2$xJ9LrtEPoI#O? zIS;u}3Og3f^a?<|+053- z#mzj|N3pG*j}2TO)3)d38vN#RhM!F+wan~4DEQ9xVe#U@w<3GnKfWHHf0nsMYk%WO zu;ed{AfZC(O27=Y%&DN*FSa6ESZ#rq}bUq(m-ZfC}F?2FT%1QVF~a)kafpdh@-`@sKn zn5(pfnC39OkaX|InjfJjnOymvRm8h<8R%VxL=Qhcr}uhCuEt7e;>_s$Ch%%{(V$W0 zy*VN-6xEBkr&`pk?7!xcll*vyTo@U@wm=wJB)`!;P}G;Z^SkhCdW?a~1G=Pp&BSzZ zY%&C7J8}S%Q6|(5(>ETa5FdvMAi^~raa<|x`cCcmwAI7f?5P;xm@+ou4_GI~)B*vcEX}p$<=$k!LUf zklJIJXv}HZ*NKF(pOO_a3X~+J3@z%T08&C@mL)3JJYe8rx-x8Og51n6#CVxW;E!sN zEFceMEVx)w7lElLxQEb8za4_0n27iNg*oePQAmBa4V`ed6Cag!B{77~TI06JWJ)aZ zIs(aWk&~Sj>fk9E@;0pg*udq8tiNY!QHa2*VYz1v5-TzzCDXL(jWX9~9h)J;;ueR^Eo(=G5 zYO*a@;A$DX{A8keDyO?Jm*ekkvMc=p248LEvk3jw6@A&(0(kB3Z9Cnu+xh3&QESV> zLdWh&#@zD&kAmINzzXfl)c3m&+X4;#%yJ)8(2(0Nem}KY+^vt2OHL}(Mv+5(D*vDt zIR3rvR=4fa$^6NZZ)j-I_VATwXXTWVDH=O!h?9&yfj_-*tSv z^d(8~J2Fa45+Q%*Lx`U3B)c{)zhnT142oQk~-MkmMu%Ivk-I9DKi(gKm^vMX~*=ams1AXc%H z97Y8wW42z2anjK*L^pOPMK(}-5O=41QM;L$+l~t7| z!QiN`&7Gf!ATN-N`ujXpfL-RXs4+h&94e3=8;Y9`QIn}ADC5PBK0-~ zlX94XpBI}5z;yfbn-RmU$*26pCnYxV>SE+ZR%ZU3<)^`BEL zwf%#7en}D_0-db$xZlEXj7OHx^OiA!1lCU+i0pF2=*@0h^*+gVWtuF20{$lyRutS84})z@D2D z;R?F7QdmZTip*Le{~P_&twqxYb~!0@uiD=_-Z?qFV!&b%>H8L#VTmznccjvC)TBXx z!gm-(Igpy^&&|!lNh&e4&rExi@dhr@?MQ4chg>3iQ&)lJ3n+u+Q_XcU_IRDlBbYxG zIw*am%mhfOL{dhKvB?BV9Q+f!mfL|BeddY$PhaNfknpb9Eg@cmebauP!@TK zj3(S7Vp4yKr&_9_|`EP0J!S%gOR5!@ztc8t zC92H^bL;OFez_a)Z>!YLdrb|*nWCof@icN(Yol|yUGmzO<8n7}r)8mG>Eqb7pWf*R z=Z~nK#DCUEyk;N$w%T?5&D(bW37EjTCaL20=r>yOEKdVn+uGprWDr7Wj1I&DP2NS? zPdPC@U6x!+*Q@hNg4J!&qK=OHEKFIybjOi^i}vMzpZaX*>Nhiadj3{I*?gYV%SOpJRid1cQISS>_NE zQH{>aw)^RAPgkfq7qyo2gLSRLym0=&X6TkczZmIWdtG8e^)EP_C{XL#6sW(${@)4qr`Ad7a`Udsv{mrFty0Q?N)a#p!`Vl zk5Cz2))g_3soO&SZ^6K2Y(ch^lr{do`SLI3;KdwW$T7j~3oD)V@-Ia29P~5Jf3zLT zebh7f%-KVUg!O|=KF92Ocd`!%lEd^~f@sCDLCPdPPU{v3cE$Es_4xVH!f9s|yaT?@ z{}4X=Ore?)`QEg+9&Gt zi)x<7!-f?>W~?vepG|gpRwP%a2^CAOb`8;!;+pi>^JK@_x#C7fF9v0!l_+IaULvx^xMQqV zhTYc$2}ylvcab2nCbl$vevM#*+jhAU-uKR7OyW~%G%>fc`CO-jb^A*$x(wtm0rf!&Ne+<`MK1)r-~a$3 zn{ETFFE$c^X;pzkg}ZJClg@OvWi*~UmTA|KNNRpV)z>4t|CY`kw0L8hz6l2lTN

    zzK@1y13Yv$J_>$(I-?Y}HKq8lWhAfN@6Y;zpWudAZs8Z?VP{-+3X93&7mx91{%ji2 zBLCiJs}EX|1n2EcrP}iS^9r^bT#;{;H!*YTF)4z3`ewp*GF8Zxoc8mFfiW!Kr`y8E zaJd5>H_KH^RAsps!!qP5O);ISj#;9>u1az124AW&5XmIz{Ls{=PtMnZ*?%qZbJXb2 zf?m4t@g-9~rA`S67i@u3bM(lFjblJZD2`s~_ICfkp#Q@C8JlI;(Q(8`-}IQ`Wumn{ zCbsW8g&e`@6;8@kJ+G3VLB;80atdei8PAid>-FW5=qbjIW5IyvO4d7reN3102QUf? z?;zh!>8X~M-%S!4J^fdW(5&=f_0QaFk}DZ+L*U&9dnUmXkccM=@V92)}aYrjDvZ*K3gfb2g-r@r&!ej53 zi*hDu=n1W*%n}2y;&X^<93@eC&D!af1ElZ)0&!Ypmuz%yxhQJ{N*QB2;9;!U4+~Z& zive@ax?oG4G4I!hkKaSBF_-v$?H8J+MXe;^N}i(Wng$4f0G8|zbtTGifC|;uTJK&* zj35#w>G|KVl#3MBBT;)BM@S;A+x^lK0~k02`91?HKGH;%8Bv6`=45rNdwM?~9Hb3B zzM~v~JGmm(#SibQBETf!n31m?v(<|G@03$oqE6Fg@!w2cTytDq3%}k|?*K%&X@~ap zAAkK$@Kb!ZoL@LesrZh?&s<#CR2sk3z459!#diEj;>bp&g}eJB@2_uXb9~}Mzy0nW zO2xjcA?=(CT*5uP9p(rL2nj0~s~}%nttgJ|?i}7F6OtP@k}!e_@5B0VTMNogNV4T7 z`vBD+mW2K6>`e;`@=q7fQRErLyR7qY$oTkq?>lt;RO0LD~IxoZo$td+!3kq4ADiCy(=-{=ft0ZXonYu z?>{~go9V9+#jW4lB|CSJ^=)HYB+>F#uaHMA?_w{3SqJ~pUp9oPR0N7q&V3Z(b2lZ5 zWyoXfnCQQS%QkH4{*K2#{dhvn9-q#vFJ}nWUJuOd#f)|C-7-z=&o$`Ad@&4~qcnp%FXw5zD>gW=*6eW*jzOBcAS8`4HyFo_Lw1ZE){Vq14$-i1D#nu zP`Jw=xk}Q2BJ{168hLlRB^C=bh{hrTV24E6XR@IdJLwS#B1LW?0o&65Mf`M_N% zI}t3wd>`5RHGc7zdru;2;_$DxjqIJNtu)8FCHBSN-|3$fWO&@144jDS1$anqExf8& z^4dIh5P6ecmo%5UIZdLLx8$BQ#xbYhdoDrF`J>_Qz^P3}aLbQ<8qtIg-jdA`Dc-Z4 zs+HeuV{GKPrnji~drhB(>(dA;KIl-Be(VPN01+Vc%|2Ln+U@1QX9aPYX`AOfn+^(< zzQXr!*OuMUc7H$H`O;3~vqeB&AkDu^qxJg9{=@bbsR^%^Unw8P)+6ciz`thVhK_mO znjk@dMr1`ecZ@$c$9E;$zt6?(kB`b`={%9vd)MhS)44d)mqX80dQ$3N8VNEo)0M7i z9~ckK^PM+(v4Ym0OZxtj?J!HV4>9>e!7Kk9d&gW`nw1hg6LAn+AiU^#cLBUdi!zvQ zyBnDiG$fWWz+v>$+ZLLtFXleF60hG_VcR_lmLx{eOHW0~@vk$oxb!BZcXDjLaDFQ< zr9}(N*$33Vrl;WOx@O`PRzS3$%Q|WCfIs%9TNDUPT{FiLa*GNnEy+klgIP8+^uc z9ICG(rqOXEbX_v?@5t!Xn$GC8v~bHSDSVa&Dll^E?as5N${GO;Uf@cBBUx9Q)?kNi z*}522=pN*A1SJn}3m7WxL1Yda$;ee3@0RBd3Q!4U4)FkoJO_7tVBZr8%9u_^kqzdx z1s)B_-Vvz(`ocPMYo}O-!ka4XU#MI!{r0V5a(=;8^s2x$6>7@bP|oj!CXL-B>!yR{ z|Mer5HXgv9nWSzB^DM#axqcKA)Vj93C2!RrmP#9{P%V-)=~?rzYNVO9 zGgq(v9$*CKIq--fxlAJTcYd>V<2BRBiCGD+GR!$Ws^9Kr=re#2;)Sy&XdH(h$AcSV zy6&*}IxsalJ|GKcAoaGRqM7Ms{|`Yc5ZQi{tCC#Jr{H(fnpU+^K&$urc7pgZbHHii zU~)ll{A77|B`>V(^i^hL4b=ON{FApL$^j$fzZWKh^+PCRKi8|UwjX(n4_AyI!PEIr zEitq)RU4KV&i7Yg_;1-xjYhcj{<}__*39cSD)HCQ^QJJFgDAJSA0uzijMuvKKYr4@zQECrKsC=EnvHwGH7n11K@PeTu7ZLG<| z7Tbpu54@i}PwoVT99OGxhV-yqUoZE9P^^!*L|_X%1x94Fh_7_162xDHr$v#e?;5OQ&$?i5TO0c zU5V+TxW$baCkBT`@=DaQR;M4;CyWwvB21T6Lh%{%NmL$_M3N#OqdLDijCVbjMwrRi zBU=jxYDgv5qCk_ALs~1BB>&>s!`jXTA!Bbb0weR-tsjD2< zlPn&rkGkzl@g5J#kgv~3dl(eRspXL%DtzI8r+6DirF^K=%HtK4HjqqEE)2gqQ;iI; zoxGikD^eGJV}+mQBt4&m&Q0t)B=65OxfozFeAN5{W@>xB(MBN6G6(HnViQ!1+%n|V z%9B;4w1#tAbU`yuOy@Y?CIH{0!OER6FvE;@Re*(gQ7lY zUzyt<@L8X}Z`^yI0&Q5Ic3?Pacb40!|P}sklg5f^hc9zq}5{SSV3TPNT zti_0UYe+AY4V2WZjU#^&cPpH0mN@9?z>6Ggep;u`6^{G&PSLWY&Q={&|TmSA!}m*VCk;sB+rl8-JF) zN3WTM87(VQPw#PVWU4^gRgzR6hOw$0`A&|1y5;y2R)~Eo2opYGBV8%HYDG-r5n3>! z)e1?k{rQc=m+MH711sRB*>?11o%mp<$Cg;7ONFEB1F&~Hf?1xoIu+L6IzX08F42{E zChAGhWR0$t1gFOE8GGQ+`)Ky2{U`GNx?w6qn?H)#H~Fv#O&&_cPq2Yf9GLSn;zyt7 z4}E9LfB***Jd7(N!7-6b2cl|!eLJk;sygjk?-GBr4EUey^}qWy66#J_dIRh7$cjKd+%_cpgfO{n9hS0<7)OFn@D z?{MvpL4CjV6Mm2-t_1t&+&O$~;{-Z3gIvkq*nCvec;PQWL-r(@T*}H5H0P2aINd0b zPoz~wk3fDUo1uX369n46=X9a%I}ODeOZAli5CTn)K{%itN`CT3fggqi<})trKqc zXL##=DU_%UpHGGmjMMvzTF=BboANlGsu#TY7&IFg%l6&-;#^s*A&~zzr1+=TzHfGe@ zsDhRTa=2+uK^d+D(ToqbN_3wqD}MIn;Hf;5aXHo36nc?G4jLRd?N*_2t3H9ZE2o{D zj}9j2LZ~1b6ia3TwVNy5NSuKrxI1}y@gXamFqRzMbnvcyr#m?=Gx#mK5CAYA#a|H% z4;W%%8~z;o3-f}5c_N;J`N3=>1*>Hy?GujzDRQ%%w!Sh!9(D;<0_a3o1&p(R&J>)C zu}q0cvIIpcNU#E`lQaSsFVE>JWsV!~~Bu>55AoCQTh21rp@_yX@e2#|* z*IGxZjq5^-(w&b`4(FxpeH$ny#;L1e@>NDSxjeu4^yjBZhfAK7d{kmo31ANEOTTiU z3Ku5nv?E=OI#w8Q*+NU#${NrE-#E?9fP*(e}R)lO0g!x@Z(^U)?h;%uHG^ul?PAv{=K^}V4O&Z!cEjAn8A?Bs$=e?FdF?Jpq}r`81|wbO2b!a%ATm?u}Gq1dFeE(ZzX)03BT*8=u(c1nbKrZ6qS9wdeJZ&%lr_gCp z$O@DPw&{;XriiIT9(erv!D})3(}k<9vhzuL#-rT*m1L2G5ecsG!(ZCJ2r&e2+TwpF zsP*xQ*STiV;^@wG-d-&!D&fw4ZmGz>=88EDIP`mk& znw_o4w{aw^HK63CDfyJr?~E4RGI)#({-zJfmQ|c<7mK z`&2{AgDCL7wvV3Gf3IBauN;Vd>h(5$;yAwhN*}*YUXpjU%(8rB`{NTJDmt>B^Xl{L zUissR?Nh3P$;Pgd4u-aR8rMnRn;rvnqF}o}+QXQb z^yRIDrUADEH{Ya8p9Foc7P)rrG&Llbj^Rl@(3qVs7dZw}mBTp#0sr@#oVYO^#XJ6^ z6}ceBs5iN1)<`V_1H#|aU}LN%{tKb6*D;!$yG%g13q+&Drw6COg(*$uzDUuaG$tdL zHIWV5^Gg(fka*j~$_G82iXs0>hAq?7zwcrEPUtLQ3?x6yqk+* z#Yr4=MjB&-IOVCyjmczX>5c8mQ(E;LY zvQbXOa{4$7nsx;-zjEcZ04XSd9%0D^j9$O5H#xGvSJ{3XwJ`|O^nW%J+mYymc94(G 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 M07*qoM6N<$g4*bEMgRZ+ diff --git a/help/img/dbgscreen.gif b/help/img/dbgscreen.gif deleted file mode 100644 index b65aa24434a356537bc54fe5b569deb59088a62a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12447 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 ABLDyZ From 8e2f0abf4a87a2630bd55623696298f6c3b496ad Mon Sep 17 00:00:00 2001 From: tomcw Date: Sun, 29 Oct 2017 20:11:07 +0000 Subject: [PATCH 48/64] History.txt updated --- bin/History.txt | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/bin/History.txt b/bin/History.txt index 6d6a53d9..e35ab6c6 100644 --- a/bin/History.txt +++ b/bin/History.txt @@ -12,6 +12,7 @@ Tom Charlesworth 1.26.3.2 (Experimental) - 21 Oct 2017 ------------------------------------- Changes: +. [Bug #504] Full-screen: hide mouse pointer after 2 seconds of inactivity (and show again if mouse is moved) . [Bug #469] New -no-printscreen-key switch to prevent the PrintScreen key from being registered. . [Bug #488] New -fs-height= switch. - best: picks the highest resolution where the height is an integer multiple of (192*2) @@ -21,6 +22,7 @@ Changes: . [Bug #428] Input option to use PC Joystick 1 Thumbstick 2 for emulated Joystick 2 . Swapping disks while a drive is on now warns and prompts if you still wish to do this instead of silently failing with no feedback. . [Bug #323] Skip hard disk boot by holding down the Open-Apple key during an Apple II restart +. [Bug #224] Added Config checkbox for 'Full-Screen: Show drive/keyboard status' . [PR #441] Update zlib to latest version 1.2.11 Fixes: @@ -28,6 +30,7 @@ Fixes: . [Bug #496] Support polling of Mockingboard's & Phasor's 6522 IFR.Timer1 . [Bug #492] UI fixes for full-screen & 2x windowed-mode . [Bug #486] Peripheral card's expansion ROM ($C800-CFFF, eg. SSC) wasn't being correctly restored from a save-state + - Resulting in regression: Mousecard crash to monitor (#495). . [Bug #464] Fix for full-screen: bottom line missing when vertical resolution is 768 . [Bug #460] Debugger: F2 whilst debugger active will immediately stop the drive spinning (allowing disk swap) . [Bug #456] Fix strange speaker clicks when changing configuration - DirectSound wasn't being uninitialised on a restart @@ -52,6 +55,7 @@ Fixes: - Experimental support for 6551's control bit: DTR via -dtr switch - Experimental support for 6551's status bits: DCD and DSR via -dcd and -dsr switches . [Bug #383] "Enhanced disk speed" is very slow when debugger is active +. [Bug #320] Mockingboard/Phasor: support 'inactive' function like real hardware . [Bug #269] When stepping, ESC no longer exits back to debugger (use F7, Pause keys or Debugger button instead). . [Bug #250] Debugger: When MODE_STEPPING, fix issue with disk LEDs staying on . [Bug #217] Debugger G(o) command should use normal speed From e1ef459bae932e83ded0f809e4df16006961f628 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sun, 12 Nov 2017 18:42:51 +0000 Subject: [PATCH 49/64] History.txt: correct the date for 1.26.3.4 --- bin/History.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/bin/History.txt b/bin/History.txt index e35ab6c6..442ee2e8 100644 --- a/bin/History.txt +++ b/bin/History.txt @@ -9,7 +9,7 @@ https://github.com/AppleWin/AppleWin/issues/new Tom Charlesworth -1.26.3.2 (Experimental) - 21 Oct 2017 +1.26.3.4 (Experimental) - 12 Nov 2017 ------------------------------------- Changes: . [Bug #504] Full-screen: hide mouse pointer after 2 seconds of inactivity (and show again if mouse is moved) From a551af020d8abad38b8bc77b4e4a5bd78da37008 Mon Sep 17 00:00:00 2001 From: tomcw Date: Wed, 29 Nov 2017 06:56:14 +0900 Subject: [PATCH 50/64] Fix so that on emu restart, mousecard state is now reset (#514) --- source/Applewin.cpp | 1 + 1 file changed, 1 insertion(+) diff --git a/source/Applewin.cpp b/source/Applewin.cpp index 71444265..36e2c8d1 100644 --- a/source/Applewin.cpp +++ b/source/Applewin.cpp @@ -1365,6 +1365,7 @@ int APIENTRY WinMain(HINSTANCE passinstance, HINSTANCE, LPSTR lpCmdLine, int) LogFileOutput("Main: MB_Reset()\n"); sg_Mouse.Uninitialize(); // Maybe restarting due to switching slot-4 card from MouseCard to Mockingboard + sg_Mouse.Reset(); LogFileOutput("Main: sg_Mouse.Uninitialize()\n"); DSUninit(); From 5505ff696fb0aefbe9e4cac6849900355ef8a5b2 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sun, 3 Dec 2017 21:05:05 +0000 Subject: [PATCH 51/64] HDD error wasn't cleared on a reset or power-cycle - fixes #515 --- source/Applewin.cpp | 4 +++- source/Disk.cpp | 3 --- source/Frame.cpp | 7 +++++-- source/Harddisk.cpp | 9 +++++++++ source/Harddisk.h | 1 + source/SaveState.cpp | 2 ++ 6 files changed, 20 insertions(+), 6 deletions(-) diff --git a/source/Applewin.cpp b/source/Applewin.cpp index 36e2c8d1..1668b8fd 100644 --- a/source/Applewin.cpp +++ b/source/Applewin.cpp @@ -1270,6 +1270,8 @@ int APIENTRY WinMain(HINSTANCE passinstance, HINSTANCE, LPSTR lpCmdLine, int) // Need to test if it's safe to call ResetMachineState(). In the meantime, just call DiskReset(): DiskReset(); // Switch from a booting A][+ to a non-autostart A][, so need to turn off floppy motor LogFileOutput("Main: DiskReset()\n"); + HD_Reset(); // GH#515 + LogFileOutput("Main: HDDReset()\n"); if (!bSysClkOK) { @@ -1365,7 +1367,7 @@ int APIENTRY WinMain(HINSTANCE passinstance, HINSTANCE, LPSTR lpCmdLine, int) LogFileOutput("Main: MB_Reset()\n"); sg_Mouse.Uninitialize(); // Maybe restarting due to switching slot-4 card from MouseCard to Mockingboard - sg_Mouse.Reset(); + sg_Mouse.Reset(); // Deassert any pending IRQs - GH#514 LogFileOutput("Main: sg_Mouse.Uninitialize()\n"); DSUninit(); diff --git a/source/Disk.cpp b/source/Disk.cpp index c3751a65..c286bfe3 100644 --- a/source/Disk.cpp +++ b/source/Disk.cpp @@ -558,9 +558,6 @@ void DiskInitialize(void) int loop = NUM_DRIVES; while (loop--) ZeroMemory(&g_aFloppyDisk[loop], sizeof(Disk_t)); - - TCHAR imagefilename[MAX_PATH]; - _tcscpy(imagefilename,g_sProgramDir); } //=========================================================================== diff --git a/source/Frame.cpp b/source/Frame.cpp index 062c7ab7..6618a91f 100644 --- a/source/Frame.cpp +++ b/source/Frame.cpp @@ -2139,8 +2139,8 @@ void RelayEvent (UINT message, WPARAM wparam, LPARAM lparam) { // CtrlReset() vs ResetMachineState(): // . CPU: -// Ctrl+Reset : sp=-3 / CpuReset() -// Power cycle: sp=0x1ff / CpuInitialize() +// Ctrl+Reset : 6502.sp=-3 / CpuReset() +// Power cycle: 6502.sp=0x1ff / CpuInitialize() // . Disk][: // Ctrl+Reset : if motor-on, then motor-off but continue to spin for 1s // Power cycle: motor-off & immediately stop spinning @@ -2149,6 +2149,7 @@ void RelayEvent (UINT message, WPARAM wparam, LPARAM lparam) { void ResetMachineState () { DiskReset(true); + HD_Reset(); g_bFullSpeed = 0; // Might've hit reset in middle of InternalCpuExecute() - so beep may get (partially) muted MemReset(); // calls CpuInitialize() @@ -2182,11 +2183,13 @@ void CtrlReset() PravetsReset(); DiskReset(); + HD_Reset(); KeybReset(); if (!IS_APPLE2) // TODO: Why not for A][ & A][+ too? VideoResetState(); // Switch Alternate char set off sg_SSC.CommReset(); MB_Reset(); + sg_Mouse.Reset(); // Deassert any pending IRQs - GH#514 #ifdef USE_SPEECH_API g_Speech.Reset(); #endif diff --git a/source/Harddisk.cpp b/source/Harddisk.cpp index f17af3cd..7132dfe4 100644 --- a/source/Harddisk.cpp +++ b/source/Harddisk.cpp @@ -289,6 +289,15 @@ static LPCTSTR HD_DiskGetBaseName(const int iDrive) // Not used return g_HardDisk[iDrive].imagename; } + +//------------------------------------- + +void HD_Reset(void) +{ + g_HardDisk[HARDDISK_1].hd_error = 0; + g_HardDisk[HARDDISK_2].hd_error = 0; +} + //------------------------------------- void HD_Load_Rom(const LPBYTE pCxRomPeripheral, const UINT uSlot) diff --git a/source/Harddisk.h b/source/Harddisk.h index ca575e84..82a70ad7 100644 --- a/source/Harddisk.h +++ b/source/Harddisk.h @@ -35,6 +35,7 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA void HD_SetEnabled(const bool bEnabled); LPCTSTR HD_GetFullName(const int iDrive); LPCTSTR HD_GetFullPathName(const int iDrive); + void HD_Reset(void); void HD_Load_Rom(const LPBYTE pCxRomPeripheral, const UINT uSlot); bool HD_Select(const int iDrive); void HD_Unplug(const int iDrive); diff --git a/source/SaveState.cpp b/source/SaveState.cpp index 8fc17c0a..aa64fad9 100644 --- a/source/SaveState.cpp +++ b/source/SaveState.cpp @@ -171,6 +171,7 @@ static void Snapshot_LoadState_v1() // .aws v1.0.0.1, up to (and including) Appl // Reset all sub-systems MemReset(); DiskReset(); + HD_Reset(); KeybReset(); VideoResetState(); MB_Reset(); @@ -492,6 +493,7 @@ static void Snapshot_LoadState_v2(void) MemReset(); PravetsReset(); DiskReset(); + HD_Reset(); KeybReset(); VideoResetState(); MB_Reset(); From d46491c5d00be456c6f823ebb1e5d443af073138 Mon Sep 17 00:00:00 2001 From: tomcw Date: Mon, 4 Dec 2017 20:43:42 +0000 Subject: [PATCH 52/64] VideoMode: 80STORE should only mask, not clear PAGE2 - and this is handled by underlying NTSC video code (#516) --- source/Video.cpp | 7 ------- 1 file changed, 7 deletions(-) diff --git a/source/Video.cpp b/source/Video.cpp index 6516192b..9bb02fd6 100644 --- a/source/Video.cpp +++ b/source/Video.cpp @@ -722,14 +722,7 @@ BYTE VideoSetMode (WORD, WORD address, BYTE write, BYTE, ULONG uExecutedCycles) case 0x5F: if (!IS_APPLE2) g_uVideoMode &= ~VF_DHIRES; break; } - // Apple IIe, Technical Notes, #3: Double High-Resolution Graphics - // 80STORE must be OFF to display page 2 - if (SW_80STORE) - g_uVideoMode &= ~VF_PAGE2; - -// NTSC_BEGIN NTSC_SetVideoMode( g_uVideoMode ); -// NTSC_END return MemReadFloatingBus(uExecutedCycles); } From 3553bc1dbfc4088e1398cf6f321b035b459641c7 Mon Sep 17 00:00:00 2001 From: tomcw Date: Mon, 4 Dec 2017 21:06:15 +0000 Subject: [PATCH 53/64] Bump to 1.26.3.5 --- bin/History.txt | 6 ++++-- resource/Applewin.rc | 8 ++++---- 2 files changed, 8 insertions(+), 6 deletions(-) diff --git a/bin/History.txt b/bin/History.txt index 442ee2e8..4b195e0a 100644 --- a/bin/History.txt +++ b/bin/History.txt @@ -9,8 +9,8 @@ https://github.com/AppleWin/AppleWin/issues/new Tom Charlesworth -1.26.3.4 (Experimental) - 12 Nov 2017 -------------------------------------- +1.26.3.5 (Experimental) - 4 Dec 2017 +------------------------------------ Changes: . [Bug #504] Full-screen: hide mouse pointer after 2 seconds of inactivity (and show again if mouse is moved) . [Bug #469] New -no-printscreen-key switch to prevent the PrintScreen key from being registered. @@ -26,6 +26,8 @@ Changes: . [PR #441] Update zlib to latest version 1.2.11 Fixes: +. [Bug #516] Internal video-mode was having PAGE2 permanently cleared (instead of just masked) when 80STORE was set. +. [Bug #514] Emulator restart (or reset) wasn't clearing any pending Mousecard interrupt . [Bug #499] Flush current track (if dirty) before 'Send to CiderPress' . [Bug #496] Support polling of Mockingboard's & Phasor's 6522 IFR.Timer1 . [Bug #492] UI fixes for full-screen & 2x windowed-mode diff --git a/resource/Applewin.rc b/resource/Applewin.rc index bb9da64c..941a797c 100644 --- a/resource/Applewin.rc +++ b/resource/Applewin.rc @@ -252,8 +252,8 @@ DISK_ICON ICON "DISK.ICO" // VS_VERSION_INFO VERSIONINFO - FILEVERSION 1,26,3,4 - PRODUCTVERSION 1,26,3,4 + FILEVERSION 1,26,3,5 + PRODUCTVERSION 1,26,3,5 FILEFLAGSMASK 0x3fL #ifdef _DEBUG FILEFLAGS 0x1L @@ -271,12 +271,12 @@ BEGIN VALUE "Comments", "https://github.com/AppleWin" VALUE "CompanyName", "AppleWin" VALUE "FileDescription", "Apple //e Emulator for Windows" - VALUE "FileVersion", "1, 26, 3, 4" + VALUE "FileVersion", "1, 26, 3, 5" VALUE "InternalName", "APPLEWIN" VALUE "LegalCopyright", " 1994-2017 Michael O'Brien, Oliver Schmidt, Tom Charlesworth, Michael Pohoreski, Nick Westgate, Linards Ticmanis" VALUE "OriginalFilename", "APPLEWIN.EXE" VALUE "ProductName", "Apple //e Emulator" - VALUE "ProductVersion", "1, 26, 3, 4" + VALUE "ProductVersion", "1, 26, 3, 5" END END BLOCK "VarFileInfo" From 664edf5b6f275b5f395a4d1e93dcc008b58fa238 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sun, 17 Dec 2017 18:20:39 +0000 Subject: [PATCH 54/64] Debugger: fix some static analysis issues from PR #517 --- source/Debugger/Debugger_Display.cpp | 775 +++++++++++++-------------- source/Debugger/Debugger_Parser.cpp | 8 +- 2 files changed, 374 insertions(+), 409 deletions(-) diff --git a/source/Debugger/Debugger_Display.cpp b/source/Debugger/Debugger_Display.cpp index 51db89af..33f80f52 100644 --- a/source/Debugger/Debugger_Display.cpp +++ b/source/Debugger/Debugger_Display.cpp @@ -543,6 +543,7 @@ HDC GetDebuggerMemDC(void) SelectObject(g_hDebuggerMemDC, g_hDebuggerMemBM); } + _ASSERT(g_hDebuggerMemDC); // TC: Could this be NULL? return g_hDebuggerMemDC; } @@ -1902,392 +1903,371 @@ WORD DrawDisassemblyLine ( int iLine, const WORD nBaseAddress ) const int DISASM_SYMBOL_LEN = 9; #endif - HDC dc = GetDebuggerMemDC(); - if (dc) // TC: Why would this be NULL? + int nFontHeight = g_aFontConfig[ FONT_DISASM_DEFAULT ]._nLineHeight; // _nFontHeight; // g_nFontHeight + + RECT linerect; + linerect.left = 0; + linerect.top = iLine * nFontHeight; + linerect.right = DISPLAY_DISASM_RIGHT; + linerect.bottom = linerect.top + nFontHeight; + + bool bBreakpointActive; + bool bBreakpointEnable; + GetBreakpointInfo( nBaseAddress, bBreakpointActive, bBreakpointEnable ); + bool bAddressAtPC = (nBaseAddress == regs.pc); + bool bAddressIsBookmark = Bookmark_Find( nBaseAddress ); + + DebugColors_e iBackground = BG_DISASM_1; + DebugColors_e iForeground = FG_DISASM_MNEMONIC; // FG_DISASM_TEXT; + bool bCursorLine = false; + + if (((! g_bDisasmCurBad) && (iLine == g_nDisasmCurLine)) + || (g_bDisasmCurBad && (iLine == 0))) { - int nFontHeight = g_aFontConfig[ FONT_DISASM_DEFAULT ]._nLineHeight; // _nFontHeight; // g_nFontHeight + bCursorLine = true; - RECT linerect; - linerect.left = 0; - linerect.top = iLine * nFontHeight; - linerect.right = DISPLAY_DISASM_RIGHT; - linerect.bottom = linerect.top + nFontHeight; - -// BOOL bp = g_nBreakpoints && CheckBreakpoint(nBaseAddress,nBaseAddress == regs.pc); - - bool bBreakpointActive; - bool bBreakpointEnable; - GetBreakpointInfo( nBaseAddress, bBreakpointActive, bBreakpointEnable ); - bool bAddressAtPC = (nBaseAddress == regs.pc); - bool bAddressIsBookmark = Bookmark_Find( nBaseAddress ); - - DebugColors_e iBackground = BG_DISASM_1; - DebugColors_e iForeground = FG_DISASM_MNEMONIC; // FG_DISASM_TEXT; - bool bCursorLine = false; - - if (((! g_bDisasmCurBad) && (iLine == g_nDisasmCurLine)) - || (g_bDisasmCurBad && (iLine == 0))) + // Breakpoint + if (bBreakpointActive) { - bCursorLine = true; - - // Breakpoint, - if (bBreakpointActive) + if (bBreakpointEnable) { - if (bBreakpointEnable) - { - iBackground = BG_DISASM_BP_S_C; iForeground = FG_DISASM_BP_S_C; - } - else - { - iBackground = BG_DISASM_BP_0_C; iForeground = FG_DISASM_BP_0_C; - } - } - else - if (bAddressAtPC) - { - iBackground = BG_DISASM_PC_C; iForeground = FG_DISASM_PC_C; + iBackground = BG_DISASM_BP_S_C; iForeground = FG_DISASM_BP_S_C; } else { - iBackground = BG_DISASM_C; iForeground = FG_DISASM_C; - // HACK? Sync Cursor back up to Address - // The cursor line may of had to be been moved, due to Disasm Singularity. - g_nDisasmCurAddress = nBaseAddress; + iBackground = BG_DISASM_BP_0_C; iForeground = FG_DISASM_BP_0_C; } } else + if (bAddressAtPC) { - if (iLine & 1) - { - iBackground = BG_DISASM_1; - } - else - { - iBackground = BG_DISASM_2; - } - - // This address has a breakpoint, but the cursor is not on it (atm) - if (bBreakpointActive) - { - if (bBreakpointEnable) - { - iForeground = FG_DISASM_BP_S_X; // Red (old Yellow) - } - else - { - iForeground = FG_DISASM_BP_0_X; // Yellow - } - } - else - if (bAddressAtPC) - { - iBackground = BG_DISASM_PC_X; iForeground = FG_DISASM_PC_X; - } - else - { - iForeground = FG_DISASM_MNEMONIC; - } - } - - if (bAddressIsBookmark) - { - DebuggerSetColorBG( DebuggerGetColor( BG_DISASM_BOOKMARK ) ); - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_BOOKMARK ) ); + iBackground = BG_DISASM_PC_C; iForeground = FG_DISASM_PC_C; } else { - DebuggerSetColorBG( DebuggerGetColor( iBackground ) ); - DebuggerSetColorFG( DebuggerGetColor( iForeground ) ); + iBackground = BG_DISASM_C; iForeground = FG_DISASM_C; + // HACK? Sync Cursor back up to Address + // The cursor line may of had to be been moved, due to Disasm Singularity. + g_nDisasmCurAddress = nBaseAddress; } - + } + else + { + if (iLine & 1) + { + iBackground = BG_DISASM_1; + } + else + { + iBackground = BG_DISASM_2; + } + + // This address has a breakpoint, but the cursor is not on it (atm) + if (bBreakpointActive) + { + if (bBreakpointEnable) + { + iForeground = FG_DISASM_BP_S_X; // Red (old Yellow) + } + else + { + iForeground = FG_DISASM_BP_0_X; // Yellow + } + } + else + if (bAddressAtPC) + { + iBackground = BG_DISASM_PC_X; iForeground = FG_DISASM_PC_X; + } + else + { + iForeground = FG_DISASM_MNEMONIC; + } + } + + if (bAddressIsBookmark) + { + DebuggerSetColorBG( DebuggerGetColor( BG_DISASM_BOOKMARK ) ); + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_BOOKMARK ) ); + } + else + { + DebuggerSetColorBG( DebuggerGetColor( iBackground ) ); + DebuggerSetColorFG( DebuggerGetColor( iForeground ) ); + } + // Address - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_ADDRESS ) ); -// else -// { -// DebuggerSetColorBG( dc, DebuggerGetColor( FG_DISASM_BOOKMARK ) ); // swapped -// DebuggerSetColorFG( dc, DebuggerGetColor( BG_DISASM_BOOKMARK ) ); // swapped -// } + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_ADDRESS ) ); +// else +// { +// DebuggerSetColorBG( GetDebuggerMemDC(), DebuggerGetColor( FG_DISASM_BOOKMARK ) ); // swapped +// DebuggerSetColorFG( GetDebuggerMemDC(), DebuggerGetColor( BG_DISASM_BOOKMARK ) ); // swapped +// } - if( g_bConfigDisasmAddressView ) - { - PrintTextCursorX( (LPCTSTR) line.sAddress, linerect ); - } + if( g_bConfigDisasmAddressView ) + { + PrintTextCursorX( (LPCTSTR) line.sAddress, linerect ); + } + + if (bAddressIsBookmark) + { + DebuggerSetColorBG( DebuggerGetColor( iBackground ) ); + DebuggerSetColorFG( DebuggerGetColor( iForeground ) ); + } - if (bAddressIsBookmark) - { - DebuggerSetColorBG( DebuggerGetColor( iBackground ) ); - DebuggerSetColorFG( DebuggerGetColor( iForeground ) ); - } - // Address Seperator - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR ) ); + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR ) ); - if (g_bConfigDisasmAddressColon) - PrintTextCursorX( ":", linerect ); - else - PrintTextCursorX( " ", linerect ); // bugfix, not showing "addr:" doesn't alternate color lines + if (g_bConfigDisasmAddressColon) + PrintTextCursorX( ":", linerect ); + else + PrintTextCursorX( " ", linerect ); // bugfix, not showing "addr:" doesn't alternate color lines // Opcodes - linerect.left = (int) aTabs[ TS_OPCODE ]; + linerect.left = (int) aTabs[ TS_OPCODE ]; - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPCODE ) ); -// PrintTextCursorX( " ", linerect ); + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPCODE ) ); - if (g_bConfigDisasmOpcodesView) - PrintTextCursorX( (LPCTSTR) line.sOpCodes, linerect ); -// PrintTextCursorX( " ", linerect ); + if (g_bConfigDisasmOpcodesView) + PrintTextCursorX( (LPCTSTR) line.sOpCodes, linerect ); // Label - linerect.left = (int) aTabs[ TS_LABEL ]; + linerect.left = (int) aTabs[ TS_LABEL ]; - if (pSymbol) - { - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_SYMBOL ) ); - PrintTextCursorX( pSymbol, linerect ); - } -// linerect.left += (g_nFontWidthAvg * DISASM_SYMBOL_LEN); -// PrintTextCursorX( " ", linerect ); + if (pSymbol) + { + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_SYMBOL ) ); + PrintTextCursorX( pSymbol, linerect ); + } // Instruction / Mnemonic - linerect.left = (int) aTabs[ TS_INSTRUCTION ]; + linerect.left = (int) aTabs[ TS_INSTRUCTION ]; - if (! bCursorLine) - { - if( pData ) // Assembler Data Directive / Data Disassembler - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_DIRECTIVE ) ); // TODO: FIXME: HACK? Is the color fine? - else - DebuggerSetColorFG( DebuggerGetColor( iForeground ) ); - } + if (! bCursorLine) + { + if( pData ) // Assembler Data Directive / Data Disassembler + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_DIRECTIVE ) ); // TODO: FIXME: HACK? Is the color fine? + else + DebuggerSetColorFG( DebuggerGetColor( iForeground ) ); + } - pMnemonic = line.sMnemonic; - PrintTextCursorX( pMnemonic, linerect ); - PrintTextCursorX( " ", linerect ); + pMnemonic = line.sMnemonic; + PrintTextCursorX( pMnemonic, linerect ); + PrintTextCursorX( " ", linerect ); // Target - if (line.bTargetImmediate) + if (line.bTargetImmediate) + { + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); + PrintTextCursorX( "#$", linerect ); + } + + if (line.bTargetIndexed || line.bTargetIndirect) + { + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); + PrintTextCursorX( "(", linerect ); + } + + char *pTarget = line.sTarget; + int nLen = strlen( pTarget ); + + if (*pTarget == '$') // BUG? if ASC #:# starts with '$' ? // && (iOpcode != OPCODE_NOP) + { + pTarget++; + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); + PrintTextCursorX( "$", linerect ); + } + + if (! bCursorLine) + { + if (bDisasmFormatFlags & DISASM_FORMAT_SYMBOL) { - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); - PrintTextCursorX( "#$", linerect ); + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_SYMBOL ) ); } - - if (line.bTargetIndexed || line.bTargetIndirect) + else { - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); - PrintTextCursorX( "(", linerect ); + if (iOpmode == AM_M) +// if (bDisasmFormatFlags & DISASM_FORMAT_CHAR) + { + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPCODE ) ); + } + else + { + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_TARGET ) ); + } } + } - char *pTarget = line.sTarget; - int nLen = strlen( pTarget ); + // https://github.com/AppleWin/AppleWin/issues/227 + // (Debugger)[1.25] AppleSoft symbol: COPY.FAC.TO.ARG.ROUNDED overflows into registers + // Repro: + // UEA39 + // 2.8.0.1 Clamp excessive symbol target to not overflow + // SYM COPY.FAC.TO.ARG.ROUNDED = EB63 + // If opcodes aren't showing then length can be longer! + // FormatOpcodeBytes() uses 3 chars/MAX_OPCODES. i.e. "## " + int nMaxLen = MAX_TARGET_LEN; - if (*pTarget == '$') // BUG? if ASC #:# starts with '$' ? // && (iOpcode != OPCODE_NOP) + // 2.8.0.8: Bug #227: AppleSoft symbol: COPY.FAC.TO.ARG.ROUNDED overflows into registers + if ( !g_bConfigDisasmAddressView ) + nMaxLen += 4; + if ( !g_bConfigDisasmOpcodesView ) + nMaxLen += (MAX_OPCODES*3); + + if( nLen >= nMaxLen ) + { +#if _DEBUG + // TODO: Warn on import about long symbol/target names +#endif + pTarget[ nMaxLen ] = 0; + } + + // TODO: FIXME: 2.8.0.7: Allow ctrl characters to show as inverse; i.e. ASC 400:40F + PrintTextCursorX( pTarget, linerect ); + + // Target Offset +/- + if (bDisasmFormatFlags & DISASM_FORMAT_OFFSET) + { + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); + + if (line.nTargetOffset > 0) + PrintTextCursorX( "+", linerect ); + else + if (line.nTargetOffset < 0) + PrintTextCursorX( "-", linerect ); + + if (! bCursorLine) { - pTarget++; + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPCODE )); // Technically, not a hex number, but decimal + } + PrintTextCursorX( line.sTargetOffset, linerect ); + } + // Inside parenthesis = Indirect Target Regs + if (line.bTargetIndirect || line.bTargetX || line.bTargetY) + { + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); + + if (line.bTargetX) + { + PrintTextCursorX( ",", linerect ); if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); - PrintTextCursorX( "$", linerect ); + DebuggerSetColorFG( DebuggerGetColor( FG_INFO_REG ) ); + PrintTextCursorX( "X", linerect ); + } + else + if ((line.bTargetY) && (! line.bTargetIndirect)) + { + PrintTextCursorX( ",", linerect ); + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_INFO_REG ) ); + PrintTextCursorX( "Y", linerect ); + } + } + + if (line.bTargetIndexed || line.bTargetIndirect) + { + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); + + PrintTextCursorX( ")", linerect ); + } + + if (line.bTargetIndexed) + { + if (line.bTargetY) + { + PrintTextCursorX( ",", linerect ); + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_INFO_REG ) ); + PrintTextCursorX( "Y", linerect ); + } + } + + // BUGFIX: 2.6.2.30: DA $target --> show right paren + if( pData ) + { + return nOpbyte; + } + + // Memory Pointer and Value + if (bDisasmFormatFlags & DISASM_FORMAT_TARGET_POINTER) // (bTargetValue) + { + linerect.left = (int) aTabs[ TS_IMMEDIATE ]; // TS_IMMEDIATE ]; + + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_ADDRESS )); + + PrintTextCursorX( line.sTargetPointer, linerect ); + + if (bDisasmFormatFlags & DISASM_FORMAT_TARGET_VALUE) + { + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); + + if (g_iConfigDisasmTargets & DISASM_TARGET_BOTH) + PrintTextCursorX( ":", linerect ); + + if (! bCursorLine) + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPCODE )); + + PrintTextCursorX( line.sTargetValue, linerect ); + PrintTextCursorX( " ", linerect ); + } + } + + // Immediate Char + if (bDisasmFormatFlags & DISASM_FORMAT_CHAR) + { + linerect.left = (int) aTabs[ TS_CHAR ]; // TS_IMMEDIATE ]; + + if (! bCursorLine) + { + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR ) ); } if (! bCursorLine) { - if (bDisasmFormatFlags & DISASM_FORMAT_SYMBOL) - { - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_SYMBOL ) ); - } - else - { - if (iOpmode == AM_M) -// if (bDisasmFormatFlags & DISASM_FORMAT_CHAR) - { - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPCODE ) ); - } - else - { - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_TARGET ) ); - } - } + ColorizeSpecialChar( NULL, line.nImmediate, MEM_VIEW_ASCII, iBackground ); } + PrintTextCursorX( line.sImmediate, linerect ); - // https://github.com/AppleWin/AppleWin/issues/227 - // (Debugger)[1.25] AppleSoft symbol: COPY.FAC.TO.ARG.ROUNDED overflows into registers - // Repro: - // UEA39 - // 2.8.0.1 Clamp excessive symbol target to not overflow - // SYM COPY.FAC.TO.ARG.ROUNDED = EB63 - // If opcodes aren't showing then length can be longer! - // FormatOpcodeBytes() uses 3 chars/MAX_OPCODES. i.e. "## " - int nMaxLen = MAX_TARGET_LEN; - - // 2.8.0.8: Bug #227: AppleSoft symbol: COPY.FAC.TO.ARG.ROUNDED overflows into registers - if ( !g_bConfigDisasmAddressView ) - nMaxLen += 4; - if ( !g_bConfigDisasmOpcodesView ) - nMaxLen += (MAX_OPCODES*3); - - if( nLen >= nMaxLen ) + DebuggerSetColorBG( DebuggerGetColor( iBackground ) ); // Hack: Colorize can "color bleed to EOL" + if (! bCursorLine) { -#if _DEBUG - // TODO: Warn on import about long symbol/target names -#endif - pTarget[ nMaxLen ] = 0; + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR ) ); } + } - // TODO: FIXME: 2.8.0.7: Allow ctrl characters to show as inverse; i.e. ASC 400:40F - PrintTextCursorX( pTarget, linerect ); -// PrintTextCursorX( " ", linerect ); - - // Target Offset +/- - if (bDisasmFormatFlags & DISASM_FORMAT_OFFSET) - { - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); - - if (line.nTargetOffset > 0) - PrintTextCursorX( "+", linerect ); - else - if (line.nTargetOffset < 0) - PrintTextCursorX( "-", linerect ); - - if (! bCursorLine) - { - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPCODE )); // Technically, not a hex number, but decimal - } - PrintTextCursorX( line.sTargetOffset, linerect ); - } - // Inside Parenthesis = Indirect Target Regs - if (line.bTargetIndirect || line.bTargetX || line.bTargetY) - { - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); - - if (line.bTargetX) - { - PrintTextCursorX( ",", linerect ); - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_INFO_REG ) ); - PrintTextCursorX( "X", linerect ); - } - else - if ((line.bTargetY) && (! line.bTargetIndirect)) - { - PrintTextCursorX( ",", linerect ); - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_INFO_REG ) ); - PrintTextCursorX( "Y", linerect ); - } - } - - if (line.bTargetIndexed || line.bTargetIndirect) - { - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); - - PrintTextCursorX( ")", linerect ); - } - - if (line.bTargetIndexed) - { - if (line.bTargetY) - { - PrintTextCursorX( ",", linerect ); - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_INFO_REG ) ); - PrintTextCursorX( "Y", linerect ); - } - } - - // BUGFIX: 2.6.2.30: DA $target --> show right paren - if( pData ) - { - return nOpbyte; - } - - // Memory Pointer and Value - if (bDisasmFormatFlags & DISASM_FORMAT_TARGET_POINTER) // (bTargetValue) - { - linerect.left = (int) aTabs[ TS_IMMEDIATE ]; // TS_IMMEDIATE ]; - -// PrintTextCursorX( " ", linerect ); - - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_ADDRESS )); - - PrintTextCursorX( line.sTargetPointer, linerect ); - - if (bDisasmFormatFlags & DISASM_FORMAT_TARGET_VALUE) - { - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR )); - - if (g_iConfigDisasmTargets & DISASM_TARGET_BOTH) - PrintTextCursorX( ":", linerect ); - - if (! bCursorLine) - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPCODE )); - - PrintTextCursorX( line.sTargetValue, linerect ); - PrintTextCursorX( " ", linerect ); - } - } - - // Immediate Char - if (bDisasmFormatFlags & DISASM_FORMAT_CHAR) - { - linerect.left = (int) aTabs[ TS_CHAR ]; // TS_IMMEDIATE ]; - - if (! bCursorLine) - { - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR ) ); - } - -// if (! (bDisasmFormatFlags & DISASM_FORMAT_TARGET_POINTER)) -// PrintTextCursorX( "'", linerect ); - - if (! bCursorLine) - { - ColorizeSpecialChar( NULL, line.nImmediate, MEM_VIEW_ASCII, iBackground ); -// iBackground, FG_INFO_CHAR_HI, FG_DISASM_CHAR, FG_INFO_CHAR_LO ); - } - PrintTextCursorX( line.sImmediate, linerect ); - - DebuggerSetColorBG( DebuggerGetColor( iBackground ) ); // Hack: Colorize can "color bleed to EOL" - if (! bCursorLine) - { - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_OPERATOR ) ); - } - -// if (! (bDisasmFormatFlags & DISASM_FORMAT_TARGET_POINTER)) -// PrintTextCursorX( "'", linerect ); - } - // Branch Indicator - if (bDisasmFormatFlags & DISASM_FORMAT_BRANCH) + if (bDisasmFormatFlags & DISASM_FORMAT_BRANCH) + { + linerect.left = (int) aTabs[ TS_BRANCH ]; + + if (! bCursorLine) { - linerect.left = (int) aTabs[ TS_BRANCH ]; - - if (! bCursorLine) - { - DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_BRANCH ) ); - } - -#if !USE_APPLE_FONT - if (g_iConfigDisasmBranchType == DISASM_BRANCH_FANCY) - SelectObject( GetDebuggerMemDC(), g_aFontConfig[ FONT_DISASM_BRANCH ]._hFont ); // g_hFontWebDings -#endif - -// PrintTextColor( sBranch, linerect ); - PrintText( line.sBranch, linerect ); - -#if !USE_APPLE_FONT - if (g_iConfigDisasmBranchType) - SelectObject( dc, g_aFontConfig[ FONT_DISASM_DEFAULT ]._hFont ); // g_hFontDisasm -#endif + DebuggerSetColorFG( DebuggerGetColor( FG_DISASM_BRANCH ) ); } + +#if !USE_APPLE_FONT + if (g_iConfigDisasmBranchType == DISASM_BRANCH_FANCY) + SelectObject( GetDebuggerMemDC(), g_aFontConfig[ FONT_DISASM_BRANCH ]._hFont ); // g_hFontWebDings +#endif + + PrintText( line.sBranch, linerect ); + +#if !USE_APPLE_FONT + if (g_iConfigDisasmBranchType) + SelectObject( GetDebuggerMemDC(), g_aFontConfig[ FONT_DISASM_DEFAULT ]._hFont ); // g_hFontDisasm +#endif } return nOpbyte; @@ -2303,7 +2283,7 @@ void DrawFlags ( int line, WORD nRegFlags, LPTSTR pFlagNames_) char sFlagNames[ _6502_NUM_FLAGS+1 ] = ""; // = "NVRBDIZC"; // copy from g_aFlagNames char sText[4] = "?"; - RECT rect; + RECT rect; int nFontWidth = g_aFontConfig[ FONT_INFO ]._nFontWidthAvg; @@ -2318,33 +2298,36 @@ void DrawFlags ( int line, WORD nRegFlags, LPTSTR pFlagNames_) nSpacerWidth++; #endif - if (GetDebuggerMemDC()) // TC: Why would this be NULL? - { - rect.top = line * g_nFontHeight; - rect.bottom = rect.top + g_nFontHeight; - rect.left = DISPLAY_FLAG_COLUMN; - rect.right = rect.left + (10 * nFontWidth); + // - DebuggerSetColorBG( DebuggerGetColor( BG_DATA_1 )); // BG_INFO - DebuggerSetColorFG( DebuggerGetColor( FG_INFO_REG )); - PrintText( "P ", rect ); + GetDebuggerMemDC(); - rect.top += g_nFontHeight; - rect.bottom += g_nFontHeight; + rect.top = line * g_nFontHeight; + rect.bottom = rect.top + g_nFontHeight; + rect.left = DISPLAY_FLAG_COLUMN; + rect.right = rect.left + (10 * nFontWidth); - sprintf( sText, "%02X", nRegFlags ); + DebuggerSetColorBG( DebuggerGetColor( BG_DATA_1 )); // BG_INFO + DebuggerSetColorFG( DebuggerGetColor( FG_INFO_REG )); + PrintText( "P ", rect ); - DebuggerSetColorBG( DebuggerGetColor( BG_INFO )); - DebuggerSetColorFG( DebuggerGetColor( FG_INFO_OPCODE )); - PrintText( sText, rect ); + rect.top += g_nFontHeight; + rect.bottom += g_nFontHeight; - rect.top -= g_nFontHeight; - rect.bottom -= g_nFontHeight; - sText[1] = 0; + sprintf( sText, "%02X", nRegFlags ); - rect.left += ((2 + _6502_NUM_FLAGS) * nSpacerWidth); - rect.right = rect.left + nFontWidth; - } + DebuggerSetColorBG( DebuggerGetColor( BG_INFO )); + DebuggerSetColorFG( DebuggerGetColor( FG_INFO_OPCODE )); + PrintText( sText, rect ); + + rect.top -= g_nFontHeight; + rect.bottom -= g_nFontHeight; + sText[1] = 0; + + rect.left += ((2 + _6502_NUM_FLAGS) * nSpacerWidth); + rect.right = rect.left + nFontWidth; + + // int iFlag = 0; int nFlag = _6502_NUM_FLAGS; @@ -2353,45 +2336,41 @@ void DrawFlags ( int line, WORD nRegFlags, LPTSTR pFlagNames_) iFlag = (_6502_NUM_FLAGS - nFlag - 1); bool bSet = (nRegFlags & 1); - if (GetDebuggerMemDC()) // TC: Why would this be NULL? + + sText[0] = g_aBreakpointSource[ BP_SRC_FLAG_C + iFlag ][0]; + + if (bSet) { - sText[0] = g_aBreakpointSource[ BP_SRC_FLAG_C + iFlag ][0]; - if (bSet) - { - DebuggerSetColorBG( DebuggerGetColor( BG_INFO_INVERSE )); - DebuggerSetColorFG( DebuggerGetColor( FG_INFO_INVERSE )); - } - else - { - DebuggerSetColorBG( DebuggerGetColor( BG_INFO )); - DebuggerSetColorFG( DebuggerGetColor( FG_INFO_TITLE )); - } - rect.left -= nSpacerWidth; - rect.right -= nSpacerWidth; - PrintText( sText, rect ); - - // Print Binary value - rect.top += g_nFontHeight; - rect.bottom += g_nFontHeight; - DebuggerSetColorBG( DebuggerGetColor( BG_INFO )); // - DebuggerSetColorFG( DebuggerGetColor( FG_INFO_TITLE )); - - sText[0] = '0' + static_cast(bSet); - PrintText( sText, rect ); - rect.top -= g_nFontHeight; - rect.bottom -= g_nFontHeight; + DebuggerSetColorBG( DebuggerGetColor( BG_INFO_INVERSE )); + DebuggerSetColorFG( DebuggerGetColor( FG_INFO_INVERSE )); } + else + { + DebuggerSetColorBG( DebuggerGetColor( BG_INFO )); + DebuggerSetColorFG( DebuggerGetColor( FG_INFO_TITLE )); + } + + rect.left -= nSpacerWidth; + rect.right -= nSpacerWidth; + PrintText( sText, rect ); + + // Print Binary value + rect.top += g_nFontHeight; + rect.bottom += g_nFontHeight; + DebuggerSetColorBG( DebuggerGetColor( BG_INFO )); + DebuggerSetColorFG( DebuggerGetColor( FG_INFO_TITLE )); + + sText[0] = '0' + static_cast(bSet); + PrintText( sText, rect ); + rect.top -= g_nFontHeight; + rect.bottom -= g_nFontHeight; if (pFlagNames_) { - if (! bSet) //(nFlags & 1)) - { + if (!bSet) sFlagNames[nFlag] = '.'; - } else - { sFlagNames[nFlag] = g_aBreakpointSource[ BP_SRC_FLAG_C + iFlag ][0]; - } } nRegFlags >>= 1; @@ -2399,27 +2378,6 @@ void DrawFlags ( int line, WORD nRegFlags, LPTSTR pFlagNames_) if (pFlagNames_) strcpy(pFlagNames_,sFlagNames); -/* - if (GetDebuggerMemDC()) // TC: Why would this be NULL? - { - rect.top += g_nFontHeight; - rect.bottom += g_nFontHeight; - rect.left = DISPLAY_FLAG_COLUMN; - rect.right = rect.left + (10 * nFontWidth); - - DebuggerSetColorFG( DebuggerGetColor( FG_INFO_REG )); - PrintTextCursorX( "P ", rect ); - - - DebuggerSetColorBG( DebuggerGetColor( BG_INFO )); // COLOR_BG_DATA - - DebuggerSetColorFG( DebuggerGetColor( FG_INFO_REG )); - PrintTextCursorX( "P ", rect ); - - rect.left += (_6502_NUM_FLAGS * nSpacerWidth); - rect.right = rect.left + nFontWidth; - } -*/ } //=========================================================================== @@ -3991,9 +3949,11 @@ void UpdateDisplay (Update_t bUpdate) case WINDOW_IO: DrawWindow_IO( bUpdate ); + break; case WINDOW_SOURCE: DrawWindow_Source( bUpdate ); + break; case WINDOW_SYMBOLS: DrawWindow_Symbols( bUpdate ); @@ -4001,6 +3961,7 @@ void UpdateDisplay (Update_t bUpdate) case WINDOW_ZEROPAGE: DrawWindow_ZeroPage( bUpdate ); + break; default: break; diff --git a/source/Debugger/Debugger_Parser.cpp b/source/Debugger/Debugger_Parser.cpp index 46edfeef..ebd3e02f 100644 --- a/source/Debugger/Debugger_Parser.cpp +++ b/source/Debugger/Debugger_Parser.cpp @@ -201,18 +201,22 @@ void ArgsClear () //=========================================================================== bool ArgsGetValue ( Arg_t *pArg, WORD * pAddressValue_, const int nBase ) { + _ASSERT(pArg); + if (pArg == NULL) + return false; + TCHAR *pSrc = & (pArg->sArg[ 0 ]); TCHAR *pEnd = NULL; - if (pArg && pAddressValue_) + if (pAddressValue_) { *pAddressValue_ = (WORD)(_tcstoul( pSrc, &pEnd, nBase) & _6502_MEM_END); return true; } + return false; } - //=========================================================================== bool ArgsGetImmediateValue ( Arg_t *pArg, WORD * pAddressValue_ ) { From 34094f7299f5aac30c06c56955cdface8c2f36e5 Mon Sep 17 00:00:00 2001 From: tomcw Date: Sun, 17 Dec 2017 19:35:54 +0000 Subject: [PATCH 55/64] Fix static analysis issues raised in PR #517 --- source/Disk.cpp | 9 +++++---- source/DiskImageHelper.cpp | 12 ------------ source/Speaker.cpp | 6 +++--- source/Tfe/Uilib.cpp | 6 ++++++ source/Tfe/Uilib.h | 2 -- 5 files changed, 14 insertions(+), 21 deletions(-) diff --git a/source/Disk.cpp b/source/Disk.cpp index c286bfe3..05761012 100644 --- a/source/Disk.cpp +++ b/source/Disk.cpp @@ -1336,11 +1336,12 @@ static void DiskLoadSnapshotDriveUnit(YamlLoadHelper& yamlLoadHelper, UINT unit) g_aFloppyDisk[unit].trackimagedata = yamlLoadHelper.LoadUint(SS_YAML_KEY_TRACK_IMAGE_DATA); g_aFloppyDisk[unit].trackimagedirty = yamlLoadHelper.LoadUint(SS_YAML_KEY_TRACK_IMAGE_DIRTY); - std::auto_ptr pTrack( new BYTE [NIBBLES_PER_TRACK] ); - memset(pTrack.get(), 0, NIBBLES_PER_TRACK); + std::vector track; + track.resize(NIBBLES_PER_TRACK); + memset(&track[0], 0, track.size()); if (yamlLoadHelper.GetSubMap(SS_YAML_KEY_TRACK_IMAGE)) { - yamlLoadHelper.LoadMemory(pTrack.get(), NIBBLES_PER_TRACK); + yamlLoadHelper.LoadMemory(&track[0], NIBBLES_PER_TRACK); yamlLoadHelper.PopMap(); } @@ -1356,7 +1357,7 @@ static void DiskLoadSnapshotDriveUnit(YamlLoadHelper& yamlLoadHelper, UINT unit) if (g_aFloppyDisk[unit].trackimage == NULL) bImageError = true; else - memcpy(g_aFloppyDisk[unit].trackimage, pTrack.get(), NIBBLES_PER_TRACK); + memcpy(g_aFloppyDisk[unit].trackimage, &track[0], NIBBLES_PER_TRACK); } if (bImageError) diff --git a/source/DiskImageHelper.cpp b/source/DiskImageHelper.cpp index d631c597..a2b21ec8 100644 --- a/source/DiskImageHelper.cpp +++ b/source/DiskImageHelper.cpp @@ -192,9 +192,6 @@ bool CImageBase::WriteBlock(ImageInfo* pImageInfo, const int nBlock, LPBYTE pBlo // Horribly inefficient! (Unzip to a normal file if you want better performance!) const UINT uNewImageSize = Offset+HD_BLOCK_SIZE; BYTE* pNewImageBuffer = new BYTE [uNewImageSize]; - _ASSERT(pNewImageBuffer); - if (!pNewImageBuffer) - return false; memcpy(pNewImageBuffer, pImageInfo->pImageBuffer, pImageInfo->uImageSize); memset(&pNewImageBuffer[pImageInfo->uImageSize], 0, uNewImageSize-pImageInfo->uImageSize); // Should always be HD_BLOCK_SIZE (so this is redundant) @@ -1153,8 +1150,6 @@ ImageError_e CImageHelperBase::CheckGZipFile(LPCTSTR pszImageFilename, ImageInfo const UINT MAX_UNCOMPRESSED_SIZE = GetMaxImageSize() + 1; // +1 to detect images that are too big pImageInfo->pImageBuffer = new BYTE[MAX_UNCOMPRESSED_SIZE]; - if (!pImageInfo->pImageBuffer) - return eIMAGE_ERROR_BAD_POINTER; int nLen = gzread(hGZFile, pImageInfo->pImageBuffer, MAX_UNCOMPRESSED_SIZE); if (nLen < 0 || nLen == MAX_UNCOMPRESSED_SIZE) @@ -1222,8 +1217,6 @@ ImageError_e CImageHelperBase::CheckZipFile(LPCTSTR pszImageFilename, ImageInfo* return eIMAGE_ERROR_BAD_SIZE; pImageInfo->pImageBuffer = new BYTE[uFileSize]; - if (!pImageInfo->pImageBuffer) - return eIMAGE_ERROR_BAD_POINTER; nRes = unzOpenCurrentFile(hZipFile); if (nRes != UNZ_OK) @@ -1352,8 +1345,6 @@ ImageError_e CImageHelperBase::CheckNormalFile(LPCTSTR pszImageFilename, ImageIn const UINT uDetectSize = GetMinDetectSize(dwSize, &bTempDetectBuffer); pImageInfo->pImageBuffer = new BYTE [dwSize]; - if (!pImageInfo->pImageBuffer) - return eIMAGE_ERROR_BAD_POINTER; DWORD dwBytesRead; BOOL bRes = ReadFile(hFile, pImageInfo->pImageBuffer, dwSize, &dwBytesRead, NULL); @@ -1377,9 +1368,6 @@ ImageError_e CImageHelperBase::CheckNormalFile(LPCTSTR pszImageFilename, ImageIn if (pImageType && dwSize) { pImageInfo->pImageBuffer = new BYTE [dwSize]; - if (!pImageInfo->pImageBuffer) - return eIMAGE_ERROR_BAD_POINTER; - ZeroMemory(pImageInfo->pImageBuffer, dwSize); } } diff --git a/source/Speaker.cpp b/source/Speaker.cpp index ff58a7fd..328093a9 100644 --- a/source/Speaker.cpp +++ b/source/Speaker.cpp @@ -130,7 +130,7 @@ static void InitRemainderBuffer() SetClksPerSpkrSample(); g_nRemainderBufferSize = (UINT) g_fClksPerSpkrSample; - if ((double)g_nRemainderBufferSize != g_fClksPerSpkrSample) + if ((double)g_nRemainderBufferSize < g_fClksPerSpkrSample) g_nRemainderBufferSize++; g_pRemainderBuffer = new short [g_nRemainderBufferSize]; @@ -339,10 +339,10 @@ BYTE __stdcall SpkrToggle (WORD, WORD, BYTE, BYTE, ULONG nCyclesLeft) if (g_bQuieterSpeaker) { // quieten the speaker if 8 bit DAC in use - if (g_nSpeakerData == (SPKR_DATA_INIT >> 2)) + if (g_nSpeakerData == (SPKR_DATA_INIT/4)) // NB. Don't shift -ve number right: undefined behaviour (MSDN says: implementation-dependent) g_nSpeakerData = ~g_nSpeakerData; else - g_nSpeakerData = SPKR_DATA_INIT>>2; + g_nSpeakerData = SPKR_DATA_INIT/4; // NB. Don't shift -ve number right: undefined behaviour (MSDN says: implementation-dependent) } else { diff --git a/source/Tfe/Uilib.cpp b/source/Tfe/Uilib.cpp index 262c5883..b350b8ce 100644 --- a/source/Tfe/Uilib.cpp +++ b/source/Tfe/Uilib.cpp @@ -58,6 +58,12 @@ void uilib_get_general_window_extents(HWND hwnd, int *xsize, int *ysize) strlen = SendMessage(hwnd, WM_GETTEXTLENGTH, 0, 0); /* RGJ added cast for AppleWin */ buffer = (char *) malloc(strlen + 1); + if (buffer == NULL) // TC: add null check for AppleWin + { + *xsize = 0; + *ysize = 0; + return; + } GetWindowText(hwnd, buffer, strlen + 1); hdc = GetDC(hwnd); diff --git a/source/Tfe/Uilib.h b/source/Tfe/Uilib.h index f8ec8c8e..22865eab 100644 --- a/source/Tfe/Uilib.h +++ b/source/Tfe/Uilib.h @@ -32,8 +32,6 @@ #include #include -extern void uilib_get_general_window_extents(HWND hwnd, int *xsize, int *ysize); - typedef struct { unsigned int idc; int element_type; From 494a1e32394757084f1ebaeee9d32cbb184b9158 Mon Sep 17 00:00:00 2001 From: tomcw Date: Mon, 18 Dec 2017 21:47:57 +0000 Subject: [PATCH 56/64] VICE KB article 13-005 --- docs/VICE Knowledge Base - Article 13-005.htm | 136 ++++++++++++++++++ .../ab-ms-star-en.gif | Bin 0 -> 1285 bytes .../icoEmail.gif | Bin 0 -> 106 bytes .../vcss.gif | Bin 0 -> 1547 bytes .../vice-logo.png | Bin 0 -> 3447 bytes .../vicekb.css | 78 ++++++++++ 6 files changed, 214 insertions(+) create mode 100644 docs/VICE Knowledge Base - Article 13-005.htm create mode 100644 docs/VICE Knowledge Base - Article 13-005_files/ab-ms-star-en.gif create mode 100644 docs/VICE Knowledge Base - Article 13-005_files/icoEmail.gif create mode 100644 docs/VICE Knowledge Base - Article 13-005_files/vcss.gif create mode 100644 docs/VICE Knowledge Base - Article 13-005_files/vice-logo.png create mode 100644 docs/VICE Knowledge Base - Article 13-005_files/vicekb.css diff --git a/docs/VICE Knowledge Base - Article 13-005.htm b/docs/VICE Knowledge Base - Article 13-005.htm new file mode 100644 index 00000000..1306d72e --- /dev/null +++ b/docs/VICE Knowledge Base - Article 13-005.htm @@ -0,0 +1,136 @@ + + + + + + + + +VICE Knowledge Base - Article 13-005 + + + +

    +
    +

    + +VICE home + Knowledge Base - Article 13-005

    +
    +
    +
    +
    + +
    +

    [Howto] Enable networking with WinVICE

    +
    + The information in this article applies to the following versions of VICE:
    • all Windows versions starting from 1.13
    +

    PROBLEMEXPOSITION

    +

    Starting with WinVICE 1.13, there is support for two ethernet cartridges allowing network access: The "The Final + Ethernet" (TFE) and the "Retroreplay-Net" (RR-Net) cartridges. If you + want to enable support for these, you have to follow the instructions below.

    !WARNING!

    +

    Installing support for networking with VICE requires you to install +3rd party products on your machine. The VICE team cannot be +made responsible for any problems + and/or damage which arises from this! The rejection of any +warranty for VICE + applies, too.
    + The product which has to be installed, WinPCAP, + is a capture library. That is, it captures every packet which is available + on the network, regardless if it was destined for your machine or not. From this, it + follows that it is a real security flaw using WinPCAP in a network. Using WinPCAP + can result in disclosure of any information that is available on your network which is + not secured by other means! Installing WinPCAP, you acknowledge that you're well aware + of this security flaw and that the VICE team cannot be made responsible for any problems + and/or damage which may arise from the use of WinPCAP!

    PREREQUISITES

    +

    At that moment, The ethernet emulation for WinVICE only works if you +have a real ethernet card on your machine and you are +connected to the net via it, that is, you must have + direct access to any station you want to access. Ethernet +is emulated as if the VICE emulator was + connected to your ethernet card via a hub. Every protocol, +in particular PPPOE or other protocols, + are only supported if the corresponding emulated program +supports these!

    SOLUTION

    +

    For networking support, you need administrative rights +(administrator account or similar) on your windows machine. +Without this, there's no chance to have networking work!

    +

    If you have administrative rights, follow the following instructions to install networking + with VICE:

    +
    • First, read the above warning!
    • Get WinPCAP + from their site. There's only need for the WinPCAP auto-installer in order to let VICE run.
    • +
    • Install the WinPCAP package you just downloaded. For this, you need to have the right to install + new drivers to your system. In general, the administrator account does have this right.
    • +
    • Now, start WinVICE as you do always. Do this with the user account you have used in the previous + step to install WinPCAP! Choosing the VICE menu entry Settings/Ethernet, a dialog box + shows up, allowing you to select Ethernet as NONE, TFE ("The final ethernet") or RR-Net. If this + is possible, WinPCAP has be installed successfully to your system. If not, check the WinPCAP FAQ to find a solution.
    • +
    • The only program using ethernet we know to date is Contiki. To use Contiki, get a version of it + from the website. Make sure that it is + a version which is enabled for ethernet (TFE or RR-Net)!
    • +
    • Run this version of Contiki inside x64. Now, enable ethernet with TFE or RR-Net settings, depending + on which type you want to use. Since these two are almost identical, only some addresses are changed, + it's more of a matter of taste which one to use. Select the ethernet device you want to use with + ethernet if you have more than one. +
    • You need an IP address in order to let Contiki run on your network. The virtual ethernet device + of VICE runs as if it were connected to your host computer's device with a hub. No network address + translation (NAT) or the like is performed! Get an IP from your network administrator as if you had + a new machine to connect to your network. In fact, you have one, although it is only emulated.
    • +
    • Now, run Contiki, enter your IP configuration using the IP from above, and everything should + work.
    +

    Enjoy the new surfing experience.

    +

    It's not necessary to log on as administrator in order to run the ethernet emulation. Anyway, + this is necessary the first time you start VICE after you've booted. After you've done + this, you can log off and log in with another account to run VICE. To circumvent this, see + the FAQ section below.

    FAQ

    +

    • Why do I have to log in as administrator in order to start VICE with network support?

      This is because the WinPCAP driver is not loaded at system startup, but rather + on-demand when someone like VICE needs it. Not every user is allowed to start services, thus, you + have to log in as a user with these rights in order to start it. The administrator is a person having + this right. On many machines, an account belonging to the "main user" group is allowed, + too. On these machines, you don't need administrator rights in order to start VICE with networking + support.

      If you don't like this solution, you have another option. See Q-18 at the WinPCAP FAQ.

    • +
    • I have problems with networking support; furthermore, there's a firewall on my machine

      +

      This is a know problem with WinPCAP, it does not work well with all firewalls, see Q-10 at the WinPCAP FAQ. Unfortunately, we don't + have a solution for this. Disabling the firewall, as suggested in Q-10, might not be an option for + you, but we cannot do anything about it.

    • +
    • I have another problem not covered here.

      Have a look at the WinPCAP FAQ, there might be a solution for your problem. +

    STATUS

    +

    This document is for information purpose only. The behaviour reported + is intentional in the VICE versions listed at the beginning + of this article.

    LINKS

    +

    REVISION

    +

    • August 25,2004: Added reference to the same information for Unix based systems
    • October 14, 2003: Before, it was mistakenly said that you find ethernet on + Options/Ethernet. This is not true, it is Settings/Ethernet.
    • +
    • October 8, 2003: Added section PREREQUISITES.
    • +
    • September 15, 2003: Original release of this document

    +
    +

    Last Reviewed: August 25, 2004

    +
    +
    + + + \ No newline at end of file diff --git a/docs/VICE Knowledge Base - Article 13-005_files/ab-ms-star-en.gif b/docs/VICE Knowledge Base - Article 13-005_files/ab-ms-star-en.gif new file mode 100644 index 0000000000000000000000000000000000000000..571d689fd7a554cc59c179f5c783e30bf8e0d0a2 GIT binary patch literal 1285 zcmV+g1^W6&Nk%v~VORhk0M!5h|NsBa&d$ut%*MvX*1f&O$(Oyoy;A4@*0Qp-wYAoz zrQV#JwY7V#t*zdal%=JmgtevKgoG)^|D2qhmX?;8nP%s0ZRcZShK7bSng3FhrIdt1 z?^05LfPfI3@Ao-5V|!z6Zf+2a#`iHXW@cspgwA7QWA`B;T3TBF5)uG&y-Hd_Qc_a? z0001EoJvYcQc590LP9A@QV3FWIXO8qGcz$UF%UUQ06AkRDk&i$As84K02m<<5D*9t z2mk;8EC2ui09XJY000L6z@KnPEE1}r~4ECCHYJ)Mz*JTopXGdx3-a+a+S-C^g-0bkN=PkXgojC$mUQS?xNE4623{8? z$izt3j}U@PblsuDK!6_IbkK+yw%R2hPm$EnFclvWltQpx8w_SbS;KB=mi;mz@r0R* z$~I66Sy$sP2^up(0s(>t4^nRw@%sa-qtmFzjOI}QLI%(hO5mGEx-`GjkP@K%M}~lf z3lRhaK;Xc)1q1>RED%m$0Rl09RkVJMql5$rJZ`vn)ci znl04#9DY7*078pC+#u3*vAMtlUPiz;#)Dht(9M_Iq#|Yj@;PAU2yCiJBm(S(xMU5yB4!#G(fzFEA5kj|imj-U%lZIl!6%xM#rts`&r|2$%}7 z9gEhP1ZpK`ToV%`nK4$A9?62y+yKf!y8r>nEs&UeZ$hW53oia(CwEcxbp(t#r6$It z0jQDxu5bugkirPK=30XaE(jq~Xg|y_)ePf?+K;)YAus|5$dNIM488tvZ@oYGuyDV` z7WP98nPiqpQanx*fDR-CP(#Nxn1DeKp3KA}T!rk=OCk-=(5<&4eHzlsS4Pa(4Ng!|{Vy}oQ96CrVFkBIKN}COirwNfuOe%^#lGpbm-!uZq`KFzFjxZs DCOai- literal 0 HcmV?d00001 diff --git a/docs/VICE Knowledge Base - Article 13-005_files/vcss.gif b/docs/VICE Knowledge Base - Article 13-005_files/vcss.gif new file mode 100644 index 0000000000000000000000000000000000000000..020c75a73a8e73243d762f000ab6e47c24f2418a GIT binary patch literal 1547 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 JmuuO-`X3iF?u7sV literal 0 HcmV?d00001 diff --git a/docs/VICE Knowledge Base - Article 13-005_files/vicekb.css b/docs/VICE Knowledge Base - Article 13-005_files/vicekb.css new file mode 100644 index 00000000..40de4933 --- /dev/null +++ b/docs/VICE Knowledge Base - Article 13-005_files/vicekb.css @@ -0,0 +1,78 @@ +BODY { + FONT-FAMILY: Helvetica, Arial, Tahoma, sans-serif +} +DIV.top { + MARGIN-TOP: 0pt; MARGIN-BOTTOM: 6pt +} +DIV.top.title { + center; FLOAT: right; MARGIN-LEFT: 20% +} +DIV.top.title P { + text-align: center; color: red +} +DIV.top.logo { + FLOAT: left; WIDTH: 20%; MARGIN-RIGHT: 80% +} + +DIV.main { +} + +DIV.sidebar { + MARGIN-TOP: 0pt; FLOAT: right; MARGIN-BOTTOM: 6pt; WIDTH: 30% +} + +DIV.sidebar P { + FONT-SIZE: 8pt; MARGIN: 0pt 2pt 6pt 36pt +} + +DIV.main.content { + MARGIN-RIGHT: 30% + PADDING-RIGHT: 2pt; PADDING-LEFT: 2pt; PADDING-BOTTOM: 2pt; PADDING-TOP: 2pt +} +DIV.main.content P { + FONT-SIZE: 12pt; MARGIN: 0pt 2pt 6pt 36pt +} +DIV.main.content P.centered { + FONT-SIZE: 12pt; MARGIN: 0pt 2pt 6pt; TEXT-ALIGN: center +} +DIV.main.content ui { + MARGIN: 0pt 0pt 6pt +} +DIV.main.content li { + FONT-SIZE: 12pt +} +DIV.main.content h1 { + FONT-SIZE: 20pt +} +DIV.content h2 { + FONT-SIZE: 15pt +} +DIV.content hr { + MARGIN-RIGHT: 30%; HEIGHT: 3pt +} + +DIV.main.content P { +} + +DIV.footer { + PADDING-RIGHT: 2pt; MARGIN-TOP: 6pt; PADDING-LEFT: 2pt; FLOAT: left; MARGIN-BOTTOM: 0pt; PADDING-BOTTOM: 2pt; VERTICAL-ALIGN: baseline; WIDTH: 100%; PADDING-TOP: 2pt +} + +DIV.copyright { + FONT-SIZE: 60%; FLOAT: left +} +DIV.review { + text-align: center; FONT-SIZE: 8pt +} +DIV.fileinfo { + FONT-SIZE: 60%; FLOAT: right +} + +/* + FILE ARCHIVED ON 03:57:53 Jul 19, 2013 AND RETRIEVED FROM THE + INTERNET ARCHIVE ON 21:23:25 Dec 18, 2017. + JAVASCRIPT APPENDED BY WAYBACK MACHINE, COPYRIGHT INTERNET ARCHIVE. + + ALL OTHER CONTENT MAY ALSO BE PROTECTED BY COPYRIGHT (17 U.S.C. + SECTION 108(a)(3)). +*/ \ No newline at end of file From e25b490198f49a40d038d4332c4388c26d25f172 Mon Sep 17 00:00:00 2001 From: tomcw Date: Mon, 18 Dec 2017 21:54:59 +0000 Subject: [PATCH 57/64] Uthernet: 'TFE not supported' message-box contains broken URL, so add a comment about a copy of the old kb article now being in the repo --- source/Configuration/PageConfigTfe.cpp | 2 ++ 1 file changed, 2 insertions(+) diff --git a/source/Configuration/PageConfigTfe.cpp b/source/Configuration/PageConfigTfe.cpp index 5c047897..96cc5814 100644 --- a/source/Configuration/PageConfigTfe.cpp +++ b/source/Configuration/PageConfigTfe.cpp @@ -255,6 +255,8 @@ void CPageConfigTfe::init_tfe_dialog(HWND hwnd) if (gray_ungray_items(hwnd)) { /* we have a problem: TFE is disabled. Give a message to the user */ + // TC (18 Dec 2017) this vicekb URL is a broken link now, so I copied it to the AppleWin repo, here: + // . https://github.com/AppleWin/AppleWin/blob/master/docs/VICE%20Knowledge%20Base%20-%20Article%2013-005.htm MessageBox( hwnd, "TFE support is not available on your system,\n" "there is some important part missing. Please have a\n" From 9236c6722f63114c55c2468f983d6c98eabf4a6a Mon Sep 17 00:00:00 2001 From: tomcw Date: Mon, 18 Dec 2017 23:14:11 +0000 Subject: [PATCH 58/64] Help doc: Add new Appendix, and sub-item about full-speed mode. (Fixes #477) --- help/Table of Contents.hhc | 13 +++++++++- help/appendix.html | 25 +++++++++++++++++++ help/fullspeed.html | 51 ++++++++++++++++++++++++++++++++++++++ help/keyboard.html | 11 +++----- help/toc.html | 24 +++++++----------- 5 files changed, 101 insertions(+), 23 deletions(-) create mode 100644 help/appendix.html create mode 100644 help/fullspeed.html diff --git a/help/Table of Contents.hhc b/help/Table of Contents.hhc index a1b839cf..d53b1bb7 100644 --- a/help/Table of Contents.hhc +++ b/help/Table of Contents.hhc @@ -141,7 +141,7 @@
    • - +
    • @@ -208,6 +208,17 @@
    +
  • + + + + +
      +
    • + + + +
    diff --git a/help/appendix.html b/help/appendix.html new file mode 100644 index 00000000..f3af9eaf --- /dev/null +++ b/help/appendix.html @@ -0,0 +1,25 @@ + + + + + + Appendix + + + + + + + +

    Appendix

    + +
    + + + + + diff --git a/help/fullspeed.html b/help/fullspeed.html new file mode 100644 index 00000000..45fdfefc --- /dev/null +++ b/help/fullspeed.html @@ -0,0 +1,51 @@ + + + + Full-speed mode + + + +

    Full-speed mode

    +
    + +

    Overview:

    +

    Emulation can be run in full-speed (aka unthrottled) mode.

    + +

    Details:

    +

    This can be enabled manually or automatically in a variety of ways:

    + +
      +
    • Permanently enable by the AppleWin Configuration tab's 'Emulation Speed Control', and setting 'Custom Speed (in MHz)' to 'Fastest'. +
    • Scroll Lock key: can be configured to toggle normal/full-speed mode, or only enable full-speed when pressed. +
        +
      • See Input for configuring how Scroll Lock behaves. +
      +
    • When 'Disk access speed' is set to 'Enhanced Speed' (the default), then whenever the Disk][ drive motor is on, the emulator will automatically switch to full-speed (and when the motor is switched off, then the emulator will automatically revert to what the 'Emulation Speed Control' has been set to). +
        +
      • See Disk for configuring 'Disk access speed'. +
      +
    • From the built-in debugger, single-stepping via the 'gg' command. +
    + +

    Limitations and things to bear in mind:

    +
      +
    • Full speed mode favours speed over video accuracy: +
        +
      • The Apple II's video is only updated periodically (once a wall-clock 60Hz frame) instead of each opcode. +
      +
    • All sound (speaker, Mockingboard, etc) is muted. +
    • Video-based timing/synchronisation loops won't work correctly. +
        +
      • The video-scanner won't advance its h/v position, so it will always returns the last value. +
      • Specifically code that does Apple II+ VBlank detection (using the floating bus) will hang, until full-speed mode is disabled. (But Apple //e soft-switch VBlank detection does work.) +
      +
    • Card detection routines (that rely on floating bus) won't work correctly. +
    • One of your PC's CPU cores will run at 100%. +
        +
      • EG. Simply boot the Apple II (or //e) without a disk in drive-1. +
      +
    + + + diff --git a/help/keyboard.html b/help/keyboard.html index 31f5fd85..0f3c4f85 100644 --- a/help/keyboard.html +++ b/help/keyboard.html @@ -43,15 +43,12 @@ key will pause emulation. Press Pause again to resume emulation.

    -

    Scroll Lock:
    - Holding down the PC's - Scroll Lock - key temporarily sets the emulation to full speed (i.e. unthrottled).
    +

    Scroll Lock:
    + Scroll Lock + key can be configured to toggle normal/full-speed mode, or only enable full-speed when pressed. See Input for configuring how Scroll Lock behaves. NOTE:  The status of the PC's Scroll Lock - LED is meaningless.  The emulator will only run full speed while the - Scroll Lock - key is pressed down.

    + LED is meaningless.

    Shift+Insert:
    Paste text from Windows' clipboard. Text gets fed a character at a time to the Apple's keyboard hardware. The 'CR+LF' combination gets converted to CR.

    diff --git a/help/toc.html b/help/toc.html index caab2ce7..304704a4 100644 --- a/help/toc.html +++ b/help/toc.html @@ -12,7 +12,7 @@ Copyright © 1994-1996, Michael O'Brien
    Copyright © 2001, Oliver Schmidt
    Copyright © 2002-2005, Tom Charlesworth
    - Copyright © 2006-2016, Tom Charlesworth, Michael Pohoreski, Nick Westgate, Linards Ticmanis + Copyright © 2006-2017, Tom Charlesworth, Michael Pohoreski, Nick Westgate, Linards Ticmanis

    Acknowledgements @@ -20,20 +20,14 @@
    Select one of the following categories: From a09d0cc6cecce8ef200045767b9fbc94e9829c94 Mon Sep 17 00:00:00 2001 From: tomcw Date: Mon, 18 Dec 2017 23:36:13 +0000 Subject: [PATCH 59/64] Help doc: Add more links to TOC, move Troubleshooting into Appendix and fix-up the URLs in Acknowledgements --- help/Table of Contents.hhc | 8 ++++---- help/acknowledgements.html | 4 ++-- help/appendix.html | 3 +-- help/toc.html | 8 ++++++++ 4 files changed, 15 insertions(+), 8 deletions(-) diff --git a/help/Table of Contents.hhc b/help/Table of Contents.hhc index d53b1bb7..1c7b3d03 100644 --- a/help/Table of Contents.hhc +++ b/help/Table of Contents.hhc @@ -185,10 +185,6 @@ -
  • - - -
  • @@ -218,6 +214,10 @@ +
  • + + + diff --git a/help/acknowledgements.html b/help/acknowledgements.html index 198b152d..ed53a02d 100644 --- a/help/acknowledgements.html +++ b/help/acknowledgements.html @@ -13,13 +13,13 @@

    Thomas Stahl: TV emulation mode (up to v1.25.0.4)

    Chris Foxwell: SSI263 phoneme samples

    Robert Hoem: Hard disk card (source module & f/w)

    -

    VICE team: TFE, Z80, MC6821 PIA emulation modules (http://www.viceteam.org)
    +

    VICE team: TFE, Z80, MC6821 PIA emulation modules (http://vice-emu.sourceforge.net/index.html#developers)
    - In particular, Spiro Trikaliotis for TFE, whose code Glenn Jones adapted for Uthernet support

    FUSE team: AY-3-8910 module (http://fuse-emulator.sourceforge.net)

    Kyle Kim: Mouse card support based on code from Apple in PC

    Fábio Belavenuto: TK3000 Brazilian //e clone (originally responsible for integrating Z80Em)

    Bob Sander-Cederlof: Applesoft Symbols (http://www.txbobsc.com/scsc/scdocumentor/ S-C DocuMentor: Applesoft)

    David Schmidt: Updates to this help file

    -

    Mike Harvey, Founder & Editor of Nibble Magazine: For providing us Apple fans the pleasure of eagerly awaiting each next month's issue to learn about the Apple! (http://www.nibblemagazine.net/)

    +

    Mike Harvey, Founder & Editor of Nibble Magazine: For providing us Apple fans the pleasure of eagerly awaiting each next month's issue to learn about the Apple! (http://www.nibblemagazine.com/)

    diff --git a/help/appendix.html b/help/appendix.html index f3af9eaf..abf5c358 100644 --- a/help/appendix.html +++ b/help/appendix.html @@ -16,9 +16,8 @@
    diff --git a/help/toc.html b/help/toc.html index 304704a4..6e8ba726 100644 --- a/help/toc.html +++ b/help/toc.html @@ -15,6 +15,8 @@ Copyright © 2006-2017, Tom Charlesworth, Michael Pohoreski, Nick Westgate, Linards Ticmanis

    + AppleWin team +
    Acknowledgements

    @@ -25,6 +27,12 @@
  • Disks and Disk Images
  • Using the Toolbar
  • Using the Keyboard +
  • Save-state Files +
  • Sound +
  • Clock +
  • Uthernet network card +
  • Command line +
  • AppleWin Configuration
  • Using the Debugger
  • Resources
  • Appendix
  • From 5ae21f70f79c38660afc7c9ca4099a57f6e8badf Mon Sep 17 00:00:00 2001 From: tomcw Date: Mon, 18 Dec 2017 23:46:48 +0000 Subject: [PATCH 60/64] Help doc: for -modem switch: add ref to GBBS Pro. (Fixes #386) --- help/CommandLine.html | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/help/CommandLine.html b/help/CommandLine.html index ed148db3..9ab9ddcb 100644 --- a/help/CommandLine.html +++ b/help/CommandLine.html @@ -1,7 +1,7 @@ - Save-State Files + Command line Load a save-state file

    -modem
    - Shorthand for passing -dtr -dcd -dsr

    + Shorthand for passing -dtr -dcd -dsr
    + Use with GBBS Pro (or any other BBS package). See the GBBS Pro 2.2 book from Call-A.P.P.L.E. +

    -dtr
    Support SSC's DTR (Data Terminal Ready) control bit

    -dcd
    From 266ff48b684b420ebe670aea1819ee78c514155d Mon Sep 17 00:00:00 2001 From: tomcw Date: Tue, 19 Dec 2017 00:19:26 +0000 Subject: [PATCH 61/64] Help doc: add Uthernet WiFi workaround. (Fixes #376) --- help/Table of Contents.hhc | 7 +++++ help/uthernet-wifi-workaround.html | 48 ++++++++++++++++++++++++++++++ help/uthernet.html | 6 ++-- 3 files changed, 58 insertions(+), 3 deletions(-) create mode 100644 help/uthernet-wifi-workaround.html diff --git a/help/Table of Contents.hhc b/help/Table of Contents.hhc index 1c7b3d03..727bd493 100644 --- a/help/Table of Contents.hhc +++ b/help/Table of Contents.hhc @@ -89,7 +89,14 @@
  • + +
      +
    • + + + +
  • diff --git a/help/uthernet-wifi-workaround.html b/help/uthernet-wifi-workaround.html new file mode 100644 index 00000000..00ff6d79 --- /dev/null +++ b/help/uthernet-wifi-workaround.html @@ -0,0 +1,48 @@ + + + + WiFi workaround + + + +

    WiFi workaround

    +
    +

    Overview: +

    +

    A (heavyweight) workaround for the WiFi issue.

    + +

    Details: +

    +

    Installing a virtualization solution like the (free) VMware +Workstation Player provides a virtual ethernet card. Then installing +WinPcap inside the virtual machine allows access to the internet via +WiFi from AppleWin.

    + +

    VMware allows you to configure the virtual ethernet card in two ways:

    +
      +
    • Bridged, this means that the virtual Uthernet card becomes visible +with its MAC address in the WiFi net and that an Apple II DHCP client +gets its address from the usual DHCP server (typically a WAN router). +
    • NAT, this means that the virtual Uthernet card is part of a virtual +network with three participants: +
        +
      • A virtual Ethernet card added by VMware to the "outside" (aka host) Windows. +
      • The virtual Ethernet card used by the "inside" (aka guest) Windows. +
      • The virtual Uthernet card. +
      +
      + That virtual network has its own IP address range and has its own DHCP +server (being part of VMware). An Apple II DHCP client gets its +address from that DHCP server. +
    + +

    Another positive aspect of that "emulation inside vitualization" +approach is that the "inside" (aka guest) Windows always has just one +single network interface: that virtual ethernet card mentioned above. +And that interface has always the same name (even when switching +between Bridged and NAT) so one never has to fiddle with network +setting of the emulators using WinPcap.

    + + + diff --git a/help/uthernet.html b/help/uthernet.html index 5076acb5..373245be 100644 --- a/help/uthernet.html +++ b/help/uthernet.html @@ -1,7 +1,7 @@ - Save-State Files + Uthernet network card Acknowledgment:

    Uthernet (TFE) support in Applewin was made possible by implementing the GPL - source written by Spiro Trikaliotis for the Vice emulator - - http://www.viceteam.org/

    + source written by Spiro Trikaliotis for the Vice emulator - + http://vice-emu.sourceforge.net/index.html#developers

    Details:

    To enable Ethernet support in AppleWin you must first download and install From 792a79bb00e35c35d3e988ad6f1cfe1973d36665 Mon Sep 17 00:00:00 2001 From: tomcw Date: Tue, 19 Dec 2017 21:24:25 +0000 Subject: [PATCH 62/64] Help doc: Fix Uthernet URLs --- help/fullspeed.html | 2 +- help/uthernet.html | 30 +++++++++++++++--------------- 2 files changed, 16 insertions(+), 16 deletions(-) diff --git a/help/fullspeed.html b/help/fullspeed.html index 45fdfefc..562c23d2 100644 --- a/help/fullspeed.html +++ b/help/fullspeed.html @@ -37,7 +37,7 @@

  • All sound (speaker, Mockingboard, etc) is muted.
  • Video-based timing/synchronisation loops won't work correctly.
      -
    • The video-scanner won't advance its h/v position, so it will always returns the last value. +
    • The video-scanner won't advance its h/v position, so the floating bus will always return the same value.
    • Specifically code that does Apple II+ VBlank detection (using the floating bus) will hang, until full-speed mode is disabled. (But Apple //e soft-switch VBlank detection does work.)
  • Card detection routines (that rely on floating bus) won't work correctly. diff --git a/help/uthernet.html b/help/uthernet.html index 373245be..2aa8c40a 100644 --- a/help/uthernet.html +++ b/help/uthernet.html @@ -19,21 +19,19 @@ http://vice-emu.sourceforge.net/index.html#developers

    Details:

    -

    To enable Ethernet support in AppleWin you must first download and install +

    To enable ethernet support in AppleWin you must first download and install WinPcap.

    -

    An Alternative to downloading WinPcap is to get the Ethereal package which - includes WinPcap along with Ethereal network analyzer code. To use Ethereal to +

    An alternative to downloading WinPcap is to get the Wireshark package which + includes WinPcap along with Wireshark network analyzer code. To use Wireshark to capture traffic (other than your own) you must be plugged into a shared hub vs - a switch. If you plan on doing any network programming ethereal is a definite + a switch. If you plan on doing any network programming Wireshark is a definite must have.

    -

    WinPcap: http://www.WinPcap.org/install/default.htm - or Ethereal: +

    WinPcap: http://www.WinPcap.org/install/default.htm + or Wireshark: https://www.wireshark.org

    -

    http://www.ethereal.com/download.html -

    -

    After AppleWin starts, select the settings ICON and then select the Ethernet +

    After AppleWin starts, select the settings icon and then select the ethernet settings button.

    Uthernet will be disabled. Select Uthernet from the list of available ethernet @@ -44,13 +42,15 @@

    If you have more than one interface you may need to select them in turn in order to get the text description for each interface vs what WinPcap likes to use for - a reference. Select Ok. and then close AppleWin. *Note:* Wireless does not work - with WinPcap. + a reference. Select Ok. and then close AppleWin.

    -

    NOTE: Due to a current limitation you must exit AppleWin and re-run AppleWin for - 'a' ethernet interface change to take effect. +

    Note: Wireless does not work + with WinPcap (but see WiFi Workaround).

    -

    In order to test the Ethernet emulation out you should grab a copy of Contiki +

    Note: Due to a current limitation you must exit AppleWin and + re-run AppleWin for an ethernet interface change to take effect. +

    +

    In order to test the ethernet emulation out you should grab a copy of Contiki for the Apple II here - http://www.a2retrosystems.com/downloads.htm

    Grab the 80 Col. Primary Disk and Supplementary Disk images if using Apple //e @@ -88,6 +88,6 @@

    If you have ZoneAlarm running then try disabling it inorder to access the web. if you are still having difficulty then you should refer to the VICE network support page for additional information - - http://vicekb.trikaliotis.net/13-005.shtml

    + http://vicekb.trikaliotis.net/13-005.shtml

    From 7e38429766e164815c3e200ea2077e2c9aab87d3 Mon Sep 17 00:00:00 2001 From: tomcw Date: Tue, 19 Dec 2017 21:35:04 +0000 Subject: [PATCH 63/64] Serial-over-TCP: Receive wasn't setting the ASIC's Status register's interrupt bit. (Fix #308) --- source/SerialComms.cpp | 1 + 1 file changed, 1 insertion(+) diff --git a/source/SerialComms.cpp b/source/SerialComms.cpp index 030b232b..7a531e85 100644 --- a/source/SerialComms.cpp +++ b/source/SerialComms.cpp @@ -401,6 +401,7 @@ void CSuperSerialCard::CommTcpSerialReceive() if (m_bRxIrqEnabled && !m_qTcpSerialBuffer.empty()) { CpuIrqAssert(IS_SSC); + m_vbRxIrqPending = true; } } } From f37b82a8e79f82f8944987088f58ca241661f356 Mon Sep 17 00:00:00 2001 From: tomcw Date: Tue, 19 Dec 2017 22:00:08 +0000 Subject: [PATCH 64/64] Serial: after loading save-state, set m_uDTR variable correctly --- source/SerialComms.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/source/SerialComms.cpp b/source/SerialComms.cpp index 7a531e85..c63533a5 100644 --- a/source/SerialComms.cpp +++ b/source/SerialComms.cpp @@ -1334,7 +1334,7 @@ void CSuperSerialCard::SetSnapshot_v1( const DWORD baudrate, // m_vRecvBytes = recvbytes; m_uStopBits = stopbits; - //m_uDTR = (m_uCommandByte & 0x01) ? DTR_CONTROL_ENABLE : DTR_CONTROL_DISABLE; // TODO: Once GH#386 is resolved + m_uDTR = (m_uCommandByte & 0x01) ? DTR_CONTROL_ENABLE : DTR_CONTROL_DISABLE; } //=========================================================================== @@ -1441,7 +1441,7 @@ bool CSuperSerialCard::LoadSnapshot(YamlLoadHelper& yamlLoadHelper, UINT slot, U m_vbRxIrqPending = yamlLoadHelper.LoadBool(SS_YAML_KEY_RXIRQPENDING); m_bWrittenTx = yamlLoadHelper.LoadBool(SS_YAML_KEY_WRITTENTX); - //m_uDTR = (m_uCommandByte & 0x01) ? DTR_CONTROL_ENABLE : DTR_CONTROL_DISABLE; // TODO: Once GH#386 is resolved + m_uDTR = (m_uCommandByte & 0x01) ? DTR_CONTROL_ENABLE : DTR_CONTROL_DISABLE; std::string serialPortName = yamlLoadHelper.LoadString(SS_YAML_KEY_SERIALPORTNAME); SetSerialPortName(serialPortName.c_str());
  • - Serial Port:
    -
    This option will remap the emulated Apple's serial port to your PC's - serial port (or TCP port 1977). The Apple Super Serial Card (SSC) is emulated in slot-2.
    - The TCP interface to the Apple SSC can be used by the
    Apple // Game Server. - For details see the notes that comes with AGS:
    -