Files
libreoffice/dbaccess/source/ui/dlg/RelationDlg.cxx
Noel Grandin d7a84ce840 vclwidget: only call dispose() once
by using a new utility method in vcl::Window
This means that we don't have to make all our dispose
methods safe to call more than once.

Change-Id: I2110c7de4a86c70fdc97dd8fd318c86b56865374
2015-04-10 10:55:36 +01:00

251 lines
7.4 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#include "RelationDlg.hxx"
#include <vcl/wrkwin.hxx>
#include <vcl/svapp.hxx>
#include "dbu_dlg.hrc"
#include "dbaccess_helpid.hrc"
#include <com/sun/star/sdbc/KeyRule.hpp>
#include <tools/debug.hxx>
#include <tools/diagnose_ex.h>
#include "UITools.hxx"
#include "JoinDesignView.hxx"
#include "JoinController.hxx"
#include <connectivity/dbexception.hxx>
#include "RTableConnectionData.hxx"
#include "RelationControl.hxx"
#include <cppuhelper/exc_hlp.hxx>
#include <comphelper/processfactory.hxx>
#include <algorithm>
using namespace ::com::sun::star::uno;
using namespace ::com::sun::star::sdbc;
using namespace ::com::sun::star::container;
using namespace ::com::sun::star::beans;
using namespace ::dbaui;
using namespace ::dbtools;
// class ORelationDialog
ORelationDialog::ORelationDialog( OJoinTableView* pParent,
const TTableConnectionData::value_type& pConnectionData,
bool bAllowTableSelect )
: ModalDialog(pParent, "RelationDialog",
"dbaccess/ui/relationdialog.ui")
, m_pTableMap(&pParent->GetTabWinMap())
, m_pOrigConnData(pConnectionData)
, m_bTriedOneUpdate(false)
{
get(m_pRB_NoCascUpd, "addaction");
get(m_pRB_CascUpd, "addcascade");
get(m_pRB_CascUpdNull, "addnull");
get(m_pRB_CascUpdDefault, "adddefault");
get(m_pRB_NoCascDel, "delaction");
get(m_pRB_CascDel, "delcascade");
get(m_pRB_CascDelNull, "delnull");
get(m_pRB_CascDelDefault, "deldefault");
get(m_pPB_OK, "ok");
m_xConnection = pParent->getDesignView()->getController().getConnection();
// Connection kopieren
m_pConnData.reset( static_cast<ORelationTableConnectionData*>(pConnectionData->NewInstance()) );
m_pConnData->CopyFrom( *pConnectionData );
Init(m_pConnData);
m_xTableControl.reset( new OTableListBoxControl(this, m_pTableMap, this) );
m_pPB_OK->SetClickHdl( LINK(this, ORelationDialog, OKClickHdl) );
m_xTableControl->Init( m_pConnData );
if ( bAllowTableSelect )
m_xTableControl->fillListBoxes();
else
m_xTableControl->fillAndDisable(pConnectionData);
m_xTableControl->lateInit();
m_xTableControl->NotifyCellChange();
}
ORelationDialog::~ORelationDialog()
{
disposeOnce();
}
void ORelationDialog::dispose()
{
m_pRB_NoCascUpd.clear();
m_pRB_CascUpd.clear();
m_pRB_CascUpdNull.clear();
m_pRB_CascUpdDefault.clear();
m_pRB_NoCascDel.clear();
m_pRB_CascDel.clear();
m_pRB_CascDelNull.clear();
m_pRB_CascDelDefault.clear();
m_pPB_OK.clear();
ModalDialog::dispose();
}
void ORelationDialog::Init(const TTableConnectionData::value_type& _pConnectionData)
{
ORelationTableConnectionData* pConnData = static_cast<ORelationTableConnectionData*>(_pConnectionData.get());
// Update Rules
switch (pConnData->GetUpdateRules())
{
case KeyRule::NO_ACTION:
case KeyRule::RESTRICT:
m_pRB_NoCascUpd->Check( true );
break;
case KeyRule::CASCADE:
m_pRB_CascUpd->Check( true );
break;
case KeyRule::SET_NULL:
m_pRB_CascUpdNull->Check( true );
break;
case KeyRule::SET_DEFAULT:
m_pRB_CascUpdDefault->Check( true );
break;
}
// Delete Rules
switch (pConnData->GetDeleteRules())
{
case KeyRule::NO_ACTION:
case KeyRule::RESTRICT:
m_pRB_NoCascDel->Check( true );
break;
case KeyRule::CASCADE:
m_pRB_CascDel->Check( true );
break;
case KeyRule::SET_NULL:
m_pRB_CascDelNull->Check( true );
break;
case KeyRule::SET_DEFAULT:
m_pRB_CascDelDefault->Check( true );
break;
}
}
IMPL_LINK( ORelationDialog, OKClickHdl, Button*, /*pButton*/ )
{
// RadioButtons auslesen
sal_uInt16 nAttrib = 0;
// Delete Rules
if( m_pRB_NoCascDel->IsChecked() )
nAttrib |= KeyRule::NO_ACTION;
if( m_pRB_CascDel->IsChecked() )
nAttrib |= KeyRule::CASCADE;
if( m_pRB_CascDelNull->IsChecked() )
nAttrib |= KeyRule::SET_NULL;
if( m_pRB_CascDelDefault->IsChecked() )
nAttrib |= KeyRule::SET_DEFAULT;
ORelationTableConnectionData* pConnData = static_cast<ORelationTableConnectionData*>(m_pConnData.get());
pConnData->SetDeleteRules( nAttrib );
// Update Rules
nAttrib = 0;
if( m_pRB_NoCascUpd->IsChecked() )
nAttrib |= KeyRule::NO_ACTION;
if( m_pRB_CascUpd->IsChecked() )
nAttrib |= KeyRule::CASCADE;
if( m_pRB_CascUpdNull->IsChecked() )
nAttrib |= KeyRule::SET_NULL;
if( m_pRB_CascUpdDefault->IsChecked() )
nAttrib |= KeyRule::SET_DEFAULT;
pConnData->SetUpdateRules( nAttrib );
m_xTableControl->SaveModified();
//// wenn die ComboBoxen fuer die Tabellenauswahl enabled sind (Constructor mit bAllowTableSelect==sal_True), dann muss ich in die
//// Connection auch die Tabellennamen stecken
//m_pConnData->SetSourceWinName(m_xTableControl->getSourceWinName());
//m_pConnData->SetDestWinName(m_xTableControl->getDestWinName());
// try to create the relation
try
{
ORelationTableConnectionData* pOrigConnData = static_cast<ORelationTableConnectionData*>(m_pOrigConnData.get());
if ( *pConnData == *pOrigConnData || pConnData->Update())
{
m_pOrigConnData->CopyFrom( *m_pConnData );
EndDialog( RET_OK );
return 0L;
}
}
catch( const SQLException& )
{
::dbaui::showError( SQLExceptionInfo( ::cppu::getCaughtException() ),
this,
static_cast<OJoinTableView*>(GetParent())->getDesignView()->getController().getORB());
}
catch( const Exception& )
{
DBG_UNHANDLED_EXCEPTION();
}
m_bTriedOneUpdate = true;
// this means that the original connection may be lost (if m_pConnData was not a newly created but an
// existent conn to be modified), which we reflect by returning RET_NO (see ::Execute)
// try again
Init(m_pConnData);
m_xTableControl->Init( m_pConnData );
m_xTableControl->lateInit();
return 0;
}
short ORelationDialog::Execute()
{
short nResult = ModalDialog::Execute();
if ((nResult != RET_OK) && m_bTriedOneUpdate)
return RET_NO;
return nResult;
}
TTableConnectionData::value_type ORelationDialog::getConnectionData() const
{
return m_pConnData;
}
void ORelationDialog::setValid(bool _bValid)
{
m_pPB_OK->Enable(_bValid);
}
void ORelationDialog::notifyConnectionChange()
{
Init(m_pConnData);
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */