2 Copyright (C) 2012 Carl Hetherington <cth@carlh.net>
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 /** @file src/job_manager_view.cc
21 * @brief Class generating a GTK widget to show the progress of jobs.
24 #include "lib/job_manager.h"
27 #include "lib/exceptions.h"
28 #include "job_manager_view.h"
32 using namespace boost;
34 /** Must be called in the GUI thread */
35 JobManagerView::JobManagerView (wxWindow* parent)
38 _sizer = new wxFlexGridSizer (2, 6, 6);
42 add_label_to_sizer (_sizer, this, "Hello world");
43 wxGauge* g = new wxGauge (this, wxID_ANY, 100);
44 _sizer->Add (g, 1, wxEXPAND | wxALL);
46 add_label_to_sizer (_sizer, this, "Shit");
47 g = new wxGauge (this, wxID_ANY, 100);
48 _sizer->Add (g, 1, wxEXPAND | wxALL);
51 Connect (wxID_ANY, wxEVT_TIMER, wxTimerEventHandler (JobManagerView::periodic), 0, this);
52 _timer.reset (new wxTimer (this));
59 JobManagerView::periodic (wxTimerEvent &)
64 /** Update the view by examining the state of each job.
65 * Must be called in the GUI thread.
68 JobManagerView::update ()
70 list<shared_ptr<Job> > jobs = JobManager::instance()->get ();
72 for (list<shared_ptr<Job> >::iterator i = jobs.begin(); i != jobs.end(); ++i) {
74 if (_job_records.find (*i) == _job_records.end ()) {
75 add_label_to_sizer (_sizer, this, (*i)->name ());
78 r.gauge = new wxGauge (this, wxID_ANY, 100);
79 r.informed_of_finish = false;
81 _sizer->Add (r.gauge, 1, wxEXPAND);
86 bool inform_of_finish = false;
87 string const st = (*i)->status ();
89 if (!(*i)->finished ()) {
90 float const p = (*i)->overall_progress ();
92 // r[_columns.text] = st;
93 _job_records[*i].gauge->SetValue (p * 100);
95 // r[_columns.text] = "Running";
96 _job_records[*i].gauge->Pulse ();
100 /* Hack to work around our lack of cross-thread
101 signalling; we tell the job to emit_finished()
102 from here (the GUI thread).
105 if ((*i)->finished_ok ()) {
106 if (!_job_records[*i].informed_of_finish) {
107 _job_records[*i].gauge->SetValue (100);
108 // r[_columns.text] = st;
109 inform_of_finish = true;
111 } else if ((*i)->finished_in_error ()) {
112 if (!_job_records[*i].informed_of_finish) {
113 _job_records[*i].gauge->SetValue (100);
114 // r[_columns.text] = st;
115 inform_of_finish = true;
119 if (inform_of_finish) {
121 (*i)->emit_finished ();
122 } catch (OpenFileError& e) {
124 s << "Error: " << e.what();
125 error_dialog (this, s.str ());
127 _job_records[*i].informed_of_finish = true;