* Refactored the way targets are collected before copy process begins, this

way, the optional packages (if there would be any) can be collected as well
  before the actual process starts and the progress bar will reflect them
  correctly. Before this change, the progress bar would have reset itself for
  every optional package.
* In one of my previous commits, I added the error, if there was any, to the
  reset message. Now the Installer window looks for the error and tells the
  user about it.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@30602 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Stephan Aßmus 2009-05-03 09:58:09 +00:00
parent f827b0168a
commit 92cd10f4db
4 changed files with 59 additions and 12 deletions

View File

@ -70,9 +70,8 @@ CopyEngine::~CopyEngine()
} }
status_t void
CopyEngine::CopyFolder(const char* source, const char* destination, CopyEngine::ResetTargets()
BLocker* locker)
{ {
fBytesRead = 0; fBytesRead = 0;
fItemsCopied = 0; fItemsCopied = 0;
@ -87,10 +86,27 @@ CopyEngine::CopyFolder(const char* source, const char* destination,
fCurrentTargetFolder = NULL; fCurrentTargetFolder = NULL;
fCurrentItem = NULL; fCurrentItem = NULL;
if (fMessage) {
BMessage message(*fMessage);
message.AddString("status", "Collecting copy information.");
fMessenger.SendMessage(&message);
}
}
status_t
CopyEngine::CollectTargets(const char* source)
{
int32 level = 0; int32 level = 0;
status_t ret = _CollectCopyInfo(source, level); return _CollectCopyInfo(source, level);
if (ret < B_OK) }
return ret;
status_t
CopyEngine::CopyFolder(const char* source, const char* destination,
BLocker* locker = NULL)
{
printf("%lld bytes to read in %lld files\n", fBytesToCopy, fItemsToCopy);
if (fMessage) { if (fMessage) {
BMessage message(*fMessage); BMessage message(*fMessage);
@ -98,9 +114,7 @@ CopyEngine::CopyFolder(const char* source, const char* destination,
fMessenger.SendMessage(&message); fMessenger.SendMessage(&message);
} }
printf("%lld bytes to read in %lld files\n", fBytesToCopy, fItemsToCopy); int32 level = 0;
level = 0;
return _CopyFolder(source, destination, level, locker); return _CopyFolder(source, destination, level, locker);
} }

View File

@ -25,6 +25,9 @@ public:
BMessage* message); BMessage* message);
virtual ~CopyEngine(); virtual ~CopyEngine();
void ResetTargets();
status_t CollectTargets(const char* source);
status_t CopyFolder(const char* source, status_t CopyFolder(const char* source,
const char* destination, const char* destination,
BLocker* locker = NULL); BLocker* locker = NULL);

View File

@ -359,9 +359,19 @@ InstallerWindow::MessageReceived(BMessage *msg)
{ {
switch (msg->what) { switch (msg->what) {
case MSG_RESET: case MSG_RESET:
{
delete fCopyEngineLock; delete fCopyEngineLock;
fCopyEngineLock = NULL; fCopyEngineLock = NULL;
status_t error;
if (msg->FindInt32("error", &error) == B_OK) {
char errorMessage[2048];
snprintf(errorMessage, sizeof(errorMessage), "An error was "
"encountered and the installation was not completed:\n\n"
"Error: %s", strerror(error));
(new BAlert("error", errorMessage, "Ok"))->Go();
}
fInstallStatus = kReadyForInstall; fInstallStatus = kReadyForInstall;
fBeginButton->SetEnabled(true); fBeginButton->SetEnabled(true);
_DisableInterface(false); _DisableInterface(false);
@ -372,6 +382,7 @@ InstallerWindow::MessageReceived(BMessage *msg)
fBeginButton->SetLabel("Begin"); fBeginButton->SetLabel("Begin");
break; break;
}
case START_SCAN: case START_SCAN:
_ScanPartitions(); _ScanPartitions();
break; break;
@ -530,7 +541,7 @@ InstallerWindow::QuitRequested()
if (fDriveSetupLaunched) { if (fDriveSetupLaunched) {
(new BAlert("driveSetup", (new BAlert("driveSetup",
"Please close the DriveSetup window before closing the " "Please close the DriveSetup window before closing the "
"Installer window.", "OK"))->Go(); "Installer window.", "Ok"))->Go();
return false; return false;
} }
_QuitCopyEngine(false); _QuitCopyEngine(false);

View File

@ -388,6 +388,25 @@ WorkerThread::_PerformInstall(BMenu *srcMenu, BMenu *targetMenu)
_LaunchInitScript(targetDirectory); _LaunchInitScript(targetDirectory);
// let the engine collect information for the progress bar later on
engine.ResetTargets();
err = engine.CollectTargets(srcDirectory.Path());
if (err != B_OK)
goto error;
// collect selected packages also
if (fPackages) {
BPath pkgRootDir(srcDirectory.Path(), PACKAGES_DIRECTORY);
int32 count = fPackages->CountItems();
for (int32 i = 0; i < count; i++) {
Package *p = static_cast<Package*>(fPackages->ItemAt(i));
BPath packageDir(pkgRootDir.Path(), p->Folder());
err = engine.CollectTargets(packageDir.Path());
if (err != B_OK)
goto error;
}
}
// copy source volume // copy source volume
err = engine.CopyFolder(srcDirectory.Path(), targetDirectory.Path(), err = engine.CopyFolder(srcDirectory.Path(), targetDirectory.Path(),
fCancelLock); fCancelLock);
@ -396,11 +415,11 @@ WorkerThread::_PerformInstall(BMenu *srcMenu, BMenu *targetMenu)
// copy selected packages // copy selected packages
if (fPackages) { if (fPackages) {
srcDirectory.Append(PACKAGES_DIRECTORY); BPath pkgRootDir(srcDirectory.Path(), PACKAGES_DIRECTORY);
int32 count = fPackages->CountItems(); int32 count = fPackages->CountItems();
for (int32 i = 0; i < count; i++) { for (int32 i = 0; i < count; i++) {
Package *p = static_cast<Package*>(fPackages->ItemAt(i)); Package *p = static_cast<Package*>(fPackages->ItemAt(i));
BPath packageDir(srcDirectory.Path(), p->Folder()); BPath packageDir(pkgRootDir.Path(), p->Folder());
err = engine.CopyFolder(packageDir.Path(), targetDirectory.Path(), err = engine.CopyFolder(packageDir.Path(), targetDirectory.Path(),
fCancelLock); fCancelLock);
if (err != B_OK) if (err != B_OK)