** This is part of the CTSim program
** Copyright (C) 1983-2001 Kevin Rosenberg
**
-** $Id: backgroundsupr.cpp,v 1.12 2001/03/04 22:30:19 kevin Exp $
+** $Id: backgroundsupr.cpp,v 1.13 2001/03/05 17:26:46 kevin Exp $
**
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License (version 2) as
-BackgroundSupervisor::BackgroundSupervisor (SupervisorThread* pMyThread, wxFrame* pParentFrame, wxDocument* pDocument, const char* const pszProcessTitle, int iTotalUnits)
+BackgroundSupervisor::BackgroundSupervisor (SupervisorThread* pMyThread, wxFrame* pParentFrame, BackgroundProcessingDocument* pDocument, const char* const pszProcessTitle, int iTotalUnits)
: wxEvtHandler(), m_pMyThread(pMyThread), m_pParentFrame(pParentFrame), m_pDocument(pDocument), m_strProcessTitle(pszProcessTitle),
m_iTotalUnits(iTotalUnits), m_iNumThreads(0), m_bDone(false), m_bFail(false), m_bCancelled(false), m_iRunning(0),
- m_pTimer(NULL), m_bBackgroundTaskAdded(false), m_bWorkersDeleted(false)
+ m_pTimer(NULL), m_bWorkersDeleted(false)
{
m_iNumThreads = theApp->getNumberCPU();
// ++m_iNumThreads;
BackgroundSupervisor::~BackgroundSupervisor()
{
- if (m_bBackgroundTaskAdded) {
- wxCommandEvent doneEvent (wxEVT_COMMAND_MENU_SELECTED, MSG_BACKGROUND_SUPERVISOR_REMOVE);
- doneEvent.SetClientData (this);
- wxPostEvent (theApp->getBackgroundManager(), doneEvent);
- wxPostEvent (m_pDocument, doneEvent);
- }
+ wxCommandEvent doneEvent (wxEVT_COMMAND_MENU_SELECTED, MSG_BACKGROUND_SUPERVISOR_REMOVE);
+ doneEvent.SetClientData (this);
+ wxPostEvent (theApp->getBackgroundManager(), doneEvent);
- while (m_bBackgroundTaskAdded) {
- m_pMyThread->Sleep(50);
- }
+ m_pDocument->removeBackgroundSupervisor (this);
delete m_pTimer;
}
addTaskEvent.SetInt (m_iTotalUnits);
addTaskEvent.SetClientData (this);
wxPostEvent (theApp->getBackgroundManager(), addTaskEvent);
- wxPostEvent (m_pDocument, addTaskEvent);
- m_bBackgroundTaskAdded = true;
+
+ m_pDocument->addBackgroundSupervisor (this);
m_iRunning = m_iNumThreads;
m_iUnitsDone = 0;
m_bDone = true;
}
-void
-BackgroundSupervisor::onAckDocumentRemove()
-{
- m_bBackgroundTaskAdded = false;
-}
-
void
BackgroundSupervisor::onWorkerUnitTick ()