LCOV - code coverage report
Current view: top level - dbaccess/source/ui/querydesign - querycontroller.cxx (source / functions) Hit Total Coverage
Test: commit 10e77ab3ff6f4314137acd6e2702a6e5c1ce1fae Lines: 19 923 2.1 %
Date: 2014-11-03 Functions: 8 77 10.4 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
       2             : /*
       3             :  * This file is part of the LibreOffice project.
       4             :  *
       5             :  * This Source Code Form is subject to the terms of the Mozilla Public
       6             :  * License, v. 2.0. If a copy of the MPL was not distributed with this
       7             :  * file, You can obtain one at http://mozilla.org/MPL/2.0/.
       8             :  *
       9             :  * This file incorporates work covered by the following license notice:
      10             :  *
      11             :  *   Licensed to the Apache Software Foundation (ASF) under one or more
      12             :  *   contributor license agreements. See the NOTICE file distributed
      13             :  *   with this work for additional information regarding copyright
      14             :  *   ownership. The ASF licenses this file to you under the Apache
      15             :  *   License, Version 2.0 (the "License"); you may not use this file
      16             :  *   except in compliance with the License. You may obtain a copy of
      17             :  *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
      18             :  */
      19             : 
      20             : #include "adtabdlg.hxx"
      21             : #include "browserids.hxx"
      22             : #include "dbu_qry.hrc"
      23             : #include "dbu_reghelper.hxx"
      24             : #include "dbustrings.hrc"
      25             : #include "defaultobjectnamecheck.hxx"
      26             : #include "dlgsave.hxx"
      27             : #include "localresaccess.hxx"
      28             : #include "uiservices.hxx"
      29             : #include "QTableWindow.hxx"
      30             : #include "QTableWindowData.hxx"
      31             : #include "querycontainerwindow.hxx"
      32             : #include "querycontroller.hxx"
      33             : #include "QueryDesignView.hxx"
      34             : #include "QueryTableView.hxx"
      35             : #include "QueryTextView.hxx"
      36             : #include "queryview.hxx"
      37             : #include "QueryViewSwitch.hxx"
      38             : #include "sqlmessage.hxx"
      39             : #include "TableConnectionData.hxx"
      40             : #include "TableFieldDescription.hxx"
      41             : #include "UITools.hxx"
      42             : #include "QueryPropertiesDialog.hxx"
      43             : 
      44             : #include <com/sun/star/beans/PropertyAttribute.hpp>
      45             : #include <com/sun/star/container/XChild.hpp>
      46             : #include <com/sun/star/container/XNameContainer.hpp>
      47             : #include <com/sun/star/frame/FrameSearchFlag.hpp>
      48             : #include <com/sun/star/frame/XLoadEventListener.hpp>
      49             : #include <com/sun/star/io/XActiveDataSink.hpp>
      50             : #include <com/sun/star/io/XActiveDataSource.hpp>
      51             : #include <com/sun/star/sdb/CommandType.hpp>
      52             : #include <com/sun/star/sdb/SQLContext.hpp>
      53             : #include <com/sun/star/sdb/XQueriesSupplier.hpp>
      54             : #include <com/sun/star/sdb/XQueryDefinitionsSupplier.hpp>
      55             : #include <com/sun/star/sdb/XSQLQueryComposerFactory.hpp>
      56             : #include <com/sun/star/sdbc/SQLWarning.hpp>
      57             : #include <com/sun/star/sdbc/XRow.hpp>
      58             : #include <com/sun/star/sdbcx/XAppend.hpp>
      59             : #include <com/sun/star/sdbcx/XDataDescriptorFactory.hpp>
      60             : #include <com/sun/star/sdbcx/XDrop.hpp>
      61             : #include <com/sun/star/sdbcx/XTablesSupplier.hpp>
      62             : #include <com/sun/star/sdbcx/XViewsSupplier.hpp>
      63             : #include <com/sun/star/ui/dialogs/XExecutableDialog.hpp>
      64             : #include <com/sun/star/util/XCloseable.hpp>
      65             : #include <com/sun/star/util/VetoException.hpp>
      66             : #include <com/sun/star/frame/XUntitledNumbers.hpp>
      67             : #include <com/sun/star/ui/XUIElement.hpp>
      68             : 
      69             : #include <comphelper/processfactory.hxx>
      70             : #include <comphelper/property.hxx>
      71             : #include <comphelper/seqstream.hxx>
      72             : #include <comphelper/streamsection.hxx>
      73             : #include <comphelper/types.hxx>
      74             : #include <connectivity/dbexception.hxx>
      75             : #include <connectivity/dbtools.hxx>
      76             : #include <cppuhelper/exc_hlp.hxx>
      77             : #include <sfx2/sfxsids.hrc>
      78             : #include <svtools/localresaccess.hxx>
      79             : #include <toolkit/helper/vclunohelper.hxx>
      80             : #include <tools/diagnose_ex.h>
      81             : #include <osl/diagnose.h>
      82             : #include <vcl/msgbox.hxx>
      83             : #include <vcl/svapp.hxx>
      84             : #include <osl/mutex.hxx>
      85             : #include <rtl/strbuf.hxx>
      86             : #include <vector>
      87             : 
      88          24 : extern "C" void SAL_CALL createRegistryInfo_OQueryControl()
      89             : {
      90          24 :     static ::dbaui::OMultiInstanceAutoRegistration< ::dbaui::OQueryController > aAutoRegistration;
      91          24 : }
      92             : 
      93             : namespace dbaui
      94             : {
      95             :     using namespace ::com::sun::star::uno;
      96             :     using namespace ::com::sun::star::beans;
      97             :     using namespace ::com::sun::star::frame;
      98             :     using namespace ::com::sun::star::util;
      99             :     using namespace ::com::sun::star::lang;
     100             : 
     101           0 :     class OViewController : public OQueryController
     102             :     {
     103           0 :         virtual OUString SAL_CALL getImplementationName() throw( RuntimeException, std::exception ) SAL_OVERRIDE
     104             :         {
     105           0 :             return getImplementationName_Static();
     106             :         }
     107           0 :         virtual Sequence< OUString> SAL_CALL getSupportedServiceNames() throw(RuntimeException, std::exception) SAL_OVERRIDE
     108             :         {
     109           0 :             return getSupportedServiceNames_Static();
     110             :         }
     111             : 
     112             :     public:
     113           0 :         OViewController(const Reference< XComponentContext >& _rM) : OQueryController(_rM){}
     114             : 
     115             :         // need by registration
     116          48 :         static OUString getImplementationName_Static() throw( RuntimeException )
     117             :         {
     118          48 :             return OUString("org.openoffice.comp.dbu.OViewDesign");
     119             :         }
     120          24 :         static Sequence< OUString > getSupportedServiceNames_Static(void) throw( RuntimeException )
     121             :         {
     122          24 :             Sequence< OUString> aSupported(1);
     123          24 :             aSupported.getArray()[0] = "com.sun.star.sdb.ViewDesign";
     124          24 :             return aSupported;
     125             :         }
     126           0 :         static Reference< XInterface > SAL_CALL Create(const Reference< XMultiServiceFactory >& _rM)
     127             :         {
     128           0 :             return *(new OViewController(comphelper::getComponentContext(_rM)));
     129             :         }
     130             :     };
     131             : }
     132             : 
     133          24 : extern "C" void SAL_CALL createRegistryInfo_OViewControl()
     134             : {
     135          24 :     static ::dbaui::OMultiInstanceAutoRegistration< ::dbaui::OViewController > aAutoRegistration;
     136          24 : }
     137             : 
     138             : namespace dbaui
     139             : {
     140             :     using namespace ::connectivity;
     141             : #if OSL_DEBUG_LEVEL > 1
     142             :     namespace
     143             :     {
     144             :         void insertParseTree(SvTreeListBox* _pBox,::connectivity::OSQLParseNode* _pNode,SvTreeListEntry* _pParent = NULL)
     145             :         {
     146             :             OUString rString;
     147             :             if (!_pNode->isToken())
     148             :             {
     149             :                 // rule name as rule: ...
     150             :                 rString = "RULE_ID: " + OUString::number( (sal_Int32)_pNode->getRuleID() ) +
     151             :                           "(" + OSQLParser::RuleIDToStr(_pNode->getRuleID()) + ")";
     152             : 
     153             :                 _pParent = _pBox->InsertEntry(rString,_pParent);
     154             : 
     155             :                 // determine how much subtrees this node has
     156             :                 sal_uInt32 nStop = _pNode->count();
     157             :                 // fetch first subtree
     158             :                 for(sal_uInt32 i=0;i<nStop;++i)
     159             :                     insertParseTree(_pBox,_pNode->getChild(i),_pParent);
     160             :             }
     161             :             else
     162             :             {
     163             :                 // token found
     164             :                 // tabs to insert according to nLevel
     165             : 
     166             :                 switch (_pNode->getNodeType())
     167             :                 {
     168             : 
     169             :                 case SQL_NODE_KEYWORD:
     170             :                     {
     171             :                         rString += "SQL_KEYWORD:";
     172             :                         OString sT = OSQLParser::TokenIDToStr(_pNode->getTokenID());
     173             :                         rString += OStringToOUString(sT, RTL_TEXTENCODING_UTF8);
     174             :                      break;}
     175             : 
     176             :                 case SQL_NODE_COMPARISON:
     177             :                     {
     178             :                         rString += "SQL_COMPARISON:" + _pNode->getTokenValue(); // append Nodevalue
     179             :                             // and start new line
     180             :                         break;}
     181             : 
     182             :                 case SQL_NODE_NAME:
     183             :                     {
     184             :                         rString += "SQL_NAME:\"" + _pNode->getTokenValue() + "\"";
     185             :                         break;}
     186             : 
     187             :                 case SQL_NODE_STRING:
     188             :                     {
     189             :                         rString += "SQL_STRING:'" + _pNode->getTokenValue();
     190             :                         break;}
     191             : 
     192             :                 case SQL_NODE_INTNUM:
     193             :                     {
     194             :                         rString += "SQL_INTNUM:" + _pNode->getTokenValue();
     195             :                         break;}
     196             : 
     197             :                 case SQL_NODE_APPROXNUM:
     198             :                     {
     199             :                         rString += "SQL_APPROXNUM:" + _pNode->getTokenValue();
     200             :                         break;}
     201             : 
     202             :                 case SQL_NODE_PUNCTUATION:
     203             :                     {
     204             :                         rString += "SQL_PUNCTUATION:" + _pNode->getTokenValue(); // append Nodevalue
     205             :                         break;}
     206             : 
     207             :                 case SQL_NODE_AMMSC:
     208             :                     {
     209             :                         rString += "SQL_AMMSC:" + _pNode->getTokenValue(); // append Nodevalue
     210             :                         break;}
     211             : 
     212             :                 default:
     213             :                     OSL_FAIL("OSQLParser::ShowParseTree: unzulaessiger NodeType");
     214             :                     rString += _pNode->getTokenValue();
     215             :                 }
     216             :                 _pBox->InsertEntry(rString,_pParent);
     217             :             }
     218             :         }
     219             :     }
     220             : #endif // OSL_DEBUG_LEVEL
     221             : 
     222             :     namespace
     223             :     {
     224           0 :         OUString lcl_getObjectResourceString( sal_uInt16 _nResId, sal_Int32 _nCommandType )
     225             :         {
     226           0 :             OUString sMessageText = ModuleRes( _nResId );
     227           0 :             OUString sObjectType;
     228             :             {
     229           0 :                 LocalResourceAccess aLocalRes( RSC_QUERY_OBJECT_TYPE, RSC_RESOURCE );
     230           0 :                 sObjectType = ModuleRes( (sal_uInt16)( _nCommandType + 1 ) );
     231             :             }
     232           0 :             sMessageText = sMessageText.replaceFirst( "$object$", sObjectType );
     233           0 :             return sMessageText;
     234             :         }
     235             :     }
     236             : 
     237             : using namespace ::com::sun::star::uno;
     238             : using namespace ::com::sun::star::io;
     239             : using namespace ::com::sun::star::beans;
     240             : using namespace ::com::sun::star::frame;
     241             : using namespace ::com::sun::star::util;
     242             : using namespace ::com::sun::star::lang;
     243             : using namespace ::com::sun::star::container;
     244             : using namespace ::com::sun::star::sdbcx;
     245             : using namespace ::com::sun::star::sdbc;
     246             : using namespace ::com::sun::star::sdb;
     247             : using namespace ::com::sun::star::ui;
     248             : using namespace ::com::sun::star::ui::dialogs;
     249             : using namespace ::com::sun::star::awt;
     250             : using namespace ::dbtools;
     251             : 
     252             : using namespace ::comphelper;
     253             : 
     254             : namespace
     255             : {
     256           0 :     void ensureToolbars( OQueryController& _rController, bool _bDesign )
     257             :     {
     258           0 :         Reference< ::com::sun::star::frame::XLayoutManager > xLayoutManager = _rController.getLayoutManager( _rController.getFrame() );
     259           0 :         if ( xLayoutManager.is() )
     260             :         {
     261           0 :             xLayoutManager->lock();
     262           0 :             static OUString s_sDesignToolbar("private:resource/toolbar/designobjectbar");
     263           0 :             static OUString s_sSqlToolbar("private:resource/toolbar/sqlobjectbar");
     264           0 :             if ( _bDesign )
     265             :             {
     266           0 :                 xLayoutManager->destroyElement( s_sSqlToolbar );
     267           0 :                 xLayoutManager->createElement( s_sDesignToolbar );
     268             :             }
     269             :             else
     270             :             {
     271           0 :                 xLayoutManager->destroyElement( s_sDesignToolbar );
     272           0 :                 xLayoutManager->createElement( s_sSqlToolbar );
     273             :             }
     274           0 :             xLayoutManager->unlock();
     275           0 :             xLayoutManager->doLayout();
     276           0 :         }
     277           0 :     }
     278             : 
     279             :     /**
     280             :      * The value of m_nLimit is updated when LimitBox loses its focus
     281             :      * So in those case when execution needs recent data, grab the focus
     282             :      * (e.g. execute SQL statement, change views)
     283             :      */
     284           0 :     void grabFocusFromLimitBox( OQueryController& _rController )
     285             :     {
     286           0 :         static const OUString sResourceURL( "private:resource/toolbar/designobjectbar" );
     287           0 :         Reference< XLayoutManager > xLayoutManager = _rController.getLayoutManager( _rController.getFrame() );
     288           0 :         Reference< XUIElement > xUIElement = xLayoutManager->getElement(sResourceURL);
     289           0 :         if (xUIElement.is())
     290             :         {
     291           0 :             Reference< XWindow > xWindow(xUIElement->getRealInterface(), css::uno::UNO_QUERY);
     292           0 :             vcl::Window* pWindow = VCLUnoHelper::GetWindow( xWindow );
     293           0 :             if( pWindow || pWindow->HasChildPathFocus() )
     294             :             {
     295           0 :                 pWindow->GrabFocusToDocument();
     296           0 :             }
     297           0 :         }
     298           0 :     }
     299             : }
     300             : 
     301           0 : OUString SAL_CALL OQueryController::getImplementationName() throw( RuntimeException, std::exception )
     302             : {
     303           0 :     return getImplementationName_Static();
     304             : }
     305             : 
     306          48 : OUString OQueryController::getImplementationName_Static() throw( RuntimeException )
     307             : {
     308          48 :     return OUString("org.openoffice.comp.dbu.OQueryDesign");
     309             : }
     310             : 
     311          24 : Sequence< OUString> OQueryController::getSupportedServiceNames_Static(void) throw( RuntimeException )
     312             : {
     313          24 :     Sequence< OUString> aSupported(1);
     314          24 :     aSupported.getArray()[0] = "com.sun.star.sdb.QueryDesign";
     315          24 :     return aSupported;
     316             : }
     317             : 
     318           0 : Sequence< OUString> SAL_CALL OQueryController::getSupportedServiceNames() throw(RuntimeException, std::exception)
     319             : {
     320           0 :     return getSupportedServiceNames_Static();
     321             : }
     322             : 
     323           0 : Reference< XInterface > SAL_CALL OQueryController::Create(const Reference<XMultiServiceFactory >& _rxFactory)
     324             : {
     325           0 :     return *(new OQueryController(comphelper::getComponentContext(_rxFactory)));
     326             : }
     327             : 
     328           0 : OQueryController::OQueryController(const Reference< XComponentContext >& _rM)
     329             :     :OJoinController(_rM)
     330           0 :     ,OQueryController_PBase( getBroadcastHelper() )
     331           0 :     ,m_pParseContext( new svxform::OSystemParseContext )
     332             :     ,m_aSqlParser( _rM, m_pParseContext )
     333             :     ,m_pSqlIterator(NULL)
     334             :     ,m_nLimit(-1)
     335             :     ,m_nVisibleRows(0x400)
     336             :     ,m_nSplitPos(-1)
     337             :     ,m_nCommandType( CommandType::QUERY )
     338             :     ,m_bGraphicalDesign(false)
     339             :     ,m_bDistinct(false)
     340             :     ,m_bViewAlias(false)
     341             :     ,m_bViewTable(false)
     342             :     ,m_bViewFunction(false)
     343           0 :     ,m_bEscapeProcessing(true)
     344             : {
     345           0 :     InvalidateAll();
     346             : 
     347             :     registerProperty( PROPERTY_ACTIVECOMMAND, PROPERTY_ID_ACTIVECOMMAND, PropertyAttribute::READONLY | PropertyAttribute::BOUND,
     348           0 :         &m_sStatement, ::getCppuType( &m_sStatement ) );
     349             :     registerProperty( PROPERTY_ESCAPE_PROCESSING, PROPERTY_ID_ESCAPE_PROCESSING, PropertyAttribute::READONLY | PropertyAttribute::BOUND,
     350           0 :         &m_bEscapeProcessing, ::getCppuType( &m_bEscapeProcessing ) );
     351           0 : }
     352             : 
     353           0 : OQueryController::~OQueryController()
     354             : {
     355           0 :     if ( !getBroadcastHelper().bDisposed && !getBroadcastHelper().bInDispose )
     356             :     {
     357             :         OSL_FAIL("Please check who doesn't dispose this component!");
     358             :         // increment ref count to prevent double call of Dtor
     359           0 :         osl_atomic_increment( &m_refCount );
     360           0 :         dispose();
     361             :     }
     362           0 : }
     363             : 
     364           0 : IMPLEMENT_FORWARD_XINTERFACE2( OQueryController, OJoinController, OQueryController_PBase )
     365           0 : IMPLEMENT_FORWARD_XTYPEPROVIDER2( OQueryController, OJoinController, OQueryController_PBase )
     366             : 
     367           0 : Reference< XPropertySetInfo > SAL_CALL OQueryController::getPropertySetInfo() throw(RuntimeException, std::exception)
     368             : {
     369           0 :     Reference< XPropertySetInfo > xInfo( createPropertySetInfo( getInfoHelper() ) );
     370           0 :     return xInfo;
     371             : }
     372             : 
     373           0 : sal_Bool SAL_CALL OQueryController::convertFastPropertyValue( Any& o_rConvertedValue, Any& o_rOldValue, sal_Int32 i_nHandle, const Any& i_rValue ) throw (IllegalArgumentException)
     374             : {
     375           0 :     return OPropertyContainer::convertFastPropertyValue( o_rConvertedValue, o_rOldValue, i_nHandle, i_rValue );
     376             : }
     377             : 
     378           0 : void SAL_CALL OQueryController::setFastPropertyValue_NoBroadcast( sal_Int32 i_nHandle, const Any& i_rValue ) throw ( Exception, std::exception )
     379             : {
     380           0 :     OPropertyContainer::setFastPropertyValue_NoBroadcast( i_nHandle, i_rValue );
     381           0 : }
     382             : 
     383           0 : void SAL_CALL OQueryController::getFastPropertyValue( Any& o_rValue, sal_Int32 i_nHandle ) const
     384             : {
     385           0 :     switch ( i_nHandle )
     386             :     {
     387             :     case PROPERTY_ID_CURRENT_QUERY_DESIGN:
     388             :     {
     389           0 :         ::comphelper::NamedValueCollection aCurrentDesign;
     390           0 :         aCurrentDesign.put( "GraphicalDesign", isGraphicalDesign() );
     391           0 :         aCurrentDesign.put( OUString(PROPERTY_ESCAPE_PROCESSING), m_bEscapeProcessing );
     392             : 
     393           0 :         if ( isGraphicalDesign() )
     394             :         {
     395           0 :             getContainer()->SaveUIConfig();
     396           0 :             saveViewSettings( aCurrentDesign, true );
     397           0 :             aCurrentDesign.put( "Statement", m_sStatement );
     398             :         }
     399             :         else
     400             :         {
     401           0 :             aCurrentDesign.put( "Statement", getContainer()->getStatement() );
     402             :         }
     403             : 
     404           0 :         o_rValue <<= aCurrentDesign.getPropertyValues();
     405             :     }
     406           0 :     break;
     407             : 
     408             :     default:
     409           0 :         OPropertyContainer::getFastPropertyValue( o_rValue, i_nHandle );
     410           0 :         break;
     411             :     }
     412           0 : }
     413             : 
     414           0 : ::cppu::IPropertyArrayHelper& OQueryController::getInfoHelper()
     415             : {
     416           0 :     return *const_cast< OQueryController* >( this )->getArrayHelper();
     417             : }
     418             : 
     419           0 : ::cppu::IPropertyArrayHelper* OQueryController::createArrayHelper( ) const
     420             : {
     421           0 :     Sequence< Property > aProps;
     422           0 :     describeProperties( aProps );
     423             : 
     424             :     // one additional property:
     425           0 :     const sal_Int32 nLength = aProps.getLength();
     426           0 :     aProps.realloc( nLength + 1 );
     427           0 :     aProps[ nLength ] = Property(
     428             :         "CurrentQueryDesign",
     429             :         PROPERTY_ID_CURRENT_QUERY_DESIGN,
     430           0 :         ::cppu::UnoType< Sequence< PropertyValue > >::get(),
     431             :         PropertyAttribute::READONLY
     432           0 :     );
     433             : 
     434             :     ::std::sort(
     435             :         aProps.getArray(),
     436           0 :         aProps.getArray() + aProps.getLength(),
     437             :         ::comphelper::PropertyCompareByName()
     438           0 :     );
     439             : 
     440           0 :     return new ::cppu::OPropertyArrayHelper(aProps);
     441             : }
     442             : 
     443           0 : void OQueryController::deleteIterator()
     444             : {
     445           0 :     if(m_pSqlIterator)
     446             :     {
     447           0 :         delete m_pSqlIterator->getParseTree();
     448           0 :         m_pSqlIterator->dispose();
     449           0 :         delete m_pSqlIterator;
     450           0 :         m_pSqlIterator = NULL;
     451             :     }
     452           0 : }
     453             : 
     454           0 : void OQueryController::disposing()
     455             : {
     456           0 :     OQueryController_PBase::disposing();
     457             : 
     458           0 :     deleteIterator();
     459             : 
     460           0 :     delete m_pParseContext;
     461             : 
     462           0 :     clearFields();
     463           0 :     OTableFields().swap(m_vUnUsedFieldsDesc);
     464             : 
     465           0 :     ::comphelper::disposeComponent(m_xComposer);
     466           0 :     OJoinController::disposing();
     467           0 :     OQueryController_PBase::disposing();
     468           0 : }
     469             : 
     470           0 : void OQueryController::clearFields()
     471             : {
     472           0 :     OTableFields().swap(m_vTableFieldDesc);
     473           0 : }
     474             : 
     475           0 : FeatureState OQueryController::GetState(sal_uInt16 _nId) const
     476             : {
     477           0 :     FeatureState aReturn;
     478           0 :     aReturn.bEnabled = true;
     479             :         // (disabled automatically)
     480             : 
     481           0 :     switch (_nId)
     482             :     {
     483             :         case ID_BROWSER_EDITDOC:
     484           0 :             if ( editingCommand() )
     485           0 :                 aReturn.bEnabled = false;
     486           0 :             else if ( editingView() && !m_xAlterView.is() )
     487           0 :                 aReturn.bEnabled = false;
     488             :             else
     489           0 :                 aReturn = OJoinController::GetState( _nId );
     490           0 :             break;
     491             : 
     492             :         case ID_BROWSER_ESACPEPROCESSING:
     493           0 :             aReturn.bChecked = !m_bEscapeProcessing;
     494           0 :             aReturn.bEnabled = ( m_pSqlIterator != NULL ) && !m_bGraphicalDesign;
     495           0 :             break;
     496             :         case SID_RELATION_ADD_RELATION:
     497           0 :             aReturn.bEnabled = isEditable() && m_bGraphicalDesign && m_vTableData.size() > 1;
     498           0 :             break;
     499             :         case ID_BROWSER_SAVEASDOC:
     500           0 :             aReturn.bEnabled = !editingCommand() && !editingView() && (!m_bGraphicalDesign || !(m_vTableFieldDesc.empty() || m_vTableData.empty()));
     501           0 :             break;
     502             :         case ID_BROWSER_SAVEDOC:
     503           0 :             aReturn.bEnabled = impl_isModified() && (!m_bGraphicalDesign || !(m_vTableFieldDesc.empty() || m_vTableData.empty()));
     504           0 :             break;
     505             :         case SID_PRINTDOCDIRECT:
     506           0 :             break;
     507             :         case ID_BROWSER_CUT:
     508           0 :             aReturn.bEnabled = isEditable() && getContainer() && getContainer()->isCutAllowed();
     509           0 :             break;
     510             :         case ID_BROWSER_COPY:
     511           0 :             aReturn.bEnabled = getContainer() && getContainer()->isCopyAllowed();
     512           0 :             break;
     513             :         case ID_BROWSER_PASTE:
     514           0 :             aReturn.bEnabled = isEditable() && getContainer() && getContainer()->isPasteAllowed();
     515           0 :             break;
     516             :         case ID_BROWSER_SQL:
     517           0 :             aReturn.bEnabled = m_bEscapeProcessing && m_pSqlIterator;
     518           0 :             aReturn.bChecked = m_bGraphicalDesign;
     519           0 :             break;
     520             :         case SID_BROWSER_CLEAR_QUERY:
     521           0 :             aReturn.bEnabled = isEditable() && (!m_sStatement.isEmpty() || !m_vTableData.empty());
     522           0 :             break;
     523             :         case SID_QUERY_VIEW_FUNCTIONS:
     524             :         case SID_QUERY_VIEW_TABLES:
     525             :         case SID_QUERY_VIEW_ALIASES:
     526           0 :             aReturn.bChecked = getContainer() && getContainer()->isSlotEnabled(_nId);
     527           0 :             aReturn.bEnabled = m_bGraphicalDesign;
     528           0 :             break;
     529             :         case SID_QUERY_DISTINCT_VALUES:
     530           0 :             aReturn.bEnabled = m_bGraphicalDesign && isEditable();
     531           0 :             aReturn.bChecked = m_bDistinct;
     532           0 :             break;
     533             :         case SID_QUERY_LIMIT:
     534           0 :             aReturn.bEnabled = m_bGraphicalDesign;
     535           0 :             if( aReturn.bEnabled )
     536           0 :                 aReturn.aValue = makeAny( m_nLimit );
     537           0 :             break;
     538             :         case SID_QUERY_PROP_DLG:
     539           0 :             aReturn.bEnabled = m_bGraphicalDesign;
     540           0 :             break;
     541             :         case ID_BROWSER_QUERY_EXECUTE:
     542           0 :             aReturn.bEnabled = true;
     543           0 :             break;
     544             :         case SID_DB_QUERY_PREVIEW:
     545           0 :             aReturn.bEnabled = true;
     546           0 :             aReturn.bChecked = getContainer() && getContainer()->getPreviewFrame().is();
     547           0 :             break;
     548             : #if OSL_DEBUG_LEVEL > 1
     549             :         case ID_EDIT_QUERY_SQL:
     550             :             break;
     551             :         case ID_EDIT_QUERY_DESIGN:
     552             :             break;
     553             : #endif
     554             :         case ID_BROWSER_ADDTABLE:
     555           0 :             if ( !m_bGraphicalDesign )
     556             :             {
     557           0 :                 aReturn.bEnabled = false;
     558           0 :                 break;
     559             :             }
     560             :             // run through
     561             :         default:
     562           0 :             aReturn = OJoinController::GetState(_nId);
     563           0 :             break;
     564             :     }
     565           0 :     return aReturn;
     566             : }
     567             : 
     568           0 : void OQueryController::Execute(sal_uInt16 _nId, const Sequence< PropertyValue >& aArgs)
     569             : {
     570           0 :     switch(_nId)
     571             :     {
     572             :         case ID_BROWSER_ESACPEPROCESSING:
     573           0 :             setEscapeProcessing_fireEvent( !m_bEscapeProcessing );
     574           0 :             if ( !editingView() )
     575           0 :                 setModified(sal_True);
     576           0 :             InvalidateFeature(ID_BROWSER_SQL);
     577           0 :             break;
     578             :         case ID_BROWSER_SAVEASDOC:
     579             :         case ID_BROWSER_SAVEDOC:
     580           0 :             grabFocusFromLimitBox(*this);
     581           0 :             doSaveAsDoc(ID_BROWSER_SAVEASDOC == _nId);
     582           0 :             break;
     583             :         case SID_RELATION_ADD_RELATION:
     584             :             {
     585           0 :                 OJoinDesignView* pView = getJoinView();
     586           0 :                 if( pView )
     587           0 :                     static_cast<OQueryTableView*>(pView->getTableView())->createNewConnection();
     588             :             }
     589           0 :             break;
     590             :         case SID_PRINTDOCDIRECT:
     591           0 :             break;
     592             :         case ID_BROWSER_CUT:
     593           0 :             getContainer()->cut();
     594           0 :             break;
     595             :         case ID_BROWSER_COPY:
     596           0 :             getContainer()->copy();
     597           0 :             break;
     598             :         case ID_BROWSER_PASTE:
     599           0 :             getContainer()->paste();
     600           0 :             break;
     601             :         case ID_BROWSER_SQL:
     602             :         {
     603           0 :             grabFocusFromLimitBox(*this);
     604           0 :             if ( !getContainer()->checkStatement() )
     605           0 :                 break;
     606           0 :             SQLExceptionInfo aError;
     607             :             try
     608             :             {
     609           0 :                 OUString aErrorMsg;
     610           0 :                 setStatement_fireEvent( getContainer()->getStatement() );
     611           0 :                 if(m_sStatement.isEmpty() && m_pSqlIterator)
     612             :                 {
     613             :                     // change the view of the data
     614           0 :                     delete m_pSqlIterator->getParseTree();
     615           0 :                     m_pSqlIterator->setParseTree(NULL);
     616           0 :                     m_bGraphicalDesign = !m_bGraphicalDesign;
     617           0 :                     impl_setViewMode( &aError );
     618             :                 }
     619             :                 else
     620             :                 {
     621           0 :                     ::connectivity::OSQLParseNode* pNode = m_aSqlParser.parseTree(aErrorMsg,m_sStatement,m_bGraphicalDesign);
     622           0 :                     if ( pNode )
     623             :                     {
     624           0 :                         delete m_pSqlIterator->getParseTree();
     625           0 :                         m_pSqlIterator->setParseTree(pNode);
     626           0 :                         m_pSqlIterator->traverseAll();
     627             : 
     628           0 :                         if ( m_pSqlIterator->hasErrors() )
     629             :                         {
     630           0 :                             aError = m_pSqlIterator->getErrors();
     631             :                         }
     632             :                         else
     633             :                         {
     634           0 :                             const OSQLTables& xTabs = m_pSqlIterator->getTables();
     635           0 :                             if ( m_pSqlIterator->getStatementType() != SQL_STATEMENT_SELECT || xTabs.begin() == xTabs.end() )
     636             :                             {
     637           0 :                                 aError = SQLException(
     638             :                                     OUString( ModuleRes( STR_QRY_NOSELECT ) ),
     639             :                                     NULL,
     640             :                                     "S1000",
     641             :                                     1000,
     642             :                                     Any()
     643           0 :                                 );
     644             :                             }
     645             :                             else
     646             :                             {
     647             :                                 // change the view of the data
     648           0 :                                 m_bGraphicalDesign = !m_bGraphicalDesign;
     649           0 :                                 OUString sNewStatement;
     650           0 :                                 pNode->parseNodeToStr( sNewStatement, getConnection() );
     651           0 :                                 setStatement_fireEvent( sNewStatement );
     652           0 :                                 getContainer()->SaveUIConfig();
     653           0 :                                 m_vTableConnectionData.clear();
     654           0 :                                 impl_setViewMode( &aError );
     655             :                             }
     656             :                         }
     657             :                     }
     658             :                     else
     659             :                     {
     660           0 :                         aError = SQLException(
     661             :                             OUString( ModuleRes( STR_QRY_SYNTAX ) ),
     662             :                             NULL,
     663             :                             "S1000",
     664             :                             1000,
     665             :                             Any()
     666           0 :                         );
     667             :                     }
     668           0 :                 }
     669             :             }
     670           0 :             catch(const SQLException&)
     671             :             {
     672           0 :                 aError = ::cppu::getCaughtException();
     673             :             }
     674           0 :             catch(const Exception&)
     675             :             {
     676             :                 DBG_UNHANDLED_EXCEPTION();
     677             :             }
     678             : 
     679           0 :             if ( aError.isValid() )
     680           0 :                 showError( aError );
     681             : 
     682           0 :             if(m_bGraphicalDesign)
     683             :             {
     684           0 :                 InvalidateFeature(ID_BROWSER_ADDTABLE);
     685           0 :                 InvalidateFeature(SID_RELATION_ADD_RELATION);
     686           0 :             }
     687             :         }
     688           0 :         break;
     689             :         case SID_BROWSER_CLEAR_QUERY:
     690             :             {
     691           0 :                 GetUndoManager().EnterListAction( OUString( ModuleRes(STR_QUERY_UNDO_TABWINDELETE) ), OUString() );
     692           0 :                 getContainer()->clear();
     693           0 :                 GetUndoManager().LeaveListAction();
     694             : 
     695           0 :                 setStatement_fireEvent( OUString() );
     696           0 :                 if(m_bGraphicalDesign)
     697           0 :                     InvalidateFeature(ID_BROWSER_ADDTABLE);
     698             :             }
     699           0 :             break;
     700             :         case SID_QUERY_VIEW_FUNCTIONS:
     701             :         case SID_QUERY_VIEW_TABLES:
     702             :         case SID_QUERY_VIEW_ALIASES:
     703           0 :             getContainer()->setSlotEnabled(_nId,!getContainer()->isSlotEnabled(_nId));
     704           0 :             setModified(sal_True);
     705           0 :             break;
     706             :         case SID_QUERY_DISTINCT_VALUES:
     707           0 :             m_bDistinct = !m_bDistinct;
     708           0 :             setModified(sal_True);
     709           0 :             break;
     710             :         case SID_QUERY_LIMIT:
     711           0 :             if ( aArgs.getLength() >= 1 && aArgs[0].Name == "DBLimit.Value" )
     712             :             {
     713           0 :                 aArgs[0].Value >>= m_nLimit;
     714           0 :                 setModified(sal_True);
     715             :             }
     716           0 :             break;
     717             :         case SID_QUERY_PROP_DLG:
     718           0 :             grabFocusFromLimitBox(*this);
     719           0 :             execute_QueryPropDlg();
     720           0 :             break;
     721             :         case ID_BROWSER_QUERY_EXECUTE:
     722           0 :             grabFocusFromLimitBox(*this);
     723           0 :             if ( getContainer()->checkStatement() )
     724           0 :                 executeQuery();
     725           0 :             break;
     726             :         case SID_DB_QUERY_PREVIEW:
     727             :             try
     728             :             {
     729           0 :                 Reference< ::com::sun::star::util::XCloseable > xCloseFrame( getContainer()->getPreviewFrame(), UNO_QUERY );
     730           0 :                 if ( xCloseFrame.is() )
     731             :                 {
     732             :                     try
     733             :                     {
     734           0 :                         xCloseFrame->close( sal_True );
     735             :                     }
     736           0 :                     catch(const Exception&)
     737             :                     {
     738             :                         OSL_FAIL( "OQueryController::Execute(SID_DB_QUERY_PREVIEW): *nobody* is expected to veto closing the preview frame!" );
     739             :                     }
     740             :                 }
     741             :                 else
     742           0 :                     Execute(ID_BROWSER_QUERY_EXECUTE,Sequence< PropertyValue >());
     743             :             }
     744           0 :             catch(const Exception&)
     745             :             {
     746             :             }
     747           0 :             break;
     748             :         case ID_QUERY_ZOOM_IN:
     749             :             {
     750             :             }
     751           0 :             break;
     752             :         case ID_QUERY_ZOOM_OUT:
     753             :             {
     754             :             }
     755           0 :             break;
     756             : #if OSL_DEBUG_LEVEL > 1
     757             :         case ID_EDIT_QUERY_DESIGN:
     758             :         case ID_EDIT_QUERY_SQL:
     759             :             {
     760             :                 OUString aErrorMsg;
     761             :                 setStatement_fireEvent( getContainer()->getStatement() );
     762             :                 ::connectivity::OSQLParseNode* pNode = m_aSqlParser.parseTree( aErrorMsg, m_sStatement, m_bGraphicalDesign );
     763             :                 if ( pNode )
     764             :                 {
     765             :                     vcl::Window* pView = getView();
     766             :                     ModalDialog* pWindow = new ModalDialog( pView, WB_STDMODAL | WB_SIZEMOVE | WB_CENTER );
     767             :                     pWindow->SetSizePixel( ::Size( pView->GetSizePixel().Width() / 2, pView->GetSizePixel().Height() / 2 ) );
     768             :                     SvTreeListBox* pTreeBox = new SvTreeListBox( pWindow, WB_BORDER | WB_HASLINES | WB_HASBUTTONS | WB_HASBUTTONSATROOT | WB_HASLINESATROOT | WB_VSCROLL );
     769             :                     pTreeBox->SetPosSizePixel( ::Point( 6, 6 ), ::Size( pWindow->GetSizePixel().Width() - 12, pWindow->GetSizePixel().Height() - 12 ));
     770             :                     pTreeBox->SetNodeDefaultImages();
     771             : 
     772             :                     if ( _nId == ID_EDIT_QUERY_DESIGN )
     773             :                     {
     774             :                         ::connectivity::OSQLParseNode* pTemp = pNode ? pNode->getChild(3)->getChild(1) : NULL;
     775             :                         // no where clause found
     776             :                         if ( pTemp && !pTemp->isLeaf() )
     777             :                         {
     778             :                             ::connectivity::OSQLParseNode * pCondition = pTemp->getChild(1);
     779             :                             if ( pCondition ) // no where clause
     780             :                             {
     781             :                                 ::connectivity::OSQLParseNode::negateSearchCondition(pCondition);
     782             :                                 ::connectivity::OSQLParseNode *pNodeTmp = pTemp->getChild(1);
     783             : 
     784             :                                 ::connectivity::OSQLParseNode::disjunctiveNormalForm(pNodeTmp);
     785             :                                 pNodeTmp = pTemp->getChild(1);
     786             :                                 ::connectivity::OSQLParseNode::absorptions(pNodeTmp);
     787             :                                 pNodeTmp = pTemp->getChild(1);
     788             :                                 OSQLParseNode::compress(pNodeTmp);
     789             :                                 pNodeTmp = pTemp->getChild(1);
     790             :                             }
     791             :                             OUString sTemp;
     792             :                             pNode->parseNodeToStr(sTemp,getConnection());
     793             :                             getContainer()->setStatement(sTemp);
     794             :                         }
     795             :                     }
     796             : 
     797             :                     insertParseTree(pTreeBox,pNode);
     798             : 
     799             :                     pTreeBox->Show();
     800             :                     pWindow->Execute();
     801             : 
     802             :                     delete pTreeBox;
     803             :                     delete pWindow;
     804             :                     delete pNode;
     805             :                 }
     806             :                 break;
     807             :             }
     808             : #endif
     809             :         default:
     810           0 :             OJoinController::Execute(_nId,aArgs);
     811           0 :             return; // else we would invalidate twice
     812             :     }
     813           0 :     InvalidateFeature(_nId);
     814             : }
     815             : 
     816           0 : void OQueryController::impl_showAutoSQLViewError( const ::com::sun::star::uno::Any& _rErrorDetails )
     817             : {
     818           0 :     SQLContext aErrorContext;
     819           0 :     aErrorContext.Message = lcl_getObjectResourceString( STR_ERROR_PARSING_STATEMENT, m_nCommandType );
     820           0 :     aErrorContext.Context = *this;
     821           0 :     aErrorContext.Details = lcl_getObjectResourceString( STR_INFO_OPENING_IN_SQL_VIEW, m_nCommandType );
     822           0 :     aErrorContext.NextException = _rErrorDetails;
     823           0 :     showError( aErrorContext );
     824           0 : }
     825             : 
     826           0 : bool OQueryController::impl_setViewMode( ::dbtools::SQLExceptionInfo* _pErrorInfo )
     827             : {
     828             :     OSL_PRECOND( getContainer(), "OQueryController::impl_setViewMode: illegal call!" );
     829             : 
     830           0 :     bool wasModified = isModified();
     831             : 
     832           0 :     SQLExceptionInfo aError;
     833           0 :     bool bSuccess = getContainer()->switchView( &aError );
     834           0 :     if ( !bSuccess )
     835             :     {
     836           0 :         m_bGraphicalDesign = !m_bGraphicalDesign;
     837             :         // restore old state
     838           0 :         getContainer()->switchView( NULL );
     839             :             // don't pass &aError here, this would overwrite the error which the first switchView call
     840             :             // returned in this location.
     841           0 :         if ( _pErrorInfo )
     842           0 :             *_pErrorInfo = aError;
     843             :         else
     844           0 :             showError( aError );
     845             :     }
     846             :     else
     847             :     {
     848           0 :         ensureToolbars( *this, m_bGraphicalDesign );
     849             :     }
     850             : 
     851           0 :     setModified( wasModified );
     852           0 :     return bSuccess;
     853             : }
     854             : 
     855           0 : void OQueryController::impl_initialize()
     856             : {
     857           0 :     OJoinController::impl_initialize();
     858             : 
     859           0 :     const NamedValueCollection& rArguments( getInitParams() );
     860             : 
     861           0 :     OUString sCommand;
     862           0 :     m_nCommandType = CommandType::QUERY;
     863             : 
     864             :     // reading parameters:
     865             : 
     866             :     // legacy parameters first (later overwritten by regular parameters)
     867           0 :     OUString sIndependentSQLCommand;
     868           0 :     if ( rArguments.get_ensureType( "IndependentSQLCommand", sIndependentSQLCommand ) )
     869             :     {
     870             :         OSL_FAIL( "OQueryController::impl_initialize: IndependentSQLCommand is regognized for compatibility only!" );
     871           0 :         sCommand = sIndependentSQLCommand;
     872           0 :         m_nCommandType = CommandType::COMMAND;
     873             :     }
     874             : 
     875           0 :     OUString sCurrentQuery;
     876           0 :     if ( rArguments.get_ensureType( "CurrentQuery", sCurrentQuery ) )
     877             :     {
     878             :         OSL_FAIL( "OQueryController::impl_initialize: CurrentQuery is regognized for compatibility only!" );
     879           0 :         sCommand = sCurrentQuery;
     880           0 :         m_nCommandType = CommandType::QUERY;
     881             :     }
     882             : 
     883           0 :     bool bCreateView( false );
     884           0 :     if ( rArguments.get_ensureType( "CreateView", bCreateView ) && bCreateView )
     885             :     {
     886             :         OSL_FAIL( "OQueryController::impl_initialize: CurrentQuery is regognized for compatibility only!" );
     887           0 :         m_nCommandType = CommandType::TABLE;
     888             :     }
     889             : 
     890             :     // non-legacy parameters which overwrite the legacy parameters
     891           0 :     rArguments.get_ensureType( OUString(PROPERTY_COMMAND), sCommand );
     892           0 :     rArguments.get_ensureType( OUString(PROPERTY_COMMAND_TYPE), m_nCommandType );
     893             : 
     894             :     // translate Command/Type into proper members
     895             :     // TODO/Later: all this (including those members) should be hidden behind some abstact interface,
     896             :     // which is implemented for all the three commands
     897           0 :     switch ( m_nCommandType )
     898             :     {
     899             :     case CommandType::QUERY:
     900           0 :         m_sName = sCommand;
     901           0 :         break;
     902             :     case CommandType::TABLE:
     903           0 :         m_sName = sCommand;
     904           0 :         break;
     905             :     case CommandType::COMMAND:
     906           0 :         setStatement_fireEvent( sCommand );
     907           0 :         m_sName = OUString();
     908           0 :         break;
     909             :     default:
     910             :         OSL_FAIL( "OQueryController::impl_initialize: logic error in code!" );
     911           0 :         throw RuntimeException();
     912             :     }
     913             : 
     914             :     // more legacy parameters
     915           0 :     bool bGraphicalDesign( true );
     916           0 :     if ( rArguments.get_ensureType( OUString(PROPERTY_QUERYDESIGNVIEW), bGraphicalDesign ) )
     917             :     {
     918             :         OSL_FAIL( "OQueryController::impl_initialize: QueryDesignView is regognized for compatibility only!" );
     919           0 :         m_bGraphicalDesign = bGraphicalDesign;
     920             :     }
     921             : 
     922             :     // more non-legacy
     923           0 :     rArguments.get_ensureType( OUString(PROPERTY_GRAPHICAL_DESIGN), m_bGraphicalDesign );
     924             : 
     925           0 :     bool bEscapeProcessing( true );
     926           0 :     if ( rArguments.get_ensureType( OUString(PROPERTY_ESCAPE_PROCESSING), bEscapeProcessing ) )
     927             :     {
     928           0 :         setEscapeProcessing_fireEvent( bEscapeProcessing );
     929             : 
     930             :         OSL_ENSURE( m_bEscapeProcessing || !m_bGraphicalDesign, "OQueryController::impl_initialize: can't do the graphical design without escape processing!" );
     931           0 :         if ( !m_bEscapeProcessing )
     932           0 :             m_bGraphicalDesign = false;
     933             :     }
     934             : 
     935             :     // initial design
     936           0 :     bool bForceInitialDesign = false;
     937           0 :     Sequence< PropertyValue > aCurrentQueryDesignProps;
     938           0 :     aCurrentQueryDesignProps = rArguments.getOrDefault( "CurrentQueryDesign", aCurrentQueryDesignProps );
     939             : 
     940           0 :     if ( aCurrentQueryDesignProps.getLength() )
     941             :     {
     942           0 :         ::comphelper::NamedValueCollection aCurrentQueryDesign( aCurrentQueryDesignProps );
     943           0 :         if ( aCurrentQueryDesign.has( OUString(PROPERTY_GRAPHICAL_DESIGN) ) )
     944             :         {
     945           0 :             aCurrentQueryDesign.get_ensureType( OUString(PROPERTY_GRAPHICAL_DESIGN), m_bGraphicalDesign );
     946             :         }
     947           0 :         if ( aCurrentQueryDesign.has( OUString(PROPERTY_ESCAPE_PROCESSING) ) )
     948             :         {
     949           0 :             aCurrentQueryDesign.get_ensureType( OUString(PROPERTY_ESCAPE_PROCESSING), m_bEscapeProcessing );
     950             :         }
     951           0 :         if ( aCurrentQueryDesign.has( "Statement" ) )
     952             :         {
     953           0 :             OUString sStatement;
     954           0 :             aCurrentQueryDesign.get_ensureType( "Statement", sStatement );
     955           0 :             aCurrentQueryDesign.remove( "Statement" );
     956           0 :             setStatement_fireEvent( sStatement );
     957             :         }
     958             : 
     959           0 :         loadViewSettings( aCurrentQueryDesign );
     960             : 
     961           0 :         bForceInitialDesign = true;
     962             :     }
     963             : 
     964           0 :     if ( !ensureConnected( false ) )
     965             :     {   // we have no connection so what else should we do
     966           0 :         m_bGraphicalDesign = false;
     967           0 :         if ( editingView() )
     968             :         {
     969           0 :             connectionLostMessage();
     970           0 :             throw SQLException();
     971             :         }
     972             :     }
     973             : 
     974             :     // check the view capabilities
     975           0 :     if ( isConnected() && editingView() )
     976             :     {
     977           0 :         Reference< XViewsSupplier > xViewsSup( getConnection(), UNO_QUERY );
     978           0 :         Reference< XNameAccess > xViews;
     979           0 :         if ( xViewsSup.is() )
     980           0 :             xViews = xViewsSup->getViews();
     981             : 
     982           0 :         if ( !xViews.is() )
     983             :         {   // we can't create views so we ask if the user wants to create a query instead
     984           0 :             m_nCommandType = CommandType::QUERY;
     985           0 :             bool bClose = false;
     986             :             {
     987           0 :                 OUString aTitle( ModuleRes( STR_QUERYDESIGN_NO_VIEW_SUPPORT ) );
     988           0 :                 OUString aMessage( ModuleRes( STR_QUERYDESIGN_NO_VIEW_ASK ) );
     989           0 :                 ODataView* pWindow = getView();
     990           0 :                 OSQLMessageBox aDlg( pWindow, aTitle, aMessage, WB_YES_NO | WB_DEF_YES, OSQLMessageBox::Query );
     991           0 :                 bClose = aDlg.Execute() == RET_NO;
     992             :             }
     993           0 :             if ( bClose )
     994           0 :                 throw VetoException();
     995             :         }
     996             : 
     997             :         // now if we are to edit an existing view, check whether this is possible
     998           0 :         if ( !m_sName.isEmpty() )
     999             :         {
    1000           0 :             Any aView( xViews->getByName( m_sName ) );
    1001             :                 // will throw if there is no such view
    1002           0 :             if ( !( aView >>= m_xAlterView ) )
    1003             :             {
    1004             :                 throw IllegalArgumentException(
    1005             :                     OUString( ModuleRes( STR_NO_ALTER_VIEW_SUPPORT ) ),
    1006             :                     *this,
    1007             :                     1
    1008           0 :                 );
    1009           0 :             }
    1010           0 :         }
    1011             :     }
    1012             : 
    1013             :     OSL_ENSURE(getDataSource().is(),"OQueryController::impl_initialize: need a datasource!");
    1014             : 
    1015             :     try
    1016             :     {
    1017           0 :         getContainer()->initialize();
    1018           0 :         impl_reset( bForceInitialDesign );
    1019             : 
    1020           0 :         SQLExceptionInfo aError;
    1021           0 :         const bool bAttemptedGraphicalDesign = m_bGraphicalDesign;
    1022             : 
    1023           0 :         if ( bForceInitialDesign )
    1024             :         {
    1025           0 :             getContainer()->forceInitialView();
    1026             :         }
    1027             :         else
    1028             :         {
    1029           0 :             impl_setViewMode( &aError );
    1030             :         }
    1031             : 
    1032           0 :         if ( aError.isValid() && bAttemptedGraphicalDesign && !m_bGraphicalDesign )
    1033             :         {
    1034             :             // we tried initializing the graphical view, this failed, and we were automatically switched to SQL
    1035             :             // view => tell this to the user
    1036           0 :             if ( !editingView() )
    1037             :             {
    1038           0 :                 impl_showAutoSQLViewError( aError.get() );
    1039             :             }
    1040             :         }
    1041             : 
    1042           0 :         ClearUndoManager();
    1043             : 
    1044           0 :         if  (  ( m_bGraphicalDesign )
    1045           0 :             && (  ( m_sName.isEmpty() && !editingCommand() )
    1046           0 :                || ( m_sStatement.isEmpty() && editingCommand() )
    1047             :                )
    1048             :             )
    1049             :         {
    1050           0 :             Application::PostUserEvent( LINK( this, OQueryController, OnExecuteAddTable ) );
    1051             :         }
    1052             : 
    1053           0 :         setModified(sal_False);
    1054             :     }
    1055           0 :     catch(const SQLException& e)
    1056             :     {
    1057             :         DBG_UNHANDLED_EXCEPTION();
    1058             :         // we caught an exception so we switch to text only mode
    1059             :         {
    1060           0 :             m_bGraphicalDesign = false;
    1061           0 :             getContainer()->initialize();
    1062           0 :             ODataView* pWindow = getView();
    1063           0 :             OSQLMessageBox(pWindow,e).Execute();
    1064             :         }
    1065           0 :         throw;
    1066           0 :     }
    1067           0 : }
    1068             : 
    1069           0 : void OQueryController::onLoadedMenu(const Reference< ::com::sun::star::frame::XLayoutManager >& /*_xLayoutManager*/)
    1070             : {
    1071           0 :     ensureToolbars( *this, m_bGraphicalDesign );
    1072           0 : }
    1073             : 
    1074           0 : OUString OQueryController::getPrivateTitle( ) const
    1075             : {
    1076           0 :     OUString sName = m_sName;
    1077           0 :     if ( sName.isEmpty() )
    1078             :     {
    1079           0 :         if ( !editingCommand() )
    1080             :         {
    1081           0 :             SolarMutexGuard aSolarGuard;
    1082           0 :             ::osl::MutexGuard aGuard( getMutex() );
    1083           0 :             OUString aDefaultName = ModuleRes( editingView() ? STR_VIEW_TITLE : STR_QRY_TITLE );
    1084           0 :             sName = aDefaultName.getToken(0,' ');
    1085           0 :             sName += OUString::number(getCurrentStartNumber());
    1086             :         }
    1087             :     }
    1088           0 :     return sName;
    1089             : }
    1090             : 
    1091           0 : void OQueryController::setQueryComposer()
    1092             : {
    1093           0 :     if(isConnected())
    1094             :     {
    1095           0 :         Reference< XSQLQueryComposerFactory >  xFactory(getConnection(), UNO_QUERY);
    1096             :         OSL_ENSURE(xFactory.is(),"Connection doesn't support a querycomposer");
    1097           0 :         if ( xFactory.is() && getContainer() )
    1098             :         {
    1099             :             try
    1100             :             {
    1101           0 :                 m_xComposer = xFactory->createQueryComposer();
    1102           0 :                 getContainer()->setStatement(m_sStatement);
    1103             :             }
    1104           0 :             catch(const Exception&)
    1105             :             {
    1106           0 :                 m_xComposer = NULL;
    1107             :             }
    1108             :             OSL_ENSURE(m_xComposer.is(),"No querycomposer available!");
    1109           0 :             Reference<XTablesSupplier> xTablesSup(getConnection(), UNO_QUERY);
    1110           0 :             deleteIterator();
    1111           0 :             m_pSqlIterator = new ::connectivity::OSQLParseTreeIterator( getConnection(), xTablesSup->getTables(), m_aSqlParser, NULL );
    1112           0 :         }
    1113             :     }
    1114           0 : }
    1115             : 
    1116           0 : bool OQueryController::Construct(vcl::Window* pParent)
    1117             : {
    1118             :     // TODO: we have to check if we should create the text view or the design view
    1119             : 
    1120           0 :     setView( * new OQueryContainerWindow( pParent, *this, getORB() ) );
    1121             : 
    1122           0 :     return OJoinController::Construct(pParent);
    1123             : }
    1124             : 
    1125           0 : OJoinDesignView* OQueryController::getJoinView()
    1126             : {
    1127           0 :     return getContainer()->getDesignView();
    1128             : }
    1129             : 
    1130           0 : void OQueryController::describeSupportedFeatures()
    1131             : {
    1132           0 :     OJoinController::describeSupportedFeatures();
    1133           0 :     implDescribeSupportedFeature( ".uno:SaveAs",            ID_BROWSER_SAVEASDOC,       CommandGroup::DOCUMENT );
    1134           0 :     implDescribeSupportedFeature( ".uno:SbaNativeSql",      ID_BROWSER_ESACPEPROCESSING,CommandGroup::FORMAT );
    1135           0 :     implDescribeSupportedFeature( ".uno:DBViewFunctions",   SID_QUERY_VIEW_FUNCTIONS,   CommandGroup::VIEW );
    1136           0 :     implDescribeSupportedFeature( ".uno:DBViewTableNames",  SID_QUERY_VIEW_TABLES,      CommandGroup::VIEW );
    1137           0 :     implDescribeSupportedFeature( ".uno:DBViewAliases",     SID_QUERY_VIEW_ALIASES,     CommandGroup::VIEW );
    1138           0 :     implDescribeSupportedFeature( ".uno:DBDistinctValues",  SID_QUERY_DISTINCT_VALUES,  CommandGroup::FORMAT );
    1139           0 :     implDescribeSupportedFeature( ".uno:DBChangeDesignMode",ID_BROWSER_SQL,             CommandGroup::VIEW );
    1140           0 :     implDescribeSupportedFeature( ".uno:DBClearQuery",      SID_BROWSER_CLEAR_QUERY,    CommandGroup::EDIT );
    1141           0 :     implDescribeSupportedFeature( ".uno:SbaExecuteSql",     ID_BROWSER_QUERY_EXECUTE,   CommandGroup::VIEW );
    1142           0 :     implDescribeSupportedFeature( ".uno:DBAddRelation",     SID_RELATION_ADD_RELATION,  CommandGroup::EDIT );
    1143           0 :     implDescribeSupportedFeature( ".uno:DBQueryPreview",    SID_DB_QUERY_PREVIEW,       CommandGroup::VIEW );
    1144           0 :     implDescribeSupportedFeature( ".uno:DBLimit",           SID_QUERY_LIMIT,            CommandGroup::FORMAT );
    1145           0 :     implDescribeSupportedFeature( ".uno:DBQueryPropertiesDialog", SID_QUERY_PROP_DLG,         CommandGroup::FORMAT );
    1146             : 
    1147             : #if OSL_DEBUG_LEVEL > 1
    1148             :     implDescribeSupportedFeature( ".uno:DBShowParseTree",   ID_EDIT_QUERY_SQL );
    1149             :     implDescribeSupportedFeature( ".uno:DBMakeDisjunct",    ID_EDIT_QUERY_DESIGN );
    1150             : #endif
    1151           0 : }
    1152             : 
    1153           0 : void OQueryController::impl_onModifyChanged()
    1154             : {
    1155           0 :     OJoinController::impl_onModifyChanged();
    1156           0 :     InvalidateFeature(SID_BROWSER_CLEAR_QUERY);
    1157           0 :     InvalidateFeature(ID_BROWSER_SAVEASDOC);
    1158           0 :     InvalidateFeature(ID_BROWSER_QUERY_EXECUTE);
    1159           0 : }
    1160             : 
    1161           0 : void SAL_CALL OQueryController::disposing( const EventObject& Source ) throw(RuntimeException, std::exception)
    1162             : {
    1163           0 :     SolarMutexGuard aGuard;
    1164             : 
    1165           0 :     if ( getContainer() && Source.Source.is() )
    1166             :     {
    1167           0 :         if ( Source.Source == m_aCurrentFrame.getFrame() )
    1168             :         {   // our frame is being disposed -> close the preview window (if we have one)
    1169           0 :             Reference< XFrame2 > xPreviewFrame( getContainer()->getPreviewFrame() );
    1170           0 :             ::comphelper::disposeComponent( xPreviewFrame );
    1171             :         }
    1172           0 :         else if ( Source.Source == getContainer()->getPreviewFrame() )
    1173             :         {
    1174           0 :             getContainer()->disposingPreview();
    1175             :         }
    1176             :     }
    1177             : 
    1178           0 :     OJoinController::disposing(Source);
    1179           0 : }
    1180             : 
    1181           0 : void OQueryController::reconnect(bool _bUI)
    1182             : {
    1183           0 :     deleteIterator();
    1184           0 :     ::comphelper::disposeComponent(m_xComposer);
    1185             : 
    1186           0 :     OJoinController::reconnect( _bUI );
    1187             : 
    1188           0 :     if (isConnected())
    1189             :     {
    1190           0 :         setQueryComposer();
    1191             :     }
    1192             :     else
    1193             :     {
    1194           0 :         if(m_bGraphicalDesign)
    1195             :         {
    1196           0 :             m_bGraphicalDesign = false;
    1197             :             // don't call Execute(SQL) because this changes the sql statement
    1198           0 :             impl_setViewMode( NULL );
    1199             :         }
    1200           0 :         InvalidateAll();
    1201             :     }
    1202           0 : }
    1203             : 
    1204           0 : void OQueryController::saveViewSettings( ::comphelper::NamedValueCollection& o_rViewSettings, const bool i_includingCriteria ) const
    1205             : {
    1206           0 :     saveTableWindows( o_rViewSettings );
    1207             : 
    1208           0 :     OTableFields::const_iterator field = m_vTableFieldDesc.begin();
    1209           0 :     OTableFields::const_iterator fieldEnd = m_vTableFieldDesc.end();
    1210             : 
    1211           0 :     ::comphelper::NamedValueCollection aAllFieldsData;
    1212           0 :     ::comphelper::NamedValueCollection aFieldData;
    1213           0 :     for ( sal_Int32 i = 1; field != fieldEnd; ++field, ++i )
    1214             :     {
    1215           0 :         if ( !(*field)->IsEmpty() )
    1216             :         {
    1217           0 :             aFieldData.clear();
    1218           0 :             (*field)->Save( aFieldData, i_includingCriteria );
    1219             : 
    1220           0 :             const OUString sFieldSettingName = "Field" + OUString::number( i );
    1221           0 :             aAllFieldsData.put( sFieldSettingName, aFieldData.getPropertyValues() );
    1222             :         }
    1223             :     }
    1224             : 
    1225           0 :     o_rViewSettings.put( "Fields", aAllFieldsData.getPropertyValues() );
    1226           0 :     o_rViewSettings.put( "SplitterPosition", m_nSplitPos );
    1227           0 :     o_rViewSettings.put( "VisibleRows", m_nVisibleRows );
    1228           0 : }
    1229             : 
    1230           0 : void OQueryController::loadViewSettings( const ::comphelper::NamedValueCollection& o_rViewSettings )
    1231             : {
    1232           0 :     loadTableWindows( o_rViewSettings );
    1233             : 
    1234           0 :     m_nSplitPos = o_rViewSettings.getOrDefault( "SplitterPosition", m_nSplitPos );
    1235           0 :     m_nVisibleRows = o_rViewSettings.getOrDefault( "VisibleRows", m_nVisibleRows );
    1236           0 :     m_aFieldInformation = o_rViewSettings.getOrDefault( "Fields", m_aFieldInformation );
    1237           0 : }
    1238             : 
    1239           0 : void OQueryController::execute_QueryPropDlg()
    1240             : {
    1241             :     QueryPropertiesDialog aQueryPropDlg(
    1242           0 :         getContainer(), m_bDistinct, m_nLimit );
    1243             : 
    1244           0 :     if( aQueryPropDlg.Execute() == RET_OK )
    1245             :     {
    1246           0 :         m_bDistinct = aQueryPropDlg.getDistinct();
    1247           0 :         m_nLimit = aQueryPropDlg.getLimit();
    1248           0 :         InvalidateFeature( SID_QUERY_DISTINCT_VALUES );
    1249           0 :         InvalidateFeature( SID_QUERY_LIMIT, 0, true );
    1250           0 :     }
    1251           0 : }
    1252             : 
    1253           0 : sal_Int32 OQueryController::getColWidth(sal_uInt16 _nColPos)  const
    1254             : {
    1255           0 :     if ( _nColPos < m_aFieldInformation.getLength() )
    1256             :     {
    1257           0 :         ::std::unique_ptr<OTableFieldDesc> pField( new OTableFieldDesc());
    1258           0 :         pField->Load( m_aFieldInformation[ _nColPos ], false );
    1259           0 :         return pField->GetColWidth();
    1260             :     }
    1261           0 :     return 0;
    1262             : }
    1263             : 
    1264           0 : Reference<XNameAccess> OQueryController::getObjectContainer()  const
    1265             : {
    1266           0 :     Reference< XNameAccess > xElements;
    1267           0 :     if ( editingView() )
    1268             :     {
    1269           0 :         Reference< XViewsSupplier > xViewsSupp( getConnection(), UNO_QUERY );
    1270           0 :         if ( xViewsSupp.is() )
    1271           0 :             xElements = xViewsSupp->getViews();
    1272             :     }
    1273             :     else
    1274             :     {
    1275           0 :         Reference< XQueriesSupplier > xQueriesSupp( getConnection(), UNO_QUERY );
    1276           0 :         if ( xQueriesSupp.is() )
    1277           0 :             xElements = xQueriesSupp->getQueries();
    1278             :         else
    1279             :         {
    1280           0 :             Reference< XQueryDefinitionsSupplier > xQueryDefsSupp( getDataSource(), UNO_QUERY );
    1281           0 :             if ( xQueryDefsSupp.is() )
    1282           0 :                 xElements = xQueryDefsSupp->getQueryDefinitions();
    1283           0 :         }
    1284             :     }
    1285             : 
    1286             :     OSL_ENSURE( xElements.is(), "OQueryController::getObjectContainer: unable to obtain the container!" );
    1287           0 :     return xElements;
    1288             : }
    1289             : 
    1290           0 : void OQueryController::executeQuery()
    1291             : {
    1292             :     // we don't need to check the connection here because we already check the composer
    1293             :     // which can't live without his connection
    1294           0 :     OUString sTranslatedStmt = translateStatement( false );
    1295             : 
    1296           0 :     OUString sDataSourceName = getDataSourceName();
    1297           0 :     if ( !(sDataSourceName.isEmpty() || sTranslatedStmt.isEmpty()) )
    1298             :     {
    1299             :         try
    1300             :         {
    1301           0 :             getContainer()->showPreview( getFrame() );
    1302           0 :             InvalidateFeature(SID_DB_QUERY_PREVIEW);
    1303             : 
    1304           0 :             URL aWantToDispatch;
    1305           0 :             aWantToDispatch.Complete = ".component:DB/DataSourceBrowser";
    1306             : 
    1307           0 :             OUString sFrameName( FRAME_NAME_QUERY_PREVIEW );
    1308           0 :             sal_Int32 nSearchFlags = FrameSearchFlag::CHILDREN;
    1309             : 
    1310           0 :             Reference< XDispatch> xDisp;
    1311           0 :             Reference< XDispatchProvider> xProv( getFrame()->findFrame( sFrameName, nSearchFlags ), UNO_QUERY );
    1312           0 :             if(!xProv.is())
    1313             :             {
    1314           0 :                 xProv.set( getFrame(), UNO_QUERY );
    1315           0 :                 if (xProv.is())
    1316           0 :                     xDisp = xProv->queryDispatch(aWantToDispatch, sFrameName, nSearchFlags);
    1317             :             }
    1318             :             else
    1319             :             {
    1320           0 :                 xDisp = xProv->queryDispatch(aWantToDispatch, sFrameName, FrameSearchFlag::SELF);
    1321             :             }
    1322           0 :             if (xDisp.is())
    1323             :             {
    1324           0 :                 Sequence< PropertyValue> aProps(9);
    1325           0 :                 aProps[0].Name = PROPERTY_DATASOURCENAME;
    1326           0 :                 aProps[0].Value <<= sDataSourceName;
    1327             : 
    1328           0 :                 aProps[1].Name = PROPERTY_COMMAND_TYPE;
    1329           0 :                 aProps[1].Value <<= CommandType::COMMAND;
    1330             : 
    1331           0 :                 aProps[2].Name = PROPERTY_COMMAND;
    1332           0 :                 aProps[2].Value <<= sTranslatedStmt;
    1333             : 
    1334           0 :                 aProps[3].Name = PROPERTY_ENABLE_BROWSER;
    1335           0 :                 aProps[3].Value <<= false;
    1336             : 
    1337           0 :                 aProps[4].Name = PROPERTY_ACTIVE_CONNECTION;
    1338           0 :                 aProps[4].Value <<= getConnection();
    1339             : 
    1340           0 :                 aProps[5].Name = PROPERTY_UPDATE_CATALOGNAME;
    1341           0 :                 aProps[5].Value <<= m_sUpdateCatalogName;
    1342             : 
    1343           0 :                 aProps[6].Name = PROPERTY_UPDATE_SCHEMANAME;
    1344           0 :                 aProps[6].Value <<= m_sUpdateSchemaName;
    1345             : 
    1346           0 :                 aProps[7].Name = PROPERTY_UPDATE_TABLENAME;
    1347           0 :                 aProps[7].Value <<= m_sUpdateTableName;
    1348             : 
    1349           0 :                 aProps[8].Name = PROPERTY_ESCAPE_PROCESSING;
    1350           0 :                 aProps[8].Value <<= m_bEscapeProcessing;
    1351             : 
    1352           0 :                 xDisp->dispatch(aWantToDispatch, aProps);
    1353             :                 // check the state of the beamer
    1354             :                 // be notified when the beamer frame is closed
    1355           0 :                 Reference< XComponent >  xComponent( getFrame()->findFrame( sFrameName, nSearchFlags ), UNO_QUERY );
    1356           0 :                 if (xComponent.is())
    1357             :                 {
    1358             :                     OSL_ENSURE(Reference< XFrame >(xComponent, UNO_QUERY).get() == getContainer()->getPreviewFrame().get(),
    1359             :                         "OQueryController::executeQuery: oops ... which window do I have here?");
    1360           0 :                     Reference< XEventListener> xEvtL((::cppu::OWeakObject*)this,UNO_QUERY);
    1361           0 :                     xComponent->addEventListener(xEvtL);
    1362           0 :                 }
    1363             :             }
    1364             :             else
    1365             :             {
    1366             :                 OSL_FAIL("Couldn't create a beamer window!");
    1367           0 :             }
    1368             :         }
    1369           0 :         catch(const Exception&)
    1370             :         {
    1371             :             OSL_FAIL("Couldn't create a beamer window!");
    1372             :         }
    1373           0 :     }
    1374           0 : }
    1375             : 
    1376           0 : bool OQueryController::askForNewName(const Reference<XNameAccess>& _xElements, bool _bSaveAs)
    1377             : {
    1378             :     OSL_ENSURE( !editingCommand(), "OQueryController::askForNewName: not to be called when designing an independent statement!" );
    1379           0 :     if ( editingCommand() )
    1380           0 :         return false;
    1381             : 
    1382             :     OSL_PRECOND( _xElements.is(), "OQueryController::askForNewName: invalid container!" );
    1383           0 :     if  ( !_xElements.is() )
    1384           0 :         return false;
    1385             : 
    1386           0 :     bool bRet = true;
    1387           0 :     bool bNew = _bSaveAs || !_xElements->hasByName( m_sName );
    1388           0 :     if(bNew)
    1389             :     {
    1390           0 :         OUString aDefaultName;
    1391           0 :         if ( ( _bSaveAs && !bNew ) || ( bNew && !m_sName.isEmpty() ) )
    1392           0 :             aDefaultName = m_sName;
    1393             :         else
    1394             :         {
    1395           0 :             OUString sName = ModuleRes( editingView() ? STR_VIEW_TITLE : STR_QRY_TITLE );
    1396           0 :             aDefaultName = sName.getToken(0,' ');
    1397           0 :             aDefaultName = ::dbtools::createUniqueName(_xElements,aDefaultName);
    1398             :         }
    1399             : 
    1400           0 :         DynamicTableOrQueryNameCheck aNameChecker( getConnection(), CommandType::QUERY );
    1401             :         OSaveAsDlg aDlg(
    1402           0 :                 getView(),
    1403             :                 m_nCommandType,
    1404             :                 getORB(),
    1405           0 :                 getConnection(),
    1406             :                 aDefaultName,
    1407             :                 aNameChecker,
    1408           0 :                 SAD_DEFAULT );
    1409             : 
    1410           0 :         bRet = ( aDlg.Execute() == RET_OK );
    1411           0 :         if ( bRet )
    1412             :         {
    1413           0 :             m_sName = aDlg.getName();
    1414           0 :             if ( editingView() )
    1415             :             {
    1416           0 :                 m_sUpdateCatalogName    = aDlg.getCatalog();
    1417           0 :                 m_sUpdateSchemaName     = aDlg.getSchema();
    1418             :             }
    1419           0 :         }
    1420             :     }
    1421           0 :     return bRet;
    1422             : }
    1423             : 
    1424           0 : bool OQueryController::doSaveAsDoc(bool _bSaveAs)
    1425             : {
    1426             :     OSL_ENSURE(isEditable(),"Slot ID_BROWSER_SAVEDOC should not be enabled!");
    1427           0 :     if ( !editingCommand() && !haveDataSource() )
    1428             :     {
    1429           0 :         OUString aMessage(ModuleRes(STR_DATASOURCE_DELETED));
    1430           0 :         OSQLWarningBox( getView(), aMessage ).Execute();
    1431           0 :         return false;
    1432             :     }
    1433             : 
    1434           0 :     Reference< XNameAccess > xElements = getObjectContainer();
    1435           0 :     if ( !xElements.is() )
    1436           0 :         return false;
    1437             : 
    1438           0 :     if ( !getContainer()->checkStatement() )
    1439           0 :         return false;
    1440             : 
    1441           0 :     OUString sTranslatedStmt = translateStatement();
    1442           0 :     if ( editingCommand() )
    1443             :     {
    1444           0 :         setModified( sal_False );
    1445             :         // this is all we need to do here. translateStatement implicitly set our m_sStatement, and
    1446             :         // notified it, and that's all
    1447           0 :         return true;
    1448             :     }
    1449             : 
    1450           0 :     if ( sTranslatedStmt.isEmpty() )
    1451           0 :         return false;
    1452             : 
    1453             :     // first we need a name for our query so ask the user
    1454             :     // did we get a name
    1455           0 :     OUString sOriginalName( m_sName );
    1456           0 :     if ( !askForNewName( xElements, _bSaveAs ) || m_sName.isEmpty() )
    1457           0 :         return false;
    1458             : 
    1459           0 :     SQLExceptionInfo aInfo;
    1460           0 :     bool bSuccess = false;
    1461           0 :     bool bNew = false;
    1462             :     try
    1463             :     {
    1464             :         bNew = ( _bSaveAs )
    1465           0 :             || ( !xElements->hasByName( m_sName ) );
    1466             : 
    1467           0 :         Reference<XPropertySet> xQuery;
    1468           0 :         if ( bNew ) // just to make sure the query already exists
    1469             :         {
    1470             :             // drop the query, in case it already exists
    1471           0 :             if ( xElements->hasByName( m_sName ) )
    1472             :             {
    1473           0 :                 Reference< XDrop > xNameCont( xElements, UNO_QUERY );
    1474           0 :                 if ( xNameCont.is() )
    1475           0 :                     xNameCont->dropByName( m_sName );
    1476             :                 else
    1477             :                 {
    1478           0 :                     Reference< XNameContainer > xCont( xElements, UNO_QUERY );
    1479           0 :                     if ( xCont.is() )
    1480           0 :                         xCont->removeByName( m_sName );
    1481           0 :                 }
    1482             :             }
    1483             : 
    1484             :             // create a new (empty, uninitialized) query resp. view
    1485           0 :             Reference< XDataDescriptorFactory > xFact( xElements, UNO_QUERY );
    1486           0 :             if ( xFact.is() )
    1487             :             {
    1488           0 :                 xQuery = xFact->createDataDescriptor();
    1489             :                 // to set the name is only allowed when the query is new
    1490           0 :                 xQuery->setPropertyValue( PROPERTY_NAME, makeAny( m_sName ) );
    1491             :             }
    1492             :             else
    1493             :             {
    1494           0 :                 Reference< XSingleServiceFactory > xSingleFac( xElements, UNO_QUERY );
    1495           0 :                 if ( xSingleFac.is() )
    1496           0 :                     xQuery.set(xSingleFac->createInstance(), css::uno::UNO_QUERY);
    1497           0 :             }
    1498             :         }
    1499             :         else
    1500             :         {
    1501           0 :             xElements->getByName( m_sName ) >>= xQuery;
    1502             :         }
    1503           0 :         if ( !xQuery.is() )
    1504           0 :             throw RuntimeException();
    1505             : 
    1506             :         // the new commands
    1507           0 :         if ( editingView() && !bNew )
    1508             :         {
    1509             :             OSL_ENSURE( xQuery == m_xAlterView, "OQueryController::doSaveAsDoc: already have another alterable view ...!?" );
    1510           0 :             m_xAlterView.set( xQuery, UNO_QUERY_THROW );
    1511           0 :             m_xAlterView->alterCommand( sTranslatedStmt );
    1512             :         }
    1513             :         else
    1514             :         {   // we're creating a query, or a *new* view
    1515           0 :             xQuery->setPropertyValue( PROPERTY_COMMAND, makeAny( sTranslatedStmt ) );
    1516             : 
    1517           0 :             if ( editingView() )
    1518             :             {
    1519           0 :                 xQuery->setPropertyValue( PROPERTY_CATALOGNAME, makeAny( m_sUpdateCatalogName ) );
    1520           0 :                 xQuery->setPropertyValue( PROPERTY_SCHEMANAME, makeAny( m_sUpdateSchemaName ) );
    1521             :             }
    1522             : 
    1523           0 :             if ( editingQuery() )
    1524             :             {
    1525           0 :                 xQuery->setPropertyValue( PROPERTY_UPDATE_TABLENAME, makeAny( m_sUpdateTableName ) );
    1526           0 :                 xQuery->setPropertyValue( PROPERTY_ESCAPE_PROCESSING, css::uno::makeAny( m_bEscapeProcessing ) );
    1527             : 
    1528           0 :                 xQuery->setPropertyValue( PROPERTY_LAYOUTINFORMATION, getViewData() );
    1529             :             }
    1530             :         }
    1531             : 
    1532           0 :         if ( bNew )
    1533             :         {
    1534           0 :             Reference< XAppend > xAppend( xElements, UNO_QUERY );
    1535           0 :             if ( xAppend.is() )
    1536             :             {
    1537           0 :                 xAppend->appendByDescriptor( xQuery );
    1538             :             }
    1539             :             else
    1540             :             {
    1541           0 :                 Reference< XNameContainer > xCont( xElements, UNO_QUERY );
    1542           0 :                 if ( xCont.is() )
    1543           0 :                     xCont->insertByName( m_sName, makeAny( xQuery ) );
    1544             :             }
    1545             : 
    1546           0 :             if ( editingView() )
    1547             :             {
    1548           0 :                 Reference< XPropertySet > xViewProps;
    1549           0 :                 if ( xElements->hasByName( m_sName ) )
    1550           0 :                     xViewProps.set( xElements->getByName( m_sName ), UNO_QUERY );
    1551             : 
    1552           0 :                 if ( !xViewProps.is() ) // correct name and try again
    1553           0 :                     m_sName = ::dbtools::composeTableName( getMetaData(), xQuery, ::dbtools::eInDataManipulation, false, false, false );
    1554             : 
    1555             :                 OSL_ENSURE( xElements->hasByName( m_sName ), "OQueryController::doSaveAsDoc: newly creaed view does not exist!" );
    1556             : 
    1557           0 :                 if ( xElements->hasByName( m_sName ) )
    1558           0 :                     m_xAlterView.set( xElements->getByName( m_sName ), UNO_QUERY );
    1559             : 
    1560             :                 // now check if our datasource has set a tablefilter and if so, append the new table name to it
    1561           0 :                 ::dbaui::appendToFilter( getConnection(), m_sName, getORB(), getView() );
    1562             :             }
    1563           0 :             Reference< XTitleChangeListener> xEventListener(impl_getTitleHelper_throw(),UNO_QUERY);
    1564           0 :             if ( xEventListener.is() )
    1565             :             {
    1566           0 :                 TitleChangedEvent aEvent;
    1567           0 :                 xEventListener->titleChanged(aEvent);
    1568             :             }
    1569           0 :             releaseNumberForComponent();
    1570             :         }
    1571             : 
    1572           0 :         setModified( sal_False );
    1573           0 :         bSuccess = true;
    1574             : 
    1575             :     }
    1576           0 :     catch(const SQLException&)
    1577             :     {
    1578           0 :         if ( !bNew )
    1579           0 :             m_sName = sOriginalName;
    1580           0 :         aInfo = SQLExceptionInfo( ::cppu::getCaughtException() );
    1581             :     }
    1582           0 :     catch(const Exception&)
    1583             :     {
    1584           0 :         if ( !bNew )
    1585           0 :             m_sName = sOriginalName;
    1586             :         DBG_UNHANDLED_EXCEPTION();
    1587             :     }
    1588             : 
    1589           0 :     showError( aInfo );
    1590             : 
    1591             :     // if we successfully saved a view we were creating, then close the designer
    1592           0 :     if ( bSuccess && editingView() && !m_xAlterView.is() )
    1593             :     {
    1594           0 :         closeTask();
    1595             :     }
    1596             : 
    1597           0 :     if ( bSuccess && editingView() )
    1598           0 :         InvalidateFeature( ID_BROWSER_EDITDOC );
    1599             : 
    1600           0 :     return bSuccess;
    1601             : }
    1602             : 
    1603             : namespace {
    1604           0 : struct CommentStrip
    1605             : {
    1606             :     OUString maComment;
    1607             :     bool            mbLastOnLine;
    1608           0 :     CommentStrip( const OUString& rComment, bool bLastOnLine )
    1609           0 :         : maComment( rComment), mbLastOnLine( bLastOnLine) {}
    1610             : };
    1611             : 
    1612             : }
    1613             : 
    1614             : /** Obtain all comments in a query.
    1615             : 
    1616             :     See also delComment() implementation for OSQLParser::parseTree().
    1617             :  */
    1618           0 : static ::std::vector< CommentStrip > getComment( const OUString& rQuery )
    1619             : {
    1620           0 :     ::std::vector< CommentStrip > aRet;
    1621             :     // First a quick search if there is any "--" or "//" or "/*", if not then
    1622             :     // the whole copying loop is pointless.
    1623           0 :     if (rQuery.indexOfAsciiL( "--", 2, 0) < 0 && rQuery.indexOfAsciiL( "//", 2, 0) < 0 &&
    1624           0 :             rQuery.indexOfAsciiL( "/*", 2, 0) < 0)
    1625           0 :         return aRet;
    1626             : 
    1627           0 :     const sal_Unicode* pCopy = rQuery.getStr();
    1628           0 :     const sal_Int32 nQueryLen = rQuery.getLength();
    1629           0 :     bool bIsText1  = false;     // "text"
    1630           0 :     bool bIsText2  = false;     // 'text'
    1631           0 :     bool bComment2 = false;     // /* comment */
    1632           0 :     bool bComment  = false;     // -- or // comment
    1633           0 :     OUStringBuffer aBuf;
    1634           0 :     for (sal_Int32 i=0; i < nQueryLen; ++i)
    1635             :     {
    1636           0 :         if (bComment2)
    1637             :         {
    1638           0 :             aBuf.append( &pCopy[i], 1);
    1639           0 :             if ((i+1) < nQueryLen)
    1640             :             {
    1641           0 :                 if (pCopy[i]=='*' && pCopy[i+1]=='/')
    1642             :                 {
    1643           0 :                     bComment2 = false;
    1644           0 :                     aBuf.append( &pCopy[++i], 1);
    1645           0 :                     aRet.push_back( CommentStrip( aBuf.makeStringAndClear(), false));
    1646             :                 }
    1647             :             }
    1648             :             else
    1649             :             {
    1650             :                 // comment can't close anymore, actually an error, but..
    1651           0 :                 aRet.push_back( CommentStrip( aBuf.makeStringAndClear(), false));
    1652             :             }
    1653           0 :             continue;
    1654             :         }
    1655           0 :         if (pCopy[i] == '\n' || i == nQueryLen-1)
    1656             :         {
    1657           0 :             if (bComment)
    1658             :             {
    1659           0 :                 if (i == nQueryLen-1 && pCopy[i] != '\n')
    1660           0 :                     aBuf.append( &pCopy[i], 1);
    1661           0 :                 aRet.push_back( CommentStrip( aBuf.makeStringAndClear(), true));
    1662           0 :                 bComment = false;
    1663             :             }
    1664           0 :             else if (!aRet.empty())
    1665           0 :                 aRet.back().mbLastOnLine = true;
    1666             :         }
    1667           0 :         else if (!bComment)
    1668             :         {
    1669           0 :             if (pCopy[i] == '\"' && !bIsText2)
    1670           0 :                 bIsText1 = !bIsText1;
    1671           0 :             else if (pCopy[i] == '\'' && !bIsText1)
    1672           0 :                 bIsText2 = !bIsText2;
    1673           0 :             if (!bIsText1 && !bIsText2 && (i+1) < nQueryLen)
    1674             :             {
    1675           0 :                 if ((pCopy[i]=='-' && pCopy[i+1]=='-') || (pCopy[i]=='/' && pCopy[i+1]=='/'))
    1676           0 :                     bComment = true;
    1677           0 :                 else if ((pCopy[i]=='/' && pCopy[i+1]=='*'))
    1678           0 :                     bComment2 = true;
    1679             :             }
    1680             :         }
    1681           0 :         if (bComment || bComment2)
    1682           0 :             aBuf.append( &pCopy[i], 1);
    1683             :     }
    1684           0 :     return aRet;
    1685             : }
    1686             : 
    1687             : /** Concat/insert comments that were previously obtained with getComment().
    1688             : 
    1689             :     NOTE: The current parser implementation does not preserve newlines, so all
    1690             :     comments are always appended to the entire query, also inline comments
    1691             :     that would need positioning anyway that can't be obtained after
    1692             :     recomposition. This is ugly but at least allows commented queries while
    1693             :     preserving the comments _somehow_.
    1694             :  */
    1695           0 : static OUString concatComment( const OUString& rQuery, const ::std::vector< CommentStrip >& rComments )
    1696             : {
    1697             :     // No comments => return query.
    1698           0 :     if (rComments.empty())
    1699           0 :         return rQuery;
    1700             : 
    1701           0 :     const sal_Unicode* pBeg = rQuery.getStr();
    1702           0 :     const sal_Int32 nLen = rQuery.getLength();
    1703           0 :     const size_t nComments = rComments.size();
    1704             :     // Obtaining the needed size once should be faster than reallocating.
    1705             :     // Also add a blank or linefeed for each comment.
    1706           0 :     sal_Int32 nBufSize = nLen + nComments;
    1707           0 :     for (::std::vector< CommentStrip >::const_iterator it( rComments.begin()); it != rComments.end(); ++it)
    1708           0 :         nBufSize += (*it).maComment.getLength();
    1709           0 :     OUStringBuffer aBuf( nBufSize );
    1710           0 :     sal_Int32 nIndBeg = 0;
    1711           0 :     sal_Int32 nIndLF = rQuery.indexOf('\n');
    1712           0 :     size_t i = 0;
    1713           0 :     while (nIndLF >= 0 && i < nComments)
    1714             :     {
    1715           0 :         aBuf.append( pBeg + nIndBeg, nIndLF - nIndBeg);
    1716           0 :         do
    1717             :         {
    1718           0 :             aBuf.append( rComments[i].maComment);
    1719           0 :         } while (!rComments[i++].mbLastOnLine && i < nComments);
    1720           0 :         aBuf.append( pBeg + nIndLF, 1);     // the LF
    1721           0 :         nIndBeg = nIndLF + 1;
    1722           0 :         nIndLF = (nIndBeg < nLen ? rQuery.indexOf( '\n', nIndBeg) : -1);
    1723             :     }
    1724             :     // Append remainder of query.
    1725           0 :     if (nIndBeg < nLen)
    1726           0 :         aBuf.append( pBeg + nIndBeg, nLen - nIndBeg);
    1727             :     // Append all remaining comments, preserve lines.
    1728           0 :     bool bNewLine = false;
    1729           0 :     for ( ; i < nComments; ++i)
    1730             :     {
    1731           0 :         if (!bNewLine)
    1732           0 :             aBuf.append( ' ');
    1733           0 :         aBuf.append( rComments[i].maComment);
    1734           0 :         if (rComments[i].mbLastOnLine)
    1735             :         {
    1736           0 :             aBuf.append( '\n');
    1737           0 :             bNewLine = true;
    1738             :         }
    1739             :         else
    1740           0 :             bNewLine = false;
    1741             :     }
    1742           0 :     return aBuf.makeStringAndClear();
    1743             : }
    1744             : 
    1745           0 : OUString OQueryController::translateStatement( bool _bFireStatementChange )
    1746             : {
    1747             :     // now set the properties
    1748           0 :     setStatement_fireEvent( getContainer()->getStatement(), _bFireStatementChange );
    1749           0 :     OUString sTranslatedStmt;
    1750           0 :     if(!m_sStatement.isEmpty() && m_xComposer.is() && m_bEscapeProcessing)
    1751             :     {
    1752             :         try
    1753             :         {
    1754           0 :             OUString aErrorMsg;
    1755             : 
    1756           0 :             ::std::vector< CommentStrip > aComments = getComment( m_sStatement);
    1757             : 
    1758           0 :             ::connectivity::OSQLParseNode* pNode = m_aSqlParser.parseTree( aErrorMsg, m_sStatement, m_bGraphicalDesign );
    1759           0 :             if(pNode)
    1760             :             {
    1761           0 :                 pNode->parseNodeToStr( sTranslatedStmt, getConnection() );
    1762           0 :                 delete pNode;
    1763             :             }
    1764             : 
    1765           0 :             m_xComposer->setQuery(sTranslatedStmt);
    1766           0 :             sTranslatedStmt = m_xComposer->getComposedQuery();
    1767           0 :             sTranslatedStmt = concatComment( sTranslatedStmt, aComments);
    1768             :         }
    1769           0 :         catch(const SQLException& e)
    1770             :         {
    1771           0 :             ::dbtools::SQLExceptionInfo aInfo(e);
    1772           0 :             showError(aInfo);
    1773             :             // an error occurred so we clear the statement
    1774           0 :             sTranslatedStmt = OUString();
    1775             :         }
    1776             :     }
    1777           0 :     else if(m_sStatement.isEmpty())
    1778             :     {
    1779           0 :         ModuleRes aModuleRes(STR_QRY_NOSELECT);
    1780           0 :         OUString sTmpStr(aModuleRes);
    1781           0 :         OUString sError(sTmpStr);
    1782           0 :         showError(SQLException(sError,NULL,"S1000",1000,Any()));
    1783             :     }
    1784             :     else
    1785           0 :         sTranslatedStmt = m_sStatement;
    1786             : 
    1787           0 :     return sTranslatedStmt;
    1788             : }
    1789             : 
    1790           0 : short OQueryController::saveModified()
    1791             : {
    1792           0 :     SolarMutexGuard aSolarGuard;
    1793           0 :     ::osl::MutexGuard aGuard( getMutex() );
    1794           0 :     short nRet = RET_YES;
    1795           0 :     if ( !isConnected() || !isModified() )
    1796           0 :         return nRet;
    1797             : 
    1798           0 :     if  (  !m_bGraphicalDesign
    1799           0 :         || (  !m_vTableFieldDesc.empty()
    1800           0 :            && !m_vTableData.empty()
    1801             :            )
    1802             :         )
    1803             :     {
    1804           0 :         OUString sMessageText( lcl_getObjectResourceString( STR_QUERY_SAVEMODIFIED, m_nCommandType ) );
    1805           0 :         QueryBox aQry( getView(), WB_YES_NO_CANCEL | WB_DEF_YES, sMessageText );
    1806             : 
    1807           0 :         nRet = aQry.Execute();
    1808           0 :         if  (   ( nRet == RET_YES )
    1809           0 :             &&  !doSaveAsDoc( false )
    1810             :             )
    1811             :         {
    1812           0 :             nRet = RET_CANCEL;
    1813           0 :         }
    1814             :     }
    1815           0 :     return nRet;
    1816             : }
    1817             : 
    1818           0 : void OQueryController::impl_reset( const bool i_bForceCurrentControllerSettings )
    1819             : {
    1820           0 :     bool bValid = false;
    1821             : 
    1822           0 :     Sequence< PropertyValue > aLayoutInformation;
    1823             :     // get command from the query if a query name was supplied
    1824           0 :     if ( !i_bForceCurrentControllerSettings && !editingCommand() )
    1825             :     {
    1826           0 :         if ( !m_sName.isEmpty() )
    1827             :         {
    1828           0 :             Reference< XNameAccess > xQueries = getObjectContainer();
    1829           0 :             if ( xQueries.is() )
    1830             :             {
    1831           0 :                 Reference< XPropertySet > xProp;
    1832           0 :                 if( xQueries->hasByName( m_sName ) && ( xQueries->getByName( m_sName ) >>= xProp ) && xProp.is() )
    1833             :                 {
    1834           0 :                     OUString sNewStatement;
    1835           0 :                     xProp->getPropertyValue( PROPERTY_COMMAND ) >>= sNewStatement;
    1836           0 :                     setStatement_fireEvent( sNewStatement );
    1837             : 
    1838           0 :                     bool bNewEscapeProcessing( true );
    1839           0 :                     if ( editingQuery() )
    1840             :                     {
    1841           0 :                         xProp->getPropertyValue( PROPERTY_ESCAPE_PROCESSING ) >>= bNewEscapeProcessing;
    1842           0 :                         setEscapeProcessing_fireEvent( bNewEscapeProcessing );
    1843             :                     }
    1844             : 
    1845           0 :                     m_bGraphicalDesign = m_bGraphicalDesign && m_bEscapeProcessing;
    1846           0 :                     bValid = true;
    1847             : 
    1848             :                     try
    1849             :                     {
    1850           0 :                         if ( editingQuery() )
    1851           0 :                             xProp->getPropertyValue( PROPERTY_LAYOUTINFORMATION ) >>= aLayoutInformation;
    1852             :                     }
    1853           0 :                     catch( const Exception& )
    1854             :                     {
    1855             :                         OSL_FAIL( "OQueryController::impl_reset: could not retrieve the layout information from the query!" );
    1856           0 :                     }
    1857           0 :                 }
    1858           0 :             }
    1859             :         }
    1860             :     }
    1861             :     else
    1862             :     {
    1863           0 :         bValid = true;
    1864             :         // assume that we got all necessary information during initialization
    1865             :     }
    1866             : 
    1867           0 :     if ( bValid )
    1868             :     {
    1869             :         // load the layoutInformation
    1870           0 :         if ( aLayoutInformation.getLength() )
    1871             :         {
    1872             :             try
    1873             :             {
    1874           0 :                 loadViewSettings( aLayoutInformation );
    1875             :             }
    1876           0 :             catch( const Exception& )
    1877             :             {
    1878             :                 DBG_UNHANDLED_EXCEPTION();
    1879             :             }
    1880             :         }
    1881             : 
    1882           0 :         if ( !m_sStatement.isEmpty() )
    1883             :         {
    1884           0 :             setQueryComposer();
    1885             : 
    1886           0 :             bool bError( false );
    1887             : 
    1888           0 :             if ( !m_pSqlIterator )
    1889             :             {
    1890           0 :                 bError = true;
    1891             :             }
    1892           0 :             else if ( m_bEscapeProcessing )
    1893             :             {
    1894           0 :                 OUString aErrorMsg;
    1895             :                 ::std::unique_ptr< ::connectivity::OSQLParseNode > pNode(
    1896           0 :                     m_aSqlParser.parseTree( aErrorMsg, m_sStatement, m_bGraphicalDesign ) );
    1897             : 
    1898           0 :                 if ( pNode.get() )
    1899             :                 {
    1900           0 :                     delete m_pSqlIterator->getParseTree();
    1901           0 :                     m_pSqlIterator->setParseTree( pNode.release() );
    1902           0 :                     m_pSqlIterator->traverseAll();
    1903           0 :                     if ( m_pSqlIterator->hasErrors() )
    1904             :                     {
    1905           0 :                         if ( !i_bForceCurrentControllerSettings && m_bGraphicalDesign && !editingView() )
    1906             :                         {
    1907           0 :                             impl_showAutoSQLViewError( makeAny( m_pSqlIterator->getErrors() ) );
    1908             :                         }
    1909           0 :                         bError = true;
    1910             :                     }
    1911             :                 }
    1912             :                 else
    1913             :                 {
    1914           0 :                     if ( !i_bForceCurrentControllerSettings && !editingView() )
    1915             :                     {
    1916           0 :                         OUString aTitle(ModuleRes(STR_SVT_SQL_SYNTAX_ERROR));
    1917           0 :                         OSQLMessageBox aDlg(getView(),aTitle,aErrorMsg);
    1918           0 :                         aDlg.Execute();
    1919             :                     }
    1920           0 :                     bError = true;
    1921           0 :                 }
    1922             :             }
    1923             : 
    1924           0 :             if ( bError )
    1925             :             {
    1926           0 :                 m_bGraphicalDesign = false;
    1927           0 :                 if ( editingView() )
    1928             :                     // if we're editing a view whose statement could not be parsed, default to "no escape processing"
    1929           0 :                     setEscapeProcessing_fireEvent( false );
    1930             :             }
    1931             :         }
    1932             :     }
    1933             : 
    1934           0 :     if(!m_pSqlIterator)
    1935           0 :         setQueryComposer();
    1936             :     OSL_ENSURE(m_pSqlIterator,"No SQLIterator set!");
    1937             : 
    1938           0 :     getContainer()->setNoneVisbleRow(m_nVisibleRows);
    1939           0 : }
    1940             : 
    1941           0 : void OQueryController::reset()
    1942             : {
    1943           0 :     impl_reset();
    1944           0 :     getContainer()->reset( NULL );
    1945           0 :     ClearUndoManager();
    1946           0 : }
    1947             : 
    1948           0 : void OQueryController::setStatement_fireEvent( const OUString& _rNewStatement, bool _bFireStatementChange )
    1949             : {
    1950           0 :     Any aOldValue = makeAny( m_sStatement );
    1951           0 :     m_sStatement = _rNewStatement;
    1952           0 :     Any aNewValue = makeAny( m_sStatement );
    1953             : 
    1954           0 :     sal_Int32 nHandle = PROPERTY_ID_ACTIVECOMMAND;
    1955           0 :     if ( _bFireStatementChange )
    1956           0 :         fire( &nHandle, &aNewValue, &aOldValue, 1, sal_False );
    1957           0 : }
    1958             : 
    1959           0 : void OQueryController::setEscapeProcessing_fireEvent( const bool _bEscapeProcessing )
    1960             : {
    1961           0 :     if ( _bEscapeProcessing == m_bEscapeProcessing )
    1962           0 :         return;
    1963             : 
    1964           0 :     Any aOldValue = makeAny( m_bEscapeProcessing );
    1965           0 :     m_bEscapeProcessing = _bEscapeProcessing;
    1966           0 :     Any aNewValue = makeAny( m_bEscapeProcessing );
    1967             : 
    1968           0 :     sal_Int32 nHandle = PROPERTY_ID_ESCAPE_PROCESSING;
    1969           0 :     fire( &nHandle, &aNewValue, &aOldValue, 1, sal_False );
    1970             : }
    1971             : 
    1972           0 : IMPL_LINK( OQueryController, OnExecuteAddTable, void*, /*pNotInterestedIn*/ )
    1973             : {
    1974           0 :     Execute( ID_BROWSER_ADDTABLE,Sequence<PropertyValue>() );
    1975           0 :     return 0L;
    1976             : }
    1977             : 
    1978           0 : bool OQueryController::allowViews() const
    1979             : {
    1980           0 :     return true;
    1981             : }
    1982             : 
    1983           0 : bool OQueryController::allowQueries() const
    1984             : {
    1985             :     OSL_ENSURE( getSdbMetaData().isConnected(), "OQueryController::allowQueries: illegal call!" );
    1986           0 :     if ( !getSdbMetaData().supportsSubqueriesInFrom() )
    1987           0 :         return false;
    1988             : 
    1989           0 :     const NamedValueCollection& rArguments( getInitParams() );
    1990           0 :     sal_Int32 nCommandType = rArguments.getOrDefault( OUString(PROPERTY_COMMAND_TYPE), (sal_Int32)CommandType::QUERY );
    1991           0 :     bool bCreatingView = ( nCommandType == CommandType::TABLE );
    1992           0 :     return !bCreatingView;
    1993             : }
    1994             : 
    1995           0 : Any SAL_CALL OQueryController::getViewData() throw( RuntimeException, std::exception )
    1996             : {
    1997           0 :     ::osl::MutexGuard aGuard( getMutex() );
    1998             : 
    1999           0 :     getContainer()->SaveUIConfig();
    2000             : 
    2001           0 :     ::comphelper::NamedValueCollection aViewSettings;
    2002           0 :     saveViewSettings( aViewSettings, false );
    2003             : 
    2004           0 :     return makeAny( aViewSettings.getPropertyValues() );
    2005             : }
    2006             : 
    2007           0 : void SAL_CALL OQueryController::restoreViewData(const Any& /*Data*/) throw( RuntimeException, std::exception )
    2008             : {
    2009             :     // TODO
    2010           0 : }
    2011             : 
    2012          72 : } // namespace dbaui
    2013             : 
    2014             : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */

Generated by: LCOV version 1.10