LCOV - code coverage report
Current view: top level - dbaccess/source/ui/querydesign - QueryTableView.cxx (source / functions) Hit Total Coverage
Test: commit 10e77ab3ff6f4314137acd6e2702a6e5c1ce1fae Lines: 1 452 0.2 %
Date: 2014-11-03 Functions: 2 37 5.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 "QueryTableView.hxx"
      21             : #include "TableFieldInfo.hxx"
      22             : #include "TableFieldDescription.hxx"
      23             : #include <tools/diagnose_ex.h>
      24             : #include <osl/diagnose.h>
      25             : #include "dbaccess_helpid.hrc"
      26             : #include "QTableWindow.hxx"
      27             : #include "QTableConnection.hxx"
      28             : #include "QTableConnectionData.hxx"
      29             : #include "QueryDesignView.hxx"
      30             : #include "querycontroller.hxx"
      31             : #include "QueryAddTabConnUndoAction.hxx"
      32             : #include "QueryTabWinShowUndoAct.hxx"
      33             : #include "browserids.hxx"
      34             : #include <com/sun/star/sdbcx/XTablesSupplier.hpp>
      35             : #include <com/sun/star/sdbc/XConnection.hpp>
      36             : #include <com/sun/star/sdbcx/XKeysSupplier.hpp>
      37             : #include <com/sun/star/sdbcx/XColumnsSupplier.hpp>
      38             : #include <com/sun/star/accessibility/AccessibleEventId.hpp>
      39             : #include "JAccess.hxx"
      40             : #include <com/sun/star/sdbcx/KeyType.hpp>
      41             : #include <com/sun/star/container/XIndexAccess.hpp>
      42             : #include <com/sun/star/beans/XPropertySet.hpp>
      43             : #include "dbustrings.hrc"
      44             : #include <connectivity/dbtools.hxx>
      45             : #include <comphelper/sequence.hxx>
      46             : #include "querydlg.hxx"
      47             : #include "JoinExchange.hxx"
      48             : #include <comphelper/extract.hxx>
      49             : #include "dbu_qry.hrc"
      50             : #include <vcl/msgbox.hxx>
      51             : #include "svtools/treelistentry.hxx"
      52             : 
      53             : using namespace dbaui;
      54             : using namespace ::com::sun::star::uno;
      55             : using namespace ::com::sun::star::sdbc;
      56             : using namespace ::com::sun::star::sdbcx;
      57             : using namespace ::com::sun::star::beans;
      58             : using namespace ::com::sun::star::container;
      59             : using namespace ::com::sun::star::accessibility;
      60             : 
      61             : namespace
      62             : {
      63           0 :     bool isColumnInKeyType(const Reference<XIndexAccess>& _rxKeys,const OUString& _rColumnName,sal_Int32 _nKeyType)
      64             :     {
      65           0 :         bool bReturn = false;
      66           0 :         if(_rxKeys.is())
      67             :         {
      68           0 :             Reference<XColumnsSupplier> xColumnsSupplier;
      69             :             // search the one and only primary key
      70           0 :             const sal_Int32 nCount = _rxKeys->getCount();
      71           0 :             for(sal_Int32 i=0;i< nCount;++i)
      72             :             {
      73           0 :                 Reference<XPropertySet> xProp(_rxKeys->getByIndex(i),UNO_QUERY);
      74           0 :                 if(xProp.is())
      75             :                 {
      76           0 :                     sal_Int32 nKeyType = 0;
      77           0 :                     xProp->getPropertyValue(PROPERTY_TYPE) >>= nKeyType;
      78           0 :                     if(_nKeyType == nKeyType)
      79             :                     {
      80           0 :                         xColumnsSupplier.set(xProp,UNO_QUERY);
      81           0 :                         if(xColumnsSupplier.is())
      82             :                         {
      83           0 :                             Reference<XNameAccess> xColumns = xColumnsSupplier->getColumns();
      84           0 :                             if(xColumns.is() && xColumns->hasByName(_rColumnName))
      85             :                             {
      86           0 :                                 bReturn = true;
      87           0 :                                 break;
      88           0 :                             }
      89             :                         }
      90             :                     }
      91             :                 }
      92           0 :             }
      93             :         }
      94           0 :         return bReturn;
      95             :     }
      96             :     /** appends a new TabAdd Undo action at controller
      97             :         @param  _pView          the view which we use
      98             :         @param  _pUndoAction    the undo action which should be added
      99             :         @param  _pConnection    the connection for which the undo action should be appended
     100             :         @param  _bOwner         is the undo action the owner
     101             :     */
     102           0 :     void addUndoAction( OQueryTableView* _pView,
     103             :                         OQueryTabConnUndoAction* _pUndoAction,
     104             :                         OQueryTableConnection* _pConnection,
     105             :                         bool _bOwner = false)
     106             :     {
     107           0 :         _pUndoAction->SetOwnership(_bOwner);
     108           0 :         _pUndoAction->SetConnection(_pConnection);
     109           0 :         _pView->getDesignView()->getController().addUndoActionAndInvalidate(_pUndoAction);
     110           0 :     }
     111             :     /** openJoinDialog opens the join dialog with this connection data
     112             :         @param  _pView              the view which we use
     113             :         @param  _pConnectionData    the connection data
     114             : 
     115             :         @return true when OK was pressed otherwise false
     116             :     */
     117           0 :     bool openJoinDialog(OQueryTableView* _pView,const TTableConnectionData::value_type& _pConnectionData,bool _bSelectableTables)
     118             :     {
     119           0 :         OQueryTableConnectionData* pData = static_cast< OQueryTableConnectionData*>(_pConnectionData.get());
     120             : 
     121           0 :         DlgQryJoin aDlg(_pView,_pConnectionData,&_pView->GetTabWinMap(),_pView->getDesignView()->getController().getConnection(),_bSelectableTables);
     122           0 :         bool bOk = aDlg.Execute() == RET_OK;
     123           0 :         if( bOk )
     124             :         {
     125           0 :             pData->SetJoinType(aDlg.GetJoinType());
     126           0 :             _pView->getDesignView()->getController().setModified(sal_True);
     127             :         }
     128             : 
     129           0 :         return bOk;
     130             :     }
     131             :     /** connectionModified adds an undo action for the modified connection and forces an redraw
     132             :         @param  _pView              the view which we use
     133             :         @param  _pConnection    the connection which was modified
     134             :         @param  _bAddUndo       true when an undo action should be appended
     135             :     */
     136           0 :     void connectionModified(OQueryTableView* _pView,
     137             :                             OTableConnection* _pConnection,
     138             :                             bool _bAddUndo)
     139             :     {
     140             :         OSL_ENSURE(_pConnection,"Invalid connection!");
     141           0 :         _pConnection->UpdateLineList();
     142             : 
     143             :         // add an undo action
     144           0 :         if ( _bAddUndo )
     145             :             addUndoAction(  _pView,
     146           0 :                             new OQueryAddTabConnUndoAction(_pView),
     147           0 :                             static_cast< OQueryTableConnection*>(_pConnection));
     148             :         // redraw
     149           0 :         _pConnection->RecalcLines();
     150             :         // force an invalidation of the bounding rectangle
     151           0 :         _pConnection->InvalidateConnection();
     152             : 
     153           0 :         _pView->Invalidate(INVALIDATE_NOCHILDREN);
     154           0 :     }
     155           0 :     void addConnections(OQueryTableView* _pView,
     156             :                         const OQueryTableWindow& _rSource,
     157             :                         const OQueryTableWindow& _rDest,
     158             :                         const Reference<XNameAccess>& _rxSourceForeignKeyColumns)
     159             :     {
     160           0 :         if ( _rSource.GetData()->isQuery() || _rDest.GetData()->isQuery() )
     161             :             // nothing to do if one of both denotes a query
     162           0 :             return;
     163             : 
     164             :         // we found a table in our view where we can insert some connections
     165             :         // the key columns have a property called RelatedColumn
     166             :         // OQueryTableConnectionData aufbauen
     167           0 :         OQueryTableConnectionData* pNewConnData = new OQueryTableConnectionData( _rSource.GetData(), _rDest.GetData() );
     168           0 :         TTableConnectionData::value_type aNewConnData(pNewConnData);
     169             : 
     170           0 :         Reference<XIndexAccess> xReferencedKeys( _rDest.GetData()->getKeys());
     171           0 :         OUString sRelatedColumn;
     172             : 
     173             :         // iterate through all foreignkey columns to create the connections
     174           0 :         Sequence< OUString> aElements(_rxSourceForeignKeyColumns->getElementNames());
     175           0 :         const OUString* pIter = aElements.getConstArray();
     176           0 :         const OUString* pEnd   = pIter + aElements.getLength();
     177           0 :         for(sal_Int32 i=0;pIter != pEnd;++pIter,++i)
     178             :         {
     179           0 :             Reference<XPropertySet> xColumn;
     180           0 :             if ( !( _rxSourceForeignKeyColumns->getByName(*pIter) >>= xColumn ) )
     181             :             {
     182             :                 OSL_FAIL( "addConnections: invalid foreign key column!" );
     183           0 :                 continue;
     184             :             }
     185             : 
     186           0 :             pNewConnData->SetFieldType(JTCS_FROM,TAB_NORMAL_FIELD);
     187             : 
     188           0 :             xColumn->getPropertyValue(PROPERTY_RELATEDCOLUMN) >>= sRelatedColumn;
     189           0 :             pNewConnData->SetFieldType(JTCS_TO,isColumnInKeyType(xReferencedKeys,sRelatedColumn,KeyType::PRIMARY) ? TAB_PRIMARY_FIELD : TAB_NORMAL_FIELD);
     190             : 
     191             :             {
     192           0 :                 Sequence< sal_Int16> aFind(::comphelper::findValue(_rSource.GetOriginalColumns()->getElementNames(),*pIter,true));
     193           0 :                 if(aFind.getLength())
     194           0 :                     pNewConnData->SetFieldIndex(JTCS_FROM,aFind[0]+1);
     195             :                 else
     196           0 :                     OSL_FAIL("Column not found!");
     197             :             }
     198             :             // get the position inside the tabe
     199           0 :             Reference<XNameAccess> xRefColumns = _rDest.GetOriginalColumns();
     200           0 :             if(xRefColumns.is())
     201             :             {
     202           0 :                 Sequence< sal_Int16> aFind(::comphelper::findValue(xRefColumns->getElementNames(),sRelatedColumn,true));
     203           0 :                 if(aFind.getLength())
     204           0 :                     pNewConnData->SetFieldIndex(JTCS_TO,aFind[0]+1);
     205             :                 else
     206           0 :                     OSL_FAIL("Column not found!");
     207             :             }
     208           0 :             pNewConnData->AppendConnLine(*pIter,sRelatedColumn);
     209             : 
     210             :             // now add the Conn itself
     211           0 :             OQueryTableConnection aNewConn(_pView, aNewConnData);
     212             :             // referring to the local variable is not important, as NotifyQueryTabConn creates a new copy
     213             :             // to add me (if not existent)
     214           0 :             _pView->NotifyTabConnection(aNewConn, false);
     215             :                 // don't create an Undo-Action for the new connection : the connection is
     216             :                 // covered by the Undo-Action for the tabwin, as the "Undo the insert" will
     217             :                 // automatically remove all connections adjacent to the win.
     218             :                 // (Because of this automatism we would have an ownerhsip ambiguity for
     219             :                 // the connection data if we would insert the conn-Undo-Action)
     220           0 :         }
     221             :     }
     222             : }
     223             : 
     224             : // class OQueryTableView
     225           0 : OQueryTableView::OQueryTableView( vcl::Window* pParent,OQueryDesignView* pView)
     226           0 :     : OJoinTableView( pParent,pView)
     227             : {
     228           0 :     SetHelpId(HID_CTL_QRYDGNTAB);
     229           0 : }
     230             : 
     231           0 : OQueryTableView::~OQueryTableView()
     232             : {
     233           0 : }
     234             : 
     235           0 : sal_Int32 OQueryTableView::CountTableAlias(const OUString& rName, sal_Int32& rMax)
     236             : {
     237           0 :     sal_Int32 nRet = 0;
     238             : 
     239           0 :     OTableWindowMap::iterator aIter = GetTabWinMap().find(rName);
     240           0 :     while(aIter != GetTabWinMap().end())
     241             :     {
     242           0 :         OUString aNewName = rName + "_" + OUString::number(++nRet);
     243           0 :         aIter = GetTabWinMap().find(aNewName);
     244           0 :     }
     245             : 
     246           0 :     rMax = nRet;
     247             : 
     248           0 :     return nRet;
     249             : }
     250             : 
     251           0 : void OQueryTableView::ReSync()
     252             : {
     253           0 :     TTableWindowData& rTabWinDataList = m_pView->getController().getTableWindowData();
     254             :     OSL_ENSURE((getTableConnections().size()==0) && (GetTabWinMap().size()==0),
     255             :         "before calling OQueryTableView::ReSync() please call ClearAll !");
     256             : 
     257             :     // I need a collection of all window names that cannot be created so that I do not initialize connections for them.
     258           0 :     ::std::vector<OUString> arrInvalidTables;
     259             : 
     260           0 :     TTableWindowData::reverse_iterator aIter = rTabWinDataList.rbegin();
     261             :     // Create the window and add it
     262             : 
     263           0 :     for(;aIter != rTabWinDataList.rend();++aIter)
     264             :     {
     265           0 :         OQueryTableWindowData* pData = static_cast<OQueryTableWindowData*>(aIter->get());
     266           0 :         OTableWindow* pTabWin = createWindow(*aIter);
     267             : 
     268             :         // I dont't use ShowTabWin as this adds the window data to the list of documents.
     269             :         // This would be bad as I am getting them from there.
     270             :         // Instead, I do it step by step
     271           0 :         if (!pTabWin->Init())
     272             :         {
     273             :             // The initialisation has gone wrong, this TabWin is not available, so
     274             :             // I must clean up the data and the document
     275           0 :             pTabWin->clearListBox();
     276           0 :             delete pTabWin;
     277           0 :             arrInvalidTables.push_back(pData->GetAliasName());
     278             : 
     279           0 :             rTabWinDataList.erase( ::std::remove(rTabWinDataList.begin(), rTabWinDataList.end(), *aIter), rTabWinDataList.end());
     280           0 :             continue;
     281             :         }
     282             : 
     283           0 :         GetTabWinMap()[pData->GetAliasName()] = pTabWin; // add at the beginning as I am going backwards through the DataList
     284             :         // Use the default if there is no position or size
     285           0 :         if (!pData->HasPosition() && !pData->HasSize())
     286           0 :             SetDefaultTabWinPosSize(pTabWin);
     287             : 
     288           0 :         pTabWin->Show();
     289             :     }
     290             : 
     291             :     // Add the connections
     292           0 :     TTableConnectionData& rTabConnDataList = m_pView->getController().getTableConnectionData();
     293           0 :     TTableConnectionData::reverse_iterator aConIter = rTabConnDataList.rbegin();
     294             : 
     295           0 :     for(;aConIter != rTabConnDataList.rend();++aConIter)
     296             :     {
     297           0 :         OQueryTableConnectionData* pTabConnData =  static_cast<OQueryTableConnectionData*>(aConIter->get());
     298             : 
     299             :         // do both tables for the connection exist ?
     300           0 :         OUString strTabExistenceTest = pTabConnData->getReferencingTable()->GetWinName();
     301           0 :         bool bInvalid = ::std::find(arrInvalidTables.begin(),arrInvalidTables.end(),strTabExistenceTest) != arrInvalidTables.end();
     302           0 :         strTabExistenceTest = pTabConnData->getReferencedTable()->GetWinName();
     303           0 :         bInvalid = bInvalid && ::std::find(arrInvalidTables.begin(),arrInvalidTables.end(),strTabExistenceTest) != arrInvalidTables.end();
     304             : 
     305           0 :         if (bInvalid)
     306             :         {
     307             :             // no -> bad luck, no connection
     308           0 :             rTabConnDataList.erase( ::std::remove(rTabConnDataList.begin(), rTabConnDataList.end(), *aConIter), rTabConnDataList.end());
     309           0 :             continue;
     310             :         }
     311             : 
     312             :         // adds a new connection to join view and notifies our accessible and invaldates the controller
     313           0 :         addConnection(new OQueryTableConnection(this, *aConIter));
     314           0 :     }
     315           0 : }
     316             : 
     317           0 : void OQueryTableView::ClearAll()
     318             : {
     319           0 :     OJoinTableView::ClearAll();
     320             : 
     321           0 :     SetUpdateMode(true);
     322           0 :     m_pView->getController().setModified(sal_True);
     323           0 : }
     324             : 
     325           0 : OTableWindow* OQueryTableView::createWindow(const TTableWindowData::value_type& _pData)
     326             : {
     327           0 :     return new OQueryTableWindow(this,_pData);
     328             : }
     329             : 
     330           0 : void OQueryTableView::NotifyTabConnection(const OQueryTableConnection& rNewConn, bool _bCreateUndoAction)
     331             : {
     332             :     // let's first check if I have the connection already
     333           0 :     OQueryTableConnection* pTabConn = NULL;
     334           0 :     const ::std::vector<OTableConnection*>& rConnections = getTableConnections();
     335           0 :     ::std::vector<OTableConnection*>::const_iterator aEnd = rConnections.end();
     336             :     ::std::vector<OTableConnection*>::const_iterator aIter = ::std::find(   rConnections.begin(),
     337             :                                                     aEnd,
     338             :                                                     static_cast<const OTableConnection*>(&rNewConn)
     339           0 :                                                     );
     340           0 :     if(aIter == aEnd )
     341             :     {
     342           0 :         aIter = rConnections.begin();
     343           0 :         for(;aIter != aEnd;++aIter)
     344             :         {
     345           0 :             if(*static_cast<OQueryTableConnection*>(*aIter) == rNewConn)
     346             :             {
     347           0 :                 pTabConn = static_cast<OQueryTableConnection*>(*aIter);
     348           0 :                 break;
     349             :             }
     350             :         }
     351             :     }
     352             :     else
     353           0 :         pTabConn = static_cast<OQueryTableConnection*>(*aIter);
     354             : 
     355             :     // no -> insert
     356           0 :     if (pTabConn == NULL)
     357             :     {
     358             :         // the new data ...
     359           0 :         OQueryTableConnectionData* pNewData = static_cast< OQueryTableConnectionData*>(rNewConn.GetData()->NewInstance());
     360           0 :         pNewData->CopyFrom(*rNewConn.GetData());
     361           0 :         TTableConnectionData::value_type aData(pNewData);
     362           0 :         OQueryTableConnection* pNewConn = new OQueryTableConnection(this, aData);
     363           0 :         GetConnection(pNewConn);
     364             : 
     365           0 :         connectionModified(this,pNewConn,_bCreateUndoAction);
     366             :     }
     367           0 : }
     368             : 
     369           0 : OTableWindowData* OQueryTableView::CreateImpl(const OUString& _rComposedName
     370             :                                              ,const OUString& _sTableName
     371             :                                              ,const OUString& _rWinName)
     372             : {
     373           0 :     return new OQueryTableWindowData( _rComposedName, _sTableName,_rWinName );
     374             : }
     375             : 
     376           0 : void OQueryTableView::AddTabWin(const OUString& _rTableName, const OUString& _rAliasName, bool bNewTable)
     377             : {
     378             :     // this method has been inherited from the base class, linking back to the parent and which constructs
     379             :     // an Alias and which passes on to my other AddTabWin
     380             : 
     381             :     // pity _rTableName is fully qualified, OQueryDesignView expects a string which only
     382             :     // contains schema and tables but no catalog.
     383           0 :     Reference< XConnection> xConnection = m_pView->getController().getConnection();
     384           0 :     if(!xConnection.is())
     385           0 :         return;
     386             :     try
     387             :     {
     388           0 :         Reference< XDatabaseMetaData > xMetaData = xConnection->getMetaData();
     389           0 :         OUString sCatalog, sSchema, sTable;
     390             :         ::dbtools::qualifiedNameComponents(xMetaData,
     391             :                                     _rTableName,
     392             :                                     sCatalog,
     393             :                                     sSchema,
     394             :                                     sTable,
     395           0 :                                     ::dbtools::eInDataManipulation);
     396           0 :         OUString sRealName(sSchema);
     397           0 :         if (!sRealName.isEmpty())
     398           0 :             sRealName+= OUString('.');
     399           0 :         sRealName += sTable;
     400             : 
     401           0 :         AddTabWin(_rTableName, sRealName, _rAliasName, bNewTable);
     402             :     }
     403           0 :     catch(SQLException&)
     404             :     {
     405             :         OSL_FAIL("qualifiedNameComponents");
     406           0 :     }
     407             : }
     408             : 
     409             : // find the table which has a foreign key with this referencedTable name
     410           0 : Reference<XPropertySet> getKeyReferencedTo(const Reference<XIndexAccess>& _rxKeys,const OUString& _rReferencedTable)
     411             : {
     412           0 :     if(!_rxKeys.is())
     413           0 :         return Reference<XPropertySet>();
     414             : 
     415           0 :     if ( !_rxKeys.is() )
     416           0 :         return Reference<XPropertySet>();
     417             :     // search the one and only primary key
     418           0 :     const sal_Int32 nCount = _rxKeys->getCount();
     419           0 :     for(sal_Int32 i=0;i<nCount ;++i)
     420             :     {
     421           0 :         Reference<XPropertySet> xKey(_rxKeys->getByIndex(i),UNO_QUERY);
     422           0 :         if(xKey.is())
     423             :         {
     424           0 :             sal_Int32 nKeyType = 0;
     425           0 :             xKey->getPropertyValue(PROPERTY_TYPE) >>= nKeyType;
     426           0 :             if(KeyType::FOREIGN == nKeyType)
     427             :             {
     428           0 :                 OUString sReferencedTable;
     429           0 :                 xKey->getPropertyValue(PROPERTY_REFERENCEDTABLE) >>= sReferencedTable;
     430             :                 // TODO check case
     431           0 :                 if(sReferencedTable == _rReferencedTable)
     432           0 :                     return xKey;
     433             :             }
     434             :         }
     435           0 :     }
     436           0 :     return Reference<XPropertySet>();
     437             : }
     438             : 
     439           0 : void OQueryTableView::AddTabWin(const OUString& _rComposedName, const OUString& _rTableName, const OUString& strAlias, bool bNewTable)
     440             : {
     441             :     OSL_ENSURE(!_rTableName.isEmpty() || !strAlias.isEmpty(), "OQueryTableView::AddTabWin : no tables or aliases !");
     442             :         // If the table is not set, then it is a dummy window, but at least the alias must be set
     443             : 
     444             :     // build a new data structure
     445             :     // first check if this already has its data
     446           0 :     bool bAppend = bNewTable;
     447           0 :     TTableWindowData::value_type pNewTabWinData;
     448           0 :     TTableWindowData& rWindowData = getDesignView()->getController().getTableWindowData();
     449           0 :     TTableWindowData::iterator aWinIter = rWindowData.begin();
     450           0 :     TTableWindowData::iterator aWinEnd = rWindowData.end();
     451           0 :     for(;aWinIter != aWinEnd;++aWinIter)
     452             :     {
     453           0 :         pNewTabWinData = *aWinIter;
     454           0 :         if (pNewTabWinData && pNewTabWinData->GetWinName() == strAlias && pNewTabWinData->GetComposedName() == _rComposedName && pNewTabWinData->GetTableName() == _rTableName)
     455           0 :             break;
     456             :     }
     457           0 :     if ( !bAppend )
     458           0 :         bAppend = ( aWinIter == aWinEnd );
     459           0 :     if ( bAppend )
     460           0 :         pNewTabWinData = createTableWindowData(_rComposedName, _rTableName, strAlias);
     461             :         // I do not need to add TabWinData to the DocShell list, ShowTabWin does that.
     462             : 
     463             :     // Create a new window
     464           0 :     OQueryTableWindow* pNewTabWin = static_cast<OQueryTableWindow*>(createWindow(pNewTabWinData));
     465             :     // No need to initialize, as that happens in ShowTabWin
     466             : 
     467             :     // New UndoAction
     468           0 :     OQueryTabWinShowUndoAct* pUndoAction = new OQueryTabWinShowUndoAct(this);
     469           0 :     pUndoAction->SetTabWin(pNewTabWin); // Window
     470           0 :     bool bSuccess = ShowTabWin(pNewTabWin, pUndoAction,bAppend);
     471           0 :     if(!bSuccess)
     472             :     {
     473             :         // reset table window
     474           0 :         pUndoAction->SetTabWin(NULL);
     475           0 :         pUndoAction->SetOwnership(false);
     476             : 
     477           0 :         delete pUndoAction;
     478           0 :         return;
     479             :     }
     480             : 
     481             :     // Show the relations between the individual tables
     482           0 :     OTableWindowMap& rTabWins = GetTabWinMap();
     483           0 :     if(bNewTable && !rTabWins.empty() && !_rTableName.isEmpty())
     484             :     {
     485           0 :         modified();
     486           0 :         if ( m_pAccessible )
     487             :             m_pAccessible->notifyAccessibleEvent(   AccessibleEventId::CHILD,
     488             :                                                     Any(),
     489             :                                                     makeAny(pNewTabWin->GetAccessible())
     490           0 :                                                     );
     491             : 
     492             :         do {
     493             : 
     494           0 :         if ( pNewTabWin->GetData()->isQuery() )
     495           0 :             break;
     496             : 
     497             :         try
     498             :         {
     499             :             // find relations between the table an the tables already inserted
     500           0 :             Reference< XIndexAccess> xKeyIndex = pNewTabWin->GetData()->getKeys();
     501           0 :             if ( !xKeyIndex.is() )
     502           0 :                 break;
     503             : 
     504           0 :             Reference<XNameAccess> xFKeyColumns;
     505           0 :             OUString aReferencedTable;
     506           0 :             Reference<XColumnsSupplier> xColumnsSupplier;
     507             : 
     508           0 :             const sal_Int32 nKeyCount = xKeyIndex->getCount();
     509           0 :             for ( sal_Int32 i=0; i<nKeyCount ; ++i )
     510             :             {
     511           0 :                 Reference< XPropertySet > xProp( xKeyIndex->getByIndex(i), UNO_QUERY_THROW );
     512           0 :                 xColumnsSupplier.set( xProp, UNO_QUERY_THROW );
     513           0 :                 xFKeyColumns.set( xColumnsSupplier->getColumns(), UNO_QUERY_THROW );
     514             : 
     515           0 :                 sal_Int32 nKeyType = 0;
     516           0 :                 xProp->getPropertyValue(PROPERTY_TYPE) >>= nKeyType;
     517             : 
     518           0 :                 switch ( nKeyType )
     519             :                 {
     520             :                 case KeyType::FOREIGN:
     521             :                 {   // our new table has a foreign key
     522             :                     // so look if the referenced table is already in our list
     523           0 :                     xProp->getPropertyValue(PROPERTY_REFERENCEDTABLE) >>= aReferencedTable;
     524             :                     OSL_ENSURE(!aReferencedTable.isEmpty(),"Foreign key without referencedTableName");
     525             : 
     526           0 :                     OTableWindowMap::const_iterator aIter = rTabWins.find(aReferencedTable);
     527           0 :                     OTableWindowMap::const_iterator aEnd  = rTabWins.end();
     528           0 :                     if(aIter == aEnd)
     529             :                     {
     530           0 :                         for(aIter = rTabWins.begin();aIter != aEnd;++aIter)
     531             :                         {
     532           0 :                             OQueryTableWindow* pTabWinTmp = static_cast<OQueryTableWindow*>(aIter->second);
     533             :                             OSL_ENSURE( pTabWinTmp,"TableWindow is null!" );
     534           0 :                             if ( pTabWinTmp != pNewTabWin && pTabWinTmp->GetComposedName() == aReferencedTable )
     535           0 :                                 break;
     536             :                         }
     537             :                     }
     538           0 :                     if ( aIter != aEnd && pNewTabWin != aIter->second )
     539           0 :                         addConnections( this, *pNewTabWin, *static_cast<OQueryTableWindow*>(aIter->second), xFKeyColumns );
     540             :                 }
     541           0 :                 break;
     542             : 
     543             :                 case KeyType::PRIMARY:
     544             :                 {
     545             :                     // we have a primary key so look in our list if there exists a key which this is referred to
     546           0 :                     OTableWindowMap::const_iterator aIter = rTabWins.begin();
     547           0 :                     OTableWindowMap::const_iterator aEnd  = rTabWins.end();
     548           0 :                     for(;aIter != aEnd;++aIter)
     549             :                     {
     550           0 :                         OQueryTableWindow* pTabWinTmp = static_cast<OQueryTableWindow*>(aIter->second);
     551           0 :                         if ( pTabWinTmp == pNewTabWin )
     552           0 :                             continue;
     553             : 
     554           0 :                         if ( pTabWinTmp->GetData()->isQuery() )
     555           0 :                             continue;
     556             : 
     557             :                         OSL_ENSURE(pTabWinTmp,"TableWindow is null!");
     558           0 :                         Reference< XPropertySet > xFKKey = getKeyReferencedTo( pTabWinTmp->GetData()->getKeys(), pNewTabWin->GetComposedName() );
     559           0 :                         if ( !xFKKey.is() )
     560           0 :                             continue;
     561             : 
     562           0 :                         Reference<XColumnsSupplier> xFKColumnsSupplier( xFKKey, UNO_QUERY_THROW );
     563           0 :                         Reference< XNameAccess > xTColumns( xFKColumnsSupplier->getColumns(), UNO_QUERY_THROW );
     564           0 :                         addConnections( this, *pTabWinTmp, *pNewTabWin, xTColumns );
     565           0 :                     }
     566             :                 }
     567           0 :                 break;
     568             :                 }
     569           0 :             }
     570             :         }
     571           0 :         catch( const Exception& )
     572             :         {
     573             :             DBG_UNHANDLED_EXCEPTION();
     574             :         }
     575             : 
     576             :         } while ( false );
     577             :     }
     578             : 
     579             :     // My parent needs to be informed about the delete
     580           0 :     m_pView->getController().addUndoActionAndInvalidate( pUndoAction );
     581             : 
     582           0 :     if (bSuccess && m_lnkTabWinsChangeHandler.IsSet())
     583             :     {
     584           0 :         TabWinsChangeNotification aHint(TabWinsChangeNotification::AT_ADDED_WIN, pNewTabWin->GetAliasName());
     585           0 :         m_lnkTabWinsChangeHandler.Call(&aHint);
     586           0 :     }
     587             : }
     588             : 
     589           0 : void OQueryTableView::AddConnection(const OJoinExchangeData& jxdSource, const OJoinExchangeData& jxdDest)
     590             : {
     591           0 :     OQueryTableWindow* pSourceWin = static_cast< OQueryTableWindow*>(jxdSource.pListBox->GetTabWin());
     592           0 :     OQueryTableWindow* pDestWin = static_cast< OQueryTableWindow*>(jxdDest.pListBox->GetTabWin());
     593             : 
     594           0 :     OUString aSourceFieldName, aDestFieldName;
     595           0 :     aSourceFieldName    = jxdSource.pListBox->GetEntryText(jxdSource.pEntry);
     596           0 :     aDestFieldName      = jxdDest.pListBox->GetEntryText(jxdDest.pEntry);
     597             : 
     598           0 :     OTableConnection* pConn = GetTabConn(pSourceWin,pDestWin,true);
     599           0 :     if ( !pConn )
     600             :     {
     601             :         // new data object
     602           0 :         OQueryTableConnectionData* pNewConnectionData = new OQueryTableConnectionData(pSourceWin->GetData(), pDestWin->GetData());
     603           0 :         TTableConnectionData::value_type aNewConnectionData(pNewConnectionData);
     604             : 
     605             :         sal_uInt32          nSourceFieldIndex, nDestFieldIndex;
     606             :         ETableFieldType eSourceFieldType, eDestFieldType;
     607             : 
     608             :         // Get name/position/type of both affected fields ...
     609             :         // Source
     610             : 
     611           0 :         nSourceFieldIndex = jxdSource.pListBox->GetModel()->GetAbsPos(jxdSource.pEntry);
     612           0 :         eSourceFieldType = static_cast< OTableFieldInfo*>(jxdSource.pEntry->GetUserData())->GetKeyType();
     613             : 
     614             :         // Dest
     615             : 
     616           0 :         nDestFieldIndex = jxdDest.pListBox->GetModel()->GetAbsPos(jxdDest.pEntry);
     617           0 :         eDestFieldType = static_cast< OTableFieldInfo*>(jxdDest.pEntry->GetUserData())->GetKeyType();
     618             : 
     619             :         // ... and set them
     620           0 :         pNewConnectionData->SetFieldIndex(JTCS_FROM, nSourceFieldIndex);
     621           0 :         pNewConnectionData->SetFieldIndex(JTCS_TO, nDestFieldIndex);
     622             : 
     623           0 :         pNewConnectionData->SetFieldType(JTCS_FROM, eSourceFieldType);
     624           0 :         pNewConnectionData->SetFieldType(JTCS_TO, eDestFieldType);
     625             : 
     626           0 :         pNewConnectionData->AppendConnLine( aSourceFieldName,aDestFieldName );
     627             : 
     628           0 :         OQueryTableConnection aNewConnection(this, aNewConnectionData);
     629           0 :         NotifyTabConnection(aNewConnection);
     630             :         // As usual with NotifyTabConnection, using a local variable is fine because a copy is made
     631             :     }
     632             :     else
     633             :     {
     634             :         // the connection could point on the other side
     635           0 :         if(pConn->GetSourceWin() == pDestWin)
     636             :         {
     637           0 :             OUString aTmp(aSourceFieldName);
     638           0 :             aSourceFieldName = aDestFieldName;
     639           0 :             aDestFieldName = aTmp;
     640             :         }
     641             : 
     642           0 :         pConn->GetData()->AppendConnLine( aSourceFieldName,aDestFieldName );
     643             : 
     644           0 :         connectionModified(this,pConn,false);
     645           0 :     }
     646           0 : }
     647             : 
     648           0 : void OQueryTableView::ConnDoubleClicked(OTableConnection* pConnection)
     649             : {
     650           0 :     if( openJoinDialog(this,pConnection->GetData(),false) )
     651             :     {
     652           0 :         connectionModified(this,pConnection,false);
     653           0 :         SelectConn( pConnection );
     654             :     }
     655           0 : }
     656             : 
     657           0 : void OQueryTableView::createNewConnection()
     658             : {
     659           0 :     TTableConnectionData::value_type pData(new OQueryTableConnectionData());
     660           0 :     if( openJoinDialog(this,pData,true) )
     661             :     {
     662           0 :         OTableWindowMap& rMap = GetTabWinMap();
     663           0 :         OQueryTableWindow* pSourceWin   = static_cast< OQueryTableWindow*>(rMap[pData->getReferencingTable()->GetWinName()]);
     664           0 :         OQueryTableWindow* pDestWin     = static_cast< OQueryTableWindow*>(rMap[pData->getReferencedTable()->GetWinName()]);
     665             :         // first we have to look if the this connection already exists
     666           0 :         OTableConnection* pConn = GetTabConn(pSourceWin,pDestWin,true);
     667           0 :         bool bNew = true;
     668           0 :         if ( pConn )
     669             :         {
     670           0 :             pConn->GetData()->CopyFrom( *pData );
     671           0 :             bNew = false;
     672             :         }
     673             :         else
     674             :         {
     675             :             // create a new conenction and append it
     676           0 :             OQueryTableConnection* pQConn = new OQueryTableConnection(this, pData);
     677           0 :             GetConnection(pQConn);
     678           0 :             pConn = pQConn;
     679             :         }
     680           0 :         connectionModified(this,pConn,bNew);
     681           0 :         if ( !bNew && pConn == GetSelectedConn() ) // our connection was selected before so we have to reselect it
     682           0 :             SelectConn( pConn );
     683           0 :     }
     684           0 : }
     685             : 
     686           0 : bool OQueryTableView::RemoveConnection( OTableConnection* _pConnection,bool /*_bDelete*/ )
     687             : {
     688             : 
     689             :     // we don't want that our connection will be deleted, we put it in the undo manager
     690           0 :     bool bRet = OJoinTableView::RemoveConnection( _pConnection,false);
     691             : 
     692             :     // add undo action
     693             :     addUndoAction(  this,
     694           0 :                     new OQueryDelTabConnUndoAction(this),
     695             :                     static_cast< OQueryTableConnection*>(_pConnection),
     696           0 :                     true);
     697           0 :     return bRet;
     698             : }
     699             : 
     700           0 : void OQueryTableView::KeyInput( const KeyEvent& rEvt )
     701             : {
     702           0 :     OJoinTableView::KeyInput( rEvt );
     703           0 : }
     704             : 
     705           0 : OQueryTableWindow* OQueryTableView::FindTable(const OUString& rAliasName)
     706             : {
     707             :     OSL_ENSURE(!rAliasName.isEmpty(), "OQueryTableView::FindTable : the  AliasName should not be empty !");
     708             :         // (it is harmless but does not make sense and indicates that there is probably an error in the caller)
     709           0 :     OTableWindowMap::const_iterator aIter = GetTabWinMap().find(rAliasName);
     710           0 :     if(aIter != GetTabWinMap().end())
     711           0 :         return static_cast<OQueryTableWindow*>(aIter->second);
     712           0 :     return NULL;
     713             : }
     714             : 
     715           0 : bool OQueryTableView::FindTableFromField(const OUString& rFieldName, OTableFieldDescRef& rInfo, sal_uInt16& rCnt)
     716             : {
     717           0 :     rCnt = 0;
     718           0 :     OTableWindowMap::const_iterator aIter = GetTabWinMap().begin();
     719           0 :     OTableWindowMap::const_iterator aEnd  = GetTabWinMap().end();
     720           0 :     for(;aIter != aEnd;++aIter)
     721             :     {
     722           0 :         if(static_cast<OQueryTableWindow*>(aIter->second)->ExistsField(rFieldName, rInfo))
     723           0 :             ++rCnt;
     724             :     }
     725             : 
     726           0 :     return rCnt == 1;
     727             : }
     728             : 
     729           0 : bool OQueryTableView::ContainsTabWin(const OTableWindow& rTabWin)
     730             : {
     731           0 :     OTableWindowMap& rTabWins = GetTabWinMap();
     732             : 
     733           0 :     OTableWindowMap::iterator aIter = rTabWins.begin();
     734           0 :     OTableWindowMap::iterator aEnd  = rTabWins.end();
     735             : 
     736           0 :     for ( ;aIter != aEnd ; ++aIter )
     737             :     {
     738           0 :         if ( aIter->second == &rTabWin )
     739             :         {
     740           0 :             return true;
     741             :         }
     742             :     }
     743             : 
     744           0 :     return false;
     745             : }
     746             : 
     747           0 : void OQueryTableView::RemoveTabWin(OTableWindow* pTabWin)
     748             : {
     749             :     OSL_ENSURE(pTabWin != NULL, "OQueryTableView::RemoveTabWin : Window should not be NULL !");
     750             : 
     751           0 :     if(pTabWin && ContainsTabWin(*pTabWin)) // #i122589# check if registered before deleting
     752             :     {
     753             :         // I need my parent so it can be informed about the deletion
     754           0 :         OQueryDesignView* pParent = static_cast<OQueryDesignView*>(getDesignView());
     755             : 
     756           0 :         SfxUndoManager& rUndoMgr = m_pView->getController().GetUndoManager();
     757           0 :         rUndoMgr.EnterListAction( OUString( ModuleRes(STR_QUERY_UNDO_TABWINDELETE) ), OUString() );
     758             : 
     759             :         // add the Undo-Action
     760           0 :         OQueryTabWinDelUndoAct* pUndoAction = new OQueryTabWinDelUndoAct(this);
     761           0 :         pUndoAction->SetTabWin(static_cast< OQueryTableWindow*>(pTabWin));
     762             : 
     763             :         // and hide the window
     764           0 :         HideTabWin(static_cast< OQueryTableWindow*>(pTabWin), pUndoAction);
     765             : 
     766             :         // Undo Actions and delete the fields in SelectionBrowseBox
     767           0 :         pParent->TableDeleted( static_cast< OQueryTableWindowData*>(pTabWin->GetData().get())->GetAliasName() );
     768             : 
     769           0 :         m_pView->getController().addUndoActionAndInvalidate( pUndoAction );
     770           0 :         rUndoMgr.LeaveListAction();
     771             : 
     772           0 :         if (m_lnkTabWinsChangeHandler.IsSet())
     773             :         {
     774           0 :             TabWinsChangeNotification aHint(TabWinsChangeNotification::AT_REMOVED_WIN, static_cast< OQueryTableWindow*>(pTabWin)->GetAliasName());
     775           0 :             m_lnkTabWinsChangeHandler.Call(&aHint);
     776             :         }
     777             : 
     778           0 :         modified();
     779           0 :         if ( m_pAccessible )
     780             :             m_pAccessible->notifyAccessibleEvent(   AccessibleEventId::CHILD,
     781             :                                                     makeAny(pTabWin->GetAccessible()),
     782             :                                                     Any()
     783           0 :                                                     );
     784             :     }
     785           0 : }
     786             : 
     787           0 : void OQueryTableView::EnsureVisible(const OTableWindow* pWin)
     788             : {
     789             : 
     790           0 :     Invalidate(INVALIDATE_NOCHILDREN);
     791           0 :     OJoinTableView::EnsureVisible(pWin);
     792           0 : }
     793             : 
     794           0 : void OQueryTableView::GetConnection(OQueryTableConnection* pConn)
     795             : {
     796             :     // add to me and the document
     797             : 
     798           0 :     addConnection( pConn );
     799           0 : }
     800             : 
     801           0 : void OQueryTableView::DropConnection(OQueryTableConnection* pConn)
     802             : {
     803             :     // Pay attention to the selection
     804             :     // remove from me and the document
     805           0 :     RemoveConnection( pConn ,false);
     806           0 : }
     807             : 
     808           0 : void OQueryTableView::HideTabWin( OQueryTableWindow* pTabWin, OQueryTabWinUndoAct* pUndoAction )
     809             : {
     810           0 :     OTableWindowMap& rTabWins = GetTabWinMap();
     811             : 
     812             :     // Window
     813             :     // save the position in its data
     814           0 :     getDesignView()->SaveTabWinUIConfig(pTabWin);
     815             :     // (I need to go via the parent, as only the parent knows the position of the scrollbars)
     816             :     // and then out of the TabWins list and hide
     817           0 :     OTableWindowMap::iterator aIter = rTabWins.begin();
     818           0 :     OTableWindowMap::iterator aEnd  = rTabWins.end();
     819           0 :     for ( ;aIter != aEnd ; ++aIter )
     820           0 :         if ( aIter->second == pTabWin )
     821             :         {
     822           0 :             rTabWins.erase( aIter );
     823           0 :             break;
     824             :         }
     825             : 
     826           0 :     pTabWin->Hide();    // do not destroy it, as it is still in the undo list!!
     827             : 
     828             :     // the TabWin data must also be passed out of my responsibility
     829           0 :     TTableWindowData& rTabWinDataList = m_pView->getController().getTableWindowData();
     830           0 :     rTabWinDataList.erase( ::std::remove(rTabWinDataList.begin(), rTabWinDataList.end(), pTabWin->GetData()), rTabWinDataList.end());
     831             :         // The data should not be destroyed as TabWin itself - which is still alive - needs them
     832             :         // Either it goes back into my responsibility, (via ShowTabWin), then I add the data back,
     833             :         // or the Undo-Action, which currently has full responsibility for the window
     834             :         // and its data, gets destroyed and destroys both the window and its data
     835             : 
     836           0 :     if (m_pLastFocusTabWin == pTabWin)
     837           0 :         m_pLastFocusTabWin = NULL;
     838             : 
     839             :     // collect connections belonging to the window and pass to UndoAction
     840           0 :     sal_Int16 nCnt = 0;
     841           0 :     const ::std::vector<OTableConnection*>& rTabConList = getTableConnections();
     842           0 :     ::std::vector<OTableConnection*>::const_iterator aIter2 = rTabConList.begin();
     843           0 :     for(;aIter2 != rTabConList.end();)// the end may change
     844             :     {
     845           0 :         OQueryTableConnection* pTmpEntry = static_cast<OQueryTableConnection*>(*aIter2);
     846             :         OSL_ENSURE(pTmpEntry,"OQueryTableConnection is null!");
     847           0 :         if( pTmpEntry->GetAliasName(JTCS_FROM) == pTabWin->GetAliasName() ||
     848           0 :             pTmpEntry->GetAliasName(JTCS_TO) == pTabWin->GetAliasName() )
     849             :         {
     850             :             // add to undo list
     851           0 :             pUndoAction->InsertConnection(pTmpEntry);
     852             : 
     853             :             // call base class because we append an undo action
     854             :             // but this time we are in a undo action list
     855           0 :             OJoinTableView::RemoveConnection(pTmpEntry,false);
     856           0 :             aIter2 = rTabConList.begin();
     857           0 :             ++nCnt;
     858             :         }
     859             :         else
     860           0 :             ++aIter2;
     861             :     }
     862             : 
     863           0 :     if (nCnt)
     864           0 :         InvalidateConnections();
     865             : 
     866           0 :     m_pView->getController().InvalidateFeature(ID_BROWSER_ADDTABLE);
     867             : 
     868             :     // inform the UndoAction that the window and connections belong to it
     869           0 :     pUndoAction->SetOwnership(true);
     870             : 
     871             :     // by doing so, we have modified the document
     872           0 :     m_pView->getController().setModified( sal_True );
     873           0 :     m_pView->getController().InvalidateFeature(SID_BROWSER_CLEAR_QUERY);
     874           0 : }
     875             : 
     876           0 : bool OQueryTableView::ShowTabWin( OQueryTableWindow* pTabWin, OQueryTabWinUndoAct* pUndoAction, bool _bAppend )
     877             : {
     878             : 
     879           0 :     bool bSuccess = false;
     880             : 
     881           0 :     if (pTabWin)
     882             :     {
     883           0 :         if (pTabWin->Init())
     884             :         {
     885           0 :             TTableWindowData::value_type pData = pTabWin->GetData();
     886             :             OSL_ENSURE(pData != 0, "OQueryTableView::ShowTabWin : TabWin has no data !");
     887             :             // If there is a position and size defined, we use them
     888           0 :             if (pData->HasPosition() && pData->HasSize())
     889             :             {
     890           0 :                 Size aSize(CalcZoom(pData->GetSize().Width()),CalcZoom(pData->GetSize().Height()));
     891           0 :                 pTabWin->SetPosSizePixel(pData->GetPosition(), aSize);
     892             :             }
     893             :             else
     894             :                 // else set a default position
     895           0 :                 SetDefaultTabWinPosSize(pTabWin);
     896             : 
     897             :             // Show the window and add to the list
     898           0 :             OUString sName = static_cast< OQueryTableWindowData*>(pData.get())->GetAliasName();
     899             :             OSL_ENSURE(GetTabWinMap().find(sName) == GetTabWinMap().end(),"Alias name already in list!");
     900           0 :             GetTabWinMap().insert(OTableWindowMap::value_type(sName,pTabWin));
     901             : 
     902           0 :             pTabWin->Show();
     903             : 
     904           0 :             pTabWin->Update();
     905             :             // We must call Update() in order to show the connections in the window correctly. This sounds strange,
     906             :             // but the Listbox  has an internal Member which is initialized when the Listbox is first shown (after the Listbox
     907             :             // is filled in Init). This Member will eventually be needed for
     908             :             // GetEntryPos, and then in turn by the Connection, when its starting point to the window must be determined.
     909             : 
     910             :             // the Connections
     911           0 :             ::std::vector<OTableConnection*>& rTableCon = pUndoAction->GetTabConnList();
     912           0 :             ::std::vector<OTableConnection*>::iterator aIter = rTableCon.begin();
     913           0 :             ::std::vector<OTableConnection*>::iterator aEnd = rTableCon.end();
     914             : 
     915           0 :             for(;aIter != aEnd;++aIter)
     916           0 :                 addConnection(*aIter); // add all connections from the undo action
     917             : 
     918           0 :             rTableCon.clear();
     919             : 
     920             :             // and add the window's data to the list (of the document)
     921           0 :             if(_bAppend)
     922           0 :                 m_pView->getController().getTableWindowData().push_back(pTabWin->GetData());
     923             : 
     924           0 :             m_pView->getController().InvalidateFeature(ID_BROWSER_ADDTABLE);
     925             : 
     926             :             // and inform the UndoAction  that the window belongs to me
     927           0 :             pUndoAction->SetOwnership(false);
     928             : 
     929           0 :             bSuccess = true;
     930             :         }
     931             :         else
     932             :         {
     933             :             // Initialisation failed
     934             :             // (for example when the Connection to the database is not available at the moment)
     935           0 :             pTabWin->clearListBox();
     936           0 :             delete pTabWin;
     937             :         }
     938             :     }
     939             : 
     940             :     // show that I have changed the document
     941           0 :     if(!m_pView->getController().isReadOnly())
     942           0 :         m_pView->getController().setModified( sal_True );
     943             : 
     944           0 :     m_pView->getController().InvalidateFeature(SID_BROWSER_CLEAR_QUERY);
     945             : 
     946           0 :     return bSuccess;
     947             : }
     948             : 
     949           0 : void OQueryTableView::InsertField(const OTableFieldDescRef& rInfo)
     950             : {
     951             :     OSL_ENSURE(getDesignView() != NULL, "OQueryTableView::InsertField : has no Parent !");
     952           0 :     static_cast<OQueryDesignView*>(getDesignView())->InsertField(rInfo);
     953           0 : }
     954             : 
     955           0 : bool OQueryTableView::ExistsAVisitedConn(const OQueryTableWindow* pFrom) const
     956             : {
     957           0 :     const ::std::vector<OTableConnection*>& rList = getTableConnections();
     958           0 :     ::std::vector<OTableConnection*>::const_iterator aIter = rList.begin();
     959           0 :     ::std::vector<OTableConnection*>::const_iterator aEnd = rList.end();
     960           0 :     for(;aIter != aEnd;++aIter)
     961             :     {
     962           0 :         OQueryTableConnection* pTemp = static_cast<OQueryTableConnection*>(*aIter);
     963           0 :         if (pTemp->IsVisited() &&
     964           0 :             (pFrom == static_cast< OQueryTableWindow*>(pTemp->GetSourceWin()) || pFrom == static_cast< OQueryTableWindow*>(pTemp->GetDestWin())))
     965           0 :             return true;
     966             :     }
     967             : 
     968           0 :     return false;
     969             : }
     970             : 
     971           0 : void OQueryTableView::onNoColumns_throw()
     972             : {
     973           0 :     OUString sError( ModuleRes( STR_STATEMENT_WITHOUT_RESULT_SET ) );
     974           0 :     ::dbtools::throwSQLException( sError, ::dbtools::SQL_GENERAL_ERROR, NULL );
     975           0 : }
     976             : 
     977           0 : bool OQueryTableView::supressCrossNaturalJoin(const TTableConnectionData::value_type& _pData) const
     978             : {
     979           0 :     OQueryTableConnectionData* pQueryData = static_cast<OQueryTableConnectionData*>(_pData.get());
     980           0 :     return pQueryData && (pQueryData->GetJoinType() == CROSS_JOIN);
     981          72 : }
     982             : 
     983             : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */

Generated by: LCOV version 1.10