/************************************************************************* * * $RCSfile: statemnt.cxx,v $ * * $Revision: 1.7 $ * * last change: $Author: vg $ $Date: 2003-06-10 11:29:44 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses * * - GNU Lesser General Public License Version 2.1 * - Sun Industry Standards Source License Version 1.1 * * Sun Microsystems Inc., October, 2002 * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2002 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 * * * Sun Industry Standards Source License Version 1.1 * ================================================= * The contents of this file are subject to the Sun Industry Standards * Source License Version 1.1 (the "License"); You may not use this file * except in compliance with the License. You may obtain a copy of the * License at http://www.openoffice.org/license.html. * * Software provided under this License is provided on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING, * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS, * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING. * See the License for the specific provisions governing your rights and * obligations concerning the Software. * * The Initial Developer of the Original Code is: Sun Microsystems, Inc. * * Copyright: 2002 by Sun Microsystems, Inc. * * All Rights Reserved. * * Contributor(s): _______________________________________ * * ************************************************************************/ #ifndef _COM_SUN_STAR_FRAME_XFRAMESSUPPLIER_HPP_ #include #endif #ifndef _COM_SUN_STAR_FRAME_XDISPATCH_HPP_ #include #endif #ifndef _COM_SUN_STAR_FRAME_XDISPATCHPROVIDER_HPP_ #include #endif #ifndef _COM_SUN_STAR_UTIL_XURLTRANSFORMER_HPP_ #include #endif #ifndef _COMPHELPER_PROCESSFACTORY_HXX_ #include #endif #include #ifndef _DIALOG_HXX //autogen #include #endif #ifndef _BUTTON_HXX //autogen #include #endif #ifndef _SV_MENUBTN_HXX //autogen #include #endif #ifndef _SVTREEBOX_HXX //autogen #include #endif #ifndef _SVX_BRWBOX_HXX //autogen #include #endif #ifndef _MSGBOX_HXX //autogen #include #endif #ifndef _DOCKWIN_HXX //autogen #include #endif #ifndef _FLOATWIN_HXX //autogen #include #endif #ifndef _LSTBOX_HXX //autogen #include #endif #ifndef _COMBOBOX_HXX //autogen #include #endif #ifndef _MOREBTN_HXX //autogen #include #endif #ifndef _FIELD_HXX //autogen #include #endif #ifndef _TOOLBOX_HXX //autogen #include #endif #ifndef _SV_TABCTRL_HXX //autogen #include #endif #ifndef _SV_TABPAGE_HXX //autogen #include #endif #ifndef _SV_MENU_HXX //autogen #include #endif #ifndef _SV_STATUS_HXX //autogen #include #endif #ifndef _PRGSBAR_HXX #include #endif #ifndef _SVTOOLS_EDITBROWSEBOX_HXX_ #include #endif #ifndef _SV_SPLITWIN_HXX //autogen #include #endif #ifndef _SV_GROUP_HXX //autogen #include #endif #ifndef _SV_FIXED_HXX //autogen #include #endif #ifndef _SV_WRKWIN_HXX //handmade #include #endif #ifndef _OSL_DIAGNOSE_H_ //handmade #include #endif #ifndef _SV_WINTYPES_HXX //autogen #include #endif #ifndef _VALUESET_HXX //autogen #include #endif #ifndef _SFXPOOLITEM_HXX //autogen #include #endif // Hat keinen Includeschutz #include #ifndef _TIME_HXX //autogen #include #endif #ifndef _SVTOOLS_STRINGTRANSFER_HXX_ #include #endif #ifndef _PRINT_HXX //autogen #include #endif #ifndef _PRNDLG_HXX //autogen #include #endif #ifndef _STREAM_HXX //autogen #include #endif #ifndef _SV_DRAG_HXX //autogen //#include #endif #ifndef _FSYS_HXX //autogen #include #endif #ifndef _SFXSTRITEM_HXX //autogen #include #endif #ifndef _SVTOOLS_TTPROPS_HXX // handmade #include #endif #ifndef _BASIC_TTRESHLP_HXX #include #endif #ifndef _BASIC_DISPDEFS_HXX #include #endif #include #include #include #include #include #ifndef _STATEMNT_HXX #include "statemnt.hxx" #endif #ifndef _SCMDSTRM_HXX #include "scmdstrm.hxx" #endif #ifndef _RETSRTM_HXX #include "retstrm.hxx" #endif #if OSL_DEBUG_LEVEL > 1 #ifndef _EDITWIN_HXX #include "editwin.hxx" #endif #endif #ifndef _RCONTROL_HXX #include "rcontrol.hxx" #endif #ifndef _COMMUNI_HXX #include #endif #ifndef SVTOOLS_TESTTOOL_HXX #include "testtool.hxx" #endif #include "profiler.hxx" #include "testtool.hrc" #include "svtools/svtmsg.hrc" #include using namespace com::sun::star::frame; using namespace com::sun::star::uno; using namespace com::sun::star::util; using namespace com::sun::star::beans; using namespace svt; #ifndef SBX_VALUE_DECL_DEFINED #define SBX_VALUE_DECL_DEFINED SV_DECL_REF(SbxValue) #endif SV_IMPL_REF(SbxValue) CommunicationLink *StatementFlow::pCommLink = NULL; BOOL StatementFlow::bUseIPC = TRUE; BOOL StatementFlow::bSending = FALSE; ImplRemoteControl *StatementFlow::pRemoteControl = NULL; USHORT StatementCommand::nDirPos = 0; Dir *StatementCommand::pDir = NULL; pfunc_osl_printDebugMessage StatementCommand::pOriginal_osl_DebugMessageFunc = NULL; #define SET_WINP_CLOSING(pWin) \ pWindowWaitPointer = pWin; \ nWindowWaitUId = pControl->GetUniqueOrHelpId(); \ nWindowWaitOldHelpId = pWin->GetHelpId(); \ nWindowWaitOldUniqueId = pWin->GetUniqueId(); \ pWin->SetHelpId(4321); \ pWin->SetUniqueId(1234); // -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= StatementFlow::StatementFlow( StatementList *pAfterThis, USHORT nArtP ) : nArt(nArtP) , nParams(0) , nSNr1(0) , nLNr1(0) , aString1() , bBool1(FALSE) { QueStatement( pAfterThis ); } StatementFlow::StatementFlow( ULONG nServiceId, SCmdStream *pCmdIn, ImplRemoteControl *pRC ) : nArt(0) , nParams(0) , nSNr1(0) , nLNr1(0) , aString1() , bBool1(FALSE) { QueStatement( NULL ); bUseIPC = (nServiceId == SI_IPCCommandBlock); pRemoteControl = pRC; pCmdIn->Read( nArt ); pCmdIn->Read( nParams ); if( nParams & PARAM_USHORT_1 ) pCmdIn->Read( nSNr1 ); if( nParams & PARAM_ULONG_1 ) pCmdIn->Read( nLNr1 ); if( nParams & PARAM_STR_1 ) pCmdIn->Read( aString1 ); if( nParams & PARAM_BOOL_1 ) pCmdIn->Read( bBool1 ); // sollte nie auftreten!! #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Reading FlowControl: " ); m_pDbgWin->AddText( String::CreateFromInt32( nArt ) ); m_pDbgWin->AddText( " Params:" ); if( nParams & PARAM_USHORT_1 ) {m_pDbgWin->AddText( " n1:" );m_pDbgWin->AddText( String::CreateFromInt32( nSNr1 ) );} if( nParams & PARAM_ULONG_1 ) {m_pDbgWin->AddText( " l1:" );m_pDbgWin->AddText( String::CreateFromInt64( nLNr1 ) );} if( nParams & PARAM_STR_1 ) {m_pDbgWin->AddText( " s1:" );m_pDbgWin->AddText( aString1 );} if( nParams & PARAM_BOOL_1 ) {m_pDbgWin->AddText( " b2:" );m_pDbgWin->AddText( bBool1 ? "TRUE" : "FALSE" );} m_pDbgWin->AddText( "\n" ); #endif } void StatementFlow::SendViaSocket() { if ( bSending ) { #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "SendViaSocket rekursiv aufgerufen. Abgebrochen!!!\n" ); #endif DBG_ERROR("SendViaSocket rekursiv aufgerufen. Abgebrochen!!!"); return; } bSending = TRUE; if ( pCommLink ) { if ( !pCommLink->TransferDataStream( pRet->GetStream() ) ) // tritt ein Fehler auf, so wird sofort gelöscht ... pCommLink = NULL; } else { // Macht nix. Wenn das Basic nicht mehr da ist, ist sowiso alles egal DBG_ERROR("Rückmeldung an Basic Fehlgeschlagen") } pRet->Reset(); bSending = FALSE; IsError = FALSE; } BOOL StatementFlow::Execute() { #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Executing Flow: " ); m_pDbgWin->AddText( String::CreateFromInt32( nArt ) ); m_pDbgWin->AddText( "\n" ); #endif switch ( nArt ) { case F_EndCommandBlock: { if ( !bUseIPC ) { // bBool1 wurde im CTOR auf FALSE initialisiert if ( !bBool1 ) // also erster Durchlauf { pRemoteControl->pRetStream = pRet->GetStream(); bBool1 = TRUE; // wurde im CTOR auf FALSE initialisiert nRetryCount = nRetryCount * 4; } if ( pRemoteControl->pRetStream && (nRetryCount--) ) // also solange nicht abgeholt { return FALSE; // Bitte einmal vom Callstack runter } } } break; } Advance(); switch ( nArt ) { case F_EndCommandBlock: if ( !bUseIPC ) { // wird oben abgehandelt pRet->Reset(); IsError = FALSE; } else SendViaSocket(); break; case F_Sequence: pRet->GenReturn(RET_Sequence,nLNr1); #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Sending Sequence Nr: " ); m_pDbgWin->AddText( String::CreateFromInt64( nLNr1 ) ); m_pDbgWin->AddText( "\n" ); #endif break; // case RET_: default: DBG_ERROR( "Unbekannter Flowcontrol" ); break; } delete this; return TRUE; } // -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= // neue Hilfsfunktion, die stetig erweitert werden muss static short ImpGetRType( Window *pWin, ULONG nUId ) { // GGGg gggg::gggg gggg::ggLL LLLl::llll llll DBG_ASSERT( pWin, "missing Parameter" ); short nRT; if( (nUId & 0xE0000000) == 0 ) // keine auto ID nRT = C_NoType; else { // if( (nUId & 0x1F) == 0 ) // globale Resource if( (nUId & 0x1FF) == 0 ) // globale Resource GH: soweit ich das verstanden habe 1FF nRT = (short)(C_TabPage - 1 + (nUId >> 29)); else nRT = (short)((nUId & 0x00003E00) >> 9); if ( nRT == C_TabPage ) // wegen TabDialog.UId = TabPage.UId nRT = C_NoType; else { #ifndef DBG_UTIL return nRT; #endif } } #ifdef DBG_UTIL short n = nRT; #endif WindowType eRT = pWin->GetType(); switch( eRT ) { case WINDOW_WINDOW: nRT = C_Window ; break; case WINDOW_TABCONTROL: nRT = C_TabControl ; break; case WINDOW_RADIOBUTTON: nRT = C_RadioButton ; break; case WINDOW_CHECKBOX: nRT = C_CheckBox ; break; case WINDOW_TRISTATEBOX: nRT = C_TriStateBox ; break; case WINDOW_EDIT: nRT = C_Edit ; break; case WINDOW_MULTILINEEDIT: nRT = C_MultiLineEdit ; break; case WINDOW_MULTILISTBOX: nRT = C_MultiListBox ; break; case WINDOW_LISTBOX: nRT = C_ListBox ; break; case WINDOW_COMBOBOX: nRT = C_ComboBox ; break; case WINDOW_PUSHBUTTON: nRT = C_PushButton ; break; case WINDOW_SPINFIELD: nRT = C_SpinField ; break; case WINDOW_PATTERNFIELD: nRT = C_PatternField ; break; case WINDOW_NUMERICFIELD: nRT = C_NumericField ; break; case WINDOW_METRICFIELD: nRT = C_MetricField ; break; case WINDOW_CURRENCYFIELD: nRT = C_CurrencyField ; break; case WINDOW_DATEFIELD: nRT = C_DateField ; break; case WINDOW_TIMEFIELD: nRT = C_TimeField ; break; case WINDOW_IMAGERADIOBUTTON: nRT = C_ImageRadioButton ; break; case WINDOW_NUMERICBOX: nRT = C_NumericBox ; break; case WINDOW_METRICBOX: nRT = C_MetricBox ; break; case WINDOW_CURRENCYBOX: nRT = C_CurrencyBox ; break; case WINDOW_DATEBOX: nRT = C_DateBox ; break; case WINDOW_TIMEBOX: nRT = C_TimeBox ; break; case WINDOW_IMAGEBUTTON: nRT = C_ImageButton ; break; case WINDOW_MENUBUTTON: nRT = C_MenuButton ; break; case WINDOW_MOREBUTTON: nRT = C_MoreButton ; break; case WINDOW_TABPAGE: nRT = C_TabPage; break; case WINDOW_MODALDIALOG: nRT = C_Dlg; break; case WINDOW_FLOATINGWINDOW: nRT = C_FloatWin; break; case WINDOW_MODELESSDIALOG: nRT = C_ModelessDlg; break; case WINDOW_WORKWINDOW: nRT = C_WorkWin; break; case WINDOW_DOCKINGWINDOW: nRT = C_DockingWin; break; case WINDOW_MESSBOX: nRT = C_MessBox; break; case WINDOW_INFOBOX: nRT = C_InfoBox; break; case WINDOW_WARNINGBOX: nRT = C_WarningBox; break; case WINDOW_ERRORBOX: nRT = C_ErrorBox; break; case WINDOW_QUERYBOX: nRT = C_QueryBox; break; #if 0 //ifndef VCL case WINDOW_FILEDIALOG: nRT = C_FileDlg; break; case WINDOW_PATHDIALOG: nRT = C_PathDlg; break; case WINDOW_PRINTDIALOG: nRT = C_PrintDlg; break; case WINDOW_PRINTERSETUPDIALOG: nRT = C_PrinterSetupDlg;break; case WINDOW_COLORDIALOG: nRT = C_ColorDlg; break; #endif case WINDOW_TABDIALOG: nRT = C_TabDlg; break; // case WINDOW_TABDIALOG: nRT = C_SingleTabDlg; break; case WINDOW_PATTERNBOX: nRT = C_PatternBox; break; case WINDOW_TOOLBOX: nRT = C_ToolBox; break; // Gibts nicht case WINDOW_VALUESET: nRT = C_ValueSet; break; case WINDOW_CONTROL: nRT = C_Control; break; case WINDOW_OKBUTTON: nRT = C_OkButton; break; case WINDOW_CANCELBUTTON: nRT = C_CancelButton; break; case WINDOW_BUTTONDIALOG: nRT = C_ButtonDialog; break; case WINDOW_TREELISTBOX: nRT = C_TreeListBox; break; } #ifdef DBG_UTIL // Die Werte n sind bei den WindowTypen nicht mehr vergeben, werden aber in der AutoID noch verwendet // Sie werden jetzt durch den Typ nRT implementiert. DBG_ASSERT( n == C_NoType || n == nRT || ( n == C_ImageButton && nRT == C_PushButton ) || ( n == C_TriStateBox && nRT == C_CheckBox ) || ( n == C_ImageRadioButton && nRT == C_RadioButton ) , "error in algorithm" ); #endif return nRT; } // -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= StatementSlot::StatementSlot( SCmdStream *pCmdIn ) : pItemArr(NULL) { QueStatement( NULL ); pCmdIn->Read( nFunctionId ); #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Reading Slot: " ); m_pDbgWin->AddText( String::CreateFromInt32( nFunctionId ) ); m_pDbgWin->AddText( "\n" ); #endif pCmdIn->Read( nAnzahl ); if ( nAnzahl ) { switch ( pCmdIn->GetNextType() ) { case BinUSHORT: // use old calling method { nAnzahl++; pItemArr = new SfxPoolItem*[nAnzahl]; for (USHORT i = 0 ; i+1 < nAnzahl ; i++) pCmdIn->Read( pItemArr[i] ); pItemArr[nAnzahl-1] = NULL; } break; case BinString: // new Method { aArgs.realloc(nAnzahl); PropertyValue* pArg = aArgs.getArray(); for (USHORT i = 0 ; i < nAnzahl ; i++) pCmdIn->Read( pArg[i] ); } break; } } } // Constructor for UnoSlot StatementSlot::StatementSlot() : pItemArr(NULL) , nAnzahl( 0 ) , nFunctionId( 0 ) {} StatementSlot::StatementSlot( ULONG nSlot, SfxPoolItem* pItem ) : pItemArr(NULL) { QueStatement( NULL ); nFunctionId = nSlot; #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Reading Slot: " ); m_pDbgWin->AddText( String::CreateFromInt32( nFunctionId ) ); m_pDbgWin->AddText( "\n" ); #endif if ( pItem ) { nAnzahl = 2; pItemArr = new SfxPoolItem*[2]; pItemArr[0] = pItem; pItemArr[1] = NULL; } else nAnzahl = 0; } StatementSlot::~StatementSlot() { if (nAnzahl) { if ( pItemArr ) { for (USHORT i = 0 ; i+1 < nAnzahl ; i++) delete pItemArr[i]; delete[] pItemArr; } aArgs.realloc( 0 ); } } void StatementSlot::AddReferer() { HACK( "only to test!" ); // because slot 6102 /*SID_VERB_START*/ crashes when called with Property Referer // We return to the previous behavior (which was a bug realy) of not adding this Property to calls which have no properties at all // according to MBA most likely this Property can be removed at all and is maybe only needed for Slots with URLs if ( !nAnzahl ) return; nAnzahl++; aArgs.realloc(nAnzahl); PropertyValue* pArg = aArgs.getArray(); pArg[nAnzahl-1].Name = rtl::OUString::createFromAscii("Referer"); pArg[nAnzahl-1].Value <<= ::rtl::OUString::createFromAscii("private:user"); } class SlotStatusListener : public cppu::WeakImplHelper1< XStatusListener > { public: SlotStatusListener(); // XStatusListener virtual void SAL_CALL statusChanged( const ::com::sun::star::frame::FeatureStateEvent& Event ) throw (::com::sun::star::uno::RuntimeException); // XEventListener virtual void SAL_CALL disposing( const ::com::sun::star::lang::EventObject& Source ) throw (::com::sun::star::uno::RuntimeException); // local Members BOOL bDisposed; BOOL bEnabled; }; /* struct FeatureStateEvent : public ::com::sun::star::lang::EventObject ::com::sun::star::util::URL FeatureURL; ::rtl::OUString FeatureDescriptor; sal_Bool IsEnabled; sal_Bool Requery; ::com::sun::star::uno::Any State; ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > Source; */ SlotStatusListener::SlotStatusListener() : bDisposed( FALSE ) , bEnabled( FALSE ) {} // XStatusListener void SAL_CALL SlotStatusListener::statusChanged( const ::com::sun::star::frame::FeatureStateEvent& Event ) { // DBG_ERROR1("FeatureURL: %s", ByteString( String( Event.FeatureURL.Complete ), RTL_TEXTENCODING_UTF8 ).GetBuffer() ) // DBG_ERROR1("FeatureDescriptor: %s", ByteString( String( Event.FeatureDescriptor ), RTL_TEXTENCODING_UTF8 ).GetBuffer() ) bEnabled = Event.IsEnabled; // DBG_ASSERT( Event.IsEnabled, "Not enabled" ) // DBG_ASSERT( !Event.Requery, "Requery" ) } // XEventListener void SAL_CALL SlotStatusListener::disposing( const ::com::sun::star::lang::EventObject& ) { bDisposed = TRUE; } BOOL StatementSlot::Execute() { if ( IsError ) { #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Skipping Slot: " ); m_pDbgWin->AddText( String::CreateFromInt32( nFunctionId ) ); m_pDbgWin->AddText( "\n" ); #endif Advance(); delete this; return TRUE; } InitProfile(); #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Executing Slot: " ); m_pDbgWin->AddText( String::CreateFromInt32( nFunctionId ) ); m_pDbgWin->AddText( "\n" ); #endif Advance(); if ( !IsError ) { if ( ( nAnzahl == 0 && !getenv("OLDSLOTHANDLING") ) || aArgs.hasElements() ) { // trying to call slots via uno AddReferer(); if ( !aUnoUrl.Len() ) aUnoUrl = CUniString("slot:").Append( String::CreateFromInt32( nFunctionId ) ); URL aTargetURL; aTargetURL.Complete = aUnoUrl; Reference < XFramesSupplier > xDesktop = Reference < XFramesSupplier >( ::comphelper::getProcessServiceFactory()->createInstance( CUniString("com.sun.star.frame.Desktop") ), UNO_QUERY ); Reference < XFrame > xFrame; if ( xDesktop.is() ) { xFrame = xDesktop->getActiveFrame(); if ( !xFrame.is() ) { Reference < XFrames > xFrames; xFrames = xDesktop->getFrames(); if ( xFrames.is() && xFrames->getCount() > 0 ) { Any aFrame = xFrames->getByIndex( xFrames->getCount() -1 ); aFrame >>= xFrame; } } if ( !xFrame.is() ) { if ( GetFirstDocWin() ) GetFirstDocWin()->ToTop(); xFrame = xDesktop->getActiveFrame(); } } if ( xFrame.is() ) xDesktop = Reference < XFramesSupplier >( xFrame, UNO_QUERY ); else xDesktop.clear(); while ( xDesktop.is() && xDesktop->getActiveFrame().is() ) { xFrame = xDesktop->getActiveFrame(); #if OSL_DEBUG_LEVEL > 1 ::rtl::OUString aName; if ( xFrame.is() ) aName = xFrame->getName(); #endif xDesktop = Reference < XFramesSupplier >( xFrame, UNO_QUERY ); } if ( !xFrame.is() ) ReportError( GEN_RES_STR1( S_UNO_URL_EXECUTE_FAILED_NO_FRAME, aTargetURL.Complete ) ); else { Reference < XURLTransformer > xTrans( ::comphelper::getProcessServiceFactory()->createInstance( CUniString("com.sun.star.util.URLTransformer" )), UNO_QUERY ); xTrans->parseStrict( aTargetURL ); Reference < XDispatchProvider > xProv( xFrame, UNO_QUERY ); Reference < XDispatch > xDisp; while ( xProv.is() && !xDisp.is() ) { xDisp = xProv->queryDispatch( aTargetURL, ::rtl::OUString(), 0 ); if ( !xDisp.is() ) { xFrame = Reference < XFrame > ( xFrame->getCreator(), UNO_QUERY ); xProv = Reference < XDispatchProvider > ( xFrame, UNO_QUERY ); } } if ( xDisp.is() ) { Reference < XStatusListener > xListener = ( XStatusListener* )new SlotStatusListener; xDisp->addStatusListener( xListener, aTargetURL ); if ( static_cast< SlotStatusListener* >(xListener.get())->bEnabled ) xDisp->dispatch( aTargetURL, aArgs ); else ReportError( GEN_RES_STR1( S_UNO_URL_EXECUTE_FAILED_DISABLED, aTargetURL.Complete ) ); xDisp->removeStatusListener( xListener, aTargetURL ); } else ReportError( GEN_RES_STR1( S_UNO_URL_EXECUTE_FAILED_NO_DISPATCHER, aTargetURL.Complete ) ); } } else { DirectLog( S_QAError, GEN_RES_STR0( S_DEPRECATED ) ); if ( !pTTProperties ) pTTProperties = new TTProperties(); switch ( pTTProperties->ExecuteFunction( nFunctionId, pItemArr, EXECUTEMODE_DIALOGASYNCHRON | nUseBindings ) ) { case TT_PR_ERR_NODISPATCHER: { ReportError(nFunctionId, GEN_RES_STR0( S_SID_EXECUTE_FAILED_NO_DISPATCHER ) ); } break; case TT_PR_ERR_NOEXECUTE: { ReportError(nFunctionId, GEN_RES_STR0( S_SID_EXECUTE_FAILED ) ); } break; } } } /* Neues Verfahren ab 334! Neue Methode zum einstellen, daß Modale Dialoge immer Asynchron aufgerufen werden und echter Returnwert, ob Slot geklappt hat und Testen ob Slot überhaupt durch UI aufgerufen werden kann */ SendProfile( SlotString( nFunctionId ) ); delete this; return TRUE; } // -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= StatementUnoSlot::StatementUnoSlot(SCmdStream *pIn) { QueStatement( NULL ); pIn->Read( aUnoUrl ); #if OSL_DEBUG_LEVEL > 1 StatementList::m_pDbgWin->AddText( "UnoUrl:" ); StatementList::m_pDbgWin->AddText( aUnoUrl ); StatementList::m_pDbgWin->AddText( "\n" ); #endif } // -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= StatementCommand::StatementCommand( SCmdStream *pCmdIn ) : nMethodId(0) , nParams(0) , nNr1(0) , nNr2(0) , nNr3(0) , nNr4(0) , nLNr1(0) , aString1() , aString2() , bBool1(FALSE) , bBool2(FALSE) { QueStatement( NULL ); pCmdIn->Read( nMethodId ); pCmdIn->Read( nParams ); if( nParams & PARAM_USHORT_1 ) pCmdIn->Read( nNr1 ); if( nParams & PARAM_USHORT_2 ) pCmdIn->Read( nNr2 ); if( nParams & PARAM_USHORT_3 ) pCmdIn->Read( nNr3 ); if( nParams & PARAM_USHORT_4 ) pCmdIn->Read( nNr4 ); if( nParams & PARAM_ULONG_1 ) pCmdIn->Read( nLNr1 ); if( nParams & PARAM_STR_1 ) pCmdIn->Read( aString1 ); if( nParams & PARAM_STR_2 ) pCmdIn->Read( aString2 ); if( nParams & PARAM_BOOL_1 ) pCmdIn->Read( bBool1 ); if( nParams & PARAM_BOOL_2 ) pCmdIn->Read( bBool2 ); #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Reading Conmmand:" ); m_pDbgWin->AddText( " Methode: " ); m_pDbgWin->AddText( String::CreateFromInt32( nMethodId ) ); m_pDbgWin->AddText( " Params:" ); if( nParams & PARAM_USHORT_1 ) {m_pDbgWin->AddText( " n1:" );m_pDbgWin->AddText( String::CreateFromInt32( nNr1 ) );} if( nParams & PARAM_USHORT_2 ) {m_pDbgWin->AddText( " n2:" );m_pDbgWin->AddText( String::CreateFromInt32( nNr2 ) );} if( nParams & PARAM_USHORT_3 ) {m_pDbgWin->AddText( " n3:" );m_pDbgWin->AddText( String::CreateFromInt32( nNr3 ) );} if( nParams & PARAM_USHORT_4 ) {m_pDbgWin->AddText( " n4:" );m_pDbgWin->AddText( String::CreateFromInt32( nNr4 ) );} if( nParams & PARAM_ULONG_1 ) {m_pDbgWin->AddText( " nl1:" );m_pDbgWin->AddText( String::CreateFromInt64( nLNr1 ) );} if( nParams & PARAM_STR_1 ) {m_pDbgWin->AddText( " s1:" );m_pDbgWin->AddText( aString1 );} if( nParams & PARAM_STR_2 ) {m_pDbgWin->AddText( " s2:" );m_pDbgWin->AddText( aString2 );} if( nParams & PARAM_BOOL_1 ) {m_pDbgWin->AddText( " b1:" );m_pDbgWin->AddText( bBool1 ? "TRUE" : "FALSE" );} if( nParams & PARAM_BOOL_2 ) {m_pDbgWin->AddText( " b2:" );m_pDbgWin->AddText( bBool2 ? "TRUE" : "FALSE" );} m_pDbgWin->AddText( "\n" ); #endif if ( nMethodId == RC_AppAbort ) { #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "*Deleting all Commands:\n" ); #endif bReadingCommands = FALSE; while ( StatementList::pFirst != this ) // Alles Löschen außer mich selbst { StatementList *pDeQue = StatementList::pFirst; pDeQue->Advance(); delete pDeQue; } bReadingCommands = TRUE; #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "*Done deleting all Commands:\n" ); #endif } } void StatementCommand::WriteControlData( Window *pBase, ULONG nConf, BOOL bFirst ) { if ( IsDialog(pBase) && !bFirst ) return; if ( bFirst ) pRet->GenReturn ( RET_WinInfo, nConf | DH_MODE_DATA_VALID, (ULONG)0, UniString(), TRUE ); { // Klammerung, so daß der String nicht während der Rekursion bestehen bleibt String aName; BOOL bSkip = FALSE; switch ( pBase->GetType() ) { case WINDOW_RADIOBUTTON: case WINDOW_CHECKBOX: case WINDOW_TRISTATEBOX: case WINDOW_PUSHBUTTON: case WINDOW_OKBUTTON: case WINDOW_CANCELBUTTON: case WINDOW_IMAGERADIOBUTTON: case WINDOW_IMAGEBUTTON: case WINDOW_MENUBUTTON: case WINDOW_MOREBUTTON: case WINDOW_TABPAGE: case WINDOW_MODALDIALOG: case WINDOW_FLOATINGWINDOW: case WINDOW_MODELESSDIALOG: case WINDOW_WORKWINDOW: case WINDOW_DOCKINGWINDOW: case WINDOW_CONTROL: case WINDOW_FILEDIALOG: case WINDOW_PATHDIALOG: case WINDOW_PRINTDIALOG: case WINDOW_PRINTERSETUPDIALOG: case WINDOW_COLORDIALOG: case WINDOW_TABDIALOG: case WINDOW_BUTTONDIALOG: aName = pBase->GetText().EraseAllChars('~'); break; case WINDOW_EDIT: case WINDOW_MULTILINEEDIT: case WINDOW_MULTILISTBOX: case WINDOW_LISTBOX: case WINDOW_COMBOBOX: case WINDOW_SPINFIELD: case WINDOW_PATTERNFIELD: case WINDOW_NUMERICFIELD: case WINDOW_METRICFIELD: case WINDOW_CURRENCYFIELD: case WINDOW_DATEFIELD: case WINDOW_TIMEFIELD: case WINDOW_NUMERICBOX: case WINDOW_METRICBOX: case WINDOW_CURRENCYBOX: case WINDOW_DATEBOX: case WINDOW_TIMEBOX: case WINDOW_PATTERNBOX: case WINDOW_TOOLBOX: aName = pBase->GetQuickHelpText(); break; case WINDOW_MESSBOX: case WINDOW_INFOBOX: case WINDOW_WARNINGBOX: case WINDOW_ERRORBOX: case WINDOW_QUERYBOX: aName = ((MessBox*)pBase)->GetMessText(); break; default: if ( pBase->GetUniqueOrHelpId() == 0 && !( nConf & DH_MODE_ALLWIN ) ) bSkip = TRUE; } if ( !bSkip ) { if ( aName.Len() == 0 ) aName = pBase->GetQuickHelpText(); if ( aName.Len() == 0 ) aName = pBase->GetHelpText(); if ( aName.Len() == 0 ) aName = pBase->GetText(); pRet->GenReturn ( RET_WinInfo, pBase->GetUniqueOrHelpId(), (ULONG)pBase->GetType(), TypeString(pBase->GetType()).AppendAscii(": ").Append(aName), FALSE ); if ( pBase->GetType() == WINDOW_TOOLBOX ) // Buttons und Controls auf Toolboxen. { ToolBox *pTB = ((ToolBox*)pBase); USHORT i; for ( i = 0; i < pTB->GetItemCount() ; i++ ) { aName = String(); // if ( aName.Len() == 0 ) // aName = pTB->GetQuickHelpText(); if ( aName.Len() == 0 ) aName = pTB->GetHelpText( pTB->GetItemId( i ) ); if ( aName.Len() == 0 ) aName = pTB->GetItemText( pTB->GetItemId( i ) ); Window *pItemWin; pItemWin = pTB->GetItemWindow( pTB->GetItemId( i ) ); if ( pTB->GetItemType( i ) == TOOLBOXITEM_BUTTON && ( !pItemWin || !pItemWin->IsVisible() ) ) { pRet->GenReturn ( RET_WinInfo, pTB->GetHelpId(pTB->GetItemId( i )), (ULONG)WINDOW_BUTTON, TypeString(WINDOW_BUTTON).AppendAscii(": ").Append(aName), FALSE ); } else { if ( pItemWin ) { pRet->GenReturn ( RET_WinInfo, pTB->GetHelpId(pTB->GetItemId( i )), (ULONG)pItemWin->GetType(), TypeString(pItemWin->GetType()).AppendAscii(": ").Append(aName), FALSE ); for( int i = 0 ; i < pItemWin->GetChildCount(); i++ ) WriteControlData( pItemWin->GetChild(i), nConf, FALSE ); } else { if ( nConf & DH_MODE_ALLWIN ) { String aToolBoxItemType; switch ( pTB->GetItemType( i ) ) { case TOOLBOXITEM_DONTKNOW: aToolBoxItemType.AssignAscii("TOOLBOXITEM_DONTKNOW"); break; case TOOLBOXITEM_BUTTON: aToolBoxItemType.AssignAscii("TOOLBOXITEM_BUTTON"); break; case TOOLBOXITEM_SPACE: aToolBoxItemType.AssignAscii("TOOLBOXITEM_SPACE"); break; case TOOLBOXITEM_SEPARATOR: aToolBoxItemType.AssignAscii("TOOLBOXITEM_SEPARATOR"); break; case TOOLBOXITEM_BREAK: aToolBoxItemType.AssignAscii("TOOLBOXITEM_BREAK"); break; default: DBG_ERROR1( "Unknown TOOLBOXITEM %i", pTB->GetItemType( i ) ); } pRet->GenReturn ( RET_WinInfo, pTB->GetHelpId(pTB->GetItemId( i )), (ULONG)WINDOW_BASE, aToolBoxItemType.AppendAscii(": ").Append(aName), FALSE ); } } } } return; // ToolBox ist hier schon komplett abgehandelt. } if ( pBase->GetType() == WINDOW_BUTTONDIALOG // Buttons auf Buttondialogen mit ID || pBase->GetType() == WINDOW_MESSBOX || pBase->GetType() == WINDOW_INFOBOX || pBase->GetType() == WINDOW_WARNINGBOX || pBase->GetType() == WINDOW_ERRORBOX || pBase->GetType() == WINDOW_QUERYBOX ) { ButtonDialog *pBD = ((ButtonDialog*)pBase); int i; for ( i = 0; i < pBD->GetButtonCount() ; i++ ) { aName = String(); if ( aName.Len() == 0 ) aName = pBD->GetPushButton( pBD->GetButtonId(i) )->GetText(); String aID; switch ( pBD->GetButtonId(i) ) { case BUTTONID_OK: aID.AssignAscii("Ok"); break; case BUTTONID_CANCEL: aID.AssignAscii("Cancel"); break; case BUTTONID_YES: aID.AssignAscii("Yes"); break; case BUTTONID_NO: aID.AssignAscii("No"); break; case BUTTONID_RETRY: aID.AssignAscii("Retry"); break; case BUTTONID_HELP: aID.AssignAscii("Help"); break; default: aID = UniString::CreateFromInt32( pBD->GetButtonId(i) ); break; } pRet->GenReturn ( RET_WinInfo, 1, (ULONG)pBD->GetPushButton( pBD->GetButtonId(i) )->GetType(), // So daß der Text angezeigt wird! TypeString(pBD->GetPushButton( pBD->GetButtonId(i) )->GetType()).AppendAscii(": ").Append(aName) .AppendAscii(" ButtonId = ").Append(aID), FALSE ); } return; // ButtonDialog ist hier schon komplett abgehandelt. } } } for( int i = 0 ; i < pBase->GetChildCount(); i++ ) WriteControlData( pBase->GetChild(i), nConf, FALSE ); } class SysWinContainer : public WorkWindow { private: ToolBox *pClientWin; DockingWindow *pDock; public: SysWinContainer( ToolBox *pClient ); ~SysWinContainer(); virtual void Resize(); virtual void Resizing( Size& rSize ); }; SysWinContainer::SysWinContainer( ToolBox *pClient ) : WorkWindow( NULL, WB_BORDER | WB_SIZEMOVE | WB_CLOSEABLE ) , pClientWin( pClient ) { pDock = new DockingWindow( this ); pClientWin->SetParent( pDock ); pClientWin->SetFloatingMode( FALSE ); SetText( pClient->GetText() ); SetPosPixel( Point( 1,40 ) ); Resize(); pDock->Show(); EnableAlwaysOnTop(); Show(); } SysWinContainer::~SysWinContainer() { delete pDock; } void SysWinContainer::Resize() { Size aSize( GetOutputSizePixel() ); Resizing( aSize ); // aSize = pClientWin->GetSizePixel(); // aSize = pClientWin->CalcWindowSizePixel(); if ( aSize != GetSizePixel() ) { SetOutputSizePixel( aSize ); pDock->SetSizePixel( aSize ); pClientWin->SetSizePixel( aSize ); } } void SysWinContainer::Resizing( Size& rSize ) { Size aSize; Size aBestSize; int i; BOOL bHasValue = FALSE; ULONG nBestValue; ULONG nThisValue; for ( i=1 ; i<=1 ; i++ ) { aSize = pClientWin->CalcWindowSizePixel( i ); nThisValue = Abs( aSize.Width() - rSize.Width() ) + Abs( aSize.Height() - rSize.Height() ); if ( !bHasValue || ( nThisValue < nBestValue ) ) { nBestValue = nThisValue; aBestSize = aSize; bHasValue = TRUE; } } rSize = aBestSize; } class DisplayHidWin : public ToolBox { Edit *pEdit; Size aMinEditSize; USHORT nLastItemID; BOOL bIsDraging; BOOL bIsPermanentDraging; void SetDraging( BOOL bNewDraging ); Image *pShow, *pShow2; BOOL bConfigChanged; void EnableButtons( ULONG nConf ); // aborting by pressing shist twice BOOL bOldShift; Time aLatest; USHORT nShiftCount; ULONG nEventHookID; static long stub_VCLEventHookProc( NotifyEvent& rEvt, void* pData ) { return ((DisplayHidWin*)pData)->VCLEventHook( rEvt ); } long VCLEventHook( NotifyEvent& rEvt ); Window *pLastMouseMoveWin; SysWinContainer *pContainer; public: DisplayHidWin(); ~DisplayHidWin(); virtual void Tracking( const TrackingEvent& rTEvt ); virtual void Click(); virtual void Select(); virtual void SetText( const XubString& rStr ); void SetDisplayText( const String &aNewText ){ pEdit->SetText(aNewText); } const String GetDisplayText(){ return pEdit->GetText(); } const BOOL IsDisplayTextModified(){ return pEdit->IsModified(); } const void ClearDisplayTextModified(){ pEdit->ClearModifyFlag(); } void SetConfig( ULONG nConf ); ULONG GetConfig(); BOOL IsConfigChanged() { return bConfigChanged; } void ConfigSent() { bConfigChanged = FALSE; } BOOL IsSendData() { return GetItemState( TT_SEND_DATA ) == STATE_CHECK; } // BOOL IsAllWin() { return GetItemState( TT_ALLWIN ) == STATE_CHECK; } BOOL IsDraging() { return bIsDraging; } Window* LastMouseMoveWin() { return pLastMouseMoveWin; } }; DisplayHidWin::DisplayHidWin() : ToolBox( StatementList::GetFirstDocWin(), TTProperties::GetSvtResId(DisplayHidToolBox) ) , bIsDraging( FALSE ) , bIsPermanentDraging( FALSE ) , pShow( NULL ) , pShow2( NULL ) , pLastMouseMoveWin( NULL ) , bOldShift( 0 ) , nShiftCount( 0 ) { SetOutStyle( TOOLBOX_STYLE_HANDPOINTER | TOOLBOX_STYLE_FLAT ); pEdit = new Edit( this, WB_CENTER | WB_BORDER ); aMinEditSize = GetItemRect( TT_OUTPUT ).GetSize(); /**/ aMinEditSize=Size(20,20); aMinEditSize.Width() *= 12; pEdit->SetSizePixel( aMinEditSize ); pEdit->Show(); SetItemWindow( TT_OUTPUT, pEdit ); Resize(); pContainer = new SysWinContainer( this ); nEventHookID = Application::AddEventHook( stub_VCLEventHookProc, this ); } DisplayHidWin::~DisplayHidWin() { Application::RemoveEventHook( nEventHookID ); Hide(); // so GetFirstDocWin won't return ourselves (needed for SOPlayer) SetParent( StatementList::GetFirstDocWin() ); delete pContainer; delete pEdit; } void DisplayHidWin::SetDraging( BOOL bNewDraging ) { if ( !pShow ) pShow = new Image( GetItemImage( TT_SHOW ) ); if ( !pShow2 ) pShow2 = new Image( Bitmap( TTProperties::GetSvtResId( TT_SHOW2 ) ) ); if ( bNewDraging ) SetItemImage( TT_SHOW, *pShow2 ); else SetItemImage( TT_SHOW, *pShow ); bIsDraging = bNewDraging; } void DisplayHidWin::EnableButtons( ULONG nConf ) { BOOL bSend = nConf & DH_MODE_SEND_DATA; EnableItem( TT_ALLWIN, bSend ); EnableItem( TT_KURZNAME, bSend ); EnableItem( TT_LANGNAME, bSend ); } void DisplayHidWin::Tracking( const TrackingEvent& rTEvt ) { // if ( nLastItemID == TT_SHOW && GetItemState( TT_SHOW ) == STATE_NOCHECK && ( rTEvt.IsTrackingEnded() || rTEvt.IsTrackingCanceled() ) ) // SetDraging( FALSE ); if ( nLastItemID == TT_SHOW && GetItemState( TT_SHOW ) == STATE_NOCHECK ) EndTracking( ENDTRACK_CANCEL ); ToolBox::Tracking( rTEvt); } void DisplayHidWin::Click() { nLastItemID = GetCurItemId(); if ( nLastItemID == TT_SHOW ) { SetDraging( TRUE ); } ToolBox::Click(); } void DisplayHidWin::Select() { if ( GetItemState( GetCurItemId() ) == STATE_NOCHECK ) { SetItemState( GetCurItemId(), STATE_CHECK ); if ( GetCurItemId() == TT_SHOW ) { bIsPermanentDraging = TRUE; SetDraging( TRUE ); } } else { SetItemState( GetCurItemId(), STATE_NOCHECK ); if ( GetCurItemId() == TT_SHOW ) { bIsPermanentDraging = FALSE; SetDraging( FALSE ); } } if ( GetCurItemId() == TT_SEND_DATA ) { EnableButtons( GetConfig() ); } } void DisplayHidWin::SetConfig( ULONG nConf ) { SetItemState( TT_KURZNAME, ( nConf & DH_MODE_KURZNAME ) ? STATE_CHECK : STATE_NOCHECK ); SetItemState( TT_LANGNAME, ( nConf & DH_MODE_LANGNAME ) ? STATE_CHECK : STATE_NOCHECK ); SetItemState( TT_ALLWIN, ( nConf & DH_MODE_ALLWIN ) ? STATE_CHECK : STATE_NOCHECK ); SetItemState( TT_SEND_DATA, ( nConf & DH_MODE_SEND_DATA ) ? STATE_CHECK : STATE_NOCHECK ); EnableButtons( nConf ); } ULONG DisplayHidWin::GetConfig() { ULONG nConf = 0; if ( GetItemState( TT_KURZNAME ) == STATE_CHECK ) nConf |= DH_MODE_KURZNAME; if ( GetItemState( TT_LANGNAME ) == STATE_CHECK ) nConf |= DH_MODE_LANGNAME; if ( GetItemState( TT_ALLWIN ) == STATE_CHECK ) nConf |= DH_MODE_ALLWIN; if ( IsSendData() ) nConf |= DH_MODE_SEND_DATA; return nConf; } void DisplayHidWin::SetText( const XubString& rStr ) { pContainer->SetText( rStr ); } long DisplayHidWin::VCLEventHook( NotifyEvent& rEvt ) { if ( EVENT_MOUSEMOVE == rEvt.GetType() ) { pLastMouseMoveWin = rEvt.GetWindow(); // check if abort with pressing shift twice MouseEvent* pMEvt = (MouseEvent*)rEvt.GetMouseEvent(); if ( ( pMEvt->IsShift() && !bOldShift ) ) // Shift pressed { if ( aLatest < Time() ) { nShiftCount = 0; aLatest = Time()+Time( 0, 0, 0, 50 ); } nShiftCount++; } if ( ( !pMEvt->IsShift() && bOldShift ) ) // Shift released { nShiftCount++; if ( nShiftCount == 4 && aLatest > Time() ) { bIsPermanentDraging = FALSE; SetDraging( FALSE ); SetItemState( TT_SHOW, STATE_NOCHECK ); } } bOldShift = pMEvt->IsShift(); } if ( ( EVENT_MOUSEBUTTONUP == rEvt.GetType() || ( EVENT_MOUSEMOVE == rEvt.GetType() && !rEvt.GetMouseEvent()->GetButtons() ) ) && IsDraging() && !bIsPermanentDraging ) SetDraging( FALSE ); return 0; } BOOL StatementCommand::DisplayHID() { // Return TRUE = static StatementCommand *pDisplayInstance = NULL; static DisplayHidWin *pDisplayHidWin; static Window *Old = NULL, *Act = NULL; static String aOriginalCaption; if ( !bBool2 ) // Wird auf FALSE initialisiert { bBool2 = TRUE; // Wir sind initialisiert. pDisplayInstance = this; // Und haben die Macht (Alle anderen beenden sich) if ( !(nParams & PARAM_ULONG_1) ) { if( pDisplayHidWin ) // Nichts verändern nLNr1 = pDisplayHidWin->GetConfig(); else // Beim ersten Aufruf wollen wir alles richtig einstellen nLNr1 = DH_MODE_KURZNAME | DH_MODE_LANGNAME; if( ((nParams & PARAM_BOOL_1) && bBool1) ) nLNr1 |= DH_MODE_SEND_DATA; else nLNr1 &= ( ~DH_MODE_SEND_DATA ); } if ( pDisplayHidWin ) pDisplayHidWin->SetConfig( nLNr1 ); } if ( pDisplayInstance && pDisplayInstance != this ) { DBG_WARNING("Mehrere DisplayHID am laufen"); return FALSE; // Noch eine andere Instanz macht das gleiche! } if ( !pDisplayHidWin ) { pDisplayHidWin = new DisplayHidWin(); aOriginalCaption = pDisplayHidWin->GetText(); pDisplayHidWin->Show(); if ( bBool1 ) nLNr1 |= DH_MODE_SEND_DATA; pDisplayHidWin->SetConfig( nLNr1 ); Old = NULL; Act = NULL; pDisplayInstance = this; } else { pDisplayHidWin->GetWindow( WINDOW_OVERLAP )->Enable( TRUE, TRUE ); pDisplayHidWin->GetWindow( WINDOW_OVERLAP )->EnableInput( TRUE, TRUE ); } if ( pDisplayHidWin->IsVisible() && !bDying ) { if ( pDisplayHidWin->IsDraging() ) { #define HIGHLIGHT_WIN( WinPtr ) \ { \ Color aLineColMem = WinPtr->GetLineColor(); \ WinPtr->SetLineColor( Color( COL_WHITE ) ); \ Color aFillColMem = WinPtr->GetFillColor(); \ WinPtr->SetFillColor( Color( COL_LIGHTRED ) ); \ RasterOp aROp = WinPtr->GetRasterOp(); \ WinPtr->SetRasterOp( ROP_XOR ); \ Size aSz = WinPtr->PixelToLogic( WinPtr->GetSizePixel() );\ ULONG nMaxCornerRadius = WinPtr->PixelToLogic( Point( 80, 0 ) ).X();\ USHORT iCorner = std::max ((ULONG) 8, (ULONG) std::min( nMaxCornerRadius, (ULONG) std::min((ULONG) (aSz.Width() / 6), (ULONG)(aSz.Height() / 6))));\ WinPtr->DrawRect(Rectangle(Point(),aSz), iCorner, iCorner);\ WinPtr->SetLineColor( aLineColMem ); \ WinPtr->SetFillColor( aFillColMem ); \ WinPtr->SetRasterOp( aROp ); \ } #define SET_WIN( WinPtr ) \ if ( StatementList::WinPtrValid(WinPtr) ) \ { \ HIGHLIGHT_WIN ( WinPtr ); \ } #define RESET_WIN( WinPtr ) \ if ( StatementList::WinPtrValid(WinPtr) ) \ { \ WinPtr->Invalidate( INVALIDATE_NOTRANSPARENT ); \ WinPtr->Update(); \ } Old = Act; // Act = GetMouseWin(); Act = pDisplayHidWin->LastMouseMoveWin(); if ( Act && Act->GetType() == WINDOW_BORDERWINDOW ) Act = Act->GetWindow( WINDOW_CLIENT ); if ( Act != Old ) { if ( Old ) { RESET_WIN(Old); } if ( Act ) { SET_WIN(Act); pDisplayHidWin->SetDisplayText(UniString::CreateFromInt64(Act->GetUniqueOrHelpId()).AppendAscii(" WinType: ") .Append(UniString::CreateFromInt64(Act->GetType())).AppendAscii(" ").Append(Act->GetText())); if ( Act && Act->GetUniqueId() != Act->GetHelpId() ) pDisplayHidWin->SetText(UniString( TTProperties::GetSvtResId( TT_ALTERNATE_CAPTION ) ).Append(UniString::CreateFromInt64(Act->GetHelpId()))); else pDisplayHidWin->SetText( aOriginalCaption ); } else pDisplayHidWin->SetDisplayText(CUniString("Kein Window/Control gefunden")); } else if ( Act ) { // SET_WIN(Act); if ( pDisplayHidWin->IsDisplayTextModified() && pDisplayHidWin->GetDisplayText().Len() > 0 ) { Act->SetUniqueId( pDisplayHidWin->GetDisplayText().ToInt32() ); pDisplayHidWin->ClearDisplayTextModified(); } } /* if ( Application::GetLastInputInterval() > 5000 ) // 5 Sekunden lang nix geschehen { pDisplayHidWin->ToTop( TOTOP_NOGRABFOCUS ); } */ if ( pDisplayHidWin->IsSendData() /*&& bBool2*/ && Act ) { if ( !StatementFlow::bSending ) { // Normalerweise syncronisierung über Protokoll. Hier ist das aber asyncron!!! WriteControlData( Act, pDisplayHidWin->GetConfig() ); new StatementFlow( this, F_EndCommandBlock ); // Kommando zum Senden erzeugen und in que eintragen } } } //if ( pDisplayHidWin->IsDraging() ) else { if ( Act ) { RESET_WIN(Act); Act = NULL; } } if ( pFirst == this ) // Sollte immer so sein, aber besser isses if ( pNext ) // Befehle warten auf Ausführung { // An Ende neu einsortieren Advance(); QueStatement( NULL ); } // { // Ersten und 2. austauschen. // pFirst = pNext; // pNext = pNext->pNext; // pFirst->pNext = this; // } } else { delete pDisplayHidWin; pDisplayHidWin = NULL; pDisplayInstance = NULL; } return pDisplayHidWin != NULL; } class TranslateWin : public WorkWindow { private: DECL_LINK( DoAccept, PushButton* ); DECL_LINK( DoNext, PushButton* ); DECL_LINK( DoSelect, PushButton* ); DECL_LINK( DoRestore, PushButton* ); DECL_LINK( TranslationChanged, Edit* ); DECL_LINK( ShowInplace, Timer* ); Timer InplaceTimer; BOOL bAvailable; BOOL bNext; // virtual void MouseButtonUp( const MouseEvent& rMEvt ); // virtual void MouseMove( const MouseEvent& rMEvt ); PushButton PushButtonTT_PB_NEXT; GroupBox GroupBoxTT_GB_TRANSLATION; Edit EditTT_E_NEW; GroupBox GroupBoxTT_GB_COMMENT; Edit EditTT_E_COMMENT; PushButton PushButtonTT_PB_ACCEPT; FixedText FixedTextTT_FT_OLD; PushButton PushButtonTT_PB_SELECT; PushButton PushButtonTT_PB_RESTORE; Window *Old; Window *Act; Window *pTranslateWin; BOOL bSelecting; BOOL TestChangedDataSaved(); ULONG nEventHookID; static long stub_VCLEventHookProc( NotifyEvent& rEvt, void* pData ) { return ((TranslateWin*)pData)->VCLEventHook( rEvt ); } long VCLEventHook( NotifyEvent& rEvt ); public: TranslateWin(); ~TranslateWin(); static String MarkShortcutErrors( Window* pBase, BOOL bMark ); BOOL IsTranslationAvailable(){ return bAvailable; } BOOL IsNextDialog(){ return bNext; } void ResetNextDialog(){ bNext = FALSE; } Window* GetTranslationWindow(){ return pTranslateWin; } String GetOriginalText(){ return FixedTextTT_FT_OLD.GetText(); } String GetTranslationText(){ return EditTT_E_NEW.GetText(); } String GetComment(){ return EditTT_E_COMMENT.GetText(); } void EnableTranslation(); }; TranslateWin::TranslateWin() : WorkWindow( NULL, TTProperties::GetSvtResId( TT_INLINE_TRANSLATION ) ) , PushButtonTT_PB_NEXT( this, TTProperties::GetSvtResId( TT_PB_NEXT ) ) , GroupBoxTT_GB_TRANSLATION( this, TTProperties::GetSvtResId( TT_GB_TRANSLATION ) ) , EditTT_E_NEW( this, TTProperties::GetSvtResId( TT_E_NEW ) ) , GroupBoxTT_GB_COMMENT( this, TTProperties::GetSvtResId( TT_GB_COMMENT ) ) , EditTT_E_COMMENT( this, TTProperties::GetSvtResId( TT_E_COMMENT ) ) , PushButtonTT_PB_ACCEPT( this, TTProperties::GetSvtResId( TT_PB_ACCEPT ) ) , FixedTextTT_FT_OLD( this, TTProperties::GetSvtResId( TT_FT_OLD ) ) , PushButtonTT_PB_SELECT( this, TTProperties::GetSvtResId( TT_PB_SELECT ) ) , PushButtonTT_PB_RESTORE( this, TTProperties::GetSvtResId( TT_PB_RESTORE ) ) , Old( NULL ) , Act( NULL ) , bSelecting( FALSE ) , bAvailable( FALSE ) , bNext( FALSE ) , pTranslateWin( NULL ) { FreeResource(); PushButtonTT_PB_NEXT.SetClickHdl( LINK( this, TranslateWin, DoNext ) ); PushButtonTT_PB_ACCEPT.SetClickHdl( LINK( this, TranslateWin, DoAccept ) ); PushButtonTT_PB_SELECT.SetClickHdl( LINK( this, TranslateWin, DoSelect ) ); PushButtonTT_PB_RESTORE.SetClickHdl( LINK( this, TranslateWin, DoRestore ) ); EditTT_E_NEW.SetModifyHdl( LINK( this, TranslateWin, TranslationChanged ) ); InplaceTimer.SetTimeout( 250 ); InplaceTimer.SetTimeoutHdl( LINK( this, TranslateWin, ShowInplace ) ); EnableAlwaysOnTop(); nEventHookID = Application::AddEventHook( stub_VCLEventHookProc, this ); } TranslateWin::~TranslateWin() { Application::RemoveEventHook( nEventHookID ); } BOOL TranslateWin::TestChangedDataSaved() { if ( ( EditTT_E_NEW.GetText().CompareTo( FixedTextTT_FT_OLD.GetText() ) != COMPARE_EQUAL || EditTT_E_COMMENT.GetText().Len() ) && PushButtonTT_PB_ACCEPT.IsEnabled() ) { return MessBox( this, TTProperties::GetSvtResId( TT_DISCARD_CHANGED_DATA ) ).Execute() == RET_YES; } else return TRUE; } IMPL_LINK( TranslateWin, DoAccept, PushButton*, EMPTYARG ) { PushButtonTT_PB_SELECT.Disable(); PushButtonTT_PB_NEXT.Disable(); PushButtonTT_PB_RESTORE.Disable(); EditTT_E_NEW.Disable(); EditTT_E_COMMENT.Disable(); PushButtonTT_PB_ACCEPT.Disable(); bAvailable = TRUE; return 0; } IMPL_LINK( TranslateWin, DoNext, PushButton*, EMPTYARG ) { if ( TestChangedDataSaved() ) { PushButtonTT_PB_SELECT.Disable(); PushButtonTT_PB_NEXT.Disable(); PushButtonTT_PB_RESTORE.Disable(); EditTT_E_NEW.Disable(); EditTT_E_COMMENT.Disable(); PushButtonTT_PB_ACCEPT.Disable(); bNext = TRUE; } return 0; } IMPL_LINK( TranslateWin, DoSelect, PushButton*, EMPTYARG ) { if ( bSelecting ) { // ReleaseMouse(); bSelecting = FALSE; } else { if ( TestChangedDataSaved() ) { PushButtonTT_PB_RESTORE.Disable(); // CaptureMouse(); bSelecting = TRUE; } } return 0; } IMPL_LINK( TranslateWin, DoRestore, PushButton*, EMPTYARG ) { String sTT_E_OLD( FixedTextTT_FT_OLD.GetText()); sTT_E_OLD.SearchAndReplaceAll( CUniString("\\n"), CUniString("\n") ); sTT_E_OLD.SearchAndReplaceAll( CUniString("\\t"), CUniString("\t") ); String sTT_E_NEW( EditTT_E_NEW.GetText()); sTT_E_NEW.SearchAndReplaceAll( CUniString("\\n"), CUniString("\n") ); sTT_E_NEW.SearchAndReplaceAll( CUniString("\\t"), CUniString("\t") ); if ( StatementList::WinPtrValid( pTranslateWin ) && pTranslateWin->GetText().CompareTo( sTT_E_NEW ) == COMPARE_EQUAL ) { // Im ersten schritt nur in der UI zurück pTranslateWin->SetText( sTT_E_OLD ); } else { // Im zweite Schritt auch den eingegebenen Text EditTT_E_NEW.SetText( FixedTextTT_FT_OLD.GetText() ); PushButtonTT_PB_RESTORE.Disable(); } if ( StatementList::WinPtrValid( pTranslateWin ) ) MarkShortcutErrors( pTranslateWin->GetWindow( WINDOW_OVERLAP ), TRUE ); return 0; } IMPL_LINK( TranslateWin, TranslationChanged, Edit*, pEdit ) { PushButtonTT_PB_RESTORE.Enable(); InplaceTimer.Start(); return 0; } IMPL_LINK( TranslateWin, ShowInplace, Timer*, EMPTYARG ) { PushButtonTT_PB_RESTORE.Enable(); if ( StatementList::WinPtrValid( pTranslateWin ) ) { String sTT_E_NEW( EditTT_E_NEW.GetText()); // alle CRs UnQuoten sTT_E_NEW.SearchAndReplaceAll( CUniString("\\n"), CUniString("\n") ); // alle TABSs UnQuoten sTT_E_NEW.SearchAndReplaceAll( CUniString("\\t"), CUniString("\t") ); pTranslateWin->SetText( sTT_E_NEW ); MarkShortcutErrors( pTranslateWin->GetWindow( WINDOW_OVERLAP ), TRUE ); } return 0; } long TranslateWin::VCLEventHook( NotifyEvent& rEvt ) { if ( EVENT_MOUSEMOVE == rEvt.GetType() ) { if ( bSelecting ) { const MouseEvent *pMEvt = rEvt.GetMouseEvent(); Old = Act; Act = rEvt.GetWindow(); if ( Act ) { Window *pWin = Act; USHORT i; for ( i = 0 ; i < Act->GetChildCount() ; i++ ) { pWin = Act->GetChild(i); Rectangle aWinPosSize( pWin->GetPosPixel(), pWin->GetSizePixel() ); if ( ( pWin->IsMouseTransparent() || !pWin->IsEnabled() ) && aWinPosSize.IsInside( pMEvt->GetPosPixel() ) ) { Act = pWin; break; } } } if ( Act != Old ) { if ( Old ) { Window *pWin; if ( Old->IsMouseTransparent() && Old->GET_REAL_PARENT() ) pWin = Old->GET_REAL_PARENT(); else pWin = Old; RESET_WIN(pWin); } if ( Act ) { SET_WIN(Act); FixedTextTT_FT_OLD.SetText( Act->GetText() ); } else FixedTextTT_FT_OLD.SetText( String() ); } else if ( Act ) { // SET_WIN(Act); } /* if ( Application::GetLastInputInterval() > 5000 ) // 5 Sekunden lang nix geschehen { ToTop(); } */ } //if ( bSelecting ) else { if ( Act ) { if ( Act->IsMouseTransparent() && Act->GET_REAL_PARENT() ) Act = Act->GET_REAL_PARENT(); RESET_WIN(Act); Act = NULL; } } } else if ( EVENT_MOUSEBUTTONUP == rEvt.GetType() ) { if ( bSelecting ) { pTranslateWin = Act; if ( pTranslateWin ) { MarkShortcutErrors( pTranslateWin->GetWindow( WINDOW_OVERLAP ), TRUE ); // alle CRs quoten (NF) String sTT_E_NEW( pTranslateWin->GetText()); sTT_E_NEW.SearchAndReplaceAll( CUniString("\n"), CUniString("\\n") ); // alle TABSs quoten () sTT_E_NEW.SearchAndReplaceAll( CUniString("\t"), CUniString("\\t") ); FixedTextTT_FT_OLD.SetText( sTT_E_NEW ); EditTT_E_NEW.SetText( sTT_E_NEW ); EditTT_E_NEW.Enable(); EditTT_E_NEW.GrabFocus(); EditTT_E_COMMENT.SetText( String() ); EditTT_E_COMMENT.Enable(); PushButtonTT_PB_ACCEPT.Enable(); } // ReleaseMouse(); bSelecting = FALSE; } } return 0; } #define FDS_ACTION_COLLECT 1 #define FDS_ACTION_MARK 2 #define FDS_ACTION_UNMARK 3 class FindShortcutErrors: public Search { String aShortcuts,aDoubleShortcuts; USHORT nAction; public: FindShortcutErrors(); virtual BOOL IsWinOK( Window *pWin ); void SetAction( USHORT nA ); String GetDoubleShortcuts() { return aDoubleShortcuts; } }; FindShortcutErrors::FindShortcutErrors() : Search( SEARCH_NOOVERLAP | SEARCH_NO_TOPLEVEL_WIN ) { SetAction( FDS_ACTION_COLLECT ); // Wir fange immer mit sammeln an, ODER?? } void FindShortcutErrors::SetAction( USHORT nA ) { nAction = nA; if ( FDS_ACTION_COLLECT == nAction ) { aShortcuts = UniString(); aDoubleShortcuts = UniString(); } } BOOL FindShortcutErrors::IsWinOK( Window *pWin ) { if ( pWin->IsReallyVisible() ) { String aText = pWin->GetText(); xub_StrLen nPos = aText.Search('~'); String aShortcut; BOOL bHasAccel = FALSE; if ( nPos != STRING_NOTFOUND ) { aShortcut = aText.Copy( nPos+1, 1 ); aShortcut.ToLowerAscii(); bHasAccel = aShortcut.Len() == 1; } switch ( nAction ) { case FDS_ACTION_COLLECT: { if ( aShortcuts.Search( aShortcut ) != STRING_NOTFOUND ) aDoubleShortcuts += aShortcut; else aShortcuts += aShortcut; } break; case FDS_ACTION_MARK: { BOOL bMissing = FALSE; if ( !bHasAccel && aText.Len() ) // should there be an accelarator defined { Window* pChild; pChild = pWin->GetWindow( WINDOW_CLIENT ); if ( (pChild->GetType() == WINDOW_RADIOBUTTON) || (pChild->GetType() == WINDOW_IMAGERADIOBUTTON) || (pChild->GetType() == WINDOW_CHECKBOX) || (pChild->GetType() == WINDOW_TRISTATEBOX) || (pChild->GetType() == WINDOW_PUSHBUTTON) ) { if ( !pChild->GetText().EqualsAscii( "..." ) ) bMissing = TRUE; } if ( pChild->GetType() == WINDOW_FIXEDTEXT ) { Window* pTempChild = pWin->GetWindow( WINDOW_NEXT ); if ( pTempChild ) pTempChild = pTempChild->GetWindow( WINDOW_CLIENT ); if ( pTempChild && pChild->GetText().Len() ) { if ( (pTempChild->GetType() == WINDOW_EDIT) || (pTempChild->GetType() == WINDOW_MULTILINEEDIT) || (pTempChild->GetType() == WINDOW_SPINFIELD) || (pTempChild->GetType() == WINDOW_PATTERNFIELD) || (pTempChild->GetType() == WINDOW_NUMERICFIELD) || (pTempChild->GetType() == WINDOW_METRICFIELD) || (pTempChild->GetType() == WINDOW_CURRENCYFIELD) || (pTempChild->GetType() == WINDOW_DATEFIELD) || (pTempChild->GetType() == WINDOW_TIMEFIELD) || (pTempChild->GetType() == WINDOW_LISTBOX) || (pTempChild->GetType() == WINDOW_MULTILISTBOX) || (pTempChild->GetType() == WINDOW_COMBOBOX) || (pTempChild->GetType() == WINDOW_PATTERNBOX) || (pTempChild->GetType() == WINDOW_NUMERICBOX) || (pTempChild->GetType() == WINDOW_METRICBOX) || (pTempChild->GetType() == WINDOW_CURRENCYBOX) || (pTempChild->GetType() == WINDOW_DATEBOX) || (pTempChild->GetType() == WINDOW_TIMEBOX) ) { bMissing = TRUE; } } } } if ( bHasAccel && aDoubleShortcuts.Search( aShortcut ) != STRING_NOTFOUND ) { if ( pWin->GetType() == WINDOW_GROUPBOX ) pWin->SetControlForeground( Color( COL_LIGHTRED ) ); else { pWin->SetControlBackground(); Color aCol(COL_GRAY); aCol.SetRed( 0xff ); pWin->SetControlBackground( aCol ); } } else if ( bMissing ) { pWin->SetControlBackground(); Color aCol(COL_GRAY); aCol.SetRed( 0xff ); aCol.SetGreen( 0xff ); pWin->SetControlBackground( aCol ); } else { pWin->SetControlForeground(); pWin->SetControlBackground(); } } break; case FDS_ACTION_UNMARK: { pWin->SetControlForeground(); pWin->SetControlBackground(); } break; } } else if ( FDS_ACTION_MARK == nAction || FDS_ACTION_UNMARK == nAction ) { pWin->SetControlForeground(); pWin->SetControlBackground(); } return FALSE; } String TranslateWin::MarkShortcutErrors( Window* pBase, BOOL bMark ) { if ( pBase ) { FindShortcutErrors aFinder; if ( bMark ) { StatementList::SearchAllWin( pBase, aFinder, TRUE ); // collect Shortcuts first aFinder.SetAction( FDS_ACTION_MARK ); } else aFinder.SetAction( FDS_ACTION_UNMARK ); StatementList::SearchAllWin( pBase, aFinder, TRUE ); return aFinder.GetDoubleShortcuts(); } return UniString(); } void TranslateWin::EnableTranslation() { PushButtonTT_PB_SELECT.Enable(); PushButtonTT_PB_NEXT.Enable(); bAvailable = FALSE; bNext = FALSE; } void StatementCommand::Translate() { static TranslateWin *pTranslateWin = NULL; static BOOL bToTop = TRUE; // Es wurde eine initale UniqueId mitgegeben. Dann nur die dopelten Shortcuts liefern if( (nParams & PARAM_ULONG_1) && nLNr1 ) { String aDouble; Window *pWin = SearchTree( nLNr1 ,FALSE ); if ( pWin ) { pWin = pWin->GetWindow( WINDOW_OVERLAP ); aDouble = TranslateWin::MarkShortcutErrors( pWin, TRUE ); } pRet->GenReturn ( RET_Value, RC_Translate, aDouble ); return; } if ( !pTranslateWin ) { pTranslateWin = new TranslateWin; bToTop = TRUE; } pTranslateWin->Show(); if ( bToTop ) { pTranslateWin->ToTop(); bToTop = FALSE; } // pTranslateWin->GetWindow( WINDOW_OVERLAP )->Enable( TRUE, TRUE ); pTranslateWin->GetWindow( WINDOW_OVERLAP )->EnableInput( TRUE, TRUE ); if ( pTranslateWin->IsTranslationAvailable() ) { String aTranslation; Window* pTranslationWindow = pTranslateWin->GetTranslationWindow(); DBG_ASSERT( pTranslationWindow, "Kein Translation Window" ); if ( WinPtrValid( pTranslationWindow ) ) { if ( pTranslationWindow->GetType() == WINDOW_BORDERWINDOW && pTranslationWindow->GetWindow( WINDOW_CLIENT ) ) { Window* pNew = pTranslationWindow->GetWindow( WINDOW_CLIENT ); // Bei Dockingwindoes das kanze Geraffel von Docking Floating überspringen while ( IsDialog( pNew ) && !pNew->GetUniqueOrHelpId() && pNew->GetChildCount() == 1 ) pNew = pNew->GetChild( 0 ); pTranslationWindow = pNew; } aTranslation = CUniString("0;"); aTranslation += UniString::CreateFromInt64( pTranslationWindow->GetUniqueOrHelpId() ); aTranslation += ';'; aTranslation += TypeString( pTranslationWindow->GetType() ); aTranslation += ';'; Window* pParentDialog = pTranslationWindow; while ( pParentDialog && !IsDialog( pParentDialog ) ) { pParentDialog = pParentDialog->GET_REAL_PARENT(); } if ( pParentDialog ) { aTranslation += UniString::CreateFromInt64( pParentDialog->GetUniqueOrHelpId() ); aTranslation += ';'; aTranslation += TypeString( pParentDialog->GetType() ); } else aTranslation.AppendAscii( "0;" ); // Zahl + leerer String aTranslation += ';'; aTranslation += '\"'; aTranslation += pTranslateWin->GetOriginalText(); aTranslation += '\"'; aTranslation += ';'; aTranslation += '\"'; aTranslation += pTranslateWin->GetTranslationText(); aTranslation += '\"'; aTranslation += ';'; aTranslation += '\"'; aTranslation += pTranslateWin->GetComment(); aTranslation += '\"'; // alle CRs quoten (NF) aTranslation.SearchAndReplaceAll( CUniString("\n"), CUniString("\\n") ); // alle TABSs quoten () aTranslation.SearchAndReplaceAll( CUniString("\t"), CUniString("\\t") ); pRet->GenReturn ( RET_Value, RC_Translate, aTranslation ); pTranslateWin->EnableTranslation(); bToTop = TRUE; } else { pRet->GenReturn ( RET_Value, RC_Translate, String() ); pTranslateWin->EnableTranslation(); ErrorBox( pTranslateWin, TTProperties::GetSvtResId( TT_NO_CONTROL ) ).Execute(); bToTop = TRUE; } } else if ( pTranslateWin->IsNextDialog() ) { pRet->GenReturn ( RET_Value, RC_Translate, CUniString("1") ); pTranslateWin->ResetNextDialog(); pTranslateWin->LoseFocus(); bToTop = TRUE; } else { pTranslateWin->EnableTranslation(); pRet->GenReturn ( RET_Value, RC_Translate, String() ); } } Window* StatementCommand::GetNextOverlap( Window* pBase ) { // Findet irgendwelche Overlap-Fenster, die schließbar aussehen // Eventuell muß noch die Auswahl verfeinert werden. if ( pBase->GetType() != WINDOW_BORDERWINDOW ) pBase = pBase->GetWindow( WINDOW_OVERLAP ); Window *pControl = NULL; if ( pBase->GetWindow( WINDOW_FIRSTOVERLAP ) ) { pControl = GetNextOverlap( pBase->GetWindow( WINDOW_FIRSTOVERLAP ) ); } if ( !pControl && pBase->GetWindow( WINDOW_NEXT ) ) { pControl = GetNextOverlap( pBase->GetWindow( WINDOW_NEXT ) ); } if ( !pControl ) { Window *pTest = pBase->GetWindow( WINDOW_CLIENT ); if ( IsAccessable (pTest) && pTest->IsEnabled() && pTest->IsVisible() && ((pTest->GetStyle() & WB_CLOSEABLE ) || (pBase->GetStyle() & WB_CLOSEABLE )) ) return pTest; else return NULL; } else return pControl; } Window* StatementCommand::GetNextRecoverWin() { // über die TopLevelWindows der App iterieren Window* pBase = Application::GetFirstTopLevelWindow(); Window *pControl = NULL; while ( pBase ) { // zuerst weitere Fenster auf dem Fenster suchen und schliessen pControl = GetNextOverlap( pBase ); if ( pControl && pControl->IsVisible() && !IsFirstDocWin( pControl ) && !IsIMEWin( pControl ) ) { /* Window *pDock = GetWinByRT( pControl, WINDOW_DOCKINGWINDOW, FALSE ); if ( pDock ) return pDock; else*/ return pControl; } // dann das Fenster selbst Schliessen // erstes DocWin überspringen // Assumption that Doc Windows are Borderwindows and ButtonDialog and such are not if ( pBase->IsVisible() && !IsFirstDocWin( pBase ) && pBase->GetType() != WINDOW_BORDERWINDOW && !IsIMEWin( pBase ) ) return pBase; pBase = Application::GetNextTopLevelWindow( pBase ); } return NULL; } BOOL StatementCommand::Execute() { if ( IsError ) { #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Skipping Command: " ); m_pDbgWin->AddText( String::CreateFromInt32( nMethodId ) ); m_pDbgWin->AddText( "\n" ); #endif Advance(); delete this; return TRUE; } InitProfile(); #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Executing Command: " ); m_pDbgWin->AddText( String::CreateFromInt32( nMethodId ) ); m_pDbgWin->AddText( "\n" ); #endif #if OSL_DEBUG_LEVEL > 1 #define REPORT_WIN_CLOSED(pControl, aInfo) \ _REPORT_WIN_CLOSED(pControl, aInfo) \ m_pDbgWin->AddText( aInfo.AppendAscii(" \"").Append( pControl->GetText() ).AppendAscii("\" geschlossen, RType = ").Append( TypeString(pControl->GetType()) ).AppendAscii(", UId = ").Append( UIdString(pControl->GetUniqueOrHelpId()) ) ); #else #define REPORT_WIN_CLOSED(pControl, aInfo) _REPORT_WIN_CLOSED(pControl, aInfo) #endif #define REPORT_WIN_CLOSEDc(pControl, aInfo ) \ REPORT_WIN_CLOSED(pControl, CUniString(aInfo) ) #define _REPORT_WIN_CLOSED(pControl, aInfo) \ if ( aString1.Len() ) \ aString1 += '\n'; \ aString1 += aInfo; \ aString1.AppendAscii(" \""); \ aString1 += pControl->GetText(); \ aString1.AppendAscii("\" geschlossen, RType = ");\ aString1 += TypeString(pControl->GetType()); \ aString1.AppendAscii(", UId = "); \ aString1 += UIdString(pControl->GetUniqueOrHelpId()); switch ( nMethodId ) { case RC_AppDelay: if ( !bBool1 ) { nLNr1 = Time().GetTime() + nNr1/10; bBool1 = TRUE; } if ( Time().GetTime() < nLNr1 ) // Aktuelle Zeit kleiner Endzeit return FALSE; break; case RC_DisplayHid: if ( DisplayHID() ) return FALSE; break; case RC_ResetApplication: { if ( !bBool1 ) { nRetryCount = 150; // das sollte reichen. bBool1 = TRUE; // Nur beim ersten mal! nNr1 = 1; // Welcher Button ist dran? nLNr1 = 0; // Speichern des AppWin aString1 = UniString(); // Liste der geschlossenen Fenster // So daß nacher auch wieder alles auf Default steht nUseBindings = 0; nControlType = CONST_CTTreeListBox; nSubMenuId1 = 0; nSubMenuId2 = 0; pMenuWindow = NULL; } if ( !nRetryCount ) ReportError( GEN_RES_STR0( S_RESETAPPLICATION_FAILED_COMPLEX ) ); bBool2 = FALSE; // no document found Window *pControl = GetNextRecoverWin(); if ( pControl ) { pControl->GrabFocus(); if ( pControl->GetType() != WINDOW_DOCKINGWINDOW && pControl->GetType() != WINDOW_FLOATINGWINDOW && pControl->GetType() != WINDOW_MODELESSDIALOG && pControl->GetType() != WINDOW_WORKWINDOW && pControl->GetType() != WINDOW_TOOLBOX && nRetryCount-- ) { short nRT = ImpGetRType( pControl, pControl->GetUniqueOrHelpId() ); if ( nRT == C_TabControl && pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_TABDIALOG ) { // Bei Tabcontrol den zugehörigen Tabdialog nehmen pControl = pControl->GET_REAL_PARENT(); nRT = ImpGetRType( pControl, pControl->GetUniqueOrHelpId() ); } switch( nRT ) { case C_Dlg: case C_TabDlg: REPORT_WIN_CLOSEDc(pControl, "Dialog"); SET_WINP_CLOSING(pControl); ((SystemWindow*)pControl)->Close(); break; case C_WorkWin: break; case C_MessBox: case C_InfoBox: case C_WarningBox: case C_ErrorBox: case C_QueryBox: case C_ButtonDialog: { ButtonDialog* pBD = (ButtonDialog*)pControl; // nNr1 >= 10 bedeutet (Custom)-Buttons durchgehen if ( nNr1 >= 10+pBD->GetButtonCount() ) nNr1 = 1; switch( nNr1 ) { case 5: if ( pBD->GetPushButton( BUTTONID_OK ) ) { REPORT_WIN_CLOSEDc(pControl, "Message Box (OK)"); SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_OK); } nNr1 = 10; // Nochmal alle Buttons der Reihe nach break; case 4: if ( pBD->GetPushButton( BUTTONID_CANCEL ) ) { REPORT_WIN_CLOSEDc(pControl, "Message Box (Cancel)"); SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_CANCEL); } nNr1++; break; case 3: if ( pBD->GetPushButton( BUTTONID_YES ) ) { REPORT_WIN_CLOSEDc(pControl, "Message Box (Yes)"); SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_YES); } nNr1++; break; case 2: // BUG 48239 case 1: if ( pBD->GetPushButton( BUTTONID_NO ) ) { REPORT_WIN_CLOSEDc(pControl, "Message Box (No)"); SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_NO); } nNr1++; break; default: { USHORT nID = pBD->GetButtonId( nNr1-10 ); if ( nID != BUTTONID_HELP ) { REPORT_WIN_CLOSED(pControl, CUniString("Message Box (").Append( UniString::CreateFromInt32(nID) ).AppendAscii(")")); SET_WINP_CLOSING(pControl); pBD->EndDialog(nID); } nNr1++; } } break; } default: DBG_ERROR( "Unbekannter Fenstertyp" ); REPORT_WIN_CLOSEDc(pControl, "Unbekannter Fenstertyp"); ReportError( 0, GEN_RES_STR0( S_RESETAPPLICATION_FAILED_UNKNOWN ), pControl->GetType() ); #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( " Unbekannter Objekttyp aus UId" ); #endif break; } return FALSE; } else { if ( (pControl->GetType() == WINDOW_DOCKINGWINDOW || pControl->GetType() == WINDOW_TOOLBOX) && nRetryCount-- ) { if ( (((DockingWindow*)pControl)->GetStyle() | ((DockingWindow*)pControl)->GetFloatStyle()) & WB_CLOSEABLE ) { REPORT_WIN_CLOSEDc(pControl, "DockingWindow"); SET_WINP_CLOSING(pControl); ((DockingWindow*)pControl)->Close(); // Eigentlich nur bei TaskWindows! Hoffen wir mal, daß keine anderen DockingWindows dazwischen hauen. if ( (Window*)nLNr1 != pControl ) nNr1 = 1; // Zum durchprobieren der Buttons beim Schließen nLNr1 = (ULONG)pControl; return FALSE; } } if ( nRetryCount-- && ( (pControl->GetType() == WINDOW_FLOATINGWINDOW) || (pControl->GetType() == WINDOW_MODELESSDIALOG) || (pControl->GetType() == WINDOW_WORKWINDOW) ) ) { // if ( pControl->GetStyle() & WB_CLOSEABLE ) { REPORT_WIN_CLOSED( pControl, TypeString(pControl->GetType())); SET_WINP_CLOSING(pControl); ((SystemWindow*)pControl)->Close(); // Eigentlich nur bei TaskWindows! if ( (Window*)nLNr1 != pControl ) nNr1 = 1; // Zum durchprobieren der Buttons beim Schließen nLNr1 = (ULONG)pControl; return FALSE; } } } } pRet->GenReturn ( RET_Value, nMethodId, aString1); } } Advance(); switch ( nMethodId ) { case RC_AppDelay: // Diese Befehle werden anderswo behandelt case RC_DisplayHid: case RC_ResetApplication: case RC_AppAbort: // Sofortiges Löschen aller Befehle break; case RC_Assert: { ByteString aAssertion( "Diese Assertion wurde vom Testtool per Befehl ausgelöst" ); aAssertion = ByteString( String( aAssertion, RTL_TEXTENCODING_MS_1252 ), RTL_TEXTENCODING_UTF8 ); DBG_ASSERT( !aString1.Len(), ByteString( aString1, RTL_TEXTENCODING_UTF8 ).GetBuffer() ) DBG_ASSERT( aString1.Len(), aAssertion.GetBuffer() ) OSL_ENSURE( !aString1.Len(), ByteString( aString1, RTL_TEXTENCODING_UTF8 ).GetBuffer() ); OSL_ENSURE( aString1.Len(), aAssertion.GetBuffer() ); } break; case RC_CaptureAssertions: #ifdef DBG_UTIL if( !(nParams & PARAM_BOOL_1) || bBool1 ) { DBG_INSTOUTERROR( DBG_OUT_TESTTOOL ) osl_setDebugMessageFunc( osl_TestToolDebugPrint ); } else { DBG_INSTOUTERROR( DBG_OUT_MSGBOX ) osl_setDebugMessageFunc( pOriginal_osl_DebugMessageFunc ); } #endif break; case RC_Translate: Translate(); break; case RC_ApplicationBusy: { BOOL bWait = FALSE; ReportError( GEN_RES_STR0( S_NO_ACTIVE_WINDOW ) ); // if ( Application::GetAppWindow() ) // bWait = Application::GetAppWindow()->IsWait(); pRet->GenReturn ( RET_Value, nMethodId, bWait ); break; } case RC_GetClipboard: { ::rtl::OUString aTemp; ::svt::OStringTransfer::PasteString( aTemp, GetFirstDocWin() ); pRet->GenReturn ( RET_Value, nMethodId, String( aTemp ) ); } break; case RC_SetClipboard: ::svt::OStringTransfer::CopyString(aString1,GetFirstDocWin()); break; case RC_WinTree: pRet->GenReturn ( RET_Value, nMethodId, Tree( NULL, 0)); break; #if OSL_DEBUG_LEVEL > 1 case RC_NoDebug: m_pDbgWin->bQuiet = TRUE; m_pDbgWin->Hide(); m_pDbgWin->Clear(); break; case RC_Debug: m_pDbgWin->bQuiet = FALSE; m_pDbgWin->Show(); break; #endif case RC_GPF: ((TabControl*)NULL)->SetCurPageId( 12345 ); break; case RC_GetNextCloseWindow: { Window *pWin = GetActive( WINDOW_BASE ); // WINDOW_ANYTYPE if ( !pWin ) ReportError( GEN_RES_STR0( S_NO_ACTIVE_WINDOW ) ); else if ( !IsDialog(pWin) ) ReportError( GEN_RES_STR0( S_NO_DIALOG_IN_GETACTIVE ) ); else pRet->GenReturn( RET_Value, nMethodId, (ULONG)pWin->GetUniqueOrHelpId()); } break; case RC_UseBindings: if( !(nParams & PARAM_BOOL_1) || bBool1 ) nUseBindings = SFX_USE_BINDINGS; else nUseBindings = 0; break; case RC_Profile: // Bei folgenden Parametern passiert folgendes: // ein boolean=false Alles Profiling stoppen (Ergebnisse liefern) // ein boolean=true, 1-4 ints Einteilung der Zeiten in Kästchen // kein! boolean keine ints loggen jeden Befehls // kein! boolean 1 int loggen alle int Millisekunden // ein String wird in das Logfile übernommen(sonst passiert nichts) if( !(nParams & PARAM_BOOL_1) || bBool1 ) { if ( !pProfiler ) { pProfiler = new TTProfiler; InitProfile(); } if( !(nParams & PARAM_BOOL_1) && (nParams & PARAM_USHORT_1) ) { // Autoprofiling: Profile nNr if ( pProfiler->IsProfilingPerCommand() ) { pProfiler->StopProfilingPerCommand(); } pProfiler->StartAutoProfiling( nNr1 ); // Der Header ist abhängig vom Modus pRet->GenReturn( RET_ProfileInfo, 0, pProfiler->GetProfileHeader() ); } else if ( nParams & PARAM_USHORT_1 ) { // Partitioning initialisieren: Profile true [,nNr][,nNr][,nNr][,nNr] ULONG nAnzahl=0; if ( nParams & PARAM_USHORT_1 ) { nAnzahl++; }; if ( nParams & PARAM_USHORT_2 ) { nAnzahl++; }; if ( nParams & PARAM_USHORT_3 ) { nAnzahl++; }; if ( nParams & PARAM_USHORT_4 ) { nAnzahl++; }; // Hier werden die Parameter ans Testtool zurück übertragen. // Das ist zwar etwas eigenartig, aber ansonsten müsste man im Testtool // die einfache Struktur der Remotebefehle aufbrechen. pRet->GenReturn( RET_ProfileInfo, S_ProfileReset, nAnzahl ); // Und die einzelnen Grenzen if ( nParams & PARAM_USHORT_1 ) { pRet->GenReturn( RET_ProfileInfo, S_ProfileBorder1, (ULONG)nNr1 ); }; if ( nParams & PARAM_USHORT_2 ) { pRet->GenReturn( RET_ProfileInfo, S_ProfileBorder2, (ULONG)nNr2 ); }; if ( nParams & PARAM_USHORT_3 ) { pRet->GenReturn( RET_ProfileInfo, S_ProfileBorder3, (ULONG)nNr3 ); }; if ( nParams & PARAM_USHORT_4 ) { pRet->GenReturn( RET_ProfileInfo, S_ProfileBorder4, (ULONG)nNr4 ); }; pProfiler->StartPartitioning(); } else if( nParams == PARAM_STR_1 ) // Genau ein String! { // Nur einen String ins Profiling aufnehmen aString1 += '\n'; pRet->GenReturn( RET_ProfileInfo, 0, aString1 ); } else { // Normales Profiling je Kommando: profile if ( pProfiler->IsAutoProfiling() ) { pRet->GenReturn( RET_ProfileInfo, 0, pProfiler->GetAutoProfiling() ); pProfiler->StopAutoProfiling(); } pProfiler->StartProfilingPerCommand(); // Der Header ist abhängig vom Modus pRet->GenReturn( RET_ProfileInfo, 0, pProfiler->GetProfileHeader() ); } } else // Profiling wieder ausschalten: Profile false if ( pProfiler ) { if ( pProfiler->IsProfilingPerCommand() ) pProfiler->StopProfilingPerCommand(); if ( pProfiler->IsAutoProfiling() ) { pRet->GenReturn( RET_ProfileInfo, 0, pProfiler->GetAutoProfiling() ); pProfiler->StopAutoProfiling(); } if ( pProfiler->IsPartitioning() ) { pRet->GenReturn( RET_ProfileInfo, S_ProfileDump, (ULONG)0 ); pProfiler->StopPartitioning(); } delete pProfiler; pProfiler = NULL; } break; case RC_MenuGetItemCount: case RC_MenuGetItemId: case RC_MenuGetItemPos: case RC_MenuIsSeperator: case RC_MenuIsItemChecked: case RC_MenuIsItemEnabled: case RC_MenuGetItemText: case RC_MenuGetItemCommand: case RC_MenuSelect: { PopupMenu *pPopup = NULL; MenuBar *pMenuBar = NULL; Menu *pMenu; if ( WinPtrValid( pMenuWindow ) ) pMenuBar = pMenuWindow->GetMenuBar(); if ( pMenuBar ) // use MenuBar as base pMenu = pMenuBar; else // use contextmenu as base { pMenu = PopupMenu::GetActivePopupMenu(); pPopup = PopupMenu::GetActivePopupMenu(); } if ( !pMenu ) { ReportError( GEN_RES_STR0( S_NO_POPUP ) ); break; } if ( nSubMenuId1 ) { pPopup = pMenu->GetPopupMenu(nSubMenuId1); pMenu = pPopup; } if ( pMenu && nSubMenuId2 ) { pPopup = pMenu->GetPopupMenu(nSubMenuId2); pMenu = pPopup; } if ( !pMenu ) { ReportError( GEN_RES_STR0( S_NO_SUBMENU ) ); break; } USHORT nItemCount = 0; switch ( nMethodId ) { case RC_MenuGetItemCount: case RC_MenuGetItemId: case RC_MenuIsSeperator: { nItemCount = pMenu->GetItemCount(); if ( pMenu->GetMenuFlags() & MENU_FLAG_HIDEDISABLEDENTRIES ) { // jep, we have to adjust the count BOOL bLastWasSeperator = TRUE; // TRUE for Separator at the top for ( USHORT i = 0 ; i < pMenu->GetItemCount() ; i++ ) { if ( !pMenu->IsItemEnabled( pMenu->GetItemId( i ) ) ) nItemCount--; else { if ( pMenu->GetItemType( i ) == MENUITEM_SEPARATOR && bLastWasSeperator ) nItemCount--; bLastWasSeperator = pMenu->GetItemType( i ) == MENUITEM_SEPARATOR; } } if ( bLastWasSeperator ) // Separator at bottom nItemCount--; } } break; } // for certain methods calculate the physical index (reinserting the hidden entries) USHORT nPhysicalIndex = 0; switch ( nMethodId ) { case RC_MenuGetItemId: case RC_MenuIsSeperator: { nPhysicalIndex = nNr1; if ( pMenu->GetMenuFlags() & MENU_FLAG_HIDEDISABLEDENTRIES ) { // jep, we have to adjust the position BOOL bLastWasSeperator = TRUE; // TRUE for Separator at the top USHORT nVisibleCount = 0; for ( USHORT i = 0 ; i < pMenu->GetItemCount() && nVisibleCount < nNr1 ; i++ ) { if ( pMenu->IsItemEnabled( pMenu->GetItemId( i ) ) && !( pMenu->GetItemType( i ) == MENUITEM_SEPARATOR && bLastWasSeperator ) ) { nVisibleCount++; bLastWasSeperator = pMenu->GetItemType( i ) == MENUITEM_SEPARATOR; } else nPhysicalIndex++; } DBG_ASSERT( nVisibleCount == nNr1, "Adaption of Index failed: nVisibleCount != nNr1" ) } } break; } switch ( nMethodId ) { case RC_MenuGetItemCount: { pRet->GenReturn ( RET_Value, nMethodId, (ULONG)nItemCount ); } break; case RC_MenuGetItemId: { if ( ValueOK(nMethodId, RcString( nMethodId ),nNr1,nItemCount) ) pRet->GenReturn ( RET_Value, nMethodId, (ULONG)pMenu->GetItemId(nPhysicalIndex-1) ); } break; case RC_MenuGetItemPos: { USHORT nLogicalPos = pMenu->GetItemPos(nNr1); if ( MENU_ITEM_NOTFOUND != nLogicalPos && pMenu->GetMenuFlags() & MENU_FLAG_HIDEDISABLEDENTRIES ) { // jep, we have to adjust the position if ( !pMenu->IsItemEnabled( nNr1 ) ) nLogicalPos = MENU_ITEM_NOTFOUND; else { BOOL bLastWasSeperator = FALSE; for ( int i = nLogicalPos ; i >= 0 ; i-- ) { if ( !pMenu->IsItemEnabled( pMenu->GetItemId( i ) ) || ( pMenu->GetItemType( i ) == MENUITEM_SEPARATOR && bLastWasSeperator ) ) nLogicalPos--; bLastWasSeperator = pMenu->GetItemType( i ) == MENUITEM_SEPARATOR; } } } pRet->GenReturn ( RET_Value, nMethodId, (ULONG)(nLogicalPos+1) ); } break; case RC_MenuIsSeperator: { if ( ValueOK(nMethodId, RcString( nMethodId ),nNr1,nItemCount) ) pRet->GenReturn ( RET_Value, nMethodId, (BOOL)(pMenu->GetItemType(nPhysicalIndex-1) == MENUITEM_SEPARATOR) ); } break; case RC_MenuIsItemChecked: { pRet->GenReturn ( RET_Value, nMethodId, (BOOL)pMenu->IsItemChecked(nNr1) ); } break; case RC_MenuIsItemEnabled: { pRet->GenReturn ( RET_Value, nMethodId, (BOOL)pMenu->IsItemEnabled(nNr1) ); } break; case RC_MenuGetItemText: { pRet->GenReturn ( RET_Value, nMethodId, (String)pMenu->GetItemText(nNr1) ); } break; case RC_MenuGetItemCommand: { pRet->GenReturn ( RET_Value, nMethodId, (String)pMenu->GetItemCommand(nNr1) ); } break; case RC_MenuSelect: { if ( pMenu->GetPopupMenu(nNr1) ) { if ( !nSubMenuId1 ) nSubMenuId1 = nNr1; else if ( !nSubMenuId2 ) nSubMenuId2 = nNr1; if ( pPopup ) pPopup->SelectEntry(nNr1); else pMenuBar->SelectEntry(nNr1); } else { if ( pPopup ) { pPopup->EndExecute(nNr1); nSubMenuId1 = 0; nSubMenuId2 = 0; pMenuWindow = NULL; } else { pMenuBar->SelectEntry(nNr1); nSubMenuId1 = 0; nSubMenuId2 = 0; pMenuWindow = NULL; } } } break; } } break; case RC_SetControlType: { switch ( nNr1 ) { case CONST_CTTreeListBox: case CONST_CTBrowseBox: case CONST_CTProgressBar: nControlType = nNr1; break; default: ReportError( 0, GEN_RES_STR1( S_CONTROLTYPE_NOT_SUPPORTED , UniString::CreateFromInt32( nNr1 ) ) ); } } break; case RC_Kill: case RC_RmDir: case RC_MkDir: case RC_FileCopy: case RC_Name: case RC_Dir: case RC_FileLen: case RC_FileDateTime: { long nErrorcode = FSYS_ERR_OK; switch ( nMethodId ) { case RC_Kill: { DirEntry aFile( aString1 ); nErrorcode = aFile.GetError(); if ( FSYS_ERR_OK == nErrorcode && FileStat( aFile ).IsKind( FSYS_KIND_FILE ) ) nErrorcode = aFile.Kill(); else nErrorcode = FSYS_ERR_NOTAFILE; } break; case RC_RmDir: { DirEntry aDir( aString1 ); nErrorcode = aDir.GetError(); if ( FSYS_ERR_OK == nErrorcode && FileStat( aDir ).IsKind( FSYS_KIND_DIR ) ) nErrorcode = aDir.Kill(); else nErrorcode = FSYS_ERR_NOTADIRECTORY; } break; case RC_MkDir: { DirEntry aDir( aString1 ); nErrorcode = aDir.GetError(); if ( !nErrorcode && !aDir.MakeDir() ) nErrorcode = FSYS_ERR_UNKNOWN; // Workaround für Bug 60693 // nErrorcode = aDir.GetError(); } break; case RC_FileCopy: { nErrorcode = DirEntry( aString1 ).CopyTo( DirEntry( aString2 ), FSYS_ACTION_COPYFILE ); } break; case RC_Name: { nErrorcode = DirEntry( aString1 ).MoveTo( DirEntry( aString2 ) ); } break; case RC_Dir: { // neues Verzeichnis einlesen if ( (nParams & PARAM_STR_1) ) { if ( pDir ) { delete pDir; pDir = NULL; } DirEntryKind aDirEntryKind = FSYS_KIND_FILE | FSYS_KIND_DIR; if ( (nParams & PARAM_USHORT_1) && nNr1 ) { if ( nNr1 & 16 ) aDirEntryKind = FSYS_KIND_DIR; else ReportError( GEN_RES_STR0( S_SELECTION_BY_ATTRIBUTE_ONLY_DIRECTORIES ) ); } DirEntry aEntry( aString1 ); nErrorcode = aEntry.GetError(); if ( !nErrorcode ) { nDirPos = 0; FileStat aFS( aEntry ); if ( !aFS.IsKind( FSYS_KIND_WILD ) && !aFS.IsKind( FSYS_KIND_DIR ) && aEntry.Exists() ) { // Sonderbehandlung für genau einen Eintrag if ( !aFS.IsKind( FSYS_KIND_DIR ) && ( aDirEntryKind == FSYS_KIND_DIR ) ) pRet->GenReturn ( RET_Value, nMethodId, String() ); else pRet->GenReturn ( RET_Value, nMethodId, (String)(aEntry.GetName()) ); break; } else { pDir = new Dir( aEntry, aDirEntryKind ); nErrorcode = pDir->GetError(); } } } if ( !pDir ) pDir = new Dir; if ( !nErrorcode && ValueOK( nMethodId, GEN_RES_STR0( S_NO_MORE_FILES ), nDirPos+1, pDir->Count()+1 ) ) { if ( nDirPos == pDir->Count() ) pRet->GenReturn ( RET_Value, nMethodId, String() ); else pRet->GenReturn ( RET_Value, nMethodId, (String)((*pDir)[ nDirPos ].GetName()) ); nDirPos++; } } break; case RC_FileLen: { DirEntry aFile( aString1 ); nErrorcode = aFile.GetError(); if ( FSYS_ERR_OK == nErrorcode ) { FileStat aFS( aFile ); pRet->GenReturn ( RET_Value, nMethodId, aFS.GetSize() ); nErrorcode = aFS.GetError(); } } break; case RC_FileDateTime: { DirEntry aFile( aString1 ); nErrorcode = aFile.GetError(); if ( FSYS_ERR_OK == nErrorcode ) { FileStat aStat( aFile ); Time aTime( aStat.TimeModified() ); Date aDate( aStat.DateModified() ); nErrorcode = aStat.GetError(); double fSerial = (double)( aDate - Date(30,12,1899) ); long nSeconds = aTime.GetHour(); nSeconds *= 3600; nSeconds += aTime.GetMin() * 60; nSeconds += aTime.GetSec(); double nDays = ((double)nSeconds) / (double)(24.0*3600.0); fSerial += nDays; SbxValueRef xValue = new SbxValue( SbxDATE ); xValue->PutDate( fSerial ); pRet->GenReturn ( RET_Value, nMethodId, *xValue ); } } break; } switch ( nErrorcode ) { case FSYS_ERR_OK: break; case FSYS_ERR_MISPLACEDCHAR: { ReportError( CUniString("MISPLACEDCHAR") ); } break; case FSYS_ERR_INVALIDCHAR: { ReportError( CUniString("INVALIDCHAR") ); } break; case FSYS_ERR_NOTEXISTS: { ReportError( CUniString("NOTEXISTS") ); } break; case FSYS_ERR_ALREADYEXISTS: { ReportError( CUniString("ALREADYEXISTS") ); } break; case FSYS_ERR_NOTADIRECTORY: { ReportError( CUniString("NOTADIRECTORY") ); } break; case FSYS_ERR_NOTAFILE: { ReportError( CUniString("NOTAFILE") ); } break; case FSYS_ERR_INVALIDDEVICE: { ReportError( CUniString("INVALIDDEVICE") ); } break; case FSYS_ERR_ACCESSDENIED: { ReportError( CUniString("ACCESSDENIED") ); } break; case FSYS_ERR_LOCKVIOLATION: { ReportError( CUniString("LOCKVIOLATION") ); } break; case FSYS_ERR_VOLUMEFULL: { ReportError( CUniString("VOLUMEFULL") ); } break; case FSYS_ERR_ISWILDCARD: { ReportError( CUniString("ISWILDCARD") ); } break; case FSYS_ERR_NOTSUPPORTED: { ReportError( CUniString("NOTSUPPORTED") ); } break; case FSYS_ERR_UNKNOWN: { ReportError( CUniString("UNKNOWN") ); } break; default: { ReportError( CUniString("Not an FSYS Error") ); } } } break; case RC_TypeKeysDelay: { if( (nParams & PARAM_BOOL_1) ) { bDoTypeKeysDelay = bBool1; } else if( nParams & PARAM_USHORT_1 ) { nMinTypeKeysDelay = nNr1; if( nParams & PARAM_USHORT_2 ) nMaxTypeKeysDelay = nNr2; else nMaxTypeKeysDelay = nMinTypeKeysDelay; } else ReportError( GEN_RES_STR0( S_INVALID_PARAMETERS ) ); } break; case RC_GetMouseStyle: { Pointer aPointer; // if ( DragManager::GetDragManager() ) // aPointer = DragManager::GetDragManager()->GetDragPointer(); // else { Window *pActualWin = GetMouseWin(); if ( pActualWin ) aPointer = pActualWin->GetPointer(); else { ReportError( 0, GEN_RES_STR1( S_POINTER_OUTSIDE_APPWIN, RcString( nMethodId ) ) ); aPointer = Pointer( POINTER_NULL ); } } pRet->GenReturn ( RET_Value, nMethodId, (ULONG)aPointer.GetStyle() ); } break; case RC_UnpackStorage: { if( (nParams & PARAM_STR_1) ) { String aFileName( aString1 ); DirEntry aDestPath; if( (nParams & PARAM_STR_2) ) aDestPath = DirEntry( aString2 ); else { aDestPath = DirEntry( aFileName ); aDestPath.SetExtension( CUniString( "plaintext" ) ); } #if OSL_DEBUG_LEVEL > 1 USHORT nEntries = Dir( aDestPath, FSYS_KIND_FILE | FSYS_KIND_DIR ).Count(); #endif // The Count is only larger than 2 is the path is a directory which is not empty // the Count of 2 results from the "." and ".." directory if ( Dir( aDestPath, FSYS_KIND_FILE | FSYS_KIND_DIR ).Count() > 2 ) DirectLog( S_QAError, GEN_RES_STR1( S_DIRECTORY_NOT_EMPTY, aDestPath.GetFull() ) ); SotStorageRef xStorage = new SotStorage( aFileName, STREAM_STD_READ ); if ( xStorage->GetError() ) ReportError( GEN_RES_STR2(S_UNPACKING_STORAGE_FAILED, aFileName, aDestPath.GetFull()) ); else UnpackStorage( xStorage, aDestPath ); } else ReportError( GEN_RES_STR0( S_INVALID_PARAMETERS ) ); } break; case RC_CloseSysDialog: case RC_ExistsSysDialog: { if( (nParams & PARAM_USHORT_1) ) { Reference < XCancellable > xPicker; switch( nNr1 ) { case CONST_FilePicker: { xPicker.set( Reference < XCancellable >( svt::GetTopMostFilePicker(), UNO_QUERY ) ); } break; case CONST_FolderPicker: { xPicker.set( Reference < XCancellable >( svt::GetTopMostFolderPicker(), UNO_QUERY ) ); } break; default: ReportError( GEN_RES_STR0( S_INVALID_PARAMETERS ) ); } switch( nMethodId ) { case RC_CloseSysDialog: { if ( xPicker.is() ) xPicker->cancel(); else ReportError( GEN_RES_STR0( S_INVALID_PARAMETERS ) ); } break; case RC_ExistsSysDialog: { pRet->GenReturn ( RET_Value, nMethodId, (BOOL)xPicker.is() ); } break; default: ReportError( GEN_RES_STR0( S_INVALID_PARAMETERS ) ); } } else ReportError( GEN_RES_STR0( S_INVALID_PARAMETERS ) ); } break; case RC_SAXCheckWellformed: case RC_SAXReadFile: case RC_SAXGetNodeType: case RC_SAXGetAttributeCount: case RC_SAXGetAttributeName: case RC_SAXGetAttributeValue: case RC_SAXGetChildCount: case RC_SAXGetElementName: case RC_SAXGetChars: case RC_SAXSeekElement: case RC_SAXHasElement: case RC_SAXGetElementPath: case RC_SAXRelease: { HandleSAXParser(); } break; case RC_RecordMacro: { HandleMacroRecorder(); } break; case RC_GetDocumentCount : { pRet->GenReturn ( RET_Value, nMethodId, (USHORT)GetDocWinCount() ); } break; case RC_ActivateDocument : { if( nParams & PARAM_USHORT_1 ) { if ( ValueOK(nMethodId, RcString( nMethodId ), nNr1, GetDocWinCount() ) ) { Window* pWin = GetDocWin( nNr1-1 ); if ( pWin ) { pWin->ToTop(); pWin->GrabFocus(); } } } else ReportError( GEN_RES_STR0( S_INVALID_PARAMETERS ) ); } break; case RC_GetSystemLanguage : { pRet->GenReturn ( RET_Value, nMethodId, (USHORT)Application::GetSettings().GetLanguage() ); } break; default: ReportError( 0, GEN_RES_STR1( S_UNKNOWN_COMMAND, RcString( nMethodId ) ) ); } SendProfile( RcString(nMethodId) ); delete this; return TRUE; } BOOL StatementCommand::UnpackStorage( SotStorageRef xStorage, DirEntry &aBaseDir ) { SvStorageInfoList aList; xStorage->FillInfoList( &aList ); for( USHORT i = 0; i < aList.Count(); i++ ) { SvStorageInfo& rInfo = aList.GetObject( i ); String aName = rInfo.GetName(); DirEntry aPath ( aBaseDir ); aPath += DirEntry( aName ); BOOL bIsStorage = xStorage->IsStorage( aName ); if ( bIsStorage ) { SotStorageRef xSubStorage = xStorage->OpenSotStorage( aName, STREAM_STD_READ ); if ( xSubStorage->GetError() ) { ReportError( GEN_RES_STR2(S_UNPACKING_STORAGE_FAILED, aName, aPath.GetFull()) ); return FALSE; } UnpackStorage( xSubStorage, aPath ); } else { if ( !aPath.MakeDir( TRUE ) ) { ReportError( GEN_RES_STR1(S_CANNOT_CREATE_DIRECTORY, aPath.GetFull()) ); return FALSE; } SotStorageStreamRef xStream = xStorage->OpenSotStream( aName, STREAM_STD_READ ); SvFileStream aDestination( aPath.GetFull(), STREAM_STD_READWRITE | STREAM_TRUNC ); (*xStream) >> aDestination; if ( aDestination.GetError() != ERRCODE_NONE ) { ReportError( GEN_RES_STR2(S_UNPACKING_STORAGE_FAILED, aName, aPath.GetFull()) ); return FALSE; } aDestination.Close(); } } return TRUE; } // -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= StatementControl::StatementControl( SCmdStream *pCmdIn ) : StatementList() , bBool1(FALSE) , bBool2(FALSE) { QueStatement( NULL ); pCmdIn->Read( nUId ); pCmdIn->Read( nMethodId ); pCmdIn->Read( nParams ); if( nParams & PARAM_USHORT_1 ) pCmdIn->Read( nNr1 ); if( nParams & PARAM_USHORT_2 ) pCmdIn->Read( nNr2 ); if( nParams & PARAM_USHORT_3 ) pCmdIn->Read( nNr3 ); if( nParams & PARAM_USHORT_4 ) pCmdIn->Read( nNr4 ); if( nParams & PARAM_ULONG_1 ) pCmdIn->Read( nLNr1 ); if( nParams & PARAM_STR_1 ) pCmdIn->Read( aString1 ); if( nParams & PARAM_STR_2 ) pCmdIn->Read( aString2 ); if( nParams & PARAM_BOOL_1 ) pCmdIn->Read( bBool1 ); if( nParams & PARAM_BOOL_2 ) pCmdIn->Read( bBool2 ); #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Reading Control: UId: " ); m_pDbgWin->AddText( String::CreateFromInt64( nUId ) ); m_pDbgWin->AddText( " Methode: " ); m_pDbgWin->AddText( String::CreateFromInt32( nMethodId ) ); m_pDbgWin->AddText( " Params:" ); if( nParams & PARAM_USHORT_1 ) {m_pDbgWin->AddText( " n1:" );m_pDbgWin->AddText( String::CreateFromInt32( nNr1 ) );} if( nParams & PARAM_USHORT_2 ) {m_pDbgWin->AddText( " n2:" );m_pDbgWin->AddText( String::CreateFromInt32( nNr2 ) );} if( nParams & PARAM_USHORT_3 ) {m_pDbgWin->AddText( " n3:" );m_pDbgWin->AddText( String::CreateFromInt32( nNr3 ) );} if( nParams & PARAM_USHORT_4 ) {m_pDbgWin->AddText( " n4:" );m_pDbgWin->AddText( String::CreateFromInt32( nNr4 ) );} if( nParams & PARAM_ULONG_1 ) {m_pDbgWin->AddText( " nl1:" );m_pDbgWin->AddText( String::CreateFromInt64( nLNr1 ) );} if( nParams & PARAM_STR_1 ) {m_pDbgWin->AddText( " s1:" );m_pDbgWin->AddText( aString1 );} if( nParams & PARAM_STR_2 ) {m_pDbgWin->AddText( " s2:" );m_pDbgWin->AddText( aString2 );} /* if( nParams & PARAM_BOOL_1 ) pCmdIn->Read( bBool1 ); if( nParams & PARAM_BOOL_2 ) pCmdIn->Read( bBool2 );*/ m_pDbgWin->AddText( "\n" ); #endif } BOOL IsDialog(Window *pWin) { // Alles was von SystemWindow abgeleitet ist if ( !pWin ) return FALSE; switch (pWin->GetType()) { case WINDOW_FLOATINGWINDOW: case WINDOW_DOCKINGWINDOW: case WINDOW_MODELESSDIALOG: case WINDOW_MODALDIALOG: case WINDOW_WORKWINDOW: case WINDOW_TABDIALOG: case WINDOW_MESSBOX: case WINDOW_INFOBOX: case WINDOW_WARNINGBOX: case WINDOW_ERRORBOX: case WINDOW_QUERYBOX: case WINDOW_BUTTONDIALOG: case WINDOW_FILEDIALOG: case WINDOW_PRINTDIALOG: case WINDOW_PRINTERSETUPDIALOG: // ab hier nicht ansprechbar (da nicht implementiert) case WINDOW_SYSWINDOW: case WINDOW_DIALOG: case WINDOW_SYSTEMDIALOG: case WINDOW_COLORDIALOG: case WINDOW_FONTDIALOG: case WINDOW_PATHDIALOG: return TRUE; break; default: return FALSE; break; } } BOOL IsAccessable(Window *pWin) { if ( pWin == NULL ) return FALSE; return pWin->IsEnabled() && pWin->IsInputEnabled(); } // neue Hilfsfunktion static Window*ImpGetButton( Window *pBase, WinBits nMask, WinBits nWinBits ) { USHORT n = pBase->GetChildCount(); for( int i = 0 ; i < n; i++ ) { Window *pChild = pBase->GetChild(i); if( pChild->GetType() == WINDOW_OKBUTTON || pChild->GetType() == WINDOW_CANCELBUTTON || pChild->GetType() == WINDOW_HELPBUTTON || pChild->GetType() == WINDOW_PUSHBUTTON ) if( !nMask || ( pChild->GetStyle() & nMask ) == nWinBits ) return pChild; } return NULL; } BOOL StatementControl::ControlOK( Window *pControl, const sal_Char* cBezeichnung ) { if ( pControl && ( ( ( IsAccessable(pControl) || (nMethodId & M_WITH_RETURN) ) && pControl->IsVisible() ) || (nUId == UID_ACTIVE) ) ) return TRUE; else { UniString aBezeichnung( cBezeichnung, RTL_TEXTENCODING_ASCII_US ); if ( aBezeichnung.Len() > 0 ) { if (!pControl) ReportError( nUId, GEN_RES_STR1( S_WIN_NOT_FOUND, aBezeichnung ) ); else if ( !pControl->IsVisible() ) ReportError( nUId, GEN_RES_STR1( S_WIN_INVISIBLE, aBezeichnung ) ); else ReportError( nUId, GEN_RES_STR1( S_WIN_DISABLED, aBezeichnung ) ); } #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( aBezeichnung.AppendAscii(" NotFound or Disabled or Invisible") ); #endif return FALSE; } } BOOL StatementList::ValueOK(ULONG nId, String aBezeichnung, ULONG nValue, ULONG nMax) { if ( nMax < nValue ) { if ( aBezeichnung.Len() > 0 ) ReportError( nId, GEN_RES_STR3( S_NUMBER_TOO_BIG, aBezeichnung, UniString::CreateFromInt32( nValue ), UniString::CreateFromInt32( nMax ) ) ); return FALSE; } if ( nValue < 1 ) { if ( aBezeichnung.Len() > 0 ) ReportError( nId, GEN_RES_STR3c3( S_NUMBER_TOO_SMALL, aBezeichnung, UniString::CreateFromInt32( nValue ), "1" ) ); return FALSE; } return TRUE; } void StatementControl::AnimateMouse( Window *pControl, TTHotSpots aWohin ) { Point aZiel; switch (aWohin) { case MitteLinks: { long nHeight = pControl->GetSizePixel().Height(); aZiel.X() += 5; aZiel.Y() += nHeight / 2; } break; case Mitte: { Size aSize = pControl->GetOutputSizePixel(); aZiel.Move( aSize.Width() / 2, aSize.Height() / 2 ); } break; case MitteOben: { long nWidth = pControl->GetSizePixel().Width(); aZiel.X() += nWidth / 2; aZiel.Y() += 5; } break; } AnimateMouse( pControl, aZiel ); } void StatementControl::AnimateMouse( Window *pControl, Point aWohin ) { Point aAkt = pControl->GetPointerPosPixel(); Point aZiel = aWohin; long nSteps; Point aDiff = aAkt - aZiel; if ( Abs(aDiff.X()) < Abs(aDiff.Y()) ) nSteps = Abs(aDiff.Y()) / 5; else nSteps = Abs(aDiff.X()) / 5; if ( nSteps == 0 ) return; aDiff *= 1000; aDiff /= nSteps; StatementList::bExecuting = TRUE; // Bah ist das ein ekliger Hack // Das verhindert, daß schon der nächste Befehl ausgeführt wird. for ( ; nSteps ; nSteps-- ) { if ( Abs((aAkt - pControl->GetPointerPosPixel()).X()) > 5 || Abs((aAkt - pControl->GetPointerPosPixel()).Y()) > 5 ) nSteps = 1; aAkt = aZiel + aDiff * nSteps / 1000; pControl->SetPointerPosPixel(aAkt); SafeReschedule(); } pControl->SetPointerPosPixel(aZiel); StatementList::bExecuting = FALSE; // Bah ist das ein ekliger Hack } BOOL StatementControl::MaybeDoTypeKeysDelay( Window *pTestWindow ) { if ( bDoTypeKeysDelay ) { ULONG nTimeWait = nMinTypeKeysDelay; if ( nMaxTypeKeysDelay != nMinTypeKeysDelay ) nTimeWait += Time::GetSystemTicks() % ( nMaxTypeKeysDelay - nMinTypeKeysDelay ); Timer aTimer; aTimer.SetTimeout( nTimeWait ); aTimer.Start(); StatementList::bExecuting = TRUE; // Bah ist das ein ekliger Hack // Das verhindert, daß schon der nächste Befehl ausgeführt wird. while ( aTimer.IsActive() ) { SafeReschedule( TRUE ); } StatementList::bExecuting = FALSE; // Bah ist das ein ekliger Hack if ( !WinPtrValid(pTestWindow ) ) { ReportError( nUId, GEN_RES_STR1( S_WINDOW_DISAPPEARED, MethodString( nMethodId ) ) ); return FALSE; } } return TRUE; } BOOL StatementControl::HandleVisibleControls( Window *pControl ) { if( pControl ) // Also auch bei Disabled nicht jedoch bei Invisible { switch( nMethodId ) { case M_IsEnabled: pRet->GenReturn ( RET_Value, nUId, IsAccessable(pControl) ); break; case M_IsVisible: pRet->GenReturn ( RET_Value, nUId, pControl->IsVisible() ); break; case M_GetPosX: if ( pControl->GetType() == WINDOW_DOCKINGWINDOW && pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_FLOATINGWINDOW ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für FloatingWindows if ( pControl->GetType() == WINDOW_TABCONTROL && pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_TABDIALOG ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für TabDialoge if ( pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_BORDERWINDOW ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für Border if ( (nParams & PARAM_BOOL_1) && bBool1 ) pControl = pControl->GetWindow( WINDOW_OVERLAP ); if ( pControl->GetType() == WINDOW_DOCKINGWINDOW && pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_SPLITWINDOW ) { Point aPos = pControl->GetPosPixel(); aPos = pControl->GET_REAL_PARENT()->OutputToScreenPixel( aPos ); pRet->GenReturn ( RET_Value, nUId, (ULONG)aPos.X() ); } else pRet->GenReturn ( RET_Value, nUId, (ULONG)pControl->GetPosPixel().X() ); break; case M_GetPosY: if ( pControl->GetType() == WINDOW_DOCKINGWINDOW && pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_FLOATINGWINDOW ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für FloatingWindows if ( pControl->GetType() == WINDOW_TABCONTROL && pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_TABDIALOG ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für TabDialoge if ( pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_BORDERWINDOW ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für Border if ( (nParams & PARAM_BOOL_1) && bBool1 ) pControl = pControl->GetWindow( WINDOW_OVERLAP ); if ( pControl->GetType() == WINDOW_DOCKINGWINDOW && pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_SPLITWINDOW ) { Point aPos = pControl->GetPosPixel(); aPos = pControl->GET_REAL_PARENT()->OutputToScreenPixel( aPos ); pRet->GenReturn ( RET_Value, nUId, (ULONG)aPos.Y() ); } else pRet->GenReturn ( RET_Value, nUId, (ULONG)pControl->GetPosPixel().Y() ); break; case M_GetSizeX: if ( pControl->GetType() == WINDOW_DOCKINGWINDOW && pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_FLOATINGWINDOW ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für FloatingWindows if ( pControl->GetType() == WINDOW_TABCONTROL && pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_TABDIALOG ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für TabDialoge if ( pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_BORDERWINDOW ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für Border if ( (nParams & PARAM_BOOL_1) && bBool1 ) pControl = pControl->GetWindow( WINDOW_OVERLAP ); pRet->GenReturn ( RET_Value, nUId, (ULONG)pControl->GetSizePixel().Width() ); break; case M_GetSizeY: if ( pControl->GetType() == WINDOW_DOCKINGWINDOW && pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_FLOATINGWINDOW ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für FloatingWindows if ( pControl->GetType() == WINDOW_TABCONTROL && pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_TABDIALOG ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für TabDialoge if ( pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_BORDERWINDOW ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für Border if ( (nParams & PARAM_BOOL_1) && bBool1 ) pControl = pControl->GetWindow( WINDOW_OVERLAP ); pRet->GenReturn ( RET_Value, nUId, (ULONG)pControl->GetSizePixel().Height() ); break; case M_SnapShot: { if ( pControl->GetType() == WINDOW_DOCKINGWINDOW && pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_FLOATINGWINDOW ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für FloatingWindows if ( pControl->GetType() == WINDOW_TABCONTROL && pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_TABDIALOG ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für TabDialoge if ( pControl->GET_REAL_PARENT() && pControl->GET_REAL_PARENT()->GetType() == WINDOW_BORDERWINDOW ) pControl = pControl->GET_REAL_PARENT(); // Sonderbehandlung für Border if ( (nParams & PARAM_BOOL_1) && bBool1 ) pControl = pControl->GetWindow( WINDOW_OVERLAP ); Bitmap aBmp = pControl->SnapShot(); if ( pControl->GetType() == WINDOW_WORKWINDOW ) { Point aStart = pControl->GetPosPixel(); if ( !(nParams & PARAM_USHORT_4) ) { nParams |= PARAM_USHORT_1; nParams |= PARAM_USHORT_2; nParams |= PARAM_USHORT_3; nParams |= PARAM_USHORT_4; nNr1 = (USHORT)-aStart.X(); nNr2 = (USHORT)-aStart.Y(); nNr3 = pControl->GetSizePixel().Width() + 2*(USHORT)aStart.X(); nNr4 = pControl->GetSizePixel().Height() + 2*(USHORT)aStart.Y(); } nNr1 = std::max((USHORT)-aStart.X(),nNr1); nNr2 = std::max((USHORT)-aStart.Y(),nNr2); nNr3 = std::min((USHORT)(pControl->GetSizePixel().Width() + 2*(USHORT)aStart.X()),nNr3); nNr4 = std::min((USHORT)(pControl->GetSizePixel().Height() + 2*(USHORT)aStart.Y()),nNr4); } if( nParams & PARAM_USHORT_4 ) { // Zuschneiden Point aPt(-nNr1,-nNr2); Size aSz(nNr3,nNr4); VirtualDevice aVDev( *pControl ); aVDev.SetOutputSizePixel( aSz ); aVDev.DrawBitmap( aPt, aBmp ); aBmp = aVDev.GetBitmap( Point(), aSz ); } SvFileStream fOut; fOut.Open(aString1,STREAM_STD_WRITE); aBmp.Write(fOut); if ( fOut.GetError() ) ReportError( nUId, GEN_RES_STR1( S_ERROR_SAVING_IMAGE, UniString::CreateFromInt32( fOut.GetError() ) ) ); fOut.Close(); } break; case M_GetFixedTextCount: { pRet->GenReturn ( RET_Value, nUId, CountWinByRT( pControl, WINDOW_FIXEDTEXT, TRUE ) ); } break; case M_GetFixedText: { if( ( nParams & PARAM_USHORT_1 ) == 0 ) nNr1 = 1; FixedText* pFixedText = (FixedText*)GetWinByRT( pControl, WINDOW_FIXEDTEXT, TRUE, nNr1-1 ); if ( pFixedText ) pRet->GenReturn ( RET_Value, nUId, pFixedText->GetText() ); else ValueOK(nUId, MethodString( nMethodId ),nNr1,CountWinByRT( pControl, WINDOW_FIXEDTEXT, TRUE ) ); } break; default: return FALSE; } SendProfile( UIdString( nUId ).Append('.').Append( MethodString( nMethodId ) ) ); return TRUE; } return FALSE; } BOOL StatementControl::HandleCommonMethods( Window *pControl ) { switch( nMethodId ) // Diese können an jedem Window ausgeführt werden { case M_Exists: // Oben schon Behandelt. Unterdrückt hier nur Fehler case M_NotExists: case M_IsEnabled: case M_IsVisible: case M_SnapShot: break; case M_Caption : { pRet->GenReturn ( RET_Value, nUId, pControl->GetText()); } break; case M_GetRT: { pRet->GenReturn ( RET_Value, nUId, (ULONG)pControl->GetType() ); } break; case M_TypeKeys: { if( !(nParams & PARAM_USHORT_1) ) // Anzahl wiederholungen nNr1 = 1; if( !(nParams & PARAM_BOOL_1) ) // Follow Focus bBool1 = FALSE; // so bleibt das bisherige Verhalten if ( !bBool1 ) // Altes Verhalten pControl->GrabFocus(); else // If focus is not inside given control we grab it once. { Window *pFocus = GetpApp()->GetFocusWindow(); if ( !pFocus || !pControl->IsWindowOrChild( pFocus, TRUE ) ) pControl->GrabFocus(); } if ( pControl->GetType() == WINDOW_COMBOBOX ) { // Bei COMBOBOX an das Edit direkt liefern Window *pTemp = NULL; for ( int i = 0 ; i < pControl->GetChildCount() && !pTemp ; i++ ) if ( pControl->GetChild( i )->GetType() == WINDOW_EDIT ) pTemp = pControl->GetChild( i ); if ( pTemp ) pControl = pTemp; } Window *pDeliverHere = pControl; for (int j = 0; j < nNr1; j++) for (xub_StrLen i = 0; i < aString1.Len(); i++) { if ( bBool1 ) // Jedesmal das FocusWindow finden { Window *pFocus = GetpApp()->GetFocusWindow(); if ( pFocus && pControl->IsWindowOrChild( pFocus, TRUE ) ) pDeliverHere = pFocus; else // sonst fallback auf das Basisfenster pDeliverHere = pControl; } KeyEvent aEvent; if ( ((USHORT)aString1.GetChar(i)) <= 7 ) { USHORT nVal; switch (aString1.GetChar(i)) { case 1: nVal = aString1.GetChar(i+1) + (aString1.GetChar(i+2) << 8); i += 2; break; case 3: nVal = (aString1.GetChar(i+1) << 8); i++; break; case 5: nVal = aString1.GetChar(i+1); i++; break; case 7: nVal = 0; break; } // #105672# // find out the keycode USHORT nKeygroup = nVal & KEYGROUP_TYPE; USHORT nKeyCode = nVal & KEY_CODE; sal_Unicode aCh; switch (nKeygroup) { case KEYGROUP_NUM: aCh = nKeyCode - KEY_0 + '0'; break; case KEYGROUP_ALPHA: aCh = nKeyCode - KEY_A; if ( nVal & KEY_MOD1 ) {} else if ( nVal & KEY_SHIFT ) aCh += 'A'; else aCh += 'a'; break; case KEYGROUP_MISC: { // CR ESC TAB BACK ByteString aPrintableMisc("\x0d\x1b\x09\x08 **+-*/.,<>=",16); if ( nKeyCode-KEY_RETURN < aPrintableMisc.Len() && nKeyCode != KEY_INSERT && nKeyCode != KEY_DELETE ) aCh = aPrintableMisc.GetChar( nKeyCode-KEY_RETURN ); else aCh = 0; } break; case KEYGROUP_CURSOR: case KEYGROUP_FKEYS: default: aCh = 0; } aEvent = KeyEvent(aCh,KeyCode(nVal & 0xFFF,nVal & 0xF000)); } else { // CR ESC TAB BACK String aPrintableMisc = CUniString("\x0d\x1b\x09\x08 xx+-*/.,<>="); sal_Unicode aCh = aString1.GetChar(i); if ( aCh >= 'a' && aCh <= 'z' ) aEvent = KeyEvent(aCh, KeyCode(KEYGROUP_ALPHA + aCh-'a', 0)); else if ( aCh >= 'A' && aCh <= 'Z' ) aEvent = KeyEvent(aCh, KeyCode(KEYGROUP_ALPHA + aCh-'a', KEY_SHIFT)); else if ( aCh >= '0' && aCh <= '9' ) aEvent = KeyEvent(aCh, KeyCode(KEYGROUP_NUM + aCh-'0', 0)); else if ( aPrintableMisc.Search(aCh) != STRING_NOTFOUND ) aEvent = KeyEvent(aCh, KeyCode(KEYGROUP_MISC + (USHORT)aPrintableMisc.Search(aCh), 0)); else // Sollte eigentlich nicht auftreten aEvent = KeyEvent(aCh, KeyCode()); } ImplKeyInput( pDeliverHere, aEvent ); if ( !MaybeDoTypeKeysDelay( pControl ) ) break; else SafeReschedule();SafeReschedule();SafeReschedule(); } } break; #define CalcMouseButton\ USHORT nButton = MOUSE_LEFT;\ if ( (nParams & PARAM_USHORT_3) )\ {\ switch ( nNr3 )\ {\ case 1: nButton = MOUSE_LEFT; break;\ case 2: nButton = MOUSE_MIDDLE; break;\ case 3: nButton = MOUSE_RIGHT; break;\ }\ }\ case M_MouseDown: { CalcMouseButton; Size aS = pControl->GetOutputSizePixel(); Point aPos = Point(aS.Width() * nNr1 / 100,aS.Height() * nNr2 / 100); Window *pActualWin = pControl->FindWindow( aPos ); // AnimateMouse( pControl, aPos ); if ( pActualWin ) aPos = pActualWin->AbsoluteScreenToOutputPixel( pControl->OutputToAbsoluteScreenPixel ( aPos ) ); // aPos = pActualWin->ScreenToOutputPixel( pControl->OutputToScreenPixel ( aPos ) ); else pActualWin = pControl; AnimateMouse( pActualWin, aPos ); pActualWin->GrabFocus(); MouseEvent aMEvnt(aPos,1,MOUSE_SIMPLECLICK|MOUSE_SELECT,nButton); ImplMouseButtonDown( pActualWin, aMEvnt ); } break; case M_MouseUp: { CalcMouseButton; Size aS = pControl->GetOutputSizePixel(); Point aPos = Point(aS.Width() * nNr1 / 100,aS.Height() * nNr2 / 100); Window *pActualWin = pControl->FindWindow( aPos ); if ( pActualWin ) aPos = pActualWin->AbsoluteScreenToOutputPixel( pControl->OutputToAbsoluteScreenPixel ( aPos ) ); // aPos = pActualWin->ScreenToOutputPixel( pControl->OutputToScreenPixel ( aPos ) ); else pActualWin = pControl; AnimateMouse( pActualWin, aPos ); // pActualWin->GrabFocus(); MouseEvent aMEvt( aPos, 1, MOUSE_SIMPLECLICK|MOUSE_SELECT, nButton ); ImplMouseButtonUp( pActualWin, aMEvt ); } break; case M_MouseMove: { CalcMouseButton; Size aS = pControl->GetOutputSizePixel(); Point aPos = Point(aS.Width() * nNr1 / 100,aS.Height() * nNr2 / 100); Window *pActualWin = pControl->FindWindow( aPos ); if ( pActualWin ) { aPos = pActualWin->AbsoluteScreenToOutputPixel( pControl->OutputToAbsoluteScreenPixel ( aPos ) ); // aPos = pActualWin->ScreenToOutputPixel( pControl->OutputToScreenPixel ( aPos ) ); } else pActualWin = pControl; AnimateMouse( pActualWin, aPos ); // pActualWin->GrabFocus(); MouseEvent aMEvt( aPos, 0, MOUSE_SIMPLEMOVE|MOUSE_DRAGMOVE, nButton ); ImplMouseMove( pActualWin, aMEvt ); } break; case M_MouseDoubleClick: { CalcMouseButton; Size aS = pControl->GetOutputSizePixel(); Point aPos = Point(aS.Width() * nNr1 / 100,aS.Height() * nNr2 / 100); Window *pActualWin = pControl->FindWindow( aPos ); if ( pActualWin ) { aPos = pActualWin->AbsoluteScreenToOutputPixel( pControl->OutputToAbsoluteScreenPixel ( aPos ) ); // aPos = pActualWin->ScreenToOutputPixel( pControl->OutputToScreenPixel ( aPos ) ); } else pActualWin = pControl; AnimateMouse( pActualWin, aPos ); pActualWin->GrabFocus(); MouseEvent aMEvnt; aMEvnt = MouseEvent(aPos,1,MOUSE_SIMPLECLICK|MOUSE_SELECT,nButton); ImplMouseButtonDown( pActualWin, aMEvnt ); ImplMouseButtonUp ( pActualWin, aMEvnt ); aMEvnt = MouseEvent(aPos,2,MOUSE_SIMPLECLICK|MOUSE_SELECT,nButton); ImplMouseButtonDown( pActualWin, aMEvnt ); ImplMouseButtonUp ( pActualWin, aMEvnt ); } break; case M_DisplayPercent: { ModelessDialog *pDlg = new ModelessDialog(NULL); pDlg->SetOutputSizePixel(Size(100,30)); Edit *pMyEd = new Edit(pDlg,WB_CENTER | WB_BORDER ); pMyEd->SetSizePixel(Size(100,30)); pDlg->SetText(CUniString("Schließen")); pDlg->Show(); pMyEd->Show(); ULONG nTime = Time().GetTime(); while (pDlg->IsVisible()) { pDlg->ToTop(); for (int i = 1 ; i<10 ; i++) SafeReschedule(); Point Pos = pControl->GetPointerPosPixel(); Size Siz=pControl->GetOutputSizePixel(); if ( Time().GetTime() - nTime > 10 ) { nTime = Time().GetTime(); pMyEd->SetText(UniString::CreateFromInt32(Pos.X()*100/Siz.Width()).AppendAscii("%x").Append( UniString::CreateFromInt32(Pos.Y()*100/Siz.Height()) ).Append('%')); } } delete pMyEd; delete pDlg; } break; case M_OpenContextMenu: { nSubMenuId1 = 0; nSubMenuId2 = 0; pMenuWindow = NULL; Point aPos; BOOL bAtMousePos = ( nParams & PARAM_BOOL_1 ) && bBool1; if ( bAtMousePos ) { aPos = pControl->GetPointerPosPixel(); Window *pActualWin = pControl->FindWindow( aPos ); if ( pActualWin ) { aPos = pActualWin->AbsoluteScreenToOutputPixel( pControl->OutputToAbsoluteScreenPixel ( aPos ) ); // aPos = pActualWin->ScreenToOutputPixel( pControl->OutputToScreenPixel ( aPos ) ); pControl = pActualWin; } } CommandEvent aEvent( aPos, COMMAND_CONTEXTMENU, bAtMousePos ); ImplCommand( pControl, aEvent ); } break; case M_UseMenu: { nSubMenuId1 = 0; nSubMenuId2 = 0; pMenuWindow = NULL; while ( pControl && !( ( pControl->GetType() == WINDOW_SYSWINDOW || pControl->GetType() == WINDOW_WORKWINDOW ) && ControlOK( pControl, "" ) ) ) pControl = pControl->GET_REAL_PARENT(); if ( pControl && ((SystemWindow*)pControl)->GetMenuBar() ) pMenuWindow = ((SystemWindow*)pControl); else ReportError( GEN_RES_STR1( S_NO_MENU, MethodString( nMethodId ) ) ); } break; case M_FadeIn: case M_FadeOut: case M_Pin: case M_IsFadeIn: case M_IsPin: { WindowAlign aWindowAlign; if ( (nParams & PARAM_USHORT_1) ) { switch ( nNr1 ) { case CONST_ALIGN_LEFT: aWindowAlign = WINDOWALIGN_LEFT; break; case CONST_ALIGN_TOP: aWindowAlign = WINDOWALIGN_TOP; break; case CONST_ALIGN_RIGHT: aWindowAlign = WINDOWALIGN_RIGHT; break; case CONST_ALIGN_BOTTOM: aWindowAlign = WINDOWALIGN_BOTTOM; break; default: ReportError( nUId, GEN_RES_STR1( S_INVALID_POSITION, MethodString( nMethodId ) ) ); } } else aWindowAlign = WINDOWALIGN_LEFT; Window* pTemp = NULL; while ( !pTemp && pControl ) { pTemp = GetFadeSplitWin( pControl, aWindowAlign ); pControl = pControl->GET_REAL_PARENT(); } if ( !pTemp ) { ReportError( nUId, GEN_RES_STR1( S_SPLITWIN_NOT_FOUND, MethodString( nMethodId ) ) ); break; } pControl = pTemp; // So daß wir unten ohne Fehler durchkommen SplitWindow *pSW = (SplitWindow*) pTemp; // Rectangle GetAutoHideRect() const; // Rectangle GetFadeInRect() const; // Rectangle GetFadeOutRect() const; switch( nMethodId ) { case M_FadeIn: if ( pSW->IsFadeInButtonVisible() ) pSW->FadeIn(); break; case M_FadeOut: if ( pSW->IsFadeOutButtonVisible() ) pSW->FadeOut(); break; case M_Pin: if ( ( pSW->GetAutoHideState() && bBool1 ) || ( !pSW->GetAutoHideState() && !bBool1 ) ) { MouseEvent aMEvnt; Point aPt( pSW->GetAutoHideRect().Center() ); aMEvnt = MouseEvent( aPt,1,MOUSE_SIMPLECLICK,MOUSE_LEFT ); ImplMouseButtonDown( pControl, aMEvnt ); ImplMouseButtonUp ( pControl, aMEvnt ); } // pSW->AutoHide(); break; case M_IsFadeIn: pRet->GenReturn ( RET_Value, nUId, pSW->IsFadeOutButtonVisible() ); break; case M_IsPin: pRet->GenReturn ( RET_Value, nUId, (BOOL)!pSW->GetAutoHideState() ); break; default: ReportError( nUId, GEN_RES_STR1( S_INTERNAL_ERROR, MethodString( nMethodId ) ) ); } SendProfile( UIdString( nUId ).Append('.').Append( MethodString( nMethodId ) ) ); } break; case M_StatusGetText: case M_StatusIsProgress: case M_StatusGetItemCount: case M_StatusGetItemId: { StatusBar *pStatus = NULL; while ( !pStatus && pControl ) { pStatus = (StatusBar*)GetWinByRT( pControl, WINDOW_STATUSBAR, TRUE ); pControl = pControl->GET_REAL_PARENT(); } if ( !pStatus ) { ReportError( nUId, GEN_RES_STR1( S_NO_STATUSBAR, MethodString( nMethodId ) ) ); break; } switch ( nMethodId ) { case M_StatusGetText: { if ( (nParams & PARAM_USHORT_1) ) { if ( pStatus->AreItemsVisible() ) pRet->GenReturn ( RET_Value, nUId, String(pStatus->GetItemText(nNr1))); else ReportError( nUId, GEN_RES_STR1( S_ITEMS_INVISIBLE, MethodString( nMethodId ) ) ); } else { if ( pStatus->AreItemsVisible() ) { if ( pStatus->GetItemCount() == 1 ) { pRet->GenReturn ( RET_Value, nUId, pStatus->GetItemText( pStatus->GetItemId(0) )); } else { pRet->GenReturn ( RET_Value, nUId, String() ); } } else pRet->GenReturn ( RET_Value, nUId, (String)pStatus->GetText() ); } } break; case M_StatusIsProgress: { pRet->GenReturn ( RET_Value, nUId, (BOOL)pStatus->IsProgressMode() ); } break; case M_StatusGetItemCount: if ( pStatus->AreItemsVisible() ) pRet->GenReturn ( RET_Value, nUId, ULONG(pStatus->GetItemCount())); else pRet->GenReturn ( RET_Value, nUId, ULONG(0)); break; case M_StatusGetItemId: if ( ValueOK(nUId, MethodString( nMethodId ),nNr1,pStatus->GetItemCount()) ) pRet->GenReturn ( RET_Value, nUId, ULONG(pStatus->GetItemId(nNr1-1))); break; } } break; case M_HasScrollBar: case M_IsScrollBarEnabled: { if ( (nParams | PARAM_USHORT_1) != PARAM_USHORT_1 ) // so there are other params { ReportError( nUId, GEN_RES_STR0( S_INVALID_PARAMETERS ) ); break; } if( !(nParams & PARAM_USHORT_1) ) nNr1 = CONST_ALIGN_RIGHT; // default is right Scrollbar(vertical) if ( (nNr1 != CONST_ALIGN_RIGHT) && (nNr1 != CONST_ALIGN_BOTTOM) ) { ReportError( nUId, GEN_RES_STR1( S_INVALID_POSITION, MethodString( nMethodId ) ) ); break; } ScrollBar *pScroll = NULL; USHORT nSteps = 2; while ( !pScroll && pControl && nSteps-- ) { pScroll = GetScrollBar( pControl, nNr1, TRUE ); pControl = pControl->GET_REAL_PARENT(); } switch ( nMethodId ) { case M_HasScrollBar: { if ( pScroll ) pRet->GenReturn ( RET_Value, nUId, (BOOL)TRUE ); else pRet->GenReturn ( RET_Value, nUId, (BOOL)FALSE ); } break; case M_IsScrollBarEnabled: { if ( !pScroll ) { ReportError( nUId, GEN_RES_STR1( S_NO_SCROLLBAR, MethodString( nMethodId ) ) ); break; } pRet->GenReturn ( RET_Value, nUId, pScroll->IsEnabled() ); } break; } } break; default: return FALSE; } return TRUE; } BOOL StatementControl::Execute() { Window *pControl; BOOL bNormalWeiter = TRUE; if ( IsError ) { #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Skipping Window: " ); m_pDbgWin->AddText( String::CreateFromInt64( nUId ) ); m_pDbgWin->AddText( " Method: " ); m_pDbgWin->AddText( String::CreateFromInt32( nMethodId ) ); m_pDbgWin->AddText( "\n" ); #endif Advance(); delete this; return TRUE; } InitProfile(); #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Executing Window: " ); m_pDbgWin->AddText( String::CreateFromInt64( nUId ) ); m_pDbgWin->AddText( " Method: " ); m_pDbgWin->AddText( String::CreateFromInt32( nMethodId ) ); m_pDbgWin->AddText( "\n" ); #endif if (nUId == UID_ACTIVE) pControl = GetAnyActive(); else { BOOL bSearchButtonOnToolbox = (nParams == PARAM_NONE) && ((M_Click == nMethodId) || (M_TearOff == nMethodId) || (M_IsEnabled == nMethodId) || (M_OpenMenu == nMethodId)); if ( nMethodId == M_TypeKeys || nMethodId == M_MouseDown || nMethodId == M_MouseUp || nMethodId == M_MouseMove || nMethodId == M_SnapShot ) { pControl = NULL; if ( /*(nMethodId == M_SnapShot || nMethodId == M_TypeKeys) &&*/ !pControl ) pControl = SearchTree( nUId ,bSearchButtonOnToolbox ); } else pControl = SearchTree( nUId ,bSearchButtonOnToolbox ); } if ( pControl && pControl->GetType() == WINDOW_TOOLBOX && pControl->GetUniqueOrHelpId() != nUId ) { // Also wenn wir irgendwas auf einer Toolbox gefunden haben switch ( nMethodId ) { case M_Click: case M_TearOff: case M_OpenMenu: break; case M_IsEnabled: nMethodId = _M_IsEnabled; // Umlabeln, da die Behandlung essentiell anders ist! break; default: pControl = NULL; } } switch ( nMethodId ) { case M_Exists: case M_NotExists: Time aT; USHORT aSeconds = aT.GetMin()*60+aT.GetSec(); if ( !bBool2 ) // wurde im Konstruktor auf FALSE gesetzt { bBool2 = TRUE; nNr2 = aSeconds; if( !(nParams & PARAM_USHORT_1) ) nNr1 = 0; // defaultmäßig sofort zurück } if ( aSeconds < nNr2 ) // Falls die Stunde umgesprungen ist aSeconds += 60*60; if ( /* !IsAccessable(pControl)#87019# */ !pControl || !pControl->IsVisible() ) pControl = NULL; if ( ((nMethodId == M_Exists) && pControl) || ((nMethodId == M_NotExists) && !pControl) ) { // Wenn Bedingung erfüllt pRet->GenReturn ( RET_Value, nUId, (BOOL)TRUE ); } else if ( aSeconds <= nNr2 + nNr1 ) // Zeit ist noch nicht abgelaufen return FALSE; else pRet->GenReturn ( RET_Value, nUId, (BOOL)FALSE ); Advance(); delete this; return TRUE; break; } short nRT = 0; if( pControl ) // Das Fenster Existiert irgendwo, kann aber auch hidden sein! { nRT = ImpGetRType( pControl, nUId ); #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Type is: " ); m_pDbgWin->AddText( String::CreateFromInt32( nRT ) ); m_pDbgWin->AddText( "\n" ); #endif } if ( (!ControlOK( pControl, "" )) && ( nMethodId != M_SnapShot ) && (nRetryCount--)) { #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( CUniString("Reschedule command (").Append( UniString::CreateFromInt32(nRetryCount) ).AppendAscii(")\n") ); #endif return FALSE; } if( ControlOK( pControl, "" ) ) { if ( nMethodId == M_OpenContextMenu && !bBool2 ) { pControl->GrabFocus(); // to get asyncron focus on unix bBool2 = TRUE; return FALSE; } } Advance(); if ( HandleVisibleControls( pControl ) ) { delete this; return TRUE; } if( ControlOK( pControl, "Window/Control" ) ) { if ((( nRT < C_TabPage && nRT > C_TabControl ) // || nMethodId == M_TypeKeys // TypeKeys macht das selbst, falls eigenes Focushandling gewünscht // || nMethodId == M_MouseDown // || nMethodId == M_MouseUp // || nMethodId == M_MouseMove // || nMethodId == M_MouseDoubleClick || nMethodId == M_OpenContextMenu ) && nMethodId != M_TypeKeys // TypeKeys macht das selbst, falls eigenes Focushandling gewünscht && nMethodId != M_MouseDown && nMethodId != M_MouseUp && nMethodId != M_MouseMove /*&& nMethodId != M_MouseDoubleClick*/ ) pControl->GrabFocus(); if ( bDoTypeKeysDelay && nMethodId == M_SetText && ( nParams & PARAM_STR_1 ) ) { // Hier wird das Statement auf ein TypeKeys umgebogen nMethodId = M_TypeKeys; nParams = PARAM_BOOL_1 | PARAM_STR_1; bBool1 = TRUE; pControl->GrabFocus(); } if ( !HandleCommonMethods( pControl ) ) { switch( nRT ) { case C_TabControl: switch( nMethodId ) { case M_GetPageId: if ( (nParams & PARAM_USHORT_1) ) { if ( ValueOK(nUId, MethodString( nMethodId ),nNr1,((TabControl*)pControl)->GetPageCount() ) ) pRet->GenReturn ( RET_Value, nUId, (ULONG)((TabControl*)pControl)->GetPageId(nNr1-1)); } else pRet->GenReturn ( RET_Value, nUId, (ULONG)((TabControl*)pControl)->GetCurPageId()); break; case M_GetPageCount: pRet->GenReturn ( RET_Value, nUId, (ULONG)((TabControl*)pControl)->GetPageCount()); break; case M_SetPageId: if (((TabControl*)pControl)->GetCurPageId()) ((TabControl*)pControl)->DeactivatePage(); ((TabControl*)pControl)->SetCurPageId( nNr1 ); ((TabControl*)pControl)->ActivatePage(); break; case M_SetPageNr: if ( ValueOK(nUId, MethodString( nMethodId ),nNr1,((TabControl*)pControl)->GetPageCount() ) ) { if (((TabControl*)pControl)->GetCurPageId()) ((TabControl*)pControl)->DeactivatePage(); ((TabControl*)pControl)->SetCurPageId( ((TabControl*)pControl)->GetPageId( nNr1-1 ) ); ((TabControl*)pControl)->ActivatePage(); } break; case M_GetPage: pRet->GenReturn ( RET_Value, nUId, ((TabControl*)pControl)->GetTabPage(((TabControl*)pControl)->GetCurPageId())->GetUniqueOrHelpId()); break; case M_SetPage : { // Wegen lokaler Variablen TabControl *pTControl = ((TabControl*)pControl); USHORT nActive = pTControl->GetCurPageId(); USHORT i,anz; ULONG nID = 0; i = pTControl->GetPagePos( pTControl->GetCurPageId() ); for ( anz=0 ; anz < pTControl->GetPageCount() && nID != nLNr1 ; anz++ ) { pTControl->SelectTabPage( pTControl->GetPageId(i) ); /*if (pTControl->GetCurPageId()) pTControl->DeactivatePage(); pTControl->SetCurPageId( pTControl->GetPageId(i) ); pTControl->ActivatePage();*/ nID = pTControl->GetTabPage(pTControl->GetCurPageId())->GetUniqueOrHelpId(); i++; if ( i >= pTControl->GetPageCount() ) i = 0; if ( !MaybeDoTypeKeysDelay( pTControl ) || !MaybeDoTypeKeysDelay( pTControl ) || !MaybeDoTypeKeysDelay( pTControl ) ) // 3 Mal aufrufen break; } if ( nID != nLNr1 ) { pTControl->SelectTabPage( nActive ); /*if (pTControl->GetCurPageId()) pTControl->DeactivatePage(); pTControl->SetCurPageId( nActive ); pTControl->ActivatePage();*/ ReportError( nLNr1, GEN_RES_STR1( S_TABPAGE_NOT_FOUND, MethodString( nMethodId ) ) ); } } break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "TabControl" ) ); break; } break; case C_RadioButton: case C_ImageRadioButton: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, MitteLinks); break; case M_IsChecked : pRet->GenReturn ( RET_Value, nUId, ((RadioButton*)pControl)->IsChecked()); break; case M_Check : ((RadioButton*)pControl)->Check(); ((RadioButton*)pControl)->Click(); break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "RadioButton" ) ); break; } break; case C_CheckBox: case C_TriStateBox: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, MitteLinks); break; case M_IsChecked : pRet->GenReturn ( RET_Value, nUId, BOOL( ((TriStateBox*)pControl)->GetState() == STATE_CHECK) ); break; case M_IsTristate : pRet->GenReturn ( RET_Value, nUId, BOOL( ((TriStateBox*)pControl)->GetState() == STATE_DONTKNOW) ); break; case M_GetState : pRet->GenReturn ( RET_Value, nUId, ULONG(((TriStateBox*)pControl)->GetState())); break; case M_Check : ((TriStateBox*)pControl)->SetState( STATE_CHECK ); ((TriStateBox*)pControl)->Click(); break; case M_UnCheck : ((TriStateBox*)pControl)->SetState( STATE_NOCHECK ); ((TriStateBox*)pControl)->Click(); break; case M_TriState : if ( ((TriStateBox*)pControl)->IsTriStateEnabled() ) { ((TriStateBox*)pControl)->SetState( STATE_DONTKNOW ); ((TriStateBox*)pControl)->Click(); } else { ReportError( nUId, GEN_RES_STR0( S_TRISTATE_NOT_ALLOWED ) ); } break; case M_Click : { TriStateBox *pTB = ((TriStateBox*)pControl); if ( pTB->GetState() == STATE_NOCHECK ) pTB->SetState( STATE_CHECK ); else if ( pTB->GetState() == STATE_CHECK ) { if ( pTB->IsTriStateEnabled() ) pTB->SetState( STATE_DONTKNOW ); else pTB->SetState( STATE_NOCHECK ); } else pTB->SetState( STATE_NOCHECK ); pTB->Click(); } break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "TriStateBox" ) ); break; } break; case C_Edit: case C_MultiLineEdit: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, Mitte); break; case M_GetText : pRet->GenReturn ( RET_Value, nUId, ((Edit*)pControl)->GetText()); break; case M_IsWritable: pRet->GenReturn ( RET_Value, nUId, (BOOL) !((Edit*)pControl)->IsReadOnly() ); break; default: if ( ! ((Edit*)pControl)->IsReadOnly() ) { switch( nMethodId ) { case M_SetText : ((Edit*)pControl)->SetText( aString1 ); ((Edit*)pControl)->SetModifyFlag(); ((Edit*)pControl)->Modify(); if ( ((Edit*)pControl)->GetText().CompareTo(aString1) != COMPARE_EQUAL ) ReportError( nUId, GEN_RES_STR1( S_ERROR_IN_SET_TEXT, MethodString( nMethodId ) ) ); break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "(MultiLine)Edit" ) ); break; } } else ReportError( nUId, GEN_RES_STR1c( S_ATTEMPT_TO_WRITE_READONLY, "(MultiLine)Edit" ) ); } break; case C_MultiListBox: case C_ListBox: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, MitteOben); break; case M_GetSelCount : pRet->GenReturn ( RET_Value, nUId, ULONG(((ListBox*)pControl)->GetSelectEntryCount())); break; case M_GetSelIndex : if ( ! (nParams & PARAM_USHORT_1) ) { if ( ((ListBox*)pControl)->GetSelectEntryCount() == 0 ) { pRet->GenReturn ( RET_Value, nUId, ULONG(0)); break; } nNr1 = 1; } ValueOK(nUId, MethodString( nMethodId ),nNr1,((ListBox*)pControl)->GetSelectEntryCount()); pRet->GenReturn ( RET_Value, nUId, ULONG(((ListBox*)pControl)->GetSelectEntryPos(nNr1-1)) +1); break; case M_GetSelText : if ( ! (nParams & PARAM_USHORT_1) ) nNr1 = 1; pRet->GenReturn ( RET_Value, nUId, ((ListBox*)pControl)->GetSelectEntry(nNr1-1)); break; case M_GetItemCount : pRet->GenReturn ( RET_Value, nUId, ULONG(((ListBox*)pControl)->GetEntryCount())); break; case M_GetItemText : pRet->GenReturn ( RET_Value, nUId, ((ListBox*)pControl)->GetEntry(nNr1-1)); break; case M_Select: case M_MultiSelect: { BOOL bUnselectBeforeSelect = ( nMethodId == M_Select ); BOOL bFehler = FALSE; if ( ! (nParams & PARAM_BOOL_1) ) bBool1 = TRUE; if ( nMethodId == M_MultiSelect && nRT == C_ListBox ) { ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "ListBox" ) ); bFehler = TRUE; } if ( !bBool1 && nMethodId == M_Select ) { ReportError( nUId, GEN_RES_STR1( S_NO_SELECT_FALSE, MethodString( nMethodId ) ) ); bFehler = TRUE; } if ( !bFehler ) { if( nParams & PARAM_STR_1 ) { ListBox *pLB = ((ListBox*)pControl); USHORT nPos; if ( (nPos = pLB->GetEntryPos( aString1 )) == LISTBOX_ENTRY_NOTFOUND ) ReportError( nUId, GEN_RES_STR2( S_ENTRY_NOT_FOUND, MethodString( nMethodId ), aString1 ) ); else { if ( bUnselectBeforeSelect ) pLB->SetNoSelection(); pLB->SelectEntryPos( nPos, bBool1 ); if ( pLB->IsEntryPosSelected( nPos ) ? !bBool1 : bBool1 ) // XOR rein mit BOOL ReportError( nUId, GEN_RES_STR2( S_METHOD_FAILED, MethodString( nMethodId ), aString1 ) ); } } else { ListBox *pLB = ((ListBox*)pControl); pLB = static_cast(pControl); if ( ValueOK(nUId, MethodString( nMethodId ),nNr1,pLB->GetEntryCount()) ) { if ( bUnselectBeforeSelect ) pLB->SetNoSelection(); pLB->SelectEntryPos( nNr1-1, bBool1 ); if ( pLB->IsEntryPosSelected( nNr1-1 ) ? !bBool1 : bBool1 ) // XOR rein mit BOOL ReportError( nUId, GEN_RES_STR2( S_METHOD_FAILED, MethodString( nMethodId ), UniString::CreateFromInt32( nNr1 ) ) ); } } ((ListBox*)pControl)->Select(); } } break; case M_SetNoSelection : ((ListBox*)pControl)->SetNoSelection(); ((ListBox*)pControl)->Select(); break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "(Multi)ListBox" ) ); break; } break; case C_ComboBox: case C_PatternBox: case C_NumericBox: case C_MetricBox: case C_CurrencyBox: case C_DateBox: case C_TimeBox: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, MitteOben); break; case M_GetSelText : pRet->GenReturn ( RET_Value, nUId, ((ComboBox*)pControl)->GetText()); break; case M_GetSelIndex : { USHORT nPos = ((ComboBox*)pControl)->GetEntryPos(((ComboBox*)pControl)->GetText()); if ( nPos == COMBOBOX_ENTRY_NOTFOUND ) nPos = 0; else nPos++; pRet->GenReturn ( RET_Value, nUId, (ULONG) nPos); } break; case M_GetItemCount : pRet->GenReturn ( RET_Value, nUId, ULONG(((ComboBox*)pControl)->GetEntryCount())); break; case M_GetItemText : pRet->GenReturn ( RET_Value, nUId, ((ComboBox*)pControl)->GetEntry(nNr1-1)); break; case M_IsWritable: pRet->GenReturn ( RET_Value, nUId, (BOOL) !((ComboBox*)pControl)->IsReadOnly() ); break; case M_Select : if( nParams & PARAM_USHORT_1 ) { if ( !ValueOK(nUId, MethodString( nMethodId ),nNr1,((ComboBox*)pControl)->GetEntryCount()) ) break; aString1 = ((ComboBox*)pControl)->GetEntry(nNr1-1); } else { if ( ((ComboBox*)pControl)->GetEntryPos( aString1 ) == COMBOBOX_ENTRY_NOTFOUND ) { ReportError( nUId, GEN_RES_STR2( S_ENTRY_NOT_FOUND, MethodString( nMethodId ), aString1 ) ); break; } } ((ComboBox*)pControl)->SetText( aString1 ); ((ComboBox*)pControl)->SetModifyFlag(); ((ComboBox*)pControl)->Modify(); break; case M_SetText : if ( ! ((ComboBox*)pControl)->IsReadOnly() ) { if ( ! (nParams & PARAM_STR_1) ) aString1 = String(); ((ComboBox*)pControl)->SetText( aString1 ); ((ComboBox*)pControl)->SetModifyFlag(); ((ComboBox*)pControl)->Modify(); } else ReportError( nUId, GEN_RES_STR1c( S_ATTEMPT_TO_WRITE_READONLY, "ComboBox" ) ); break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "ComboBox" ) ); break; } break; case C_PushButton: case C_OkButton: case C_CancelButton: case C_ImageButton: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, Mitte); break; case M_Click : ((PushButton*)pControl)->Click(); break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "PushButton" ) ); break; } break; case C_MoreButton: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, Mitte); break; case M_IsOpen : pRet->GenReturn ( RET_Value, nUId, ((MoreButton*)pControl)->GetState()); break; case M_Click : ((MoreButton*)pControl)->Click(); break; case M_Open : ((MoreButton*)pControl)->SetState(TRUE); break; case M_Close : ((MoreButton*)pControl)->SetState(FALSE); break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "MoreButton" ) ); break; } break; case C_SpinField: case C_PatternField: case C_NumericField: case C_MetricField: case C_CurrencyField: case C_DateField: case C_TimeField: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, Mitte); break; case M_GetText : pRet->GenReturn ( RET_Value, nUId, ((SpinField*)pControl)->GetText()); break; case M_IsWritable: pRet->GenReturn ( RET_Value, nUId, (BOOL) !((SpinField*)pControl)->IsReadOnly() ); break; case M_SetText : if ( ! ((SpinField*)pControl)->IsReadOnly() ) { ((SpinField*)pControl)->SetText( aString1 ); ((SpinField*)pControl)->SetModifyFlag(); ((SpinField*)pControl)->Modify(); } else ReportError( nUId, GEN_RES_STR1c( S_ATTEMPT_TO_WRITE_READONLY, "SpinField" ) ); break; case M_More : { if ( !(nParams & PARAM_USHORT_1) ) nNr1 = 1; for (int i = 1; i<= nNr1; i++) { ((SpinField*)pControl)->Up(); ((SpinField*)pControl)->SetModifyFlag(); ((SpinField*)pControl)->Modify(); } } break; case M_Less : { if ( !(nParams & PARAM_USHORT_1) ) nNr1 = 1; for (int i = 1; i<= nNr1; i++) { ((SpinField*)pControl)->Down(); ((SpinField*)pControl)->SetModifyFlag(); ((SpinField*)pControl)->Modify(); } } break; case M_ToMin : ((SpinField*)pControl)->First(); ((SpinField*)pControl)->SetModifyFlag(); ((SpinField*)pControl)->Modify(); break; case M_ToMax : ((SpinField*)pControl)->Last(); ((SpinField*)pControl)->SetModifyFlag(); ((SpinField*)pControl)->Modify(); break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "SpinField" ) ); break; } break; case C_MenuButton: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, Mitte); break; case M_Click : { MouseEvent aMEvnt; Point aPt( pControl->GetSizePixel().Width() / 2, pControl->GetSizePixel().Height() / 2 ); aMEvnt = MouseEvent( aPt,1,MOUSE_SIMPLECLICK,MOUSE_LEFT ); ImplMouseButtonDown( pControl, aMEvnt ); ImplMouseButtonUp ( pControl, aMEvnt ); } break; case M_Open : case M_OpenMenu : { MouseEvent aMEvnt; Point aPt( pControl->GetSizePixel().Width() / 2, pControl->GetSizePixel().Height() / 2 ); aMEvnt = MouseEvent( aPt,1,MOUSE_SIMPLECLICK,MOUSE_LEFT ); ImplMouseButtonDown( pControl, aMEvnt ); ULONG nStart = Time::GetSystemTicks(); ULONG nDelay = pControl->GetSettings().GetMouseSettings().GetActionDelay(); while ( ( Time::GetSystemTicks() - nStart ) < nDelay + 100 ) SafeReschedule(); ImplMouseButtonUp ( pControl, aMEvnt ); nSubMenuId1 = 0; nSubMenuId2 = 0; pMenuWindow = NULL; } break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "MenuButton" ) ); break; } break; case C_ToolBox: { ToolBox *pTB = ((ToolBox*)pControl); if ( pTB->GetUniqueOrHelpId() != nUId ) // Also Button auf der ToolBox gefunden { if ( nParams == PARAM_NONE ) { // Wir fälschen einen Parameter nParams = PARAM_USHORT_1; nNr1 = nUId; } else ReportError( nUId, GEN_RES_STR1( S_INTERNAL_ERROR, MethodString( nMethodId ) ) ); } #define FIND_HELP\ {\ if( nParams == PARAM_USHORT_1 )\ nLNr1 = nNr1;\ for ( nNr1 = 0; nNr1 < pTB->GetItemCount() && nLNr1 != pTB->GetHelpId(pTB->GetItemId(nNr1)) ; nNr1++ ) {}\ bBool1 = nLNr1 == pTB->GetHelpId(pTB->GetItemId(nNr1));\ if ( !bBool1 )\ ReportError( nUId, GEN_RES_STR1( S_HELPID_ON_TOOLBOX_NOT_FOUND, MethodString( nMethodId ) ) );\ else\ {\ if ( !pTB->IsItemEnabled( pTB->GetItemId(nNr1) ) && nMethodId != _M_IsEnabled )\ {\ ReportError( nUId, GEN_RES_STR1( S_BUTTON_DISABLED_ON_TOOLBOX, MethodString( nMethodId ) ) );\ bBool1 = FALSE;\ }\ else if ( !pTB->IsItemVisible( pTB->GetItemId(nNr1) ) )\ {\ ReportError( nUId, GEN_RES_STR1( S_BUTTON_HIDDEN_ON_TOOLBOX, MethodString( nMethodId ) ) );\ bBool1 = FALSE;\ }\ else\ {\ if ( pTB->GetItemRect(pTB->GetItemId(nNr1)).IsEmpty() )\ {\ USHORT nLine = pTB->GetCurLine();\ do\ {\ pTB->ShowLine( FALSE );\ for ( int i = 1 ; i < 30 ; i++ )\ SafeReschedule();\ }\ while ( pTB->GetCurLine() != nLine && pTB->GetItemRect(pTB->GetItemId(nNr1)).IsEmpty() );\ pTB->Invalidate( pTB->GetScrollRect() );\ }\ if ( pTB->GetItemRect(pTB->GetItemId(nNr1)).IsEmpty() )\ {\ ReportError( nUId, GEN_RES_STR1( S_CANNOT_MAKE_BUTTON_VISIBLE_IN_TOOLBOX, MethodString( nMethodId ) ) );\ bBool1 = FALSE;\ }\ }\ }\ }\ switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, MitteLinks); break; case M_Click : { FIND_HELP; if ( bBool1 ) // FIND_HELP Erfolgreich { Rectangle aRect = pTB->GetItemRect(pTB->GetItemId(nNr1)); MouseEvent aMEvnt; aMEvnt = MouseEvent(aRect.Center(),1,MOUSE_SIMPLECLICK,MOUSE_LEFT); ImplMouseButtonDown( pTB, aMEvnt ); ImplMouseButtonUp ( pTB, aMEvnt ); } } break; case M_TearOff : { FIND_HELP; if ( bBool1 ) // FIND_HELP Erfolgreich { Rectangle aRect = pTB->GetItemRect(pTB->GetItemId(nNr1)); AnimateMouse( pControl, aRect.Center() ); MouseEvent aMEvnt(aRect.Center(),1,MOUSE_SIMPLECLICK,MOUSE_LEFT); ImplMouseButtonDown( pTB, aMEvnt ); Window *pWin = NULL; StatementList::bExecuting = TRUE; // Bah ist das ein ekliger Hack { // Das verhindert, daß schon der nächste Befehl ausgeführt wird. ULONG nStart = Time::GetSystemTicks(); ULONG nDelay = pControl->GetSettings().GetMouseSettings().GetActionDelay(); while ( !(pWin = GetPopupFloatingWin()) && ( Time::GetSystemTicks() - nStart ) < nDelay + 100 ) SafeReschedule(); } StatementList::bExecuting = FALSE; // Bah ist das ein ekliger Hack // Das Fenster ist offen. StatementList::bExecuting = TRUE; // Bah ist das ein ekliger Hack { // Das verhindert, daß schon der nächste Befehl ausgeführt wird. Time aDelay; while ( !pWin && !(pWin = GetPopupFloatingWin()) && ( Time() - aDelay ).GetSec() < 15 ) SafeReschedule(); } StatementList::bExecuting = FALSE; // Bah ist das ein ekliger Hack if ( pWin ) { MouseEvent aMEvnt(aRect.Center(),1,MOUSE_SIMPLECLICK,MOUSE_LEFT); ImplMouseButtonUp( pTB, aMEvnt ); ((FloatingWindow*)pWin)->EndPopupMode( FLOATWIN_POPUPMODEEND_TEAROFF ); } else { MouseEvent aMEvnt(Point(1,-10), 1, MOUSE_SIMPLECLICK,MOUSE_LEFT); ImplMouseButtonUp( pTB, aMEvnt ); ReportError( nUId, GEN_RES_STR1( S_TEAROFF_FAILED, MethodString( nMethodId ) ) ); } } } break; case M_OpenMenu : { FIND_HELP; if ( bBool1 ) // FIND_HELP Erfolgreich { Rectangle aRect = pTB->GetItemRect(pTB->GetItemId(nNr1)); AnimateMouse( pControl, aRect.Center() ); MouseEvent aMEvnt(aRect.Center(),1,MOUSE_SIMPLECLICK,MOUSE_LEFT); ImplMouseButtonDown( pTB, aMEvnt ); StatementList::bExecuting = TRUE; // Bah ist das ein ekliger Hack { // Das verhindert, daß schon der nächste Befehl ausgeführt wird. ULONG nStart = Time::GetSystemTicks(); ULONG nDelay = pControl->GetSettings().GetMouseSettings().GetActionDelay(); while ( ( Time::GetSystemTicks() - nStart ) < nDelay + 100 ) SafeReschedule(); } StatementList::bExecuting = FALSE; // Bah ist das ein ekliger Hack // Das Fenster ist offen. nSubMenuId1 = 0; nSubMenuId2 = 0; pMenuWindow = NULL; } } break; case _M_IsEnabled: { FIND_HELP; if ( bBool1 ) // FIND_HELP Erfolgreich { pRet->GenReturn ( RET_Value, nUId, pTB->IsItemEnabled( pTB->GetItemId(nNr1) ) ); } } break; case M_GetState : if ( !ValueOK(nUId, CUniString("GetState"),nNr1,pTB->GetItemCount()) ) break; switch (nNr2) { case 0: pRet->GenReturn ( RET_Value, nUId, (ULONG)pTB->GetHelpId(pTB->GetItemId(nNr1-1))); break; case 1: pRet->GenReturn ( RET_Value, nUId, (ULONG)pTB->GetItemType(nNr1-1)); break; case 2: pRet->GenReturn ( RET_Value, nUId, (ULONG)pTB->GetItemState(pTB->GetItemId(nNr1-1))); break; case 3: pRet->GenReturn ( RET_Value, nUId, (ULONG)pTB->GetItemId(nNr1-1)); break; default: pRet->GenReturn ( RET_Value, nUId, ULONG(0)); break; } break; case M_GetItemText : if ( ValueOK(nUId, CUniString("GetItemText"),nNr1,pTB->GetItemCount()) ) pRet->GenReturn ( RET_Value, nUId, (String)pTB->GetItemText(nNr1-1)); break; case M_GetText : pRet->GenReturn ( RET_Value, nUId, (String)pTB->GetText()); break; case M_GetItemCount : pRet->GenReturn ( RET_Value, nUId, (ULONG)pTB->GetItemCount()); break; case M_SetNextToolBox : if ( (nParams & PARAM_STR_1) ) pTB->SetNextToolBox( aString1 ); else pTB->SetNextToolBox( pTB->GetNextToolBox() ); pTB->NextToolBox(); break; case M_GetNextToolBox : pRet->GenReturn ( RET_Value, nUId, (String)pTB->GetNextToolBox()); break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "ToolBox" ) ); break; } } break; case C_ValueSet: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, Mitte); break; case M_Select : ((ValueSet*)pControl)->SelectItem( nNr1 ); break; case M_SetNoSelection : ((ValueSet*)pControl)->SetNoSelection(); break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "ValueSet" ) ); break; } break; case C_TreeListBox: switch( nMethodId ) { #define COUNT_LBOX( First, Next, Anzahl) \ SvLBoxEntry *pThisEntry = ((SvTreeListBox*)pControl)->First(); \ { \ int niTemp = Anzahl; \ while ( Anzahl-- ) \ { \ pThisEntry = ((SvTreeListBox*)pControl)->Next( pThisEntry ); \ } \ } #define FIND_LBOX( First, Next, Cond) \ SvLBoxEntry *pFindEntry = (SvLBoxEntry*)((SvTreeListBox*)pControl)->First(); \ { \ while ( pFindEntry && !(Cond) ) \ { \ pFindEntry = (SvLBoxEntry*)((SvTreeListBox*)pControl)->Next( pFindEntry ); \ } \ } #define GetFirstValidTextItem( pThisEntry, nNr )\ SvLBoxString* pItem = NULL;\ USHORT nValidTextItemCount = 0;\ {\ USHORT nIndex = 0;\ SvLBoxItem *pMyItem;\ while ( ( nValidTextItemCount < nNr ) && nIndex < pThisEntry->ItemCount() )\ {\ pMyItem = pThisEntry->GetItem( nIndex );\ if ( pMyItem->IsA() == SV_ITEM_ID_LBOXSTRING )\ if ( ((SvLBoxString*)pMyItem)->GetText().Len() )\ {\ pItem = (SvLBoxString*)pMyItem;\ nValidTextItemCount++;\ }\ nIndex++;\ }\ } case M_GetText : { SvTreeListBox *pTree = (SvTreeListBox*)pControl; SvLBoxEntry *pThisEntry = pTree->GetCurEntry(); if ( ! (nParams & PARAM_USHORT_1) ) nNr1 = 1; if ( pThisEntry ) { GetFirstValidTextItem( pThisEntry, nNr1 ); if ( ValueOK( nUId, CUniString("GetText"), nNr1, nValidTextItemCount ) ) pRet->GenReturn ( RET_Value, nUId, pItem->GetText() ); } else ReportError( nUId, GEN_RES_STR2c2( S_NO_SELECTED_ENTRY, MethodString( nMethodId ), "TreeListBox" ) ); } break; case M_GetSelCount : pRet->GenReturn ( RET_Value, nUId, ULONG(((SvLBox*)pControl)->GetSelectionCount())); break; case M_GetSelIndex : if ( ! (nParams & PARAM_USHORT_1) ) nNr1 = 1; if ( ValueOK(nUId, CUniString("GetSelIndex"),nNr1,((SvLBox*)pControl)->GetSelectionCount()) ) { nNr1--; COUNT_LBOX( FirstSelected, NextSelected, nNr1); pRet->GenReturn ( RET_Value, nUId, ULONG( ((SvTreeListBox*)pControl)->GetVisiblePos( pThisEntry )) +1 ); } break; case M_GetSelText : if ( ! (nParams & PARAM_USHORT_1) ) nNr1 = 1; if ( ! (nParams & PARAM_USHORT_2) ) nNr2 = 1; if ( ValueOK(nUId, CUniString("GetSelText"),nNr1,((SvLBox*)pControl)->GetSelectionCount()) ) { nNr1--; COUNT_LBOX( FirstSelected, NextSelected, nNr1); GetFirstValidTextItem( pThisEntry, nNr2 ); if ( ValueOK( nUId, CUniString("GetSelText"), nNr2, nValidTextItemCount ) ) pRet->GenReturn ( RET_Value, nUId, pItem->GetText() ); } break; case M_GetItemCount : pRet->GenReturn ( RET_Value, nUId, ULONG(((SvLBox*)pControl)->GetVisibleCount()) ); break; case M_GetItemText : if ( ValueOK(nUId, MethodString( nMethodId ),nNr1,((SvLBox*)pControl)->GetVisibleCount()) ) { SvLBoxEntry *pEntry = (SvLBoxEntry*)((SvTreeListBox*)pControl)->GetEntryAtVisPos( nNr1-1 ); if ( ! (nParams & PARAM_USHORT_2) ) nNr2 = 1; GetFirstValidTextItem( pEntry, nNr2 ); if ( ValueOK( nUId, CUniString("GetItemText"), nNr2, nValidTextItemCount ) ) pRet->GenReturn ( RET_Value, nUId, pItem->GetText() ); } break; case M_Select : if ( ! (nParams & PARAM_BOOL_1) ) bBool1 = TRUE; if( nParams & PARAM_STR_1 ) { /* ListBox *pLB = ((ListBox*)pControl); if ( pLB->GetEntryPos( aString1 ) == LISTBOX_ENTRY_NOTFOUND ) ReportError( nUId, GEN_RES_STR2( S_ENTRY_NOT_FOUND, MethodString( nMethodId ), aString1 ) ); else { pLB->SelectEntry( aString1, bBool1 ); if ( pLB->IsEntrySelected( aString1 ) ? !bBool1 : bBool1 ) // XOR rein mit BOOL ReportError( nUId, GEN_RES_STR2( S_METHOD_FAILED, MethodString( nMethodId ), aString1 ) ); } */ ReportError( nUId, GEN_RES_STR1( S_SELECT_DESELECT_VIA_STRING_NOT_IMPLEMENTED, MethodString( nMethodId ) ) ); } else { if ( ValueOK(nUId, MethodString( nMethodId ),nNr1,((SvLBox*)pControl)->GetVisibleCount()) ) { SvLBoxEntry *pEntry = (SvLBoxEntry*)((SvTreeListBox*)pControl)->GetEntryAtVisPos( nNr1-1 ); ((SvTreeListBox*)pControl)->Select ( pEntry, bBool1 ); } } break; case M_IsChecked : case M_IsTristate : case M_GetState : case M_Check : case M_UnCheck : case M_TriState : { SvTreeListBox *pTree = (SvTreeListBox*)pControl; SvLBoxEntry *pThisEntry = pTree->GetCurEntry(); if ( !pThisEntry ) ReportError( nUId, GEN_RES_STR2c2( S_NO_SELECTED_ENTRY, MethodString( nMethodId ), "TreeListBox" ) ); else { SvLBoxButton* pItem = (SvLBoxButton*)(pThisEntry->GetFirstItem(SV_ITEM_ID_LBOXBUTTON)); if(!pItem) ReportError( nUId, GEN_RES_STR1( S_NO_LIST_BOX_BUTTON, MethodString( nMethodId ) ) ); else switch( nMethodId ) { case M_IsChecked : pRet->GenReturn ( RET_Value, nUId, BOOL( pItem->IsStateChecked() ) ); break; case M_IsTristate : pRet->GenReturn ( RET_Value, nUId, BOOL( pItem->IsStateTristate() ) ); break; case M_GetState : pRet->GenReturn ( RET_Value, nUId, ULONG( pItem->GetButtonFlags() & ~SV_STATE_MASK )); break; case M_Check : pTree->SetCheckButtonState( pThisEntry, SV_BUTTON_CHECKED ); pTree->CheckButtonHdl(); break; case M_UnCheck : pTree->SetCheckButtonState( pThisEntry, SV_BUTTON_UNCHECKED ); pTree->CheckButtonHdl(); break; case M_TriState : pTree->SetCheckButtonState( pThisEntry, SV_BUTTON_TRISTATE ); pTree->CheckButtonHdl(); break; default: ReportError( nUId, GEN_RES_STR1( S_INTERNAL_ERROR, MethodString( nMethodId ) ) ); break; } } } break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "TreeListBox" ) ); break; } break; case C_Control: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, MitteOben); break; default: switch( nControlType ) { case CONST_CTBrowseBox: switch( nMethodId ) { /* BOOL MakeFieldVisible( long nRow, USHORT nColId, BOOL bComplete = FALSE ); // access to dynamic values of cursor row String GetColumnTitle( USHORT nColumnId ) const; USHORT GetColumnId( USHORT nPos ) const; USHORT GetColumnPos( USHORT nColumnId ) const; // access and movement of cursor long GetCurRow() const { return nCurRow; } USHORT GetCurColumnId() const { return nCurColId; } BOOL GoToRow( long nRow ); BOOL GoToRowAndDoNotModifySelection( long nRow ); BOOL GoToColumnId( USHORT nColId ); BOOL GoToRowColumnId( long nRow, USHORT nColId ); // selections void SetNoSelection(); void SelectAll(); void SelectRow( long nRow, BOOL bSelect = TRUE, BOOL bExpand = TRUE ); void SelectColumnPos( USHORT nCol, BOOL bSelect = TRUE ) { SelectColumnPos( nCol, bSelect, TRUE); } void SelectColumnId( USHORT nColId, BOOL bSelect = TRUE ) { SelectColumnPos( GetColumnPos(nColId), bSelect, TRUE); } long GetSelectRowCount() const; USHORT GetSelectColumnCount() const; BOOL IsRowSelected( long nRow ) const; BOOL IsColumnSelected( USHORT nColumnId ) const; long FirstSelectedRow( BOOL bInverse = FALSE ); long LastSelectedRow( BOOL bInverse = FALSE ); long PrevSelectedRow(); long NextSelectedRow(); const MultiSelection* GetSelection() const { return bMultiSelection ? uRow.pSel : 0; } void SetSelection( const MultiSelection &rSelection ); EditBrowseBox sal_Bool IsEditing() const {return aController.Is();} void InvalidateStatusCell(long nRow) {RowModified(nRow, 0);} void InvalidateHandleColumn(); CellControllerRef Controller() const { return aController; } sal_Int32 GetBrowserFlags() const { return m_nBrowserFlags; } virtual void ActivateCell(long nRow, sal_uInt16 nCol, sal_Bool bSetCellFocus = sal_True); virtual void DeactivateCell(sal_Bool bUpdate = sal_True); #define COUNT_LBOX( First, Next, Anzahl) \ SvLBoxEntry *pThisEntry = ((SvTreeListBox*)pControl)->First(); \ { \ int niTemp = Anzahl; \ while ( Anzahl-- ) \ { \ pThisEntry = ((SvTreeListBox*)pControl)->Next( pThisEntry ); \ } \ } #define FIND_LBOX( First, Next, Cond) \ SvLBoxEntry *pFindEntry = (SvLBoxEntry*)((SvTreeListBox*)pControl)->First(); \ { \ while ( pFindEntry && !(Cond) ) \ { \ pFindEntry = (SvLBoxEntry*)((SvTreeListBox*)pControl)->Next( pFindEntry ); \ } \ } #define GetFirstValidTextItem( pThisEntry )\ SvLBoxString* pItem = NULL;\ {\ USHORT nIndex = 0;\ SvLBoxItem *pMyItem;\ while ( nIndex < pThisEntry->ItemCount() )\ {\ pMyItem = pThisEntry->GetItem( nIndex );\ if ( pMyItem->IsA() == SV_ITEM_ID_LBOXSTRING )\ if ( ((SvLBoxString*)pMyItem)->GetText().Len() )\ pItem = (SvLBoxString*)pMyItem;\ nIndex++;\ }\ } */ case M_GetSelText : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) { CellControllerRef aControler; aControler = ((EditBrowseBox*)pControl)->Controller(); if ( aControler.Is() ) { Window& aWin = aControler->GetWindow(); pRet->GenReturn ( RET_Value, nUId, aControler->GetWindow().GetText() ); } else ReportError( nUId, GEN_RES_STR2c2( S_NO_SELECTED_ENTRY, MethodString( nMethodId ), "BrowseBox" ) ); } break;/* case M_GetSelCount : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) pRet->GenReturn ( RET_Value, nUId, ULONG(((SvLBox*)pControl)->GetSelectionCount())); break; case M_GetSelIndex : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) if ( ! (nParams & PARAM_USHORT_1) ) nNr1 = 1; if ( ValueOK(nUId, CUniString("GetSelIndex"),nNr1,((SvLBox*)pControl)->GetSelectionCount()) ) { nNr1--; COUNT_LBOX( FirstSelected, NextSelected, nNr1); pRet->GenReturn ( RET_Value, nUId, ULONG( ((SvTreeListBox*)pControl)->GetVisiblePos( pThisEntry )) +1 ); } break; case M_GetSelText : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) if ( ! (nParams & PARAM_USHORT_1) ) nNr1 = 1; if ( ValueOK(nUId, CUniString("GetSelText"),nNr1,((SvLBox*)pControl)->GetSelectionCount()) ) { nNr1--; COUNT_LBOX( FirstSelected, NextSelected, nNr1); GetFirstValidTextItem( pThisEntry ); pRet->GenReturn ( RET_Value, nUId, pItem->GetText() ); } break; case M_GetItemCount : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) pRet->GenReturn ( RET_Value, nUId, ULONG(((SvLBox*)pControl)->GetVisibleCount()) ); break; case M_GetItemText : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) if ( ValueOK(nUId, MethodString( nMethodId ),nNr1,((SvLBox*)pControl)->GetVisibleCount()) ) { SvLBoxEntry *pEntry = (SvLBoxEntry*)((SvTreeListBox*)pControl)->GetEntryAtVisPos( nNr1-1 ); GetFirstValidTextItem( pEntry ); pRet->GenReturn ( RET_Value, nUId, pItem->GetText() ); } break; case M_Select : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) if ( ! (nParams & PARAM_BOOL_1) ) bBool1 = TRUE; if( nParams & PARAM_STR_1 ) { /* ListBox *pLB = ((ListBox*)pControl); if ( pLB->GetEntryPos( aString1 ) == LISTBOX_ENTRY_NOTFOUND ) ReportError( nUId, GEN_RES_STR2( S_ENTRY_NOT_FOUND, MethodString( nMethodId ), aString1 ) ); else { pLB->SelectEntry( aString1, bBool1 ); if ( pLB->IsEntrySelected( aString1 ) ? !bBool1 : bBool1 ) // XOR rein mit BOOL ReportError( nUId, GEN_RES_STR2( S_METHOD_FAILED, MethodString( nMethodId ), aString1 ) ); } * / ReportError( nUId, GEN_RES_STR1( S_SELECT_DESELECT_VIA_STRING_NOT_IMPLEMENTED, MethodString( nMethodId ) ) ); } else { if ( ValueOK(nUId, MethodString( nMethodId ),nNr1,((SvLBox*)pControl)->GetVisibleCount()) ) { SvLBoxEntry *pEntry = (SvLBoxEntry*)((SvTreeListBox*)pControl)->GetEntryAtVisPos( nNr1-1 ); ((SvTreeListBox*)pControl)->Select ( pEntry, bBool1 ); } } break; case M_IsChecked : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) case M_IsTristate : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) case M_GetState : case M_Check : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) case M_UnCheck : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) case M_TriState : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) { SvTreeListBox *pTree = (SvTreeListBox*)pControl; SvLBoxEntry *pThisEntry = pTree->GetCurEntry(); if ( !pThisEntry ) ReportError( nUId, GEN_RES_STR2c2( S_NO_SELECTED_ENTRY, MethodString( nMethodId ), "BrowseBox" ) ); else { SvLBoxButton* pItem = (SvLBoxButton*)(pThisEntry->GetFirstItem(SV_ITEM_ID_LBOXBUTTON)); if(!pItem) ReportError( nUId, GEN_RES_STR1( S_NO_LIST_BOX_BUTTON, MethodString( nMethodId ) ) ); else switch( nMethodId ) { case M_IsChecked : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) pRet->GenReturn ( RET_Value, nUId, BOOL( pItem->IsStateChecked() ) ); break; case M_IsTristate : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) pRet->GenReturn ( RET_Value, nUId, BOOL( pItem->IsStateTristate() ) ); break; case M_GetState : pRet->GenReturn ( RET_Value, nUId, ULONG( pItem->GetButtonFlags() & ~SV_STATE_MASK )); break; case M_Check : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) pItem->SetStateChecked(); pTree->InvalidateEntry( pThisEntry ); break; case M_UnCheck : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) pItem->SetStateUnchecked(); pTree->InvalidateEntry( pThisEntry ); break; case M_TriState : // EditBrowseBox wird angenommen! (Das kann ja nur schief gehen) pItem->SetStateTristate(); pTree->InvalidateEntry( pThisEntry ); break; default: ReportError( nUId, GEN_RES_STR1( S_INTERNAL_ERROR, MethodString( nMethodId ) ) ); break; } } } break;*/ default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "EditBrowseBox" ) ); break; } break; case CONST_CTProgressBar: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "Control" ) ); break; default: ReportError( nUId, GEN_RES_STR1( S_INTERNAL_ERROR, MethodString( nMethodId ) ) ); break; } } break; case C_Window: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, MitteOben); break; default: switch( nControlType ) { case CONST_CTProgressBar: switch ( nMethodId ) { // Erstmal nichts, da sowiso nur Prozente abgefragt werden k"onnten default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "ProgressBar" ) ); break; } break; case CONST_CTTreeListBox: case CONST_CTBrowseBox: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "Window" ) ); break; default: ReportError( nUId, GEN_RES_STR1( S_INTERNAL_ERROR, MethodString( nMethodId ) ) ); break; } ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "Window" ) ); break; } break; case C_DockingWin: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, MitteOben); break; case M_Dock : if ( ((DockingWindow*)pControl)->IsFloatingMode() ) ((DockingWindow*)pControl)->SetFloatingMode(FALSE); else ReportError( nUId, GEN_RES_STR1( S_ALLOWED_ONLY_IN_FLOATING_MODE, MethodString( nMethodId ) ) ); break; case M_Undock : if ( !((DockingWindow*)pControl)->IsFloatingMode() ) ((DockingWindow*)pControl)->SetFloatingMode(TRUE); else ReportError( nUId, GEN_RES_STR1( S_ALLOWED_ONLY_IN_FLOATING_MODE, MethodString( nMethodId ) ) ); break; case M_IsDocked : pRet->GenReturn ( RET_Value, nUId, (BOOL) !((DockingWindow*)pControl)->IsFloatingMode()); break; case M_Close: //nWindowWaitUId = nUId; DBG_ASSERT( nUId == pControl->GetUniqueOrHelpId(), "nUID != UniqueOrHelpId"); SET_WINP_CLOSING(pControl); ((DockingWindow*)pControl)->Close(); break; case M_Size: case M_Move: case M_IsMax : case M_Minimize : case M_Maximize : if ( ((DockingWindow*)pControl)->IsFloatingMode() ) { pControl = ((DockingWindow*)pControl)->GetFloatingWindow(); goto FloatWin; } else ReportError( nUId, GEN_RES_STR1( S_ALLOWED_ONLY_IN_DOCKING_MODE, MethodString( nMethodId ) ) ); break; case M_Help: // Alles was unten weiterbehandelt werden soll goto MoreDialog; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "DockingWindow" ) ); break; } break; case C_FloatWin: FloatWin: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, MitteOben); break; case M_IsMax : pRet->GenReturn ( RET_Value, nUId, (BOOL)!((FloatingWindow*)pControl)->IsRollUp()); break; case M_Minimize : ((FloatingWindow*)pControl)->RollUp(); break; case M_Maximize : ((FloatingWindow*)pControl)->RollDown(); break; case M_Size: { if ( pControl->GetStyle() & WB_SIZEABLE ) { pControl->SetSizePixel(Size(nNr1,nNr2)); pControl->Resize(); } else ReportError( nUId, GEN_RES_STR1( S_SIZE_NOT_CHANGEABLE, MethodString( nMethodId ) ) ); break; } case M_Close: DBG_ASSERT( nUId == pControl->GetUniqueOrHelpId(), "nUID != UniqueOrHelpId"); SET_WINP_CLOSING(pControl); ((FloatingWindow*)pControl)->Close(); break; case M_Help: // Alles was unten weiterbehandelt werden soll case M_Move: goto MoreDialog; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "FloatingWin" ) ); break; } break; case C_ModelessDlg: case C_Dlg: case C_TabDlg: MoreDialog: switch( nMethodId ) { // (Rect GetRect) case M_AnimateMouse : AnimateMouse( pControl, MitteOben); break; case M_Close: DBG_ASSERT( nUId == pControl->GetUniqueOrHelpId(), "nUID != UniqueOrHelpId"); SET_WINP_CLOSING(pControl); ((SystemWindow*)pControl)->Close(); break; case M_OK: { USHORT ntRT = pControl->GetType(); Window *pChild = GetWinByRT( pControl, WINDOW_OKBUTTON ); if( ControlOK( pChild, "OK Button" ) ) { DBG_ASSERT( nUId == pControl->GetUniqueOrHelpId(), "nUID != UniqueOrHelpId"); SET_WINP_CLOSING(pControl); ((Button*)pChild)->Click(); } break; } case M_Cancel: { // Window *pChild = ImpGetChild( pControl, WINDOW_CANCELBUTTON ); Window *pChild = GetWinByRT( pControl, WINDOW_CANCELBUTTON ); if( ControlOK( pChild, "Cancel Button" ) ) { DBG_ASSERT( nUId == pControl->GetUniqueOrHelpId(), "nUID != UniqueOrHelpId"); SET_WINP_CLOSING(pControl); ((Button*)pChild)->Click(); } break; } case M_Help: { Window *pChild = GetWinByRT( pControl, WINDOW_HELPBUTTON ); if( ControlOK( pChild, "Help Button" ) ) ((Button*)pChild)->Click(); break; } case M_Default: { Window *pChild = ImpGetButton( pControl, WB_DEFBUTTON, WB_DEFBUTTON ); if( ControlOK( pChild, "Default Button" ) ) ((Button*)pChild)->Click(); break; } case M_Move: { pControl->SetPosPixel(Point(nNr1,nNr2)); break; } default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "Dialog" ) ); break; } break; case C_WorkWin: switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, MitteOben); break; case M_Close: DBG_ASSERT( nUId == pControl->GetUniqueOrHelpId(), "nUID != UniqueOrHelpId"); SET_WINP_CLOSING(pControl); ((WorkWindow*)pControl)->Close(); break; case M_Size: case M_Move: goto FloatWin; break; case M_Help: // Alles was unten weiterbehandelt werden soll goto MoreDialog; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "WorkWindow" ) ); break; } break; case C_TabPage: switch( nMethodId ) { } break; case C_MessBox: case C_InfoBox: case C_WarningBox: case C_ErrorBox: case C_QueryBox: { BOOL bDone = TRUE; MessBox* pMB = (MessBox*)pControl; switch( nMethodId ) { case M_GetCheckBoxText: pRet->GenReturn ( RET_Value, nUId, pMB->GetCheckBoxText() ); break; case M_IsChecked : pRet->GenReturn ( RET_Value, nUId, BOOL( pMB->GetCheckBoxState() == STATE_CHECK) ); break; case M_Check : pMB->SetCheckBoxState( TRUE ); break; case M_UnCheck : pMB->SetCheckBoxState( FALSE ); break; case M_GetText : pRet->GenReturn ( RET_Value, nUId, pMB->GetMessText()); break; default: bDone = FALSE; break; } if ( bDone ) break; // break the case here else continue at C_ButtonDialog } case C_ButtonDialog: { ButtonDialog* pBD = (ButtonDialog*)pControl; #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "Working MessBox: " ); if (pControl->IsVisible()) m_pDbgWin->AddText("*(Visible)\n"); else m_pDbgWin->AddText("*(nicht Visible)\n"); #endif switch( nMethodId ) { case M_AnimateMouse : AnimateMouse( pControl, Mitte); break; case M_OK: #if ( BUTTONID_OK != RET_OK ) #error BUTTONID_OK != RET_OK #endif if ( pBD->GetPushButton( BUTTONID_OK ) ) { SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_OK); } else ReportError( nUId, GEN_RES_STR1( S_NO_OK_BUTTON, MethodString( nMethodId ) ) ); break; case M_Cancel: if ( pBD->GetPushButton( BUTTONID_CANCEL ) ) { SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_CANCEL); } else ReportError( nUId, GEN_RES_STR1( S_NO_CANCEL_BUTTON, MethodString( nMethodId ) ) ); break; case M_Yes: if ( pBD->GetPushButton( BUTTONID_YES ) ) { SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_YES); } else ReportError( nUId, GEN_RES_STR1( S_NO_YES_BUTTON, MethodString( nMethodId ) ) ); break; case M_No: if ( pBD->GetPushButton( BUTTONID_NO ) ) { SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_NO); } else ReportError( nUId, GEN_RES_STR1( S_NO_NO_BUTTON, MethodString( nMethodId ) ) ); break; case M_Repeat: if ( pBD->GetPushButton( BUTTONID_RETRY ) ) { SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_RETRY); } else ReportError( nUId, GEN_RES_STR1( S_NO_RETRY_BUTTON, MethodString( nMethodId ) ) ); break; case M_Help: if ( pBD->GetPushButton( BUTTONID_HELP ) ) { SET_WINP_CLOSING(pControl); pBD->EndDialog(BUTTONID_HELP); } else ReportError( nUId, GEN_RES_STR1( S_NO_HELP_BUTTON, MethodString( nMethodId ) ) ); break; case M_Default: { USHORT Style = pControl->GetStyle(); if ( Style & WB_DEF_OK ) { SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_OK); } else if ( Style & WB_DEF_CANCEL ) { SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_CANCEL); } else if ( Style & WB_DEF_YES ) { SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_YES); } else if ( Style & WB_DEF_NO ) { SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_NO); } else if ( Style & WB_DEF_RETRY ) { SET_WINP_CLOSING(pControl); pBD->EndDialog(RET_RETRY); } else ReportError( nUId, GEN_RES_STR1( S_NO_DEFAULT_BUTTON, MethodString( nMethodId ) ) ); } break; case M_GetText : pRet->GenReturn ( RET_Value, nUId, pControl->GetText()); break; case M_Click: if ( nParams & PARAM_USHORT_1 ) { if ( pBD->GetPushButton( nNr1 ) ) { if ( nNr1 != BUTTONID_HELP ) { SET_WINP_CLOSING(pControl); } pBD->GetPushButton( nNr1 )->Click(); } else ReportError( nUId, GEN_RES_STR2( S_NO_DEFAULT_BUTTON, UniString::CreateFromInt32( nNr1 ), MethodString( nMethodId ) ) ); } else ReportError( nUId, GEN_RES_STR1( S_BUTTONID_REQUIRED, MethodString( nMethodId ) ) ); break; case M_GetButtonCount : pRet->GenReturn ( RET_Value, nUId, ULONG(pBD->GetButtonCount())); break; case M_GetButtonId : if ( ValueOK(nUId, MethodString( nMethodId ),nNr1,pBD->GetButtonCount()) ) pRet->GenReturn ( RET_Value, nUId, ULONG(pBD->GetButtonId(nNr1-1))); break; default: ReportError( nUId, GEN_RES_STR2c2( S_UNKNOWN_METHOD, MethodString(nMethodId), "MessageBox" ) ); break; } break; } default: DBG_ERROR( "Unbekannter Objekttyp aus UId oder Methode nicht unterstützt" ); ReportError( nUId, GEN_RES_STR2( S_UNKNOWN_TYPE, UniString::CreateFromInt32( nRT ), MethodString(nMethodId) ) ); #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( " Unbekannter Objekttyp aus UId" ); #endif break; } } for( int i = 0; i < 32; i++ ) SafeReschedule(); } #if OSL_DEBUG_LEVEL > 1 m_pDbgWin->AddText( "\n" ); #endif if (bNormalWeiter) { SendProfile( UIdString( nUId ).Append('.').Append( MethodString( nMethodId ) ) ); delete this; } return bNormalWeiter; #define FINISH_NEXT #define FINISH_SAME }