summaryrefslogtreecommitdiff
path: root/extensions/source/scanner
diff options
context:
space:
mode:
authorJens-Heiner Rechtien <hr@openoffice.org>2004-02-02 18:34:49 +0000
committerJens-Heiner Rechtien <hr@openoffice.org>2004-02-02 18:34:49 +0000
commita7f7bd6aaae2ded85b4ba99f0c30d432fd818e1a (patch)
treed33819c323966dda7c90b6b668b0014fd72fc027 /extensions/source/scanner
parent2d976d6eac76871add3d30ba797f02b8d876d1af (diff)
INTEGRATION: CWS geordi2q14 (1.5.132); FILE MERGED
2004/01/28 15:41:14 hr 1.5.132.1: #111934#: merge CWS vcl7pp1r3
Diffstat (limited to 'extensions/source/scanner')
-rw-r--r--extensions/source/scanner/scanunx.cxx32
1 files changed, 28 insertions, 4 deletions
diff --git a/extensions/source/scanner/scanunx.cxx b/extensions/source/scanner/scanunx.cxx
index 9a727866e328..3528fa996f25 100644
--- a/extensions/source/scanner/scanunx.cxx
+++ b/extensions/source/scanner/scanunx.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: scanunx.cxx,v $
*
- * $Revision: 1.5 $
+ * $Revision: 1.6 $
*
- * last change: $Author: vg $ $Date: 2003-04-15 16:19:13 $
+ * last change: $Author: hr $ $Date: 2004-02-02 19:34:49 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -143,6 +143,7 @@ struct SaneHolder
REF( AWT::XBitmap ) m_xBitmap;
vos::OMutex m_aProtector;
ScanError m_nError;
+ bool m_bBusy;
};
DECLARE_LIST( SaneHolderList, SaneHolder* );
@@ -198,6 +199,7 @@ void ScannerThread::run()
m_pHolder->m_xBitmap = REF( AWT::XBitmap )( aIf, UNO_QUERY );
+ m_pHolder->m_bBusy = true;
if( m_pHolder->m_aSane.IsOpen() )
{
int nOption = m_pHolder->m_aSane.GetOptionByName( "preview" );
@@ -214,6 +216,7 @@ void ScannerThread::run()
REF( XInterface ) xXInterface( static_cast< OWeakObject* >( m_pManager ) );
m_xListener->disposing( com::sun::star::lang::EventObject(xXInterface) );
+ m_pHolder->m_bBusy = false;
}
// ------------------
@@ -251,6 +254,7 @@ SEQ( ScannerContext ) ScannerManager::getAvailableScanners() throw()
{
SaneHolder* pSaneHolder = new SaneHolder;
pSaneHolder->m_nError = ScanError_ScanErrorNone;
+ pSaneHolder->m_bBusy = false;
if( Sane::IsSane() )
allSanes.Insert( pSaneHolder );
else
@@ -284,8 +288,21 @@ BOOL ScannerManager::configureScanner( ScannerContext& scanner_context ) throw(
REF( XScannerManager )( this ),
ScanError_InvalidContext
);
- SaneDlg aDlg( NULL, allSanes.GetObject( scanner_context.InternalData )->m_aSane );
- return (BOOL)aDlg.Execute();
+
+ SaneHolder* pHolder = allSanes.GetObject( scanner_context.InternalData );
+ if( pHolder->m_bBusy )
+ throw ScannerException(
+ ::rtl::OUString::createFromAscii( "Scanner is busy" ),
+ REF( XScannerManager )( this ),
+ ScanError_ScanInProgress
+ );
+
+ pHolder->m_bBusy = true;
+ SaneDlg aDlg( NULL, pHolder->m_aSane );
+ BOOL bRet = (BOOL)aDlg.Execute();
+ pHolder->m_bBusy = false;
+
+ return bRet;
}
// -----------------------------------------------------------------------------
@@ -306,6 +323,13 @@ void ScannerManager::startScan( const ScannerContext& scanner_context,
ScanError_InvalidContext
);
SaneHolder* pHolder = allSanes.GetObject( scanner_context.InternalData );
+ if( pHolder->m_bBusy )
+ throw ScannerException(
+ ::rtl::OUString::createFromAscii( "Scanner is busy" ),
+ REF( XScannerManager )( this ),
+ ScanError_ScanInProgress
+ );
+ pHolder->m_bBusy = true;
ScannerThread* pThread = new ScannerThread( pHolder, listener, this );
pThread->create();