From 01e48461e3ddf45c2e9065276ff4b4c5f59ae77b Mon Sep 17 00:00:00 2001 From: George Hazan Date: Sun, 25 Mar 2018 21:39:35 +0300 Subject: MIDatabaseChecker interface removed --- plugins/Db3x_mmap/src/dbtool/aggressive.cpp | 55 ---- plugins/Db3x_mmap/src/dbtool/contactchain.cpp | 109 ------- plugins/Db3x_mmap/src/dbtool/disk.cpp | 103 ------- plugins/Db3x_mmap/src/dbtool/eventchain.cpp | 392 ------------------------- plugins/Db3x_mmap/src/dbtool/finaltasks.cpp | 37 --- plugins/Db3x_mmap/src/dbtool/initialchecks.cpp | 74 ----- plugins/Db3x_mmap/src/dbtool/modulechain.cpp | 140 --------- plugins/Db3x_mmap/src/dbtool/settingschain.cpp | 78 ----- plugins/Db3x_mmap/src/dbtool/user.cpp | 76 ----- 9 files changed, 1064 deletions(-) delete mode 100644 plugins/Db3x_mmap/src/dbtool/aggressive.cpp delete mode 100644 plugins/Db3x_mmap/src/dbtool/contactchain.cpp delete mode 100644 plugins/Db3x_mmap/src/dbtool/disk.cpp delete mode 100644 plugins/Db3x_mmap/src/dbtool/eventchain.cpp delete mode 100644 plugins/Db3x_mmap/src/dbtool/finaltasks.cpp delete mode 100644 plugins/Db3x_mmap/src/dbtool/initialchecks.cpp delete mode 100644 plugins/Db3x_mmap/src/dbtool/modulechain.cpp delete mode 100644 plugins/Db3x_mmap/src/dbtool/settingschain.cpp delete mode 100644 plugins/Db3x_mmap/src/dbtool/user.cpp (limited to 'plugins/Db3x_mmap/src/dbtool') diff --git a/plugins/Db3x_mmap/src/dbtool/aggressive.cpp b/plugins/Db3x_mmap/src/dbtool/aggressive.cpp deleted file mode 100644 index b0db2001fd..0000000000 --- a/plugins/Db3x_mmap/src/dbtool/aggressive.cpp +++ /dev/null @@ -1,55 +0,0 @@ -/* -Miranda Database Tool -Copyright (C) 2001-2005 Richard Hughes - -This program is free software; you can redistribute it and/or -modify it under the terms of the GNU General Public License -as published by the Free Software Foundation; either version 2 -of the License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU General Public License for more details. - -You should have received a copy of the GNU General Public License -along with this program; if not, write to the Free Software -Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -*/ -#include "../stdafx.h" - -#define BLOCKSIZE 65536 - -int CDb3Mmap::WorkAggressive(int firstTime) -{ - if (firstTime) { - if (!cb->bAggressive) - return ERROR_NO_MORE_ITEMS; - - cb->pfnAddLogMessage(STATUS_MESSAGE, TranslateT("Performing aggressive pass")); - ofsAggrCur = 0; - cb->spaceProcessed = 0; - } - - int blockBytes = min(BLOCKSIZE + 3, (int)(sourceFileSize - ofsAggrCur)); - if (blockBytes <= 0) - return ERROR_NO_MORE_ITEMS; - - BYTE *buf = m_pDbCache + ofsAggrCur; - blockBytes -= 3; - for (int i = 0; i < blockBytes; i++) { - if (buf[i]) { - if ((*(PDWORD)&buf[i] & 0x00FFFFFF) != 0xDECADE) - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("Aggressive: random junk at %08X: skipping"), ofsAggrCur + i); - else - //TODO: give user the option of placing manually - cb->pfnAddLogMessage(STATUS_ERROR, TranslateT("Aggressive: unlinked data at %08X: can't automatically place"), ofsAggrCur + i); - - for (; i < blockBytes; i++) - if (buf[i] == 0) { i--; break; } - } - } - ofsAggrCur += BLOCKSIZE; - cb->spaceProcessed = ofsAggrCur; - return ERROR_SUCCESS; -} diff --git a/plugins/Db3x_mmap/src/dbtool/contactchain.cpp b/plugins/Db3x_mmap/src/dbtool/contactchain.cpp deleted file mode 100644 index fdc0922aba..0000000000 --- a/plugins/Db3x_mmap/src/dbtool/contactchain.cpp +++ /dev/null @@ -1,109 +0,0 @@ -/* -Miranda Database Tool -Copyright (C) 2001-2005 Richard Hughes - -This program is free software; you can redistribute it and/or -modify it under the terms of the GNU General Public License -as published by the Free Software Foundation; either version 2 -of the License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU General Public License for more details. - -You should have received a copy of the GNU General Public License -along with this program; if not, write to the Free Software -Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -*/ - -#include "../stdafx.h" - -static DWORD ofsThisContact, ofsDestPrevContact; -static DWORD contactCount; -static DWORD ofsDestThis, ofsNextContact; -static int phase; -static DBContact dbc; - -int CDb3Mmap::WorkContactChain(int firstTime) -{ - int first = 0; - int ret; - - if (firstTime) { - cb->pfnAddLogMessage(STATUS_MESSAGE, TranslateT("Processing contact chain")); - ofsDestPrevContact = 0; - ofsThisContact = m_dbHeader.ofsFirstContact; - contactCount = 0; - m_dbHeader.ofsFirstContact = 0; - phase = 0; - } - - switch (phase) { - case 0: - if (ofsThisContact == 0) { - LBL_FinishUp: - if (contactCount != m_dbHeader.contactCount) - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("Contact count marked wrongly: correcting")); - m_dbHeader.contactCount = contactCount; - return ERROR_NO_MORE_ITEMS; - } - if (!SignatureValid(ofsThisContact, DBCONTACT_SIGNATURE)) { - cb->pfnAddLogMessage(STATUS_ERROR, TranslateT("Contact chain corrupted, further entries ignored")); - goto LBL_FinishUp; - } - - if (m_dbHeader.version < DB_095_VERSION) { - if (ReadSegment(ofsThisContact, &dbc, offsetof(DBContact, dwContactID)) != ERROR_SUCCESS) - goto LBL_FinishUp; - dbc.dwContactID = m_dwMaxContactId++; - } - else { - if (ReadSegment(ofsThisContact, &dbc, sizeof(dbc)) != ERROR_SUCCESS) - goto LBL_FinishUp; - } - - ofsNextContact = dbc.ofsNext; - dbc.ofsNext = 0; - if (!cb->bCheckOnly) { - if ((ofsDestThis = WriteSegment(WSOFS_END, &dbc, sizeof(dbc))) == WS_ERROR) - return ERROR_HANDLE_DISK_FULL; - if (ofsDestPrevContact) - WriteSegment(ofsDestPrevContact + offsetof(DBContact, ofsNext), &ofsDestThis, sizeof(DWORD)); - else - m_dbHeader.ofsFirstContact = ofsDestThis; - } - else ofsDestThis = ofsThisContact; // needed in event chain worker - - contactCount++; - phase++; first = 1; - - // fall thru - case 1: - ret = WorkSettingsChain(&dbc, first); - if (ret == ERROR_NO_MORE_ITEMS) { - phase++; first = 1; - } - else if (ret) return ret; - else break; - - // fall thru - case 2: - ret = WorkEventChain(ofsDestThis, &dbc, first); - if (ret == ERROR_NO_MORE_ITEMS) { - phase++; first = 1; - } - else if (ret) return ret; - else break; - - // fall thru - case 3: - if (WriteSegment(ofsDestThis, &dbc, sizeof(DBContact)) == WS_ERROR) - return ERROR_HANDLE_DISK_FULL; - ofsDestPrevContact = ofsDestThis; - ofsThisContact = ofsNextContact; - phase = 0; - break; - } - return ERROR_SUCCESS; -} diff --git a/plugins/Db3x_mmap/src/dbtool/disk.cpp b/plugins/Db3x_mmap/src/dbtool/disk.cpp deleted file mode 100644 index 3310c7dd67..0000000000 --- a/plugins/Db3x_mmap/src/dbtool/disk.cpp +++ /dev/null @@ -1,103 +0,0 @@ -/* -Miranda Database Tool -Copyright (C) 2001-2005 Richard Hughes - -This program is free software; you can redistribute it and/or -modify it under the terms of the GNU General Public License -as published by the Free Software Foundation; either version 2 -of the License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU General Public License for more details. - -You should have received a copy of the GNU General Public License -along with this program; if not, write to the Free Software -Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -*/ - -#include "../stdafx.h" - -int CDb3Mmap::SignatureValid(DWORD ofs, DWORD signature) -{ - if (ofs + sizeof(DWORD) >= sourceFileSize) { - cb->pfnAddLogMessage(STATUS_ERROR, TranslateT("Invalid offset found (database truncated?)")); - return 0; - } - - DWORD *sig = (DWORD*)(m_pDbCache + ofs); - return *sig == signature; -} - -int CDb3Mmap::PeekSegment(DWORD ofs, PVOID buf, int cbBytes) -{ - if (ofs >= sourceFileSize) { - cb->pfnAddLogMessage(STATUS_ERROR, TranslateT("Invalid offset found")); - return ERROR_SEEK; - } - - DWORD bytesRead; - if (ofs + cbBytes > sourceFileSize) - bytesRead = sourceFileSize - ofs; - else - bytesRead = cbBytes; - - if (bytesRead == 0) { - cb->pfnAddLogMessage(STATUS_ERROR, TranslateT("Error reading, database truncated? (%u)"), GetLastError()); - return ERROR_READ_FAULT; - } - - memcpy(buf, m_pDbCache + ofs, bytesRead); - - if ((int)bytesReadbAggressive) { - if (ofs + cbBytes > sourceFileSize) { - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("Can't write to working file, aggressive mode may be too aggressive now")); - memset((m_pDbCache + ofs), 0, (sourceFileSize - ofs)); - } - else memset((m_pDbCache + ofs), 0, cbBytes); - } - cb->spaceProcessed += cbBytes; - return ERROR_SUCCESS; -} - -DWORD CDb3Mmap::WriteSegment(DWORD ofs, PVOID buf, int cbBytes) -{ - DWORD bytesWritten; - if (cb->bCheckOnly) return 0xbfbfbfbf; - if (ofs == WSOFS_END) { - ofs = m_dbHeader.ofsFileEnd; - m_dbHeader.ofsFileEnd += cbBytes; - } - SetFilePointer(cb->hOutFile, ofs, nullptr, FILE_BEGIN); - WriteFile(cb->hOutFile, buf, cbBytes, &bytesWritten, nullptr); - if ((int)bytesWritten < cbBytes) { - cb->pfnAddLogMessage(STATUS_FATAL, TranslateT("Can't write to output file - disk full? (%u)"), GetLastError()); - return WS_ERROR; - } - return ofs; -} - -int CDb3Mmap::ReadWrittenSegment(DWORD ofs, PVOID buf, int cbBytes) -{ - DWORD bytesRead; - if (cb->bCheckOnly) return 0xbfbfbfbf; - if (ofs + cbBytes > m_dbHeader.ofsFileEnd) - return ERROR_SEEK; - - SetFilePointer(cb->hOutFile, ofs, nullptr, FILE_BEGIN); - ReadFile(cb->hOutFile, buf, cbBytes, &bytesRead, nullptr); - if ((int)bytesRead < cbBytes) - return ERROR_READ_FAULT; - - return ERROR_SUCCESS; -} diff --git a/plugins/Db3x_mmap/src/dbtool/eventchain.cpp b/plugins/Db3x_mmap/src/dbtool/eventchain.cpp deleted file mode 100644 index 1546df418d..0000000000 --- a/plugins/Db3x_mmap/src/dbtool/eventchain.cpp +++ /dev/null @@ -1,392 +0,0 @@ -/* - -Miranda Database Tool -Miranda NG: the free IM client for Microsoft* Windows* - -Copyright (c) 2012-18 Miranda NG team (https://miranda-ng.org), -Copyright 2000-2011 Miranda ICQ/IM project, -all portions of this codebase are copyrighted to the people -listed in contributors.txt. - -This program is free software; you can redistribute it and/or -modify it under the terms of the GNU General Public License -as published by the Free Software Foundation; either version 2 -of the License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU General Public License for more details. - -You should have received a copy of the GNU General Public License -along with this program; if not, write to the Free Software -Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -*/ -#include "../stdafx.h" - -#define DBEF_ALL (DBEF_READ | DBEF_SENT | DBEF_RTL | DBEF_UTF | DBEF_ENCRYPTED) - -static BOOL backLookup; -static DWORD ofsThisEvent, ofsPrevEvent; -static DWORD ofsDestPrevEvent; -static DWORD eventCount; -static DWORD lastTimestamp; -static DWORD ofsFirstUnread, tsFirstUnread; -static DWORD memsize = 0; -static DBEvent* memblock = nullptr; -static DBEvent* dbePrevEvent = nullptr; - -void CDb3Mmap::ConvertOldEvent(DBEvent*& dbei) -{ - int msglen = (int)mir_strlen((char*)dbei->blob) + 1, msglenW = 0; - if (msglen != (int)dbei->cbBlob) { - int count = ((dbei->cbBlob - msglen) / sizeof(WCHAR)); - WCHAR* p = (WCHAR*)&dbei->blob[msglen]; - for (int i = 0; i < count; i++) { - if (p[i] == 0) { - msglenW = i; - break; - } - } - } - else { - if (!Utf8CheckString((char*)dbei->blob)) - dbei->flags &= ~DBEF_UTF; - } - - if (msglenW > 0 && msglenW <= msglen) { - char* utf8str = Utf8EncodeW((WCHAR*)&dbei->blob[msglen]); - if (utf8str == nullptr) - return; - - dbei->cbBlob = (DWORD)mir_strlen(utf8str) + 1; - dbei->flags |= DBEF_UTF; - if (offsetof(DBEvent, blob) + dbei->cbBlob > memsize) { - memsize = offsetof(DBEvent, blob) + dbei->cbBlob; - memblock = (DBEvent*)realloc(memblock, memsize); - dbei = memblock; - } - memcpy(&dbei->blob, utf8str, dbei->cbBlob); - mir_free(utf8str); - } -} - -void CDb3Mmap::WriteOfsNextToPrevious(DWORD ofsPrev, DBContact *dbc, DWORD ofsNext) -{ - if (ofsPrev) - WriteSegment(ofsPrev + offsetof(DBEvent, ofsNext), &ofsNext, sizeof(DWORD)); - else - dbc->ofsFirstEvent = ofsNext; -} - -void CDb3Mmap::FinishUp(DWORD ofsLast, DBContact *dbc) -{ - WriteOfsNextToPrevious(ofsLast, dbc, 0); - if (eventCount != dbc->eventCount && !(dbc->ofsFirstEvent == 0 && dbc->ofsLastEvent == 0 && dbc->ofsFirstUnread == 0)) { - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("Event count marked wrongly: correcting")); - dbc->eventCount = eventCount; - } - dbc->ofsLastEvent = ofsLast; - if (cb->bMarkRead) { - dbc->ofsFirstUnread = 0; - dbc->tsFirstUnread = 0; - } - else { - dbc->ofsFirstUnread = ofsFirstUnread; - dbc->tsFirstUnread = tsFirstUnread; - } - if (memsize && memblock) { - free(memblock); - memsize = 0; - memblock = nullptr; - } -} - -DWORD CDb3Mmap::PeekEvent(DWORD ofs, DWORD dwContactID, DBEvent &dbe) -{ - if (m_dbHeader.version >= DB_095_1_VERSION) - return PeekSegment(ofs, &dbe, sizeof(DBEvent)); - - DBEvent_094 oldEvent; - DWORD ret = PeekSegment(ofs, &oldEvent, sizeof(oldEvent)); - if (ret != ERROR_SUCCESS) - return ret; - - dbe.signature = oldEvent.signature; - dbe.contactID = dwContactID; - memcpy(&dbe.ofsPrev, &oldEvent.ofsPrev, sizeof(oldEvent) - sizeof(DWORD)); - return ERROR_SUCCESS; -} - -DWORD CDb3Mmap::WriteEvent(DBEvent *dbe) -{ - DWORD ofs = WriteSegment(WSOFS_END, dbe, offsetof(DBEvent, blob) + dbe->cbBlob); - if (ofs == WS_ERROR) { - free(memblock); - memblock = nullptr; - memsize = 0; - return 0; - } - return ofs; -} - -int CDb3Mmap::WorkEventChain(DWORD ofsContact, DBContact *dbc, int firstTime) -{ - int isUnread = 0; - - if (firstTime) { - dbePrevEvent = nullptr; - ofsPrevEvent = 0; - ofsDestPrevEvent = 0; - ofsThisEvent = dbc->ofsFirstEvent; - eventCount = 0; - backLookup = 0; - lastTimestamp = 0; - ofsFirstUnread = tsFirstUnread = 0; - if (cb->bEraseHistory) { - dbc->eventCount = 0; - dbc->ofsFirstEvent = 0; - dbc->ofsLastEvent = 0; - dbc->ofsFirstUnread = 0; - dbc->tsFirstUnread = 0; - return ERROR_NO_MORE_ITEMS; - } - } - - if (ofsThisEvent == 0) { - FinishUp(ofsDestPrevEvent, dbc); - return ERROR_NO_MORE_ITEMS; - } - - DBEvent dbeOld; - if (!SignatureValid(ofsThisEvent, DBEVENT_SIGNATURE)) { - DWORD ofsNew = 0; - DWORD ofsTmp = dbc->ofsLastEvent; - - if (!backLookup && ofsTmp) { - backLookup = 1; - while (SignatureValid(ofsTmp, DBEVENT_SIGNATURE)) { - if (PeekEvent(ofsTmp, dbc->dwContactID, dbeOld) != ERROR_SUCCESS) - break; - ofsNew = ofsTmp; - ofsTmp = dbeOld.ofsPrev; - } - } - if (ofsNew) { - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("Event chain corrupted, trying to recover...")); - ofsThisEvent = ofsNew; - } - else { - cb->pfnAddLogMessage(STATUS_ERROR, TranslateT("Event chain corrupted, further entries ignored")); - FinishUp(ofsDestPrevEvent, dbc); - return ERROR_NO_MORE_ITEMS; - } - } - - if (PeekEvent(ofsThisEvent, dbc->dwContactID, dbeOld) != ERROR_SUCCESS) { - FinishUp(ofsDestPrevEvent, dbc); - return ERROR_NO_MORE_ITEMS; - } - - if (firstTime) { - if (dbeOld.ofsPrev != 0) - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("First event not marked as such: correcting")); - - dbeOld.ofsPrev = 0; - lastTimestamp = dbeOld.timestamp; - } - - if (dbeOld.flags & 1) - dbeOld.flags &= ~1; - - if (dbeOld.flags & ~DBEF_ALL) { - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("Extra flags found in event: removing")); - dbeOld.flags &= DBEF_ALL; - } - - if (!(dbeOld.flags & (DBEF_READ | DBEF_SENT))) { - if (cb->bMarkRead) dbeOld.flags |= DBEF_READ; - else if (ofsFirstUnread == 0) { - if (dbc->ofsFirstUnread != ofsThisEvent || dbc->tsFirstUnread != dbeOld.timestamp) - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("First unread event marked wrong: fixing")); - isUnread = 1; - } - } - - if (dbeOld.cbBlob > 1024 * 1024 || dbeOld.cbBlob == 0) { - cb->pfnAddLogMessage(STATUS_ERROR, TranslateT("Infeasibly large event blob: skipping")); - ofsThisEvent = dbeOld.ofsNext; - return ERROR_SUCCESS; - } - - DBEvent *dbePrev = nullptr; - if (dbePrevEvent && dbeOld.timestamp == lastTimestamp) { - int len = offsetof(DBEvent, blob) + dbePrevEvent->cbBlob; - dbePrev = (DBEvent*)malloc(len); - memcpy(dbePrev, dbePrevEvent, len); - } - - if (offsetof(DBEvent, blob) + dbeOld.cbBlob > memsize) { - memsize = offsetof(DBEvent, blob) + dbeOld.cbBlob; - memblock = (DBEvent*)realloc(memblock, memsize); - } - DBEvent *dbeNew = memblock; - - DWORD ret; - if (m_dbHeader.version < DB_095_1_VERSION) { - DBEvent_094 oldEvent; - ret = ReadSegment(ofsThisEvent, &oldEvent, offsetof(DBEvent_094, blob)); - if (ret == ERROR_SUCCESS) { - dbeNew->signature = oldEvent.signature; - dbeNew->contactID = dbc->dwContactID; - memcpy(&dbeNew->ofsPrev, &oldEvent.ofsPrev, offsetof(DBEvent_094, blob) - sizeof(DWORD)); - ret = ReadSegment(ofsThisEvent + offsetof(DBEvent_094, blob), &dbeNew->blob, dbeOld.cbBlob); - } - } - else ret = ReadSegment(ofsThisEvent, dbeNew, offsetof(DBEvent, blob) + dbeOld.cbBlob); - - if (ret != ERROR_SUCCESS) { - FinishUp(ofsDestPrevEvent, dbc); - return ERROR_NO_MORE_ITEMS; - } - - if ((dbeNew->ofsModuleName = ConvertModuleNameOfs(dbeOld.ofsModuleName)) == 0) { - ofsThisEvent = dbeOld.ofsNext; - return ERROR_SUCCESS; - } - - if (!firstTime && dbeOld.ofsPrev != ofsPrevEvent) - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("Event not backlinked correctly: fixing")); - - dbeNew->flags = dbeOld.flags; - dbeNew->ofsPrev = ofsDestPrevEvent; - dbeNew->ofsNext = 0; - if (dbeNew->contactID == 0) - dbeNew->contactID = dbc->dwContactID; - - if (dbeOld.wEventType == EVENTTYPE_MESSAGE && cb->bConvertUtf && !(dbeOld.flags & DBEF_ENCRYPTED)) - ConvertOldEvent(dbeNew); - - if (dbePrev) { - if (dbePrev->cbBlob == dbeNew->cbBlob && - dbePrev->ofsModuleName == dbeNew->ofsModuleName && - dbePrev->wEventType == dbeNew->wEventType && - (dbePrev->flags & DBEF_SENT) == (dbeNew->flags & DBEF_SENT) && !memcmp(dbePrev->blob, dbeNew->blob, dbeNew->cbBlob)) - { - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("Duplicate event was found: skipping")); - if (dbc->eventCount) - dbc->eventCount--; - free(dbePrev); - // ofsDestPrevEvent is still the same! - ofsPrevEvent = ofsThisEvent; - ofsThisEvent = dbeOld.ofsNext; - return ERROR_SUCCESS; - } - free(dbePrev); - } - else if (!firstTime && dbeNew->timestamp < lastTimestamp) { - DWORD found = 0; - DBEvent dbeTmp = { 0 }; - DWORD ofsTmp = 0; - - if (cb->bCheckOnly) { - if (!cb->bAggressive) { - ofsTmp = dbeOld.ofsPrev; - while (PeekEvent(ofsTmp, dbc->dwContactID, dbeTmp) == ERROR_SUCCESS) { - if (dbeTmp.ofsPrev == ofsContact) { - found = 1; - break; - } - if (dbeTmp.timestamp < dbeNew->timestamp) { - found = 2; - break; - } - ofsTmp = dbeTmp.ofsPrev; - } - } - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("Event position in chain is not correct")); - } - else { - ofsTmp = ofsDestPrevEvent; - while (ReadWrittenSegment(ofsTmp, &dbeTmp, sizeof(dbeTmp)) == ERROR_SUCCESS) { - if (dbeTmp.ofsPrev == ofsContact) { - found = 1; - break; - } - if (dbeTmp.timestamp < dbeNew->timestamp) { - found = 2; - break; - } - ofsTmp = dbeTmp.ofsPrev; - } - if (found) - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("Event position in chain is not correct: fixing")); - else - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("Event position in chain is not correct: unable to fix")); - } - - // insert before FIRST - if (found == 1 && !cb->bCheckOnly) { - dbeNew->ofsPrev = 0; - dbeNew->ofsNext = dbc->ofsFirstEvent; - - DWORD ofsDestThis = WriteEvent(dbeNew); - if (!ofsDestThis) - return ERROR_HANDLE_DISK_FULL; - - if (isUnread && tsFirstUnread >= dbeNew->timestamp) { - ofsFirstUnread = ofsDestThis; - tsFirstUnread = dbeNew->timestamp; - } - // fix first event - WriteOfsNextToPrevious(0, dbc, ofsDestThis); - // fix next event - WriteSegment(dbeNew->ofsNext + offsetof(DBEvent, ofsPrev), &ofsDestThis, sizeof(DWORD)); - } - else if (found == 2 && !cb->bCheckOnly) { - dbeNew->ofsPrev = ofsTmp; - dbeNew->ofsNext = dbeTmp.ofsNext; - - DWORD ofsDestThis = WriteEvent(dbeNew); - if (!ofsDestThis) - return ERROR_HANDLE_DISK_FULL; - - if (isUnread && tsFirstUnread >= dbeNew->timestamp) { - ofsFirstUnread = ofsDestThis; - tsFirstUnread = dbeNew->timestamp; - } - // fix previous event - WriteOfsNextToPrevious(dbeNew->ofsPrev, dbc, ofsDestThis); - // fix next event - WriteSegment(dbeNew->ofsNext + offsetof(DBEvent, ofsPrev), &ofsDestThis, sizeof(DWORD)); - } - - if (found) { - eventCount++; - // ofsDestPrevEvent is still the same! - ofsPrevEvent = ofsThisEvent; - ofsThisEvent = dbeOld.ofsNext; - return ERROR_SUCCESS; - } - } - - lastTimestamp = dbeNew->timestamp; - dbePrevEvent = dbeNew; - - DWORD ofsDestThis = WriteEvent(dbeNew); - if (!ofsDestThis) - return ERROR_HANDLE_DISK_FULL; - - if (isUnread) { - ofsFirstUnread = ofsDestThis; - tsFirstUnread = dbeOld.timestamp; - } - - eventCount++; - WriteOfsNextToPrevious(ofsDestPrevEvent, dbc, ofsDestThis); - - ofsDestPrevEvent = ofsDestThis; - ofsPrevEvent = ofsThisEvent; - ofsThisEvent = dbeOld.ofsNext; - return ERROR_SUCCESS; -} diff --git a/plugins/Db3x_mmap/src/dbtool/finaltasks.cpp b/plugins/Db3x_mmap/src/dbtool/finaltasks.cpp deleted file mode 100644 index 82a8b29a09..0000000000 --- a/plugins/Db3x_mmap/src/dbtool/finaltasks.cpp +++ /dev/null @@ -1,37 +0,0 @@ -/* -Miranda Database Tool -Copyright (C) 2001-2005 Richard Hughes - -This program is free software; you can redistribute it and/or -modify it under the terms of the GNU General Public License -as published by the Free Software Foundation; either version 2 -of the License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU General Public License for more details. - -You should have received a copy of the GNU General Public License -along with this program; if not, write to the Free Software -Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -*/ - -#include "../stdafx.h" - -int CDb3Mmap::WorkFinalTasks(int) -{ - FreeModuleChain(); - cb->pfnAddLogMessage(STATUS_MESSAGE, TranslateT("Processing final tasks")); - m_dbHeader.slackSpace = 0; - - if (m_dbHeader.version < DB_095_1_VERSION) { - memcpy(&m_dbHeader.signature, &dbSignatureU, sizeof(m_dbHeader.signature)); - m_dbHeader.version = DB_095_1_VERSION; - } - - if (WriteSegment(0, &m_dbHeader, sizeof(m_dbHeader)) == WS_ERROR) - return ERROR_WRITE_FAULT; - - return ERROR_NO_MORE_ITEMS; -} diff --git a/plugins/Db3x_mmap/src/dbtool/initialchecks.cpp b/plugins/Db3x_mmap/src/dbtool/initialchecks.cpp deleted file mode 100644 index 45c8120442..0000000000 --- a/plugins/Db3x_mmap/src/dbtool/initialchecks.cpp +++ /dev/null @@ -1,74 +0,0 @@ -/* -Miranda Database Tool -Copyright (C) 2001-2005 Richard Hughes - -This program is free software; you can redistribute it and/or -modify it under the terms of the GNU General Public License -as published by the Free Software Foundation; either version 2 -of the License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU General Public License for more details. - -You should have received a copy of the GNU General Public License -along with this program; if not, write to the Free Software -Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -*/ - -#include "../stdafx.h" - -int CDb3Mmap::WorkInitialCheckHeaders() -{ - if (memcmp(m_dbHeader.signature, &dbSignatureU, sizeof(m_dbHeader.signature)) && - memcmp(m_dbHeader.signature, &dbSignatureE, sizeof(m_dbHeader.signature)) && - memcmp(m_dbHeader.signature, &dbSignatureIM, sizeof(m_dbHeader.signature)) && - memcmp(m_dbHeader.signature, &dbSignatureSA, sizeof(m_dbHeader.signature))) - { - cb->pfnAddLogMessage(STATUS_FATAL, TranslateT("Database signature is corrupted, automatic repair is impossible")); - return ERROR_BAD_FORMAT; - } - - switch (m_dbHeader.version) { - case DB_OLD_VERSION: - case DB_094_VERSION: - case DB_095_VERSION: - case DB_095_1_VERSION: - break; - - default: - cb->pfnAddLogMessage(STATUS_FATAL, TranslateT("Database version doesn't match this driver's one. Convert a database first")); - return ERROR_BAD_FORMAT; - } - - return ERROR_SUCCESS; -} - -int CDb3Mmap::WorkInitialChecks(int) -{ - sourceFileSize = GetFileSize(m_hDbFile, nullptr); - if (sourceFileSize == 0) { - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("Database is newly created and has no data to process")); - cb->pfnAddLogMessage(STATUS_SUCCESS, TranslateT("Processing completed successfully")); - return ERROR_INVALID_DATA; - } - - int res = WorkInitialCheckHeaders(); - if (res) - return res; - - if (!m_pDbCache) { - cb->pfnAddLogMessage(STATUS_FATAL, TranslateT("Can't create map view of file (%u)"), GetLastError()); - return ERROR_ACCESS_DENIED; - } - if (ReadSegment(0, &m_dbHeader, sizeof(m_dbHeader)) != ERROR_SUCCESS) - return ERROR_READ_FAULT; - - if (WriteSegment(0, &m_dbHeader, sizeof(m_dbHeader)) == WS_ERROR) - return ERROR_HANDLE_DISK_FULL; - - cb->spaceUsed = m_dbHeader.ofsFileEnd - m_dbHeader.slackSpace; - m_dbHeader.ofsFileEnd = sizeof(m_dbHeader); - return ERROR_NO_MORE_ITEMS; -} diff --git a/plugins/Db3x_mmap/src/dbtool/modulechain.cpp b/plugins/Db3x_mmap/src/dbtool/modulechain.cpp deleted file mode 100644 index 60ae30af7c..0000000000 --- a/plugins/Db3x_mmap/src/dbtool/modulechain.cpp +++ /dev/null @@ -1,140 +0,0 @@ -/* -Miranda Database Tool -Copyright (C) 2001-2005 Richard Hughes - -This program is free software; you can redistribute it and/or -modify it under the terms of the GNU General Public License -as published by the Free Software Foundation; either version 2 -of the License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU General Public License for more details. - -You should have received a copy of the GNU General Public License -along with this program; if not, write to the Free Software -Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -*/ - -#include "../stdafx.h" - -struct ModChainEntry { - DWORD ofsOld, ofsNew; - int size; - char name[257]; -} static *modChain = nullptr; -static int modChainCount; -static DWORD ofsCurrent; -static int phase, iCurrentModName; -static DWORD ofsLast; -static int last_mod = 0; - -int CDb3Mmap::WorkModuleChain(int firstTime) -{ - DBModuleName moduleName, *newModName; - - if (firstTime) { - cb->pfnAddLogMessage(STATUS_MESSAGE, TranslateT("Processing module name chain")); - modChainCount = 0; - last_mod = 0; - free(modChain); - modChain = (ModChainEntry*)malloc(sizeof(ModChainEntry)); - phase = 0; - ofsCurrent = m_dbHeader.ofsModuleNames; - } - - switch (phase) { - case 0: - if (ofsCurrent == 0) { - phase++; - return ERROR_SUCCESS; - } - if (!SignatureValid(ofsCurrent, DBMODULENAME_SIGNATURE)) { - cb->pfnAddLogMessage(STATUS_ERROR, TranslateT("Module chain corrupted, further entries ignored")); - phase++; - return ERROR_SUCCESS; - } - if (PeekSegment(ofsCurrent, &moduleName, offsetof(DBModuleName, name)) != ERROR_SUCCESS) { - phase++; - return ERROR_SUCCESS; - } - modChain = (ModChainEntry*)realloc(modChain, sizeof(ModChainEntry)*++modChainCount); - - modChain[modChainCount - 1].ofsOld = ofsCurrent; - modChain[modChainCount - 1].size = offsetof(DBModuleName, name) + moduleName.cbName; - modChain[modChainCount - 1].ofsNew = 0; - - if (moduleName.cbName) - PeekSegment(ofsCurrent + offsetof(DBModuleName, name), &modChain[modChainCount - 1].name, moduleName.cbName); - modChain[modChainCount - 1].name[moduleName.cbName] = 0; - ofsCurrent = moduleName.ofsNext; - break; - case 1: - ofsLast = 0; - iCurrentModName = 0; - m_dbHeader.ofsModuleNames = 0; - phase++; - case 2: - if (iCurrentModName >= modChainCount) { - DWORD dw = 0; - if (ofsLast) WriteSegment(ofsLast + offsetof(DBModuleName, ofsNext), &dw, sizeof(DWORD)); - return ERROR_NO_MORE_ITEMS; - } - if (modChain[iCurrentModName].ofsNew == 0) { - newModName = (DBModuleName*)_alloca(modChain[iCurrentModName].size); - if (ReadSegment(modChain[iCurrentModName].ofsOld, newModName, modChain[iCurrentModName].size) != ERROR_SUCCESS) - return ERROR_NO_MORE_ITEMS; - if ((modChain[iCurrentModName].ofsNew = WriteSegment(WSOFS_END, newModName, modChain[iCurrentModName].size)) == WS_ERROR) - return ERROR_HANDLE_DISK_FULL; - - // check duplicated modulenames - int i, n = 0; - for (i = iCurrentModName + 1; i < modChainCount; i++) - if (!mir_strcmp(modChain[i].name, modChain[iCurrentModName].name)) { - modChain[i].ofsNew = modChain[iCurrentModName].ofsNew; - n++; - } - if (n) { - wchar_t szModuleName[257]; - MultiByteToWideChar(CP_ACP, 0, modChain[iCurrentModName].name, -1, szModuleName, _countof(szModuleName)); - wchar_t *pszModuleName = szModuleName; - - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("Module name '%s' is not unique: %d duplicates found"), pszModuleName, n); - } - - if (iCurrentModName == 0) - m_dbHeader.ofsModuleNames = modChain[iCurrentModName].ofsNew; - else if (WriteSegment(ofsLast + offsetof(DBModuleName, ofsNext), &modChain[iCurrentModName].ofsNew, sizeof(DWORD)) == WS_ERROR) - return ERROR_HANDLE_DISK_FULL; - ofsLast = modChain[iCurrentModName].ofsNew; - } - iCurrentModName++; - break; - } - return ERROR_SUCCESS; -} - -DWORD CDb3Mmap::ConvertModuleNameOfs(DWORD ofsOld) -{ - if (modChain[last_mod].ofsOld == ofsOld) - return modChain[last_mod].ofsNew; - - for (int i = 0; i < modChainCount; i++) - if (modChain[i].ofsOld == ofsOld) { - last_mod = i; - return modChain[last_mod].ofsNew; - } - - cb->pfnAddLogMessage(STATUS_ERROR, TranslateT("Invalid module name offset, skipping data")); - return 0; -} - -void CDb3Mmap::FreeModuleChain() -{ - if (modChain != nullptr) { - free(modChain); - modChain = nullptr; - last_mod = 0; - } -} diff --git a/plugins/Db3x_mmap/src/dbtool/settingschain.cpp b/plugins/Db3x_mmap/src/dbtool/settingschain.cpp deleted file mode 100644 index 775e768d0a..0000000000 --- a/plugins/Db3x_mmap/src/dbtool/settingschain.cpp +++ /dev/null @@ -1,78 +0,0 @@ -/* -Miranda Database Tool -Copyright (C) 2001-2005 Richard Hughes - -This program is free software; you can redistribute it and/or -modify it under the terms of the GNU General Public License -as published by the Free Software Foundation; either version 2 -of the License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU General Public License for more details. - -You should have received a copy of the GNU General Public License -along with this program; if not, write to the Free Software -Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -*/ - -#include "../stdafx.h" - -static DWORD ofsThisSettings, ofsDestPrevSettings; - -int CDb3Mmap::WorkSettingsChain(DBContact *dbc, int firstTime) -{ - DWORD ofsDestThis; - int ret; - - if (firstTime) { - ofsDestPrevSettings = 0; - ofsThisSettings = dbc->ofsFirstSettings; - dbc->ofsFirstSettings = 0; - } - if (ofsThisSettings == 0) - return ERROR_NO_MORE_ITEMS; - - if (!SignatureValid(ofsThisSettings, DBCONTACTSETTINGS_SIGNATURE)) { - cb->pfnAddLogMessage(STATUS_ERROR, TranslateT("Settings chain corrupted, further entries ignored")); - return ERROR_NO_MORE_ITEMS; - } - DBContactSettings dbcsOld; - if (PeekSegment(ofsThisSettings, &dbcsOld, sizeof(dbcsOld)) != ERROR_SUCCESS) - return ERROR_NO_MORE_ITEMS; - - if (dbcsOld.cbBlob > 256 * 1024 || dbcsOld.cbBlob == 0) { - cb->pfnAddLogMessage(STATUS_ERROR, TranslateT("Infeasibly large settings blob: skipping")); - ofsThisSettings = dbcsOld.ofsNext; - return ERROR_SUCCESS; - } - - DBContactSettings *dbcsNew = (DBContactSettings*)_alloca(offsetof(DBContactSettings, blob) + dbcsOld.cbBlob); - if ((ret = ReadSegment(ofsThisSettings, dbcsNew, offsetof(DBContactSettings, blob) + dbcsOld.cbBlob)) != ERROR_SUCCESS) - if (ret != ERROR_HANDLE_EOF) //eof is OK because blank space at the end doesn't matter - return ERROR_NO_MORE_ITEMS; - - if ((dbcsNew->ofsModuleName = ConvertModuleNameOfs(dbcsOld.ofsModuleName)) == 0) { - ofsThisSettings = dbcsOld.ofsNext; - return ERROR_SUCCESS; - } - - if (dbcsNew->blob[0] == 0) { - cb->pfnAddLogMessage(STATUS_MESSAGE, TranslateT("Empty settings group at %08X: skipping"), ofsThisSettings); - ofsThisSettings = dbcsOld.ofsNext; - return ERROR_SUCCESS; - } - dbcsNew->ofsNext = 0; - //TODO? validate all settings in blob/compact if necessary - if ((ofsDestThis = WriteSegment(WSOFS_END, dbcsNew, offsetof(DBContactSettings, blob) + dbcsNew->cbBlob)) == WS_ERROR) - return ERROR_HANDLE_DISK_FULL; - - if (ofsDestPrevSettings) - WriteSegment(ofsDestPrevSettings + offsetof(DBContactSettings, ofsNext), &ofsDestThis, sizeof(DWORD)); - else - dbc->ofsFirstSettings = ofsDestThis; - ofsDestPrevSettings = ofsDestThis; - ofsThisSettings = dbcsOld.ofsNext; - return ERROR_SUCCESS; -} diff --git a/plugins/Db3x_mmap/src/dbtool/user.cpp b/plugins/Db3x_mmap/src/dbtool/user.cpp deleted file mode 100644 index 361e02d559..0000000000 --- a/plugins/Db3x_mmap/src/dbtool/user.cpp +++ /dev/null @@ -1,76 +0,0 @@ -/* -Miranda Database Tool -Copyright (C) 2001-2005 Richard Hughes - -This program is free software; you can redistribute it and/or -modify it under the terms of the GNU General Public License -as published by the Free Software Foundation; either version 2 -of the License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU General Public License for more details. - -You should have received a copy of the GNU General Public License -along with this program; if not, write to the Free Software -Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -*/ - -#include "../stdafx.h" - -static DBContact user; -static int phase; -static DWORD ofsUser; - -int CDb3Mmap::WorkUser(int firstTime) -{ - int first = 0; - - if (firstTime) { - cb->pfnAddLogMessage(STATUS_MESSAGE, TranslateT("Processing user data")); - if (!SignatureValid(m_dbHeader.ofsUser, DBCONTACT_SIGNATURE)) { - cb->pfnAddLogMessage(STATUS_ERROR, TranslateT("User corrupted, this could cause major problems")); - return ERROR_NO_MORE_ITEMS; - } - - DWORD dwSize = (m_dbHeader.version < DB_095_VERSION) ? offsetof(DBContact, dwContactID) : sizeof(DBContact); - if (ReadSegment(m_dbHeader.ofsUser, &user, dwSize) != ERROR_SUCCESS) - return ERROR_NO_MORE_ITEMS; - - if (user.ofsNext) { - cb->pfnAddLogMessage(STATUS_WARNING, TranslateT("More than one user contact: keeping only first")); - user.ofsNext = 0; - } - - if ((ofsUser = WriteSegment(WSOFS_END, &user, sizeof(DBContact))) == WS_ERROR) - return ERROR_HANDLE_DISK_FULL; - - m_dbHeader.ofsUser = ofsUser; - phase = 0; - first = 1; - } - - int ret; - switch (phase) { - case 0: - ret = WorkSettingsChain(&user, first); - if (ret == ERROR_NO_MORE_ITEMS) { - phase++; first = 1; - } - else if (ret) return ret; - else break; - - case 1: - ret = WorkEventChain(ofsUser, &user, first); - if (ret == ERROR_NO_MORE_ITEMS) { - if (WriteSegment(ofsUser, &user, sizeof(DBContact)) == WS_ERROR) - return ERROR_HANDLE_DISK_FULL; - return ERROR_NO_MORE_ITEMS; - } - else if (ret) - return ret; - break; - } - return ERROR_SUCCESS; -} -- cgit v1.2.3