From 8d771d049e936e0e7064dbd3d76ad8f96b497e0e Mon Sep 17 00:00:00 2001 From: tomascz Date: Sat, 16 Nov 2019 17:59:39 +0100 Subject: [PATCH] [#28] Spectrum Tape: Minor source code improvements and bugfixes (Part 9: Fixed computation of checksum for newly imported data blocks) --- Main/src/SpectrumDos_Tape.cpp | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/Main/src/SpectrumDos_Tape.cpp b/Main/src/SpectrumDos_Tape.cpp index 10de5ced..ec153ed4 100644 --- a/Main/src/SpectrumDos_Tape.cpp +++ b/Main/src/SpectrumDos_Tape.cpp @@ -258,6 +258,12 @@ #define NUMBER_OF_BYTES_TO_ALLOCATE_FILE(dataLength)\ (sizeof(TTapeFile)+dataLength) + static BYTE __getChecksum__(BYTE flag,PCBYTE data,WORD nBytes){ + // computes and returns the Checksum based on specified Flag and Data + while (nBytes--) flag^=*data++; + return flag; + } + TStdWinError CSpectrumDos::CTape::ImportFile(CFile *f,DWORD fileSize,LPCTSTR nameAndExtension,DWORD winAttr,PFile &rFile){ // imports specified File (physical or virtual) into the Image; returns Windows standard i/o error // - checking if there's an empty slot in Tape's "Directory" @@ -317,6 +323,7 @@ } // - importing File Data f->Read( tf->data, fileSize ); + tf->dataChecksum=__getChecksum__( tf->dataBlockFlag, tf->data, fileSize ); // - File successfully imported into Tape m_bModified=TRUE; return ERROR_SUCCESS; @@ -379,11 +386,6 @@ - static BYTE __getChecksum__(BYTE flag,PCBYTE data,WORD nBytes){ - // computes and returns the Checksum based on specified Flag and Data - while (nBytes--) flag^=*data++; - return flag; - } BOOL CSpectrumDos::CTape::DoSave(LPCTSTR,BOOL){ // True <=> Image successfully saved, otherwise False fileManager.f.SetLength(0); // rewriting Tape's underlying physical file