Files
libreoffice/dbaccess/source/ui/browser/AsyncronousLink.cxx
Jens-Heiner Rechtien 9dbb41b555 INTEGRATION: CWS dba201b (1.2.450); FILE MERGED
2005/09/21 07:52:43 oj 1.2.450.2: RESYNC: (1.2-1.3); FILE MERGED
2005/07/11 13:37:12 fs 1.2.450.1: merging CWS dba201 into CWS dba201b
2005-09-23 11:18:50 +00:00

140 lines
4.5 KiB
C++

/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: AsyncronousLink.cxx,v $
*
* $Revision: 1.4 $
*
* last change: $Author: hr $ $Date: 2005-09-23 12:18:50 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library 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 this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
************************************************************************/
#ifndef DBAUI_ASYNCRONOUSLINK_HXX
#include "AsyncronousLink.hxx"
#endif
#ifndef _SV_SVAPP_HXX
#include <vcl/svapp.hxx>
#endif
#ifndef _TOOLS_DEBUG_HXX
#include <tools/debug.hxx>
#endif
//==================================================================
//= OAsyncronousLink
//==================================================================
using namespace dbaui;
DBG_NAME(OAsyncronousLink)
//------------------------------------------------------------------
OAsyncronousLink::OAsyncronousLink(const Link& _rHandler, ::vos::OMutex* _pEventSafety, ::vos::OMutex* _pDestructionSafety)
:m_aHandler(_rHandler)
,m_pEventSafety(NULL)
,m_pDestructionSafety(NULL)
,m_bOwnMutexes(FALSE)
,m_nEventId(0)
{
DBG_CTOR(OAsyncronousLink,NULL);
if (_pEventSafety && _pDestructionSafety)
{
m_pEventSafety = _pEventSafety;
m_pDestructionSafety = _pDestructionSafety;
m_bOwnMutexes = FALSE;
}
else
{
m_pEventSafety = new ::vos::OMutex;
m_pDestructionSafety = new ::vos::OMutex;
m_bOwnMutexes = TRUE;
}
}
//------------------------------------------------------------------
OAsyncronousLink::~OAsyncronousLink()
{
{
::vos::OGuard aEventGuard(*m_pEventSafety);
if (m_nEventId)
Application::RemoveUserEvent(m_nEventId);
m_nEventId = 0;
}
{
::vos::OGuard aDestructionGuard(*m_pDestructionSafety);
// this is just for the case we're deleted while another thread just handled the event :
// if this other thread called our link while we were deleting the event here, the
// link handler blocked. With leaving the above block it continued, but now we are prevented
// to leave this destructor 'til the link handler recognizes that nEvent == 0 and leaves.
}
if (m_bOwnMutexes)
{
delete m_pEventSafety;
delete m_pDestructionSafety;
}
m_pEventSafety = NULL;
m_pDestructionSafety = NULL;
DBG_DTOR(OAsyncronousLink,NULL);
}
//------------------------------------------------------------------
void OAsyncronousLink::Call(void* _pArgument)
{
::vos::OGuard aEventGuard(*m_pEventSafety);
if (m_nEventId)
Application::RemoveUserEvent(m_nEventId);
m_nEventId = Application::PostUserEvent(LINK(this, OAsyncronousLink, OnAsyncCall));
}
//------------------------------------------------------------------
void OAsyncronousLink::CancelCall()
{
::vos::OGuard aEventGuard(*m_pEventSafety);
if (m_nEventId)
Application::RemoveUserEvent(m_nEventId);
m_nEventId = 0;
}
//------------------------------------------------------------------
IMPL_LINK(OAsyncronousLink, OnAsyncCall, void*, _pArg)
{
{
::vos::OGuard aDestructionGuard(*m_pDestructionSafety);
{
::vos::OGuard aEventGuard(*m_pEventSafety);
if (!m_nEventId)
// our destructor deleted the event just while we we're waiting for m_pEventSafety
// -> get outta here
return 0;
m_nEventId = 0;
}
}
if (m_aHandler.IsSet())
return m_aHandler.Call(_pArg);
return 0L;
}