/* * Copyright 2009, Stephan Aßmus * All rights reserved. Distributed under the terms of the MIT License. */ #include "ProgressReporter.h" #include ProgressReporter::ProgressReporter(const BMessenger& messenger, BMessage* message) : fStartTime(0), fBytesToWrite(0), fBytesWritten(0), fItemsToWrite(0), fItemsWritten(0), fMessenger(messenger), fMessage(message) { } ProgressReporter::~ProgressReporter() { delete fMessage; } void ProgressReporter::Reset() { fBytesToWrite = 0; fBytesWritten = 0; fItemsToWrite = 0; fItemsWritten = 0; if (fMessage) { BMessage message(*fMessage); message.AddString("status", "Collecting copy information."); fMessenger.SendMessage(&message); } } void ProgressReporter::AddItems(uint64 count, off_t bytes) { fBytesToWrite += bytes; fItemsToWrite += count; } void ProgressReporter::StartTimer() { fStartTime = system_time(); printf("%lld bytes to write in %lld files\n", fBytesToWrite, fItemsToWrite); if (fMessage) { BMessage message(*fMessage); message.AddString("status", "Performing installation."); fMessenger.SendMessage(&message); } } void ProgressReporter::ItemsWritten(uint64 items, off_t bytes, const char* itemName, const char* targetFolder) { fItemsWritten += items; fBytesWritten += bytes; _UpdateProgress(itemName, targetFolder); } void ProgressReporter::_UpdateProgress(const char* itemName, const char* targetFolder) { if (fMessage == NULL) return; // TODO: Could add time to finish calculation here... BMessage message(*fMessage); float progress = 100.0 * fBytesWritten / fBytesToWrite; message.AddFloat("progress", progress); message.AddInt32("current", fItemsWritten); message.AddInt32("maximum", fItemsToWrite); message.AddString("item", itemName); message.AddString("folder", targetFolder); fMessenger.SendMessage(&message); }