blob: 94f0a47c1a6ff3811d32d7cc46d078d01aa321d6 [file] [log] [blame]
// UpdateCallbackFar.cpp
#include "StdAfx.h"
#ifndef Z7_ST
#include "../../../Windows/Synchronization.h"
#endif
#include "../../../Common/StringConvert.h"
#include "FarUtils.h"
#include "UpdateCallbackFar.h"
using namespace NWindows;
using namespace NFar;
#ifndef Z7_ST
static NSynchronization::CCriticalSection g_CriticalSection;
#define MT_LOCK NSynchronization::CCriticalSectionLock lock(g_CriticalSection);
#else
#define MT_LOCK
#endif
static HRESULT CheckBreak2()
{
return WasEscPressed() ? E_ABORT : S_OK;
}
Z7_COM7F_IMF(CUpdateCallback100Imp::ScanProgress(UInt64 numFolders, UInt64 numFiles, UInt64 totalSize, const wchar_t *path, Int32 /* isDir */))
{
MT_LOCK
if (_percent)
{
_percent->FilesTotal = numFolders + numFiles;
_percent->Total = totalSize;
_percent->Command = "Scanning";
_percent->FileName = path;
_percent->Print();
_percent->Print();
}
return CheckBreak2();
}
Z7_COM7F_IMF(CUpdateCallback100Imp::ScanError(const wchar_t *path, HRESULT errorCode))
{
if (ShowSysErrorMessage(errorCode, path) == -1)
return E_ABORT;
return CheckBreak2();
}
Z7_COM7F_IMF(CUpdateCallback100Imp::SetNumFiles(UInt64 numFiles))
{
MT_LOCK
if (_percent)
{
_percent->FilesTotal = numFiles;
_percent->Print();
}
return CheckBreak2();
}
Z7_COM7F_IMF(CUpdateCallback100Imp::SetTotal(const UInt64 * /* files */, const UInt64 * /* bytes */))
{
return S_OK;
}
Z7_COM7F_IMF(CUpdateCallback100Imp::SetCompleted(const UInt64 * /* files */, const UInt64 * /* bytes */))
{
MT_LOCK
return CheckBreak2();
}
Z7_COM7F_IMF(CUpdateCallback100Imp::SetTotal(UInt64 size))
{
MT_LOCK
if (_percent)
{
_percent->Total = size;
_percent->Print();
}
return CheckBreak2();
}
Z7_COM7F_IMF(CUpdateCallback100Imp::SetCompleted(const UInt64 *completeValue))
{
MT_LOCK
if (_percent)
{
if (completeValue)
_percent->Completed = *completeValue;
_percent->Print();
}
return CheckBreak2();
}
Z7_COM7F_IMF(CUpdateCallback100Imp::CompressOperation(const wchar_t *name))
{
MT_LOCK
if (_percent)
{
_percent->Command = "Adding";
_percent->FileName = name;
_percent->Print();
}
return CheckBreak2();
}
Z7_COM7F_IMF(CUpdateCallback100Imp::DeleteOperation(const wchar_t *name))
{
MT_LOCK
if (_percent)
{
_percent->Command = "Deleting";
_percent->FileName = name;
_percent->Print();
}
return CheckBreak2();
}
Z7_COM7F_IMF(CUpdateCallback100Imp::OperationResult(Int32 /* opRes */))
{
MT_LOCK
if (_percent)
{
_percent->Files++;
}
return CheckBreak2();
}
Z7_COM7F_IMF(CUpdateCallback100Imp::UpdateErrorMessage(const wchar_t *message))
{
MT_LOCK
if (g_StartupInfo.ShowErrorMessage(UnicodeStringToMultiByte(message, CP_OEMCP)) == -1)
return E_ABORT;
return CheckBreak2();
}
Z7_COM7F_IMF(CUpdateCallback100Imp::OpenFileError(const wchar_t *path, HRESULT errorCode))
{
if (ShowSysErrorMessage(errorCode, path) == -1)
return E_ABORT;
return CheckBreak2();
}
Z7_COM7F_IMF(CUpdateCallback100Imp::ReadingFileError(const wchar_t *path, HRESULT errorCode))
{
if (ShowSysErrorMessage(errorCode, path) == -1)
return E_ABORT;
return CheckBreak2();
}
void SetExtractErrorMessage(Int32 opRes, Int32 encrypted, AString &s);
Z7_COM7F_IMF(CUpdateCallback100Imp::ReportExtractResult(Int32 opRes, Int32 isEncrypted, const wchar_t *name))
{
MT_LOCK
if (opRes != NArchive::NExtract::NOperationResult::kOK)
{
AString s;
SetExtractErrorMessage(opRes, isEncrypted, s);
if (PrintErrorMessage(s, name) == -1)
return E_ABORT;
}
return CheckBreak2();
}
Z7_COM7F_IMF(CUpdateCallback100Imp::ReportUpdateOperation(UInt32 op, const wchar_t *name, Int32 /* isDir */))
{
const char *s;
switch (op)
{
case NUpdateNotifyOp::kAdd: s = "Adding"; break;
case NUpdateNotifyOp::kUpdate: s = "Updating"; break;
case NUpdateNotifyOp::kAnalyze: s = "Analyzing"; break;
case NUpdateNotifyOp::kReplicate: s = "Replicating"; break;
case NUpdateNotifyOp::kRepack: s = "Repacking"; break;
case NUpdateNotifyOp::kSkip: s = "Skipping"; break;
case NUpdateNotifyOp::kHeader: s = "Header creating"; break;
case NUpdateNotifyOp::kDelete: s = "Deleting"; break;
default: s = "Unknown operation";
}
MT_LOCK
if (_percent)
{
_percent->Command = s;
_percent->FileName.Empty();
if (name)
_percent->FileName = name;
_percent->Print();
}
return CheckBreak2();
}
extern HRESULT GetPassword(UString &password);
Z7_COM7F_IMF(CUpdateCallback100Imp::CryptoGetTextPassword(BSTR *password))
{
MT_LOCK
*password = NULL;
if (!PasswordIsDefined)
{
RINOK(GetPassword(Password))
PasswordIsDefined = true;
}
return StringToBstr(Password, password);
}
Z7_COM7F_IMF(CUpdateCallback100Imp::CryptoGetTextPassword2(Int32 *passwordIsDefined, BSTR *password))
{
MT_LOCK
*password = NULL;
*passwordIsDefined = BoolToInt(PasswordIsDefined);
if (!PasswordIsDefined)
return S_OK;
return StringToBstr(Password, password);
}