diff --git a/clientgui/DlgItemProperties.cpp b/clientgui/DlgItemProperties.cpp
index 62471ac64e..83116c42a2 100755
--- a/clientgui/DlgItemProperties.cpp
+++ b/clientgui/DlgItemProperties.cpp
@@ -1,532 +1,532 @@
-// This file is part of BOINC.
-// http://boinc.berkeley.edu
-// Copyright (C) 2008 University of California
-//
-// BOINC is free software; you can redistribute it and/or modify it
-// under the terms of the GNU Lesser General Public License
-// as published by the Free Software Foundation,
-// either version 3 of the License, or (at your option) any later version.
-//
-// BOINC 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 Lesser General Public License for more details.
-//
-// You should have received a copy of the GNU Lesser General Public License
-// along with BOINC. If not, see .
-//
-#if defined(__GNUG__) && !defined(__APPLE__)
-#pragma implementation "DlgItemProperties.h"
-#endif
-
-#include "stdwx.h"
-#include "util.h"
-#include "DlgItemProperties.h"
-#include "BOINCGUIApp.h"
-#include "BOINCBaseFrame.h"
-#include "Events.h"
-#include "error_numbers.h"
-
-IMPLEMENT_DYNAMIC_CLASS(CDlgItemProperties, wxDialog)
+// This file is part of BOINC.
+// http://boinc.berkeley.edu
+// Copyright (C) 2008 University of California
+//
+// BOINC is free software; you can redistribute it and/or modify it
+// under the terms of the GNU Lesser General Public License
+// as published by the Free Software Foundation,
+// either version 3 of the License, or (at your option) any later version.
+//
+// BOINC 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 Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public License
+// along with BOINC. If not, see .
+//
+#if defined(__GNUG__) && !defined(__APPLE__)
+#pragma implementation "DlgItemProperties.h"
+#endif
+
+#include "stdwx.h"
+#include "util.h"
+#include "DlgItemProperties.h"
+#include "BOINCGUIApp.h"
+#include "BOINCBaseFrame.h"
+#include "Events.h"
+#include "error_numbers.h"
+
+IMPLEMENT_DYNAMIC_CLASS(CDlgItemProperties, wxDialog)
BEGIN_EVENT_TABLE(CDlgItemProperties, wxDialog)
END_EVENT_TABLE()
-
-/* Constructor */
-CDlgItemProperties::CDlgItemProperties(wxWindow* parent) :
- wxDialog( parent, ID_ANYDIALOG, wxEmptyString, wxDefaultPosition,
- wxSize( 503,480 ), wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER ) {
- CBOINCBaseFrame* pFrame = wxGetApp().GetFrame();
- wxASSERT(pFrame);
- if (!pFrame) return;
-
- SetSizeHints( wxDefaultSize, wxDefaultSize );
- SetExtraStyle( wxWS_EX_VALIDATE_RECURSIVELY );
-
- m_bSizer1 = new wxBoxSizer( wxVERTICAL );
-
- m_scrolledWindow = new wxScrolledWindow( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxHSCROLL|wxVSCROLL );
- m_scrolledWindow->SetScrollRate( 5, 5 );
- wxBoxSizer* m_bSizer2;
- m_bSizer2 = new wxBoxSizer( wxVERTICAL );
-
- m_gbSizer = new wxGridBagSizer( 0, 0 );
- m_gbSizer->AddGrowableCol( 1 );
- m_gbSizer->SetFlexibleDirection( wxBOTH );
- m_gbSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED );
-
- m_bSizer2->Add( m_gbSizer, 1, wxEXPAND, 5 );
-
- m_scrolledWindow->SetSizer( m_bSizer2 );
- m_scrolledWindow->Layout();
- m_bSizer2->Fit( m_scrolledWindow );
- m_bSizer1->Add( m_scrolledWindow, 1, wxEXPAND | wxALL, 5 );
-
- m_btnClose = new wxButton( this, wxID_OK, _("&Close"), wxDefaultPosition, wxDefaultSize, 0 );
- m_btnClose->SetDefault();
- m_bSizer1->Add( m_btnClose, 0, wxALIGN_BOTTOM|wxALIGN_CENTER_HORIZONTAL|wxALL, 5 );
-
- SetSizer( m_bSizer1 );
- Layout();
-
- Centre( wxBOTH );
-
- m_current_row=0;
-
- int currentTabView = pFrame->GetCurrentViewPage();
- switch(currentTabView) {
- case VW_PROJ:
- m_strBaseConfigLocation = wxString(wxT("/DlgProjectProperties/"));
- break;
- case VW_TASK:
- m_strBaseConfigLocation = wxString(wxT("/DlgTaskProperties/"));
- break;
- default:
- m_strBaseConfigLocation = wxString(wxT("/DlgProperties/"));
- break;
- }
-
- RestoreState();
-}
-
-// destructor
-CDlgItemProperties::~CDlgItemProperties() {
- SaveState();
-}
-
-/* saves dialog size and (on Mac) position */
-bool CDlgItemProperties::SaveState() {
- wxConfigBase* pConfig = wxConfigBase::Get(FALSE);
-
- wxASSERT(pConfig);
- if (!pConfig) return false;
-
- pConfig->SetPath(m_strBaseConfigLocation);
- pConfig->Write(wxT("Width"), GetSize().GetWidth());
- pConfig->Write(wxT("Height"), GetSize().GetHeight());
-#ifdef __WXMAC__
- pConfig->Write(wxT("XPos"), GetPosition().x);
- pConfig->Write(wxT("YPos"), GetPosition().y);
-#endif
- return true;
-}
-
-/* restores former dialog size and (on Mac) position */
-bool CDlgItemProperties::RestoreState() {
- wxConfigBase* pConfig = wxConfigBase::Get(FALSE);
- int iWidth, iHeight;
-
- wxASSERT(pConfig);
- if (!pConfig) return false;
-
- pConfig->SetPath(m_strBaseConfigLocation);
-
- pConfig->Read(wxT("Width"), &iWidth, wxDefaultCoord);
- pConfig->Read(wxT("Height"), &iHeight, wxDefaultCoord);
-
-#ifndef __WXMAC__
- // Set size to saved values or defaults if no saved values
- SetSize(iWidth, iHeight);
-#else
- int iTop, iLeft;
-
- pConfig->Read(wxT("YPos"), &iTop, wxDefaultCoord);
- pConfig->Read(wxT("XPos"), &iLeft, wxDefaultCoord);
-
- // If either co-ordinate is less then 0 then set it equal to 0 to ensure
- // it displays on the screen.
- if ((iLeft < 0) && (iLeft != wxDefaultCoord)) iLeft = 30;
- if ((iTop < 0) && (iTop != wxDefaultCoord)) iTop = 30;
-
- // Set size and position to saved values or defaults if no saved values
- SetSize(iLeft, iTop, iWidth, iHeight, wxSIZE_USE_EXISTING);
-
- // Now make sure window is on screen
- GetScreenPosition(&iLeft, &iTop);
- GetSize(&iWidth, &iHeight);
-
- Rect titleRect = {iTop, iLeft, iTop+22, iLeft+iWidth };
- InsetRect(&titleRect, 5, 5); // Make sure at least a 5X5 piece visible
- RgnHandle displayRgn = NewRgn();
- CopyRgn(GetGrayRgn(), displayRgn); // Region encompassing all displays
- Rect menuRect = ((**GetMainDevice())).gdRect;
- menuRect.bottom = GetMBarHeight() + menuRect.top;
- RgnHandle menuRgn = NewRgn();
- RectRgn(menuRgn, &menuRect); // Region hidden by menu bar
- DiffRgn(displayRgn, menuRgn, displayRgn); // Subtract menu bar region
- if (!RectInRgn(&titleRect, displayRgn)) {
- iTop = iLeft = 30;
- SetSize(iLeft, iTop, iWidth, iHeight, wxSIZE_USE_EXISTING);
- }
- DisposeRgn(menuRgn);
- DisposeRgn(displayRgn);
-#endif
-
- return true;
-}
-// show project properties
-//
-void CDlgItemProperties::renderInfos(PROJECT* project_in) {
- std::string projectname;
- //collecting infos
- project_in->get_name(projectname);
- //disk usage needs additional lookups
- CMainDocument* pDoc = wxGetApp().GetDocument();
- pDoc->CachedDiskUsageUpdate();
-
- // CachedDiskUsageUpdate() may have invalidated our project
- // pointer, so get an updated pointer to this project
- PROJECT* project = pDoc->project(wxString(projectname.c_str(),wxConvUTF8));
- if(!project) return; // TODO: display some sort of error alert?
-
- std::vector dp = pDoc->disk_usage.projects;
- double diskusage=0.0;
- for (unsigned int i=0; i< dp.size(); i++) {
- PROJECT* tp = dp[i];
- std::string tname;
- tp->get_name(tname);
- wxString t1(wxString(tname.c_str(),wxConvUTF8));
- if(t1.IsSameAs(wxString(projectname.c_str(),wxConvUTF8)) || t1.IsSameAs(wxString(project->master_url, wxConvUTF8))) {
- diskusage =tp->disk_usage;
- break;
- }
- }
- //set dialog title
- wxString wxTitle = _("Properties of project ");
- wxTitle.append(wxString(projectname.c_str(),wxConvUTF8));
- SetTitle(wxTitle);
- //layout controls
- addSection(_("General"));
- addProperty(_("Master URL"),wxString(project->master_url, wxConvUTF8));
- addProperty(_("User name"),wxString(project->user_name.c_str(),wxConvUTF8));
- addProperty(_("Team name"),wxString(project->team_name.c_str(),wxConvUTF8));
- addProperty(_("Resource share"),wxString::Format(wxT("%0.0f"),project->resource_share));
- if (project->min_rpc_time > dtime()) {
- addProperty(_("Scheduler RPC deferred for"), FormatTime(project->min_rpc_time - dtime()));
- }
- if (project->download_backoff) {
- addProperty(_("File downloads deferred for"), FormatTime(project->download_backoff));
- }
- if (project->upload_backoff) {
- addProperty(_("File uploads deferred for"), FormatTime(project->upload_backoff));
- }
- addProperty(_("Disk usage"),FormatDiskSpace(diskusage));
- addProperty(_("Computer ID"), wxString::Format(wxT("%d"), project->hostid));
- addProperty(_("Non CPU intensive"),project->non_cpu_intensive ? _("yes") : _("no"));
- addProperty(_("Suspended via GUI"),project->suspended_via_gui ? _("yes") : _("no"));
- addProperty(_("Don't request more work"),project->dont_request_more_work ? _("yes") : _("no"));
- addProperty(_("Scheduler call in progress"),project->scheduler_rpc_in_progress ? _("yes") : _("no"));
- addProperty(_("Attached via account manager"),project->attached_via_acct_mgr ? _("yes") : _("no"));
- addProperty(_("Detach when done"),project->detach_when_done ? _("yes") : _("no"));
- addProperty(_("Ended"),project->ended ? _("yes") : _("no"));
- addSection(_("Credit"));
- addProperty(_("User"),
- wxString::Format(
- wxT("%0.2f total, %0.2f average"),
- project->user_total_credit,
- project->user_expavg_credit
- )
- );
- addProperty(_("Host"),
- wxString::Format(
- wxT("%0.2f total, %0.2f average"),
- project->host_total_credit,
- project->host_expavg_credit
- )
- );
-
- if (!project->non_cpu_intensive) {
- addSection(_("Scheduling"));
- addProperty(_("CPU scheduling priority"),wxString::Format(wxT("%0.2f"), project->cpu_short_term_debt));
- addProperty(_("CPU work fetch priority"),wxString::Format(wxT("%0.2f"), project->cpu_long_term_debt));
- double x = project->cpu_backoff_time - dtime();
- if (x<0) x = 0;
- addProperty(_("CPU work fetch deferred for"), FormatTime(x));
- addProperty(_("CPU work fetch deferral interval"), FormatTime(project->cpu_backoff_interval));
- if (pDoc->state.have_cuda) {
- addProperty(_("NVIDIA GPU scheduling priority"),wxString::Format(wxT("%0.2f"), project->cuda_short_term_debt));
- addProperty(_("NVIDIA GPU work fetch priority"),wxString::Format(wxT("%0.2f"), project->cuda_debt));
- x = project->cuda_backoff_time - dtime();
- if (x<0) x = 0;
- addProperty(_("NVIDIA GPU work fetch deferred for"), FormatTime(x));
- addProperty(_("NVIDIA GPU work fetch deferral interval"), FormatTime(project->cuda_backoff_interval));
- }
- if (pDoc->state.have_ati) {
- addProperty(_("ATI GPU scheduling priority"),wxString::Format(wxT("%0.2f"), project->ati_short_term_debt));
- addProperty(_("ATI GPU work fetch priority"),wxString::Format(wxT("%0.2f"), project->ati_debt));
- x = project->ati_backoff_time - dtime();
- if (x<0) x = 0;
- addProperty(_("ATI GPU work fetch deferred for"), FormatTime(x));
- addProperty(_("ATI GPU work fetch deferral interval"), FormatTime(project->ati_backoff_interval));
- }
- addProperty(_("Duration correction factor"),wxString::Format(wxT("%0.4f"), project->duration_correction_factor));
- }
- m_gbSizer->Layout();
- m_scrolledWindow->FitInside();
-}
-
-// show task properties
-//
-void CDlgItemProperties::renderInfos(RESULT* result) {
- wxDateTime dt;
- wxString wxTitle = _("Properties of task ");
- wxTitle.append(wxString(result->name, wxConvUTF8));
- SetTitle(wxTitle);
-
- addProperty(_("Application"), FormatApplicationName(result));
- addProperty(_("Workunit name"),wxString(result->wu_name, wxConvUTF8));
- addProperty(_("State"), FormatStatus(result));
- if (result->received_time) {
- dt.Set((time_t)result->received_time);
- addProperty(_("Received"), dt.Format());
- }
- dt.Set((time_t)result->report_deadline);
- addProperty(_("Report deadline"), dt.Format());
- if (strlen(result->resources)) {
- addProperty(_("Resources"), wxString(result->resources, wxConvUTF8));
- }
- if (result->active_task) {
- addProperty(_("CPU time at last checkpoint"), FormatTime(result->checkpoint_cpu_time));
- addProperty(_("CPU time"), FormatTime(result->current_cpu_time));
- if (result->elapsed_time >= 0) {
- addProperty(_("Elapsed time"), FormatTime(result->elapsed_time));
- }
- addProperty(_("Estimated time remaining"), FormatTime(result->estimated_cpu_time_remaining));
- addProperty(_("Fraction done"), wxString::Format(wxT("%.3f %%"), result->fraction_done*100));
- addProperty(_("Virtual memory size"), FormatDiskSpace(result->swap_size));
- addProperty(_("Working set size"), FormatDiskSpace(result->working_set_size_smoothed));
- if (result->slot >= 0) {
- addProperty(_("Directory"), wxString::Format(wxT("slots/%d"), result->slot));
- }
- if (result->pid) {
- addProperty(_("Process ID"), wxString::Format(wxT("%d"), result->pid));
- }
- } else if (result->state >= RESULT_COMPUTE_ERROR) {
- addProperty(_("CPU time"), FormatTime(result->final_cpu_time));
- addProperty(_("Elapsed time"), FormatTime(result->final_elapsed_time));
- }
- m_gbSizer->Layout();
- m_scrolledWindow->FitInside();
-}
-
-//
-wxString CDlgItemProperties::FormatDiskSpace(double bytes) {
- double xTera = 1099511627776.0;
- double xGiga = 1073741824.0;
- double xMega = 1048576.0;
- double xKilo = 1024.0;
- wxString strBuffer= wxEmptyString;
-
- if (bytes >= xTera) {
- strBuffer.Printf(wxT("%0.2f TB"), bytes/xTera);
- } else if (bytes >= xGiga) {
- strBuffer.Printf(wxT("%0.2f GB"), bytes/xGiga);
- } else if (bytes >= xMega) {
- strBuffer.Printf(wxT("%0.2f MB"), bytes/xMega);
- } else if (bytes >= xKilo) {
- strBuffer.Printf(wxT("%0.2f KB"), bytes/xKilo);
- } else {
- strBuffer.Printf(wxT("%0.0f bytes"), bytes);
- }
- return strBuffer;
-}
-
-//
-wxString CDlgItemProperties::FormatApplicationName(RESULT* result ) {
- wxString strBuffer = wxEmptyString;
- CMainDocument* pDoc = wxGetApp().GetDocument();
- RESULT* state_result = NULL;
- wxString strAppBuffer = wxEmptyString;
- wxString strClassBuffer = wxEmptyString;
-
- wxASSERT(pDoc);
- wxASSERT(wxDynamicCast(pDoc, CMainDocument));
-
- if (result) {
- state_result = pDoc->state.lookup_result(result->project_url, result->name);
- if (!state_result) {
- pDoc->ForceCacheUpdate();
- state_result = pDoc->state.lookup_result(result->project_url, result->name);
- }
- wxASSERT(state_result);
-
- if (!state_result) return strBuffer;
- WORKUNIT* wup = state_result->wup;
- if (!wup) return strBuffer;
- APP* app = wup->app;
- if (!app) return strBuffer;
- APP_VERSION* avp = state_result->avp;
- if (!avp) return strBuffer;
-
- if (strlen(app->user_friendly_name)) {
- strAppBuffer = wxString(state_result->app->user_friendly_name, wxConvUTF8);
- } else {
- strAppBuffer = wxString(state_result->avp->app_name, wxConvUTF8);
- }
-
- if (strlen(avp->plan_class)) {
- strClassBuffer.Printf(
- wxT(" (%s)"),
- wxString(avp->plan_class, wxConvUTF8).c_str()
- );
- }
-
- strBuffer.Printf(
- wxT("%s %d.%02d %s"),
- strAppBuffer.c_str(),
- state_result->avp->version_num / 100,
- state_result->avp->version_num % 100,
- strClassBuffer.c_str()
- );
- }
- return strBuffer;
-}
-
-
-//
-wxString CDlgItemProperties::FormatStatus(RESULT* result) {
- wxString strBuffer= wxEmptyString;
- CMainDocument* doc = wxGetApp().GetDocument();
- CC_STATUS status;
-
- wxASSERT(doc);
- wxASSERT(wxDynamicCast(doc, CMainDocument));
-
- doc->GetCoreClientStatus(status);
-
- int throttled = status.task_suspend_reason & SUSPEND_REASON_CPU_THROTTLE;
- switch(result->state) {
- case RESULT_NEW:
- strBuffer = _("New");
- break;
- case RESULT_FILES_DOWNLOADING:
- if (result->ready_to_report) {
- strBuffer = _("Download failed");
- } else {
- strBuffer = _("Downloading");
- }
- break;
- case RESULT_FILES_DOWNLOADED:
- if (result->project_suspended_via_gui) {
- strBuffer = _("Project suspended by user");
- } else if (result->suspended_via_gui) {
- strBuffer = _("Task suspended by user");
- } else if (status.task_suspend_reason && !throttled) {
- strBuffer = _("Suspended");
- if (status.task_suspend_reason & SUSPEND_REASON_BATTERIES) {
- strBuffer += _(" - on batteries");
- }
- if (status.task_suspend_reason & SUSPEND_REASON_USER_ACTIVE) {
- strBuffer += _(" - user active");
- }
- if (status.task_suspend_reason & SUSPEND_REASON_USER_REQ) {
- strBuffer += _(" - computation suspended");
- }
- if (status.task_suspend_reason & SUSPEND_REASON_TIME_OF_DAY) {
- strBuffer += _(" - time of day");
- }
- if (status.task_suspend_reason & SUSPEND_REASON_BENCHMARKS) {
- strBuffer += _(" - CPU benchmarks");
- }
- if (status.task_suspend_reason & SUSPEND_REASON_DISK_SIZE) {
- strBuffer += _(" - need disk space");
- }
- } else if (result->active_task) {
- if (result->too_large) {
- strBuffer = _("Waiting for memory");
- } else if (result->needs_shmem) {
- strBuffer = _("Waiting for shared memory");
- } else if (result->scheduler_state == CPU_SCHED_SCHEDULED) {
- if (result->edf_scheduled) {
- strBuffer = _("Running, high priority");
- } else {
- strBuffer = _("Running");
- }
- } else if (result->scheduler_state == CPU_SCHED_PREEMPTED) {
- strBuffer = _("Waiting to run");
- } else if (result->scheduler_state == CPU_SCHED_UNINITIALIZED) {
- strBuffer = _("Ready to start");
- }
- } else {
- strBuffer = _("Ready to start");
- }
- break;
- case RESULT_COMPUTE_ERROR:
- strBuffer = _("Computation error");
- break;
- case RESULT_FILES_UPLOADING:
- if (result->ready_to_report) {
- strBuffer = _("Upload failed");
- } else {
- strBuffer = _("Uploading");
- }
- break;
- case RESULT_ABORTED:
- switch(result->exit_status) {
- case ERR_ABORTED_VIA_GUI:
- strBuffer = _("Aborted by user");
- break;
- case ERR_ABORTED_BY_PROJECT:
- strBuffer = _("Aborted by project");
- break;
- default:
- strBuffer = _("Aborted");
- }
- break;
- default:
- if (result->got_server_ack) {
- strBuffer = _("Acknowledged");
- } else if (result->ready_to_report) {
- strBuffer = _("Ready to report");
- } else {
- strBuffer.Format(_("Error: invalid state '%d'"), result->state);
- }
- break;
- }
- return strBuffer;
-}
-
-//
-wxString CDlgItemProperties::FormatTime(float fBuffer) {
- wxInt32 iHour = 0;
- wxInt32 iMin = 0;
- wxInt32 iSec = 0;
- wxTimeSpan ts;
- wxString strBuffer= wxEmptyString;
-
- if (0 >= fBuffer) {
- strBuffer = wxT("---");
- } else {
- iHour = (wxInt32)(fBuffer / (60 * 60));
- iMin = (wxInt32)(fBuffer / 60) % 60;
- iSec = (wxInt32)(fBuffer) % 60;
-
- ts = wxTimeSpan(iHour, iMin, iSec);
-
- strBuffer = ts.Format();
- }
-
- return strBuffer;
-}
-
-// adds a title section label to the dialog
-void CDlgItemProperties::addSection(const wxString& title) {
- wxStaticText* staticText = new wxStaticText( m_scrolledWindow, wxID_ANY, title, wxDefaultPosition, wxDefaultSize, 0);
- staticText->Wrap( -1 );
- staticText->SetFont( wxFont( wxNORMAL_FONT->GetPointSize(), 70, 90, 92, false, wxEmptyString ) );
- m_gbSizer->Add( staticText, wxGBPosition( m_current_row, 0 ), wxGBSpan( 1, 2 ), wxALL|wxEXPAND, 3);
- m_current_row++;
-}
-
-// adds a property row to the dialog
-void CDlgItemProperties::addProperty(const wxString& name, const wxString& value) {
-
- wxStaticText* staticText = new wxStaticText( m_scrolledWindow, wxID_ANY, name, wxDefaultPosition, wxDefaultSize, 0 );
- staticText->Wrap( -1 );
- m_gbSizer->Add( staticText, wxGBPosition( m_current_row, 0 ), wxGBSpan( 1, 1 ), wxALL, 3 );
-
- staticText = new wxStaticText( m_scrolledWindow, wxID_ANY, value, wxDefaultPosition, wxDefaultSize, 0 );
- staticText->Wrap( -1 );
- m_gbSizer->Add( staticText, wxGBPosition( m_current_row, 1 ), wxGBSpan( 1, 1 ), wxALL|wxEXPAND, 3 );
- m_current_row++;
-}
+
+/* Constructor */
+CDlgItemProperties::CDlgItemProperties(wxWindow* parent) :
+ wxDialog( parent, ID_ANYDIALOG, wxEmptyString, wxDefaultPosition,
+ wxSize( 503,480 ), wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER ) {
+ CBOINCBaseFrame* pFrame = wxGetApp().GetFrame();
+ wxASSERT(pFrame);
+ if (!pFrame) return;
+
+ SetSizeHints( wxDefaultSize, wxDefaultSize );
+ SetExtraStyle( wxWS_EX_VALIDATE_RECURSIVELY );
+
+ m_bSizer1 = new wxBoxSizer( wxVERTICAL );
+
+ m_scrolledWindow = new wxScrolledWindow( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxHSCROLL|wxVSCROLL );
+ m_scrolledWindow->SetScrollRate( 5, 5 );
+ wxBoxSizer* m_bSizer2;
+ m_bSizer2 = new wxBoxSizer( wxVERTICAL );
+
+ m_gbSizer = new wxGridBagSizer( 0, 0 );
+ m_gbSizer->AddGrowableCol( 1 );
+ m_gbSizer->SetFlexibleDirection( wxBOTH );
+ m_gbSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED );
+
+ m_bSizer2->Add( m_gbSizer, 1, wxEXPAND, 5 );
+
+ m_scrolledWindow->SetSizer( m_bSizer2 );
+ m_scrolledWindow->Layout();
+ m_bSizer2->Fit( m_scrolledWindow );
+ m_bSizer1->Add( m_scrolledWindow, 1, wxEXPAND | wxALL, 5 );
+
+ m_btnClose = new wxButton( this, wxID_OK, _("&Close"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_btnClose->SetDefault();
+ m_bSizer1->Add( m_btnClose, 0, wxALIGN_BOTTOM|wxALIGN_CENTER_HORIZONTAL|wxALL, 5 );
+
+ SetSizer( m_bSizer1 );
+ Layout();
+
+ Centre( wxBOTH );
+
+ m_current_row=0;
+
+ int currentTabView = pFrame->GetCurrentViewPage();
+ switch(currentTabView) {
+ case VW_PROJ:
+ m_strBaseConfigLocation = wxString(wxT("/DlgProjectProperties/"));
+ break;
+ case VW_TASK:
+ m_strBaseConfigLocation = wxString(wxT("/DlgTaskProperties/"));
+ break;
+ default:
+ m_strBaseConfigLocation = wxString(wxT("/DlgProperties/"));
+ break;
+ }
+
+ RestoreState();
+}
+
+// destructor
+CDlgItemProperties::~CDlgItemProperties() {
+ SaveState();
+}
+
+/* saves dialog size and (on Mac) position */
+bool CDlgItemProperties::SaveState() {
+ wxConfigBase* pConfig = wxConfigBase::Get(FALSE);
+
+ wxASSERT(pConfig);
+ if (!pConfig) return false;
+
+ pConfig->SetPath(m_strBaseConfigLocation);
+ pConfig->Write(wxT("Width"), GetSize().GetWidth());
+ pConfig->Write(wxT("Height"), GetSize().GetHeight());
+#ifdef __WXMAC__
+ pConfig->Write(wxT("XPos"), GetPosition().x);
+ pConfig->Write(wxT("YPos"), GetPosition().y);
+#endif
+ return true;
+}
+
+/* restores former dialog size and (on Mac) position */
+bool CDlgItemProperties::RestoreState() {
+ wxConfigBase* pConfig = wxConfigBase::Get(FALSE);
+ int iWidth, iHeight;
+
+ wxASSERT(pConfig);
+ if (!pConfig) return false;
+
+ pConfig->SetPath(m_strBaseConfigLocation);
+
+ pConfig->Read(wxT("Width"), &iWidth, wxDefaultCoord);
+ pConfig->Read(wxT("Height"), &iHeight, wxDefaultCoord);
+
+#ifndef __WXMAC__
+ // Set size to saved values or defaults if no saved values
+ SetSize(iWidth, iHeight);
+#else
+ int iTop, iLeft;
+
+ pConfig->Read(wxT("YPos"), &iTop, wxDefaultCoord);
+ pConfig->Read(wxT("XPos"), &iLeft, wxDefaultCoord);
+
+ // If either co-ordinate is less then 0 then set it equal to 0 to ensure
+ // it displays on the screen.
+ if ((iLeft < 0) && (iLeft != wxDefaultCoord)) iLeft = 30;
+ if ((iTop < 0) && (iTop != wxDefaultCoord)) iTop = 30;
+
+ // Set size and position to saved values or defaults if no saved values
+ SetSize(iLeft, iTop, iWidth, iHeight, wxSIZE_USE_EXISTING);
+
+ // Now make sure window is on screen
+ GetScreenPosition(&iLeft, &iTop);
+ GetSize(&iWidth, &iHeight);
+
+ Rect titleRect = {iTop, iLeft, iTop+22, iLeft+iWidth };
+ InsetRect(&titleRect, 5, 5); // Make sure at least a 5X5 piece visible
+ RgnHandle displayRgn = NewRgn();
+ CopyRgn(GetGrayRgn(), displayRgn); // Region encompassing all displays
+ Rect menuRect = ((**GetMainDevice())).gdRect;
+ menuRect.bottom = GetMBarHeight() + menuRect.top;
+ RgnHandle menuRgn = NewRgn();
+ RectRgn(menuRgn, &menuRect); // Region hidden by menu bar
+ DiffRgn(displayRgn, menuRgn, displayRgn); // Subtract menu bar region
+ if (!RectInRgn(&titleRect, displayRgn)) {
+ iTop = iLeft = 30;
+ SetSize(iLeft, iTop, iWidth, iHeight, wxSIZE_USE_EXISTING);
+ }
+ DisposeRgn(menuRgn);
+ DisposeRgn(displayRgn);
+#endif
+
+ return true;
+}
+// show project properties
+//
+void CDlgItemProperties::renderInfos(PROJECT* project_in) {
+ std::string projectname;
+ //collecting infos
+ project_in->get_name(projectname);
+ //disk usage needs additional lookups
+ CMainDocument* pDoc = wxGetApp().GetDocument();
+ pDoc->CachedDiskUsageUpdate();
+
+ // CachedDiskUsageUpdate() may have invalidated our project
+ // pointer, so get an updated pointer to this project
+ PROJECT* project = pDoc->project(wxString(projectname.c_str(),wxConvUTF8));
+ if(!project) return; // TODO: display some sort of error alert?
+
+ std::vector dp = pDoc->disk_usage.projects;
+ double diskusage=0.0;
+ for (unsigned int i=0; i< dp.size(); i++) {
+ PROJECT* tp = dp[i];
+ std::string tname;
+ tp->get_name(tname);
+ wxString t1(wxString(tname.c_str(),wxConvUTF8));
+ if(t1.IsSameAs(wxString(projectname.c_str(),wxConvUTF8)) || t1.IsSameAs(wxString(project->master_url, wxConvUTF8))) {
+ diskusage =tp->disk_usage;
+ break;
+ }
+ }
+ //set dialog title
+ wxString wxTitle = _("Properties of project ");
+ wxTitle.append(wxString(projectname.c_str(),wxConvUTF8));
+ SetTitle(wxTitle);
+ //layout controls
+ addSection(_("General"));
+ addProperty(_("Master URL"),wxString(project->master_url, wxConvUTF8));
+ addProperty(_("User name"),wxString(project->user_name.c_str(),wxConvUTF8));
+ addProperty(_("Team name"),wxString(project->team_name.c_str(),wxConvUTF8));
+ addProperty(_("Resource share"),wxString::Format(wxT("%0.0f"),project->resource_share));
+ if (project->min_rpc_time > dtime()) {
+ addProperty(_("Scheduler RPC deferred for"), FormatTime(project->min_rpc_time - dtime()));
+ }
+ if (project->download_backoff) {
+ addProperty(_("File downloads deferred for"), FormatTime(project->download_backoff));
+ }
+ if (project->upload_backoff) {
+ addProperty(_("File uploads deferred for"), FormatTime(project->upload_backoff));
+ }
+ addProperty(_("Disk usage"),FormatDiskSpace(diskusage));
+ addProperty(_("Computer ID"), wxString::Format(wxT("%d"), project->hostid));
+ addProperty(_("Non CPU intensive"),project->non_cpu_intensive ? _("yes") : _("no"));
+ addProperty(_("Suspended via GUI"),project->suspended_via_gui ? _("yes") : _("no"));
+ addProperty(_("Don't request more work"),project->dont_request_more_work ? _("yes") : _("no"));
+ addProperty(_("Scheduler call in progress"),project->scheduler_rpc_in_progress ? _("yes") : _("no"));
+ addProperty(_("Attached via account manager"),project->attached_via_acct_mgr ? _("yes") : _("no"));
+ addProperty(_("Detach when done"),project->detach_when_done ? _("yes") : _("no"));
+ addProperty(_("Ended"),project->ended ? _("yes") : _("no"));
+ addSection(_("Credit"));
+ addProperty(_("User"),
+ wxString::Format(
+ wxT("%0.2f total, %0.2f average"),
+ project->user_total_credit,
+ project->user_expavg_credit
+ )
+ );
+ addProperty(_("Host"),
+ wxString::Format(
+ wxT("%0.2f total, %0.2f average"),
+ project->host_total_credit,
+ project->host_expavg_credit
+ )
+ );
+
+ if (!project->non_cpu_intensive) {
+ addSection(_("Scheduling"));
+ addProperty(_("CPU scheduling priority"),wxString::Format(wxT("%0.2f"), project->cpu_short_term_debt));
+ addProperty(_("CPU work fetch priority"),wxString::Format(wxT("%0.2f"), project->cpu_long_term_debt));
+ double x = project->cpu_backoff_time - dtime();
+ if (x<0) x = 0;
+ addProperty(_("CPU work fetch deferred for"), FormatTime(x));
+ addProperty(_("CPU work fetch deferral interval"), FormatTime(project->cpu_backoff_interval));
+ if (pDoc->state.have_cuda) {
+ addProperty(_("NVIDIA GPU scheduling priority"),wxString::Format(wxT("%0.2f"), project->cuda_short_term_debt));
+ addProperty(_("NVIDIA GPU work fetch priority"),wxString::Format(wxT("%0.2f"), project->cuda_debt));
+ x = project->cuda_backoff_time - dtime();
+ if (x<0) x = 0;
+ addProperty(_("NVIDIA GPU work fetch deferred for"), FormatTime(x));
+ addProperty(_("NVIDIA GPU work fetch deferral interval"), FormatTime(project->cuda_backoff_interval));
+ }
+ if (pDoc->state.have_ati) {
+ addProperty(_("ATI GPU scheduling priority"),wxString::Format(wxT("%0.2f"), project->ati_short_term_debt));
+ addProperty(_("ATI GPU work fetch priority"),wxString::Format(wxT("%0.2f"), project->ati_debt));
+ x = project->ati_backoff_time - dtime();
+ if (x<0) x = 0;
+ addProperty(_("ATI GPU work fetch deferred for"), FormatTime(x));
+ addProperty(_("ATI GPU work fetch deferral interval"), FormatTime(project->ati_backoff_interval));
+ }
+ addProperty(_("Duration correction factor"),wxString::Format(wxT("%0.4f"), project->duration_correction_factor));
+ }
+ m_gbSizer->Layout();
+ m_scrolledWindow->FitInside();
+}
+
+// show task properties
+//
+void CDlgItemProperties::renderInfos(RESULT* result) {
+ wxDateTime dt;
+ wxString wxTitle = _("Properties of task ");
+ wxTitle.append(wxString(result->name, wxConvUTF8));
+ SetTitle(wxTitle);
+
+ addProperty(_("Application"), FormatApplicationName(result));
+ addProperty(_("Workunit name"),wxString(result->wu_name, wxConvUTF8));
+ addProperty(_("State"), FormatStatus(result));
+ if (result->received_time) {
+ dt.Set((time_t)result->received_time);
+ addProperty(_("Received"), dt.Format());
+ }
+ dt.Set((time_t)result->report_deadline);
+ addProperty(_("Report deadline"), dt.Format());
+ if (strlen(result->resources)) {
+ addProperty(_("Resources"), wxString(result->resources, wxConvUTF8));
+ }
+ if (result->active_task) {
+ addProperty(_("CPU time at last checkpoint"), FormatTime(result->checkpoint_cpu_time));
+ addProperty(_("CPU time"), FormatTime(result->current_cpu_time));
+ if (result->elapsed_time >= 0) {
+ addProperty(_("Elapsed time"), FormatTime(result->elapsed_time));
+ }
+ addProperty(_("Estimated time remaining"), FormatTime(result->estimated_cpu_time_remaining));
+ addProperty(_("Fraction done"), wxString::Format(wxT("%.3f %%"), result->fraction_done*100));
+ addProperty(_("Virtual memory size"), FormatDiskSpace(result->swap_size));
+ addProperty(_("Working set size"), FormatDiskSpace(result->working_set_size_smoothed));
+ if (result->slot >= 0) {
+ addProperty(_("Directory"), wxString::Format(wxT("slots/%d"), result->slot));
+ }
+ if (result->pid) {
+ addProperty(_("Process ID"), wxString::Format(wxT("%d"), result->pid));
+ }
+ } else if (result->state >= RESULT_COMPUTE_ERROR) {
+ addProperty(_("CPU time"), FormatTime(result->final_cpu_time));
+ addProperty(_("Elapsed time"), FormatTime(result->final_elapsed_time));
+ }
+ m_gbSizer->Layout();
+ m_scrolledWindow->FitInside();
+}
+
+//
+wxString CDlgItemProperties::FormatDiskSpace(double bytes) {
+ double xTera = 1099511627776.0;
+ double xGiga = 1073741824.0;
+ double xMega = 1048576.0;
+ double xKilo = 1024.0;
+ wxString strBuffer= wxEmptyString;
+
+ if (bytes >= xTera) {
+ strBuffer.Printf(wxT("%0.2f TB"), bytes/xTera);
+ } else if (bytes >= xGiga) {
+ strBuffer.Printf(wxT("%0.2f GB"), bytes/xGiga);
+ } else if (bytes >= xMega) {
+ strBuffer.Printf(wxT("%0.2f MB"), bytes/xMega);
+ } else if (bytes >= xKilo) {
+ strBuffer.Printf(wxT("%0.2f KB"), bytes/xKilo);
+ } else {
+ strBuffer.Printf(wxT("%0.0f bytes"), bytes);
+ }
+ return strBuffer;
+}
+
+//
+wxString CDlgItemProperties::FormatApplicationName(RESULT* result ) {
+ wxString strBuffer = wxEmptyString;
+ CMainDocument* pDoc = wxGetApp().GetDocument();
+ RESULT* state_result = NULL;
+ wxString strAppBuffer = wxEmptyString;
+ wxString strClassBuffer = wxEmptyString;
+
+ wxASSERT(pDoc);
+ wxASSERT(wxDynamicCast(pDoc, CMainDocument));
+
+ if (result) {
+ state_result = pDoc->state.lookup_result(result->project_url, result->name);
+ if (!state_result) {
+ pDoc->ForceCacheUpdate();
+ state_result = pDoc->state.lookup_result(result->project_url, result->name);
+ }
+ wxASSERT(state_result);
+
+ if (!state_result) return strBuffer;
+ WORKUNIT* wup = state_result->wup;
+ if (!wup) return strBuffer;
+ APP* app = wup->app;
+ if (!app) return strBuffer;
+ APP_VERSION* avp = state_result->avp;
+ if (!avp) return strBuffer;
+
+ if (strlen(app->user_friendly_name)) {
+ strAppBuffer = wxString(state_result->app->user_friendly_name, wxConvUTF8);
+ } else {
+ strAppBuffer = wxString(state_result->avp->app_name, wxConvUTF8);
+ }
+
+ if (strlen(avp->plan_class)) {
+ strClassBuffer.Printf(
+ wxT(" (%s)"),
+ wxString(avp->plan_class, wxConvUTF8).c_str()
+ );
+ }
+
+ strBuffer.Printf(
+ wxT("%s %d.%02d %s"),
+ strAppBuffer.c_str(),
+ state_result->avp->version_num / 100,
+ state_result->avp->version_num % 100,
+ strClassBuffer.c_str()
+ );
+ }
+ return strBuffer;
+}
+
+
+//
+wxString CDlgItemProperties::FormatStatus(RESULT* result) {
+ wxString strBuffer= wxEmptyString;
+ CMainDocument* doc = wxGetApp().GetDocument();
+ CC_STATUS status;
+
+ wxASSERT(doc);
+ wxASSERT(wxDynamicCast(doc, CMainDocument));
+
+ doc->GetCoreClientStatus(status);
+
+ int throttled = status.task_suspend_reason & SUSPEND_REASON_CPU_THROTTLE;
+ switch(result->state) {
+ case RESULT_NEW:
+ strBuffer = _("New");
+ break;
+ case RESULT_FILES_DOWNLOADING:
+ if (result->ready_to_report) {
+ strBuffer = _("Download failed");
+ } else {
+ strBuffer = _("Downloading");
+ }
+ break;
+ case RESULT_FILES_DOWNLOADED:
+ if (result->project_suspended_via_gui) {
+ strBuffer = _("Project suspended by user");
+ } else if (result->suspended_via_gui) {
+ strBuffer = _("Task suspended by user");
+ } else if (status.task_suspend_reason && !throttled) {
+ strBuffer = _("Suspended");
+ if (status.task_suspend_reason & SUSPEND_REASON_BATTERIES) {
+ strBuffer += _(" - on batteries");
+ }
+ if (status.task_suspend_reason & SUSPEND_REASON_USER_ACTIVE) {
+ strBuffer += _(" - user active");
+ }
+ if (status.task_suspend_reason & SUSPEND_REASON_USER_REQ) {
+ strBuffer += _(" - computation suspended");
+ }
+ if (status.task_suspend_reason & SUSPEND_REASON_TIME_OF_DAY) {
+ strBuffer += _(" - time of day");
+ }
+ if (status.task_suspend_reason & SUSPEND_REASON_BENCHMARKS) {
+ strBuffer += _(" - CPU benchmarks");
+ }
+ if (status.task_suspend_reason & SUSPEND_REASON_DISK_SIZE) {
+ strBuffer += _(" - need disk space");
+ }
+ } else if (result->active_task) {
+ if (result->too_large) {
+ strBuffer = _("Waiting for memory");
+ } else if (result->needs_shmem) {
+ strBuffer = _("Waiting for shared memory");
+ } else if (result->scheduler_state == CPU_SCHED_SCHEDULED) {
+ if (result->edf_scheduled) {
+ strBuffer = _("Running, high priority");
+ } else {
+ strBuffer = _("Running");
+ }
+ } else if (result->scheduler_state == CPU_SCHED_PREEMPTED) {
+ strBuffer = _("Waiting to run");
+ } else if (result->scheduler_state == CPU_SCHED_UNINITIALIZED) {
+ strBuffer = _("Ready to start");
+ }
+ } else {
+ strBuffer = _("Ready to start");
+ }
+ break;
+ case RESULT_COMPUTE_ERROR:
+ strBuffer = _("Computation error");
+ break;
+ case RESULT_FILES_UPLOADING:
+ if (result->ready_to_report) {
+ strBuffer = _("Upload failed");
+ } else {
+ strBuffer = _("Uploading");
+ }
+ break;
+ case RESULT_ABORTED:
+ switch(result->exit_status) {
+ case ERR_ABORTED_VIA_GUI:
+ strBuffer = _("Aborted by user");
+ break;
+ case ERR_ABORTED_BY_PROJECT:
+ strBuffer = _("Aborted by project");
+ break;
+ default:
+ strBuffer = _("Aborted");
+ }
+ break;
+ default:
+ if (result->got_server_ack) {
+ strBuffer = _("Acknowledged");
+ } else if (result->ready_to_report) {
+ strBuffer = _("Ready to report");
+ } else {
+ strBuffer.Format(_("Error: invalid state '%d'"), result->state);
+ }
+ break;
+ }
+ return strBuffer;
+}
+
+//
+wxString CDlgItemProperties::FormatTime(float fBuffer) {
+ wxInt32 iHour = 0;
+ wxInt32 iMin = 0;
+ wxInt32 iSec = 0;
+ wxTimeSpan ts;
+ wxString strBuffer= wxEmptyString;
+
+ if (0 >= fBuffer) {
+ strBuffer = wxT("---");
+ } else {
+ iHour = (wxInt32)(fBuffer / (60 * 60));
+ iMin = (wxInt32)(fBuffer / 60) % 60;
+ iSec = (wxInt32)(fBuffer) % 60;
+
+ ts = wxTimeSpan(iHour, iMin, iSec);
+
+ strBuffer = ts.Format();
+ }
+
+ return strBuffer;
+}
+
+// adds a title section label to the dialog
+void CDlgItemProperties::addSection(const wxString& title) {
+ wxStaticText* staticText = new wxStaticText( m_scrolledWindow, wxID_ANY, title, wxDefaultPosition, wxDefaultSize, 0);
+ staticText->Wrap( -1 );
+ staticText->SetFont( wxFont( wxNORMAL_FONT->GetPointSize(), 70, 90, 92, false, wxEmptyString ) );
+ m_gbSizer->Add( staticText, wxGBPosition( m_current_row, 0 ), wxGBSpan( 1, 2 ), wxALL|wxEXPAND, 3);
+ m_current_row++;
+}
+
+// adds a property row to the dialog
+void CDlgItemProperties::addProperty(const wxString& name, const wxString& value) {
+
+ wxStaticText* staticText = new wxStaticText( m_scrolledWindow, wxID_ANY, name, wxDefaultPosition, wxDefaultSize, 0 );
+ staticText->Wrap( -1 );
+ m_gbSizer->Add( staticText, wxGBPosition( m_current_row, 0 ), wxGBSpan( 1, 1 ), wxALL, 3 );
+
+ staticText = new wxStaticText( m_scrolledWindow, wxID_ANY, value, wxDefaultPosition, wxDefaultSize, 0 );
+ staticText->Wrap( -1 );
+ m_gbSizer->Add( staticText, wxGBPosition( m_current_row, 1 ), wxGBSpan( 1, 1 ), wxALL|wxEXPAND, 3 );
+ m_current_row++;
+}
diff --git a/clientgui/DlgItemProperties.h b/clientgui/DlgItemProperties.h
index 1eb49093eb..d9ac701a03 100755
--- a/clientgui/DlgItemProperties.h
+++ b/clientgui/DlgItemProperties.h
@@ -39,6 +39,7 @@
class CDlgItemProperties : public wxDialog {
DECLARE_DYNAMIC_CLASS( CDlgItemProperties )
+ DECLARE_EVENT_TABLE()
public:
CDlgItemProperties(wxWindow* parent=NULL);//to act as standard constructor set a default value
virtual ~CDlgItemProperties();