Files
libreoffice/dbaccess/source/ui/tabledesign/TableController.cxx

1695 lines
66 KiB
C++
Raw Normal View History

2001-02-14 13:28:01 +00:00
/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
2001-02-14 13:28:01 +00:00
*
* $RCSfile: TableController.cxx,v $
2001-02-14 13:28:01 +00:00
*
* $Revision: 1.101 $
2001-02-14 13:28:01 +00:00
*
* last change: $Author: obo $ $Date: 2006-03-29 12:40:09 $
2001-02-14 13:28:01 +00:00
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
2001-02-14 13:28:01 +00:00
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
2001-02-14 13:28:01 +00:00
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
2001-02-14 13:28:01 +00:00
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
2001-02-14 13:28:01 +00:00
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
2001-02-14 13:28:01 +00:00
*
************************************************************************/
#ifndef DBUI_TABLECONTROLLER_HXX
#include "TableController.hxx"
#endif
#ifndef _DBAU_REGHELPER_HXX_
#include "dbu_reghelper.hxx"
#endif
2002-04-02 05:27:11 +00:00
#ifndef _STRING_HXX
#include <tools/string.hxx>
#endif
2001-02-14 13:28:01 +00:00
#ifndef _SFXSIDS_HRC
#include <sfx2/sfxsids.hrc>
#endif
2002-08-19 07:01:32 +00:00
#ifndef _DBU_TBL_HRC_
#include "dbu_tbl.hrc"
2001-02-14 13:28:01 +00:00
#endif
#ifndef DBACCESS_UI_BROWSER_ID_HXX
#include "browserids.hxx"
#endif
#ifndef _COMPHELPER_TYPES_HXX_
#include <comphelper/types.hxx>
#endif
#ifndef DBACCESS_SHARED_DBUSTRINGS_HRC
#include "dbustrings.hrc"
#endif
#ifndef _CONNECTIVITY_DBTOOLS_HXX_
#include <connectivity/dbtools.hxx>
#endif
#ifndef _COM_SUN_STAR_FRAME_FRAMESEARCHFLAG_HPP_
#include <com/sun/star/frame/FrameSearchFlag.hpp>
#endif
#ifndef _COMPHELPER_EXTRACT_HXX_
#include <comphelper/extract.hxx>
2001-02-14 13:28:01 +00:00
#endif
#ifndef DBAUI_DLGSAVE_HXX
#include "dlgsave.hxx"
#endif
#ifndef _COM_SUN_STAR_CONTAINER_XCHILD_HPP_
#include <com/sun/star/container/XChild.hpp>
#endif
#ifndef _COM_SUN_STAR_CONTAINER_XNAMECONTAINER_HPP_
#include <com/sun/star/container/XNameContainer.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_XDATADESCRIPTORFACTORY_HPP_
#include <com/sun/star/sdbcx/XDataDescriptorFactory.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_XTABLESSUPPLIER_HPP_
#include <com/sun/star/sdbcx/XTablesSupplier.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_KEYTYPE_HPP_
#include <com/sun/star/sdbcx/KeyType.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_XDROP_HPP_
#include <com/sun/star/sdbcx/XDrop.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_XALTERTABLE_HPP_
#include <com/sun/star/sdbcx/XAlterTable.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_XAPPEND_HPP_
#include <com/sun/star/sdbcx/XAppend.hpp>
#endif
#ifndef _COM_SUN_STAR_SDB_SQLCONTEXT_HPP_
#include <com/sun/star/sdb/SQLContext.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBC_SQLWARNING_HPP_
#include <com/sun/star/sdbc/SQLWarning.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBC_COLUMNVALUE_HPP_
#include <com/sun/star/sdbc/ColumnValue.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBC_XROW_HPP_
#include <com/sun/star/sdbc/XRow.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_XINDEXESSUPPLIER_HPP_
#include <com/sun/star/sdbcx/XIndexesSupplier.hpp>
#endif
2001-02-14 13:28:01 +00:00
#ifndef _DBHELPER_DBEXCEPTION_HXX_
#include <connectivity/dbexception.hxx>
#endif
#ifndef _COM_SUN_STAR_UI_XEXECUTABLEDIALOG_HPP_
2001-07-04 08:28:50 +00:00
#include <com/sun/star/ui/dialogs/XExecutableDialog.hpp>
2001-02-14 13:28:01 +00:00
#endif
#ifndef _COMPHELPER_STREAMSECTION_HXX_
#include <comphelper/streamsection.hxx>
#endif
#ifndef _COM_SUN_STAR_IO_XACTIVEDATASOURCE_HPP_
#include <com/sun/star/io/XActiveDataSource.hpp>
#endif
#ifndef _COM_SUN_STAR_IO_XACTIVEDATASINK_HPP_
#include <com/sun/star/io/XActiveDataSink.hpp>
#endif
#ifndef DBAUI_TABLEDESIGNVIEW_HXX
#include "TableDesignView.hxx"
#endif
#ifndef _COM_SUN_STAR_SDB_COMMANDTYPE_HPP_
#include <com/sun/star/sdb/CommandType.hpp>
#endif
#ifndef DBAUI_FIELDDESCRIPTIONS_HXX
#include "FieldDescriptions.hxx"
#endif
#ifndef DBAUI_TABLEROW_HXX
#include "TableRow.hxx"
#endif
#ifndef DBAUI_TYPEINFO_HXX
#include "TypeInfo.hxx"
#endif
#ifndef DBAUI_TABLEEDITORCONTROL_HXX
#include "TEditControl.hxx"
#endif
#ifndef _DBAUI_SQLMESSAGE_HXX_
#include "sqlmessage.hxx"
#endif
#ifndef _SV_MSGBOX_HXX
#include <vcl/msgbox.hxx>
#endif
#ifndef _DBAUI_INDEXDIALOG_HXX_
#include "indexdialog.hxx"
#endif
#ifndef DBAUI_TOOLS_HXX
#include "UITools.hxx"
#endif
2001-07-02 09:31:49 +00:00
#ifndef DBAUI_TOOLS_HXX
#include "UITools.hxx"
#endif
2001-02-14 13:28:01 +00:00
extern "C" void SAL_CALL createRegistryInfo_OTableControl()
{
static ::dbaui::OMultiInstanceAutoRegistration< ::dbaui::OTableController > aAutoRegistration;
}
using namespace ::com::sun::star::uno;
using namespace ::com::sun::star::io;
using namespace ::com::sun::star::beans;
using namespace ::com::sun::star::frame;
using namespace ::com::sun::star::util;
using namespace ::com::sun::star::lang;
using namespace ::com::sun::star::container;
using namespace ::com::sun::star::sdbcx;
using namespace ::com::sun::star::sdbc;
using namespace ::com::sun::star::sdb;
using namespace ::com::sun::star::ui;
2001-04-17 08:15:33 +00:00
using namespace ::com::sun::star::util;
2001-02-14 13:28:01 +00:00
using namespace ::dbtools;
using namespace ::dbaui;
using namespace ::comphelper;
namespace
{
void dropTable(const Reference<XNameAccess>& _rxTable,const ::rtl::OUString& _sTableName)
{
if ( _rxTable->hasByName(_sTableName) )
{
Reference<XDrop> xNameCont(_rxTable,UNO_QUERY);
OSL_ENSURE(xNameCont.is(),"No drop interface for tables!");
if ( xNameCont.is() )
xNameCont->dropByName(_sTableName);
}
}
//------------------------------------------------------------------------------
struct OTableRowCompare : public ::std::binary_function< OTableRow*, ::rtl::OUString, bool>
{
bool operator() (const OTableRow* lhs, const ::rtl::OUString& rhs) const
{
OFieldDescription* pField = lhs->GetActFieldDescr();
return pField && pField->GetName() == rhs;
}
};
}
2001-02-14 13:28:01 +00:00
//------------------------------------------------------------------------------
::rtl::OUString SAL_CALL OTableController::getImplementationName() throw( RuntimeException )
{
return getImplementationName_Static();
}
//------------------------------------------------------------------------------
::rtl::OUString OTableController::getImplementationName_Static() throw( RuntimeException )
{
return ::rtl::OUString::createFromAscii("org.openoffice.comp.dbu.OTableDesign");
}
//------------------------------------------------------------------------------
Sequence< ::rtl::OUString> OTableController::getSupportedServiceNames_Static(void) throw( RuntimeException )
{
Sequence< ::rtl::OUString> aSupported(1);
aSupported.getArray()[0] = ::rtl::OUString::createFromAscii("com.sun.star.sdb.TableDesign");
return aSupported;
}
//-------------------------------------------------------------------------
Sequence< ::rtl::OUString> SAL_CALL OTableController::getSupportedServiceNames() throw(RuntimeException)
{
return getSupportedServiceNames_Static();
}
// -------------------------------------------------------------------------
Reference< XInterface > SAL_CALL OTableController::Create(const Reference<XMultiServiceFactory >& _rxFactory)
{
return *(new OTableController(_rxFactory));
}
DBG_NAME(OTableController)
2001-02-14 13:28:01 +00:00
// -----------------------------------------------------------------------------
OTableController::OTableController(const Reference< XMultiServiceFactory >& _rM) : OTableController_BASE(_rM)
2001-02-14 13:28:01 +00:00
,m_sTypeNames(ModuleRes(STR_TABLEDESIGN_DBFIELDTYPES))
,m_bNew(sal_True)
,m_pTypeInfo()
2002-07-25 06:03:59 +00:00
,m_bAllowAutoIncrementValue(sal_False)
2001-02-14 13:28:01 +00:00
{
DBG_CTOR(OTableController,NULL);
2001-02-14 13:28:01 +00:00
InvalidateAll();
m_pTypeInfo = TOTypeInfoSP(new OTypeInfo());
m_pTypeInfo->aUIName = m_sTypeNames.GetToken(TYPE_OTHER);
2001-02-14 13:28:01 +00:00
}
// -----------------------------------------------------------------------------
OTableController::~OTableController()
{
2001-07-02 09:31:49 +00:00
m_aTypeInfoIndex.clear();
2001-02-14 13:28:01 +00:00
m_aTypeInfo.clear();
DBG_DTOR(OTableController,NULL);
2001-02-14 13:28:01 +00:00
}
// -----------------------------------------------------------------------------
void OTableController::startTableListening()
{
Reference< XComponent > xComponent(m_xTable, UNO_QUERY);
if (xComponent.is())
xComponent->addEventListener(static_cast<XModifyListener*>(this));
}
// -----------------------------------------------------------------------------
void OTableController::stopTableListening()
{
Reference< XComponent > xComponent(m_xTable, UNO_QUERY);
if (xComponent.is())
xComponent->removeEventListener(static_cast<XModifyListener*>(this));
}
2001-02-14 13:28:01 +00:00
// -----------------------------------------------------------------------------
2001-03-01 14:17:55 +00:00
void OTableController::disposing()
2001-02-14 13:28:01 +00:00
{
OTableController_BASE::disposing();
2001-02-14 13:28:01 +00:00
m_pView = NULL;
2001-04-11 10:36:03 +00:00
::std::vector<OTableRow*>::iterator aIter = m_vRowList.begin();
for(;aIter != m_vRowList.end();++aIter)
delete *aIter;
2001-02-14 13:28:01 +00:00
}
// -----------------------------------------------------------------------------
2002-04-03 12:21:15 +00:00
FeatureState OTableController::GetState(sal_uInt16 _nId) const
2001-02-14 13:28:01 +00:00
{
FeatureState aReturn;
2001-04-24 13:32:28 +00:00
// (disabled automatically)
2001-02-14 13:28:01 +00:00
switch (_nId)
{
case ID_BROWSER_CLOSE:
2001-04-24 13:32:28 +00:00
aReturn.bEnabled = sal_True;
break;
2001-02-14 13:28:01 +00:00
case ID_BROWSER_EDITDOC:
2002-08-19 07:01:32 +00:00
aReturn.aState = ::cppu::bool2any(isEditable());
aReturn.bEnabled = m_bNew || isEditable();// the editable flag is set through this one -> || isAddAllowed() || isDropAllowed() || isAlterAllowed();
2001-02-14 13:28:01 +00:00
break;
case ID_BROWSER_SAVEDOC:
2002-08-19 07:01:32 +00:00
aReturn.bEnabled = isModified();
if ( aReturn.bEnabled )
{
2002-04-04 09:50:26 +00:00
::std::vector<OTableRow*>::const_iterator aIter = ::std::find_if(m_vRowList.begin(),m_vRowList.end(),::std::mem_fun(&OTableRow::isValid));
aReturn.bEnabled = aIter != m_vRowList.end();
}
break;
case ID_BROWSER_SAVEASDOC:
aReturn.bEnabled = isConnected() && isEditable();
if ( aReturn.bEnabled )
{
2002-04-04 09:50:26 +00:00
::std::vector<OTableRow*>::const_iterator aIter = ::std::find_if(m_vRowList.begin(),m_vRowList.end(),::std::mem_fun(&OTableRow::isValid));
aReturn.bEnabled = aIter != m_vRowList.end();
}
2001-02-14 13:28:01 +00:00
break;
2001-02-14 13:28:01 +00:00
case ID_BROWSER_CUT:
2002-08-19 07:01:32 +00:00
aReturn.bEnabled = isEditable() && m_bFrameUiActive && getView() && static_cast<OTableDesignView*>(getView())->isCutAllowed();
2001-02-14 13:28:01 +00:00
break;
case ID_BROWSER_COPY:
2001-07-16 06:55:35 +00:00
aReturn.bEnabled = m_bFrameUiActive && getView() && static_cast<OTableDesignView*>(getView())->isCopyAllowed();
2001-02-14 13:28:01 +00:00
break;
case ID_BROWSER_PASTE:
aReturn.bEnabled = isEditable() && m_bFrameUiActive && getView() && static_cast<OTableDesignView*>(getView())->isPasteAllowed();
2001-02-14 13:28:01 +00:00
break;
case SID_INDEXDESIGN:
aReturn.bEnabled =
2002-08-19 07:01:32 +00:00
( ( ((!m_bNew && isModified()) || isModified())
|| Reference< XIndexesSupplier >(m_xTable, UNO_QUERY).is()
)
&& isConnected()
);
if ( aReturn.bEnabled )
{
::std::vector<OTableRow*>::const_iterator aIter = ::std::find_if(m_vRowList.begin(),m_vRowList.end(),::std::mem_fun(&OTableRow::isValid));
aReturn.bEnabled = aIter != m_vRowList.end();
}
break;
2002-08-19 07:01:32 +00:00
default:
aReturn = OTableController_BASE::GetState(_nId);
2001-02-14 13:28:01 +00:00
}
return aReturn;
}
// -----------------------------------------------------------------------------
void OTableController::Execute(sal_uInt16 _nId, const Sequence< PropertyValue >& aArgs)
2001-02-14 13:28:01 +00:00
{
switch(_nId)
{
case ID_BROWSER_EDITDOC:
2002-08-19 07:01:32 +00:00
setEditable(!isEditable());
static_cast<OTableDesignView*>(getView())->setReadOnly(!isEditable());
2001-02-14 13:28:01 +00:00
InvalidateFeature(ID_BROWSER_PASTE);
InvalidateFeature(SID_BROWSER_CLEAR_QUERY);
2001-02-14 13:28:01 +00:00
break;
case ID_BROWSER_SAVEASDOC:
doSaveDoc(sal_True);
break;
2001-02-14 13:28:01 +00:00
case ID_BROWSER_SAVEDOC:
2001-05-04 09:04:23 +00:00
static_cast<OTableDesignView*>(getView())->GetEditorCtrl()->SaveCurRow();
doSaveDoc(sal_False);
2001-02-14 13:28:01 +00:00
break;
case ID_BROWSER_CUT:
static_cast<OTableDesignView*>(getView())->cut();
break;
case ID_BROWSER_COPY:
static_cast<OTableDesignView*>(getView())->copy();
break;
case ID_BROWSER_PASTE:
static_cast<OTableDesignView*>(getView())->paste();
break;
case SID_INDEXDESIGN:
doEditIndexes();
break;
2002-08-19 07:01:32 +00:00
default:
OTableController_BASE::Execute(_nId,aArgs);
2001-02-14 13:28:01 +00:00
}
InvalidateFeature(_nId);
}
// -----------------------------------------------------------------------------
sal_Bool OTableController::doSaveDoc(sal_Bool _bSaveAs)
{
if (!isConnected())
reconnect(sal_True); // ask the user for a new connection
Reference<XTablesSupplier> xTablesSup(getConnection(),UNO_QUERY);
if (!xTablesSup.is())
{
String aMessage(ModuleRes(STR_TABLEDESIGN_CONNECTION_MISSING));
String sTitle(ModuleRes(STR_STAT_WARNING));
OSQLMessageBox aMsg(getView(),sTitle,aMessage);
aMsg.Execute();
return sal_False;
}
// check if a column exists
// TODO
Reference<XNameAccess> xTables;
::rtl::OUString sCatalog, sSchema;
sal_Bool bNew = (0 == m_sName.getLength());
bNew = bNew || m_bNew || _bSaveAs;
try
{
xTables = xTablesSup->getTables();
OSL_ENSURE(xTables.is(),"The tables can't be null!");
bNew = bNew || (xTables.is() && !xTables->hasByName(m_sName));
// first we need a name for our query so ask the user
if(bNew)
{
String aDefaultName;
if (_bSaveAs && !bNew)
aDefaultName = String(m_sName);
else
{
String aName = String(ModuleRes(STR_TBL_TITLE));
aName = aName.GetToken(0,' ');
aDefaultName = ::dbaui::createDefaultName(getConnection()->getMetaData(),xTables,aName);
}
OSaveAsDlg aDlg(getView(),CommandType::TABLE,xTables,getConnection()->getMetaData(),getConnection(),aDefaultName);
if(aDlg.Execute() == RET_OK)
{
m_sName = aDlg.getName();
sCatalog = aDlg.getCatalog();
sSchema = aDlg.getSchema();
}
2001-07-24 05:54:43 +00:00
else
return sal_False;
}
// did we get a name
if(!m_sName.getLength())
return sal_False;
}
catch(Exception&)
{
OSL_ENSURE(sal_False, "OTableController::doSaveDoc: nothing is expected to happen here!");
}
2001-07-06 07:16:05 +00:00
sal_Bool bAlter = sal_False;
2002-04-02 05:27:11 +00:00
sal_Bool bError = sal_False;
SQLExceptionInfo aInfo;
try
{
// check the columns for double names
if(!checkColumns(bNew || !xTables->hasByName(m_sName)))
{
// #105323# OJ
return sal_False;
}
Reference<XPropertySet> xTable;
if(bNew || !xTables->hasByName(m_sName)) // just to make sure the table already exists
{
dropTable(xTables,m_sName);
Reference<XDataDescriptorFactory> xFact(xTables,UNO_QUERY);
OSL_ENSURE(xFact.is(),"OTableController::doSaveDoc: No XDataDescriptorFactory available!");
xTable = xFact->createDataDescriptor();
OSL_ENSURE(xTable.is(),"OTableController::doSaveDoc: Create query failed!");
// to set the name is only allowed when the wuery is new
xTable->setPropertyValue(PROPERTY_CATALOGNAME,makeAny(sCatalog));
xTable->setPropertyValue(PROPERTY_SCHEMANAME,makeAny(sSchema));
xTable->setPropertyValue(PROPERTY_NAME,makeAny(m_sName));
// now append the columns
Reference<XColumnsSupplier> xColSup(xTable,UNO_QUERY);
appendColumns(xColSup,bNew);
// now append the primary key
Reference<XKeysSupplier> xKeySup(xTable,UNO_QUERY);
appendPrimaryKey(xKeySup,bNew);
}
// now set the properties
if(bNew)
{
Reference<XAppend> xAppend(xTables,UNO_QUERY);
OSL_ENSURE(xAppend.is(),"OTableController::doSaveDoc: No XAppend Interface!");
xAppend->appendByDescriptor(xTable);
assignTable();
if(!m_xTable.is()) // correct name and try again
{
// it can be that someone inserted new data for us
m_sName = ::dbtools::composeTableName(getConnection()->getMetaData(),xTable,sal_False,::dbtools::eInDataManipulation);
assignTable();
}
2001-04-17 08:15:33 +00:00
// now check if our datasource has set a tablefilter and if append the new table name to it
::dbaui::appendToFilter(getConnection(),m_sName,getORB(),getView()); // we are not interessted in the return value
}
else if(m_xTable.is())
{
2001-07-06 07:16:05 +00:00
bAlter = sal_True;
alterColumns();
}
reSyncRows();
}
2002-04-02 05:27:11 +00:00
catch(const SQLContext& e)
{
aInfo = SQLExceptionInfo(e);
}
2002-04-02 05:27:11 +00:00
catch(const SQLWarning& e)
{
aInfo = SQLExceptionInfo(e);
}
2002-04-02 05:27:11 +00:00
catch(const SQLException& e)
{
aInfo = SQLExceptionInfo(e);
}
2002-04-02 05:27:11 +00:00
catch(const ElementExistException& )
{
2002-08-19 07:01:32 +00:00
String sText( ModuleRes(STR_OBJECT_ALREADY_EXISTS));
2002-04-02 05:27:11 +00:00
sText.SearchAndReplaceAscii( "#" , m_sName);
OSQLMessageBox aDlg(getView(), String(ModuleRes(STR_OBJECT_ALREADY_EXSISTS)), sText, WB_OK, OSQLMessageBox::Error);
aDlg.Execute();
bError = sal_True;
}
catch(Exception&)
{
2002-04-02 05:27:11 +00:00
bError = sal_True;
OSL_ENSURE(sal_False, "OTableController::doSaveDoc: table could not be inserted (caught a generic exception)!");
}
showError(aInfo);
2002-04-02 05:27:11 +00:00
if (aInfo.isValid() || bError)
2001-07-06 07:16:05 +00:00
{
2002-04-02 05:27:11 +00:00
if(!bAlter || bNew)
2001-07-06 07:16:05 +00:00
{
m_sName = ::rtl::OUString();
stopTableListening();
m_xTable = NULL;
}
// reload(); // a error occured so we have to reload
2001-07-06 07:16:05 +00:00
}
2002-04-02 05:27:11 +00:00
return ! (aInfo.isValid() || bError);
}
// -----------------------------------------------------------------------------
void OTableController::doEditIndexes()
{
// table needs to be saved before editing indexes
2002-08-19 07:01:32 +00:00
if (m_bNew || isModified())
{
QueryBox aAsk(getView(), ModuleRes(QUERY_SAVE_TABLE_EDIT_INDEXES));
if (RET_YES != aAsk.Execute())
return;
if (!doSaveDoc(sal_False))
return;
2002-08-19 07:01:32 +00:00
OSL_ENSURE(!m_bNew && !isModified(), "OTableController::doEditIndexes: what the hell did doSaveDoc do?");
}
Reference< XNameAccess > xIndexes; // will be the keys of the table
Sequence< ::rtl::OUString > aFieldNames; // will be the column names of the table
try
{
// get the keys
Reference< XIndexesSupplier > xIndexesSupp(m_xTable, UNO_QUERY);
if (xIndexesSupp.is())
{
xIndexes = xIndexesSupp->getIndexes();
OSL_ENSURE(xIndexes.is(), "OTableController::doEditIndexes: no keys got from the indexes supplier!");
}
else
OSL_ENSURE(sal_False, "OTableController::doEditIndexes: should never have reached this (no indexes supplier)!");
// get the field names
Reference< XColumnsSupplier > xColSupp(m_xTable, UNO_QUERY);
OSL_ENSURE(xColSupp.is(), "OTableController::doEditIndexes: no columns supplier!");
if (xColSupp.is())
{
Reference< XNameAccess > xCols = xColSupp->getColumns();
OSL_ENSURE(xCols.is(), "OTableController::doEditIndexes: no columns!");
if (xCols.is())
aFieldNames = xCols->getElementNames();
}
}
catch(Exception&)
{
OSL_ENSURE(sal_False, "OTableController::doEditIndexes: caught an exception while retrieving the indexes/columns!");
}
if (!xIndexes.is())
return;
DbaIndexDialog aDialog(getView(), aFieldNames, xIndexes, getConnection(),getORB(),isConnected() ? getConnection()->getMetaData().is() && getConnection()->getMetaData()->getMaxColumnsInIndex() : sal_Int32(0));
if (RET_OK != aDialog.Execute())
return;
}
2001-02-14 13:28:01 +00:00
// -----------------------------------------------------------------------------
void OTableController::impl_initialize( const Sequence< Any >& aArguments )
2001-02-14 13:28:01 +00:00
{
try
{
OTableController_BASE::impl_initialize(aArguments);
2001-02-14 13:28:01 +00:00
PropertyValue aValue;
const Any* pIter = aArguments.getConstArray();
const Any* pEnd = pIter + aArguments.getLength();
2001-02-14 13:28:01 +00:00
for(;pIter != pEnd;++pIter)
2001-02-14 13:28:01 +00:00
{
if (!(*pIter >>= aValue))
throw Exception(::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("Invalid type in argument list. PropertyValue expected.")),*this);
if ( 0 == aValue.Name.compareToAscii(PROPERTY_ACTIVECONNECTION) )
2001-02-14 13:28:01 +00:00
{
Reference< XConnection > xConn;
if ( !(aValue.Value >>= xConn) )
throw Exception(::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("Invalid argument type for ActiveConnection.")),*this);
OSL_ENSURE( xConn.is(), "OTableController::initialize: invalid connection given!!" );
if ( xConn.is() )
initializeConnection( xConn );
2001-02-14 13:28:01 +00:00
}
2001-06-12 12:06:54 +00:00
else if (0 == aValue.Name.compareToAscii(PROPERTY_CURRENTTABLE))
2001-02-14 13:28:01 +00:00
{
if ( !(aValue.Value >>= m_sName) )
throw Exception(::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("Invalid argument type for CurrentTable.")),*this);
2001-02-14 13:28:01 +00:00
}
}
// read autoincrement value set in the datasource
::dbaui::fillAutoIncrementValue(getDataSource(),m_bAllowAutoIncrementValue,m_sAutoIncrementValue);
2001-02-14 13:28:01 +00:00
sal_Bool bFirstTry = sal_False;
if (!isConnected())
2001-02-14 13:28:01 +00:00
{ // whoever instantiated us did not give us a connection to share. Okay, create an own one
reconnect(sal_False);
bFirstTry = sal_True;
2001-02-14 13:28:01 +00:00
}
if (!isConnected()) // so what should otherwise
2001-02-14 13:28:01 +00:00
{
if(!bFirstTry)
{
String aMessage(ModuleRes(RID_STR_CONNECTION_LOST));
ODataView* pWindow = getView();
InfoBox(pWindow, aMessage).Execute();
}
throw Exception();
2001-02-14 13:28:01 +00:00
}
2001-03-12 13:06:25 +00:00
assignTable();
2001-02-14 13:28:01 +00:00
if(!m_xFormatter.is())
{
Reference< XNumberFormatsSupplier> xSupplier = ::dbtools::getNumberFormats(getConnection());
if(xSupplier.is())
2001-02-14 13:28:01 +00:00
{
m_xFormatter = Reference< ::com::sun::star::util::XNumberFormatter >(getORB()
->createInstance(::rtl::OUString::createFromAscii("com.sun.star.util.NumberFormatter")), UNO_QUERY);
m_xFormatter->attachNumberFormatsSupplier(xSupplier);
2001-02-14 13:28:01 +00:00
}
OSL_ENSURE(m_xFormatter.is(),"No NumberFormatter!");
}
}
catch(const SQLException&)
{
OSL_ENSURE(sal_False, "OTableController::initialize: caught an exception!");
}
try
{
2001-07-02 09:31:49 +00:00
::dbaui::fillTypeInfo(getConnection(),m_sTypeNames,m_aTypeInfo,m_aTypeInfoIndex); // fill the needed type information
}
catch(const SQLException&)
{
OSQLMessageBox aErr(getView(),ModuleRes(STR_STAT_WARNING),ModuleRes(STR_NO_TYPE_INFO_AVAILABLE));
aErr.Execute();
throw;
}
try
{
2001-02-14 13:28:01 +00:00
loadData(); // fill the column information form the table
getView()->initialize(); // show the windows and fill with our informations
getUndoMgr()->Clear(); // clear all undo redo things
setModified(sal_False); // and we are not modified yet
}
catch(const SQLException&)
2001-02-14 13:28:01 +00:00
{
2001-04-03 13:16:03 +00:00
OSL_ENSURE(sal_False, "OTableController::initialize: caught an exception!");
2001-02-14 13:28:01 +00:00
}
}
// -----------------------------------------------------------------------------
sal_Bool OTableController::Construct(Window* pParent)
{
m_pView = new OTableDesignView(pParent,m_xMultiServiceFacatory,this);
OTableController_BASE::Construct(pParent);
// m_pView->Construct();
// m_pView->Show();
2001-02-14 13:28:01 +00:00
return sal_True;
}
// -----------------------------------------------------------------------------
sal_Bool SAL_CALL OTableController::suspend(sal_Bool _bSuspend) throw( RuntimeException )
2001-02-14 13:28:01 +00:00
{
if ( getBroadcastHelper().bInDispose || getBroadcastHelper().bDisposed )
return sal_True;
vos::OGuard aSolarGuard( Application::GetSolarMutex() );
::osl::MutexGuard aGuard(m_aMutex);
sal_Bool bCheck = sal_True;
if ( isModified() )
2001-02-23 14:11:40 +00:00
{
::std::vector<OTableRow*>::iterator aIter = ::std::find_if(m_vRowList.begin(),m_vRowList.end(),::std::mem_fun(&OTableRow::isValid));
if ( aIter != m_vRowList.end() )
2001-02-23 14:11:40 +00:00
{
QueryBox aQry(getView(), ModuleRes(TABLE_DESIGN_SAVEMODIFIED));
switch (aQry.Execute())
{
case RET_YES:
Execute(ID_BROWSER_SAVEDOC,Sequence<PropertyValue>());
if ( isModified() )
bCheck = sal_False; // when we save the table this must be false else some press cancel
break;
case RET_CANCEL:
bCheck = sal_False;
default:
break;
}
}
else if ( !m_bNew )
{
QueryBox aQry(getView(), ModuleRes(TABLE_DESIGN_ALL_ROWS_DELETED));
switch (aQry.Execute())
{
case RET_YES:
{
try
{
Reference<XTablesSupplier> xTablesSup(getConnection(),UNO_QUERY);
Reference<XNameAccess> xTables = xTablesSup->getTables();
dropTable(xTables,m_sName);
}
catch(const Exception&)
{
OSL_ENSURE(sal_False, "OTableController::suspend: nothing is expected to happen here!");
}
}
break;
case RET_CANCEL:
bCheck = sal_False;
default:
break;
}
2001-02-23 14:11:40 +00:00
}
}
/*
if ( bCheck )
OSingleDocumentController::suspend(_bSuspend);
*/
return bCheck;
2001-02-14 13:28:01 +00:00
}
// -----------------------------------------------------------------------------
void OTableController::describeSupportedFeatures()
2001-02-14 13:28:01 +00:00
{
OSingleDocumentController::describeSupportedFeatures();
implDescribeSupportedFeature( ".uno:Redo", ID_BROWSER_REDO, CommandGroup::EDIT );
implDescribeSupportedFeature( ".uno:Save", ID_BROWSER_SAVEDOC, CommandGroup::EDIT );
implDescribeSupportedFeature( ".uno:Undo", ID_BROWSER_UNDO, CommandGroup::EDIT );
implDescribeSupportedFeature( ".uno:HelpMenu", SID_HELPMENU, CommandGroup::APPLICATION );
implDescribeSupportedFeature( ".uno:NewDoc", SID_NEWDOC, CommandGroup::DOCUMENT );
implDescribeSupportedFeature( ".uno:SaveAs", ID_BROWSER_SAVEASDOC, CommandGroup::DOCUMENT );
implDescribeSupportedFeature( ".uno:DBIndexDesign", SID_INDEXDESIGN, CommandGroup::APPLICATION );
implDescribeSupportedFeature( ".uno:EditDoc", ID_BROWSER_EDITDOC, CommandGroup::EDIT );
2001-02-14 13:28:01 +00:00
}
// -----------------------------------------------------------------------------
SfxUndoManager* OTableController::getUndoMgr()
{
return &m_aUndoManager;
}
// -----------------------------------------------------------------------------
void OTableController::setModified(sal_Bool _bModified)
{
2002-08-19 07:01:32 +00:00
OSingleDocumentController::setModified(_bModified);
InvalidateFeature(SID_INDEXDESIGN);
2001-02-14 13:28:01 +00:00
}
// -----------------------------------------------------------------------------
void SAL_CALL OTableController::disposing( const EventObject& _rSource ) throw(RuntimeException)
2001-02-14 13:28:01 +00:00
{
if ( _rSource.Source == m_xTable )
2001-03-12 13:06:25 +00:00
{ // some deleted our table so we have a new one
stopTableListening();
2001-03-12 13:06:25 +00:00
m_xTable = NULL;
m_bNew = sal_True;
setModified(sal_True);
2001-02-14 13:28:01 +00:00
}
else
OTableController_BASE::disposing( _rSource );
2001-02-14 13:28:01 +00:00
}
// -----------------------------------------------------------------------------
void OTableController::Save(const Reference< XObjectOutputStream>& _rxOut)
{
OStreamSection aSection(_rxOut.get());
}
// -----------------------------------------------------------------------------
void OTableController::Load(const Reference< XObjectInputStream>& _rxIn)
{
OStreamSection aSection(_rxIn.get());
}
2001-02-14 13:28:01 +00:00
// -----------------------------------------------------------------------------
void OTableController::losingConnection( )
2001-02-14 13:28:01 +00:00
{
// let the base class do it's reconnect
OTableController_BASE::losingConnection( );
2001-02-14 13:28:01 +00:00
// remove from the table
Reference< XComponent > xComponent(m_xTable, UNO_QUERY);
if (xComponent.is())
2001-02-14 13:28:01 +00:00
{
Reference<XEventListener> xEvtL( static_cast< ::cppu::OWeakObject*>(this), UNO_QUERY);
xComponent->removeEventListener(xEvtL);
}
stopTableListening();
m_xTable = NULL;
assignTable();
if(!m_xTable.is())
{
m_bNew = sal_True;
setModified(sal_True);
2001-02-14 13:28:01 +00:00
}
InvalidateAll();
}
2001-02-14 13:28:01 +00:00
// -----------------------------------------------------------------------------
TOTypeInfoSP OTableController::getTypeInfoByType(sal_Int32 _nDataType) const
2001-02-14 13:28:01 +00:00
{
2002-11-14 06:58:31 +00:00
return queryTypeInfoByType(_nDataType,m_aTypeInfo);
2001-02-14 13:28:01 +00:00
}
// -----------------------------------------------------------------------------
void OTableController::appendColumns(Reference<XColumnsSupplier>& _rxColSup,sal_Bool _bNew,sal_Bool _bKeyColumns)
2001-02-14 13:28:01 +00:00
{
try
{
// now append the columns
OSL_ENSURE(_rxColSup.is(),"No columns supplier");
if(!_rxColSup.is())
return;
Reference<XNameAccess> xColumns = _rxColSup->getColumns();
OSL_ENSURE(xColumns.is(),"No columns");
Reference<XDataDescriptorFactory> xColumnFactory(xColumns,UNO_QUERY);
Reference<XAppend> xAppend(xColumns,UNO_QUERY);
OSL_ENSURE(xAppend.is(),"No XAppend Interface!");
::std::vector<OTableRow*>::iterator aIter = m_vRowList.begin();
::std::vector<OTableRow*>::iterator aEnd = m_vRowList.end();
for(;aIter != aEnd;++aIter)
2001-02-14 13:28:01 +00:00
{
OSL_ENSURE(*aIter,"OTableRow is null!");
OFieldDescription* pField = (*aIter)->GetActFieldDescr();
if ( !pField || (!_bNew && (*aIter)->IsReadOnly() && !_bKeyColumns) )
2001-02-14 13:28:01 +00:00
continue;
Reference<XPropertySet> xColumn;
if(pField->IsPrimaryKey() || !_bKeyColumns)
xColumn = xColumnFactory->createDataDescriptor();
if(xColumn.is())
{
if(!_bKeyColumns)
2001-07-02 09:31:49 +00:00
::dbaui::setColumnProperties(xColumn,pField);
2001-02-14 13:28:01 +00:00
else
xColumn->setPropertyValue(PROPERTY_NAME,makeAny(pField->GetName()));
xAppend->appendByDescriptor(xColumn);
xColumn = NULL;
// now only the settings are missing
if(xColumns->hasByName(pField->GetName()))
{
xColumns->getByName(pField->GetName()) >>= xColumn;
if(xColumn.is())
dbaui::setColumnUiProperties(xColumn,pField);
2001-02-14 13:28:01 +00:00
}
else
{
2001-04-03 13:16:03 +00:00
OSL_ENSURE(sal_False, "OTableController::appendColumns: invalid field name!");
2001-02-14 13:28:01 +00:00
}
}
}
}
catch(SQLException& e)
{
showError(SQLExceptionInfo(e));
}
catch(Exception&)
{
2001-04-03 13:16:03 +00:00
OSL_ENSURE(sal_False, "OTableController::appendColumns: caught an exception!");
2001-02-14 13:28:01 +00:00
}
}
// -----------------------------------------------------------------------------
void OTableController::appendPrimaryKey(Reference<XKeysSupplier>& _rxSup,sal_Bool _bNew)
2001-02-14 13:28:01 +00:00
{
if(!_rxSup.is())
return; // the database doesn't support keys
OSL_ENSURE(_rxSup.is(),"No XKeysSupplier!");
Reference<XDataDescriptorFactory> xKeyFactory(_rxSup->getKeys(),UNO_QUERY);
OSL_ENSURE(xKeyFactory.is(),"No XDataDescriptorFactory Interface!");
if ( !xKeyFactory.is() )
return;
Reference<XAppend> xAppend(xKeyFactory,UNO_QUERY);
OSL_ENSURE(xAppend.is(),"No XAppend Interface!");
2001-02-14 13:28:01 +00:00
Reference<XPropertySet> xKey = xKeyFactory->createDataDescriptor();
OSL_ENSURE(xKey.is(),"Key is null!");
xKey->setPropertyValue(PROPERTY_TYPE,makeAny(KeyType::PRIMARY));
2001-02-14 13:28:01 +00:00
Reference<XColumnsSupplier> xColSup(xKey,UNO_QUERY);
if(xColSup.is())
2001-02-14 13:28:01 +00:00
{
appendColumns(xColSup,_bNew,sal_True);
Reference<XNameAccess> xColumns = xColSup->getColumns();
if(xColumns->hasElements())
xAppend->appendByDescriptor(xKey);
2001-02-14 13:28:01 +00:00
}
}
// -----------------------------------------------------------------------------
void OTableController::loadData()
{
//////////////////////////////////////////////////////////////////////
// Wenn Datenstruktur bereits vorhanden, Struktur leeren
::std::vector<OTableRow*>::iterator aIter = m_vRowList.begin();
for(;aIter != m_vRowList.end();++aIter)
2001-02-14 13:28:01 +00:00
delete *aIter;
m_vRowList.clear();
OTableRow* pTabEdRow = NULL;
Reference< XDatabaseMetaData> xMetaData = getMetaData( );
2001-02-14 13:28:01 +00:00
//////////////////////////////////////////////////////////////////////
// Datenstruktur mit Daten aus DatenDefinitionsObjekt fuellen
if(m_xTable.is() && xMetaData.is())
2001-02-14 13:28:01 +00:00
{
Reference<XColumnsSupplier> xColSup(m_xTable,UNO_QUERY);
OSL_ENSURE(xColSup.is(),"No XColumnsSupplier!");
Reference<XNameAccess> xColumns = xColSup->getColumns();
OFieldDescription* pActFieldDescr = NULL;
String aType;
//////////////////////////////////////////////////////////////////////
// ReadOnly-Flag
// Bei Drop darf keine Zeile editierbar sein.
// Bei Add duerfen nur die leeren Zeilen editierbar sein.
// Bei Add und Drop koennen alle Zeilen editiert werden.
// sal_Bool bReadOldRow = xMetaData->supportsAlterTableWithAddColumn() && xMetaData->supportsAlterTableWithDropColumn();
sal_Bool bIsAlterAllowed = isAlterAllowed();
2001-02-14 13:28:01 +00:00
Sequence< ::rtl::OUString> aColumns = xColumns->getElementNames();
const ::rtl::OUString* pIter = aColumns.getConstArray();
const ::rtl::OUString* pEnd = pIter + aColumns.getLength();
2001-02-14 13:28:01 +00:00
for(;pIter != pEnd;++pIter)
2001-02-14 13:28:01 +00:00
{
Reference<XPropertySet> xColumn;
xColumns->getByName(*pIter) >>= xColumn;
2001-02-14 13:28:01 +00:00
sal_Int32 nType = 0;
sal_Int32 nScale = 0;
sal_Int32 nPrecision = 0;
sal_Int32 nNullable = 0;
sal_Int32 nFormatKey = 0;
sal_Int32 nAlign = 0;
sal_Bool bIsAutoIncrement,bIsCurrency;
::rtl::OUString sName,sDescription,sTypeName;
Any aControlDefault;
2001-02-14 13:28:01 +00:00
// get the properties from the column
xColumn->getPropertyValue(PROPERTY_NAME) >>= sName;
xColumn->getPropertyValue(PROPERTY_TYPENAME) >>= sTypeName;
xColumn->getPropertyValue(PROPERTY_ISNULLABLE) >>= nNullable;
xColumn->getPropertyValue(PROPERTY_ISAUTOINCREMENT) >>= bIsAutoIncrement;
xColumn->getPropertyValue(PROPERTY_ISCURRENCY) >>= bIsCurrency;
2001-02-14 13:28:01 +00:00
xColumn->getPropertyValue(PROPERTY_TYPE) >>= nType;
xColumn->getPropertyValue(PROPERTY_SCALE) >>= nScale;
xColumn->getPropertyValue(PROPERTY_PRECISION) >>= nPrecision;
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_HELPTEXT))
xColumn->getPropertyValue(PROPERTY_HELPTEXT) >>= sDescription;
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_CONTROLDEFAULT))
aControlDefault = xColumn->getPropertyValue(PROPERTY_CONTROLDEFAULT);
2001-02-14 13:28:01 +00:00
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_FORMATKEY))
xColumn->getPropertyValue(PROPERTY_FORMATKEY) >>= nFormatKey;
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_ALIGN))
xColumn->getPropertyValue(PROPERTY_ALIGN) >>= nAlign;
pTabEdRow = new OTableRow();
pTabEdRow->SetReadOnly(!bIsAlterAllowed);
2001-02-14 13:28:01 +00:00
// search for type
sal_Bool bForce;
::rtl::OUString sCreate(RTL_CONSTASCII_USTRINGPARAM("x"));
TOTypeInfoSP pTypeInfo = ::dbaui::getTypeInfoFromType(m_aTypeInfo,nType,sTypeName,sCreate,nPrecision,nScale,bIsAutoIncrement,bForce);
if ( !pTypeInfo.get() )
pTypeInfo = m_pTypeInfo;
pTabEdRow->SetFieldType( pTypeInfo, bForce );
2001-02-14 13:28:01 +00:00
pActFieldDescr = pTabEdRow->GetActFieldDescr();
OSL_ENSURE(pActFieldDescr, "OTableController::loadData: invalid field description generated by the table row!");
2002-07-25 06:03:59 +00:00
if ( pActFieldDescr )
{
pActFieldDescr->SetName(sName);
pActFieldDescr->SetFormatKey(nFormatKey);
// pActFieldDescr->SetPrimaryKey(pPrimary->GetValue());
pActFieldDescr->SetDescription(sDescription);
pActFieldDescr->SetAutoIncrement(bIsAutoIncrement);
2002-09-24 08:48:22 +00:00
pActFieldDescr->SetHorJustify(dbaui::mapTextJustify(nAlign));
pActFieldDescr->SetCurrency(bIsCurrency);
//////////////////////////////////////////////////////////////////////
// Spezielle Daten
pActFieldDescr->SetIsNullable(nNullable);
pActFieldDescr->SetControlDefault(aControlDefault);
pActFieldDescr->SetPrecision(nPrecision);
pActFieldDescr->SetScale(nScale);
}
2001-02-14 13:28:01 +00:00
m_vRowList.push_back( pTabEdRow);
}
// fill the primary key information
Reference<XNameAccess> xKeyColumns = getKeyColumns();
if(xKeyColumns.is())
{
Sequence< ::rtl::OUString> aKeyColumns = xKeyColumns->getElementNames();
const ::rtl::OUString* pKeyBegin = aKeyColumns.getConstArray();
const ::rtl::OUString* pKeyEnd = pKeyBegin + aKeyColumns.getLength();
for(;pKeyBegin != pKeyEnd;++pKeyBegin)
{
::std::vector<OTableRow*>::iterator aIter = m_vRowList.begin();
for(;aIter != m_vRowList.end();++aIter)
{
if((*aIter)->GetActFieldDescr()->GetName() == *pKeyBegin)
{
(*aIter)->SetPrimaryKey(sal_True);
break;
}
}
}
}
}
//////////////////////////////////////////////////////////////////////
// Leere Zeilen fuellen
OTypeInfoMap::iterator aTypeIter = m_aTypeInfo.find(DataType::VARCHAR);
if(aTypeIter == m_aTypeInfo.end())
aTypeIter = m_aTypeInfo.begin();
OSL_ENSURE(aTypeIter != m_aTypeInfo.end(),"We have no type infomation!");
bool bReadRow = !isAddAllowed();
2001-02-14 13:28:01 +00:00
for(sal_Int32 i=m_vRowList.size(); i<128; i++ )
{
pTabEdRow = new OTableRow();
pTabEdRow->SetReadOnly(bReadRow);
m_vRowList.push_back( pTabEdRow);
}
}
// -----------------------------------------------------------------------------
Reference<XNameAccess> OTableController::getKeyColumns() const
{
// use keys and indexes for excat postioning
// first the keys
Reference<XKeysSupplier> xKeySup(m_xTable,UNO_QUERY);
Reference<XIndexAccess> xKeys;
if(xKeySup.is())
xKeys = xKeySup->getKeys();
Reference<XColumnsSupplier> xKeyColsSup;
Reference<XNameAccess> xKeyColumns;
if(xKeys.is())
{
Reference<XPropertySet> xProp;
sal_Int32 nCount = xKeys->getCount();
for(sal_Int32 i=0;i< nCount;++i)
2001-02-14 13:28:01 +00:00
{
xKeys->getByIndex(i) >>= xProp;
OSL_ENSURE(xProp.is(),"Key is invalid: NULL!");
if ( xProp.is() )
2001-02-14 13:28:01 +00:00
{
sal_Int32 nKeyType = 0;
xProp->getPropertyValue(PROPERTY_TYPE) >>= nKeyType;
if(KeyType::PRIMARY == nKeyType)
{
xKeyColsSup.set(xProp,UNO_QUERY);
OSL_ENSURE(xKeyColsSup.is(),"Columnsupplier is null!");
xKeyColumns = xKeyColsSup->getColumns();
break;
}
2001-02-14 13:28:01 +00:00
}
}
}
return xKeyColumns;
}
// -----------------------------------------------------------------------------
sal_Bool OTableController::checkColumns(sal_Bool _bNew) throw(::com::sun::star::sdbc::SQLException)
2001-02-14 13:28:01 +00:00
{
sal_Bool bOk = sal_True;
2001-04-11 10:36:03 +00:00
sal_Bool bFoundPKey = sal_False;
Reference< XDatabaseMetaData> xMetaData = getMetaData( );
::comphelper::UStringMixEqual bCase(xMetaData.is() ? xMetaData->supportsMixedCaseQuotedIdentifiers() : sal_True);
2001-02-14 13:28:01 +00:00
::std::vector<OTableRow*>::const_iterator aIter = m_vRowList.begin();
for(;aIter != m_vRowList.end();++aIter)
{
OFieldDescription* pFieldDesc = (*aIter)->GetActFieldDescr();
if (pFieldDesc && pFieldDesc->GetName().getLength())
{
2001-04-11 10:36:03 +00:00
bFoundPKey |= (*aIter)->IsPrimaryKey();
2001-02-14 13:28:01 +00:00
sal_uInt16 nErrorRes = sal_uInt16(-1);
sal_uInt16 nFieldPos = sal_uInt16(-1);
// first check for duplicate names
::std::vector<OTableRow*>::const_iterator aIter2 = aIter+1;
for(;aIter2 != m_vRowList.end();++aIter2)
{
OFieldDescription* pCompareDesc = (*aIter2)->GetActFieldDescr();
if (pCompareDesc && bCase(pCompareDesc->GetName(),pFieldDesc->GetName()))
{
String strMessage = String(ModuleRes(STR_TABLEDESIGN_DUPLICATE_NAME));
strMessage.SearchAndReplaceAscii("$column$", pFieldDesc->GetName());
2001-07-16 06:55:35 +00:00
String sTitle(ModuleRes(STR_STAT_WARNING));
OSQLMessageBox aMsg(getView(),sTitle,strMessage,WB_OK | WB_DEF_OK,OSQLMessageBox::Error);
aMsg.Execute();
return sal_False;
2001-02-14 13:28:01 +00:00
}
}
}
}
2001-04-11 10:36:03 +00:00
if(!bFoundPKey)
{
if(_bNew && xMetaData.is() && xMetaData->supportsCoreSQLGrammar())
{
String sTitle(ModuleRes(STR_TABLEDESIGN_NO_PRIM_KEY_HEAD));
String sMsg(ModuleRes(STR_TABLEDESIGN_NO_PRIM_KEY));
OSQLMessageBox aBox(getView(), sTitle,sMsg, WB_YES_NO_CANCEL | WB_DEF_YES);
INT16 nReturn = aBox.Execute();
if (nReturn == RET_YES)
{
OTableRow* pNewRow = new OTableRow();
TOTypeInfoSP pTypeInfo = ::dbaui::queryPrimaryKeyType(m_aTypeInfo);
2001-04-11 10:36:03 +00:00
if ( pTypeInfo.get() )
2001-04-27 10:39:14 +00:00
{
pNewRow->SetFieldType( pTypeInfo );
OFieldDescription* pActFieldDescr = pNewRow->GetActFieldDescr();
2001-04-11 10:36:03 +00:00
pActFieldDescr->SetAutoIncrement(sal_False); // #95927# pTypeInfo->bAutoIncrement
2001-04-27 10:39:14 +00:00
pActFieldDescr->SetIsNullable(ColumnValue::NO_NULLS);
2001-04-11 10:36:03 +00:00
2001-04-27 10:39:14 +00:00
pActFieldDescr->SetName( createUniqueName(::rtl::OUString::createFromAscii("ID") ));
pActFieldDescr->SetPrimaryKey( sal_True );
m_vRowList.insert(m_vRowList.begin(),pNewRow);
2001-04-11 10:36:03 +00:00
2001-04-27 10:39:14 +00:00
static_cast<OTableDesignView*>(getView())->GetEditorCtrl()->Invalidate();
2002-04-02 05:27:11 +00:00
// static_cast<OTableDesignView*>(getView())->GetEditorCtrl()->DisplayData(0);
static_cast<OTableDesignView*>(getView())->GetEditorCtrl()->RowInserted(0);
2001-04-27 10:39:14 +00:00
}
2001-04-11 10:36:03 +00:00
}
2001-05-10 07:48:02 +00:00
else if (nReturn == RET_CANCEL)
bOk = sal_False;
2001-04-11 10:36:03 +00:00
}
}
return bOk;
2001-02-14 13:28:01 +00:00
}
// -----------------------------------------------------------------------------
void OTableController::alterColumns()
{
Reference<XColumnsSupplier> xColSup(m_xTable,UNO_QUERY);
OSL_ENSURE(xColSup.is(),"What happen here?!");
Reference<XNameAccess> xColumns = xColSup->getColumns();
Reference<XIndexAccess> xIdxColumns(xColumns,UNO_QUERY);
2001-02-14 13:28:01 +00:00
OSL_ENSURE(xColumns.is(),"No columns");
Reference<XAlterTable> xAlter(m_xTable,UNO_QUERY); // can be null
sal_Int32 nColumnCount = xColumns->getElementNames().getLength();
Reference<XDrop> xDrop(xColumns,UNO_QUERY); // can be null
Reference<XAppend> xAppend(xColumns,UNO_QUERY); // can be null
Reference<XDataDescriptorFactory> xColumnFactory(xColumns,UNO_QUERY); // can be null
2001-02-14 13:28:01 +00:00
sal_Bool bReload = sal_False; // refresh the data
// contains all columns names which are already handled those which are not in the list will be deleted
Reference< XDatabaseMetaData> xMetaData = getMetaData( );
2001-07-06 07:16:05 +00:00
::std::map< ::rtl::OUString,sal_Bool,::comphelper::UStringMixLess> aColumns(xMetaData.is() ? (xMetaData->supportsMixedCaseQuotedIdentifiers() ? true : false): sal_True);
2001-02-14 13:28:01 +00:00
::std::vector<OTableRow*>::iterator aIter = m_vRowList.begin();
::std::vector<OTableRow*>::iterator aEnd = m_vRowList.end();
2001-07-06 07:16:05 +00:00
// first look for columns where something other than the name changed
for(sal_Int32 nPos = 0;aIter != aEnd;++aIter,++nPos)
2001-02-14 13:28:01 +00:00
{
OSL_ENSURE(*aIter,"OTableRow is null!");
OFieldDescription* pField = (*aIter)->GetActFieldDescr();
2002-07-11 06:13:46 +00:00
if ( !pField )
continue;
if ( (*aIter)->IsReadOnly() )
{
aColumns[pField->GetName()] = sal_True;
2001-02-14 13:28:01 +00:00
continue;
2002-07-11 06:13:46 +00:00
}
2001-02-14 13:28:01 +00:00
Reference<XPropertySet> xColumn;
if ( xColumns->hasByName(pField->GetName()) )
2001-02-14 13:28:01 +00:00
{
aColumns[pField->GetName()] = sal_True;
xColumns->getByName(pField->GetName()) >>= xColumn;
OSL_ENSURE(xColumn.is(),"Column is null!");
sal_Int32 nType,nPrecision,nScale,nNullable,nFormatKey=0,nAlignment=0;
2001-02-14 13:28:01 +00:00
sal_Bool bAutoIncrement;
::rtl::OUString sDescription, sTypeName;
Any aControlDefault;
2001-02-14 13:28:01 +00:00
xColumn->getPropertyValue(PROPERTY_TYPE) >>= nType;
xColumn->getPropertyValue(PROPERTY_PRECISION) >>= nPrecision;
xColumn->getPropertyValue(PROPERTY_SCALE) >>= nScale;
xColumn->getPropertyValue(PROPERTY_ISNULLABLE) >>= nNullable;
xColumn->getPropertyValue(PROPERTY_ISAUTOINCREMENT) >>= bAutoIncrement;
try { xColumn->getPropertyValue(PROPERTY_TYPENAME) >>= sTypeName; }
catch( const Exception& )
{
OSL_ENSURE( sal_False, "no TypeName property?!" );
// since this is a last minute fix for #i41785#, I want to be on the safe side,
// and catch errors here as early as possible (instead of the whole process of altering
// the columns failing)
// Normally, sdbcx::Column objects are expected to have a TypeName property
}
2001-02-14 13:28:01 +00:00
// xColumn->getPropertyValue(PROPERTY_ISCURRENCY,::cppu::bool2any(pField->IsCurrency()));
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_HELPTEXT))
xColumn->getPropertyValue(PROPERTY_HELPTEXT) >>= sDescription;
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_CONTROLDEFAULT))
aControlDefault = xColumn->getPropertyValue(PROPERTY_CONTROLDEFAULT);
2001-02-14 13:28:01 +00:00
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_FORMATKEY))
xColumn->getPropertyValue(PROPERTY_FORMATKEY) >>= nFormatKey;
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_ALIGN))
xColumn->getPropertyValue(PROPERTY_ALIGN) >>= nAlignment;
// check if something changed
if((nType != pField->GetType() ||
sTypeName != pField->GetTypeName() ||
2001-02-14 13:28:01 +00:00
nPrecision != pField->GetPrecision() ||
nScale != pField->GetScale() ||
nNullable != pField->GetIsNullable() ||
bAutoIncrement != pField->IsAutoIncrement())&&
2001-02-14 13:28:01 +00:00
xColumnFactory.is())
{
Reference<XPropertySet> xNewColumn;
xNewColumn = xColumnFactory->createDataDescriptor();
2001-07-02 09:31:49 +00:00
::dbaui::setColumnProperties(xNewColumn,pField);
2001-02-14 13:28:01 +00:00
// first try to alter the column
sal_Bool bNotOk = sal_False;
try
{
// first try if we can alter the column
2001-02-14 13:28:01 +00:00
if(xAlter.is())
xAlter->alterColumnByName(pField->GetName(),xNewColumn);
}
2001-07-06 07:16:05 +00:00
catch(const SQLException&)
2001-02-14 13:28:01 +00:00
{
2001-07-06 07:16:05 +00:00
if(xDrop.is() && xAppend.is())
{
String aMessage(ModuleRes(STR_TABLEDESIGN_ALTER_ERROR));
2001-11-09 06:19:47 +00:00
aMessage.SearchAndReplaceAscii("$column$",pField->GetName());
2001-07-06 07:16:05 +00:00
String sTitle(ModuleRes(STR_STAT_WARNING));
OSQLMessageBox aMsg(getView(),sTitle,aMessage,WB_YES_NO|WB_DEF_YES,OSQLMessageBox::Warning);
bNotOk = aMsg.Execute() == RET_YES;
}
else
throw;
2001-02-14 13:28:01 +00:00
}
2001-07-06 07:16:05 +00:00
// if something went wrong or we can't alter columns
// drop and append a new one
2001-02-14 13:28:01 +00:00
if((!xAlter.is() || bNotOk) && xDrop.is() && xAppend.is())
{
xDrop->dropByName(pField->GetName());
2001-07-06 07:16:05 +00:00
try
{
xAppend->appendByDescriptor(xNewColumn);
}
catch(const SQLException&)
{ // an error occured so we try to reactivate the old one
xAppend->appendByDescriptor(xColumn);
throw;
}
2001-02-14 13:28:01 +00:00
}
// exceptions are catched outside
2001-02-14 13:28:01 +00:00
xNewColumn = NULL;
if(xColumns->hasByName(pField->GetName()))
xColumns->getByName(pField->GetName()) >>= xColumn;
2001-02-14 13:28:01 +00:00
bReload = sal_True;
}
if(nFormatKey != pField->GetFormatKey())
{
if(xColumn.is() && xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_FORMATKEY))
2001-02-14 13:28:01 +00:00
xColumn->setPropertyValue(PROPERTY_FORMATKEY,makeAny(pField->GetFormatKey()));
}
if(nAlignment != dbaui::mapTextAllign(pField->GetHorJustify()))
2001-02-14 13:28:01 +00:00
{
if(xColumn.is() && xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_ALIGN))
xColumn->setPropertyValue(PROPERTY_ALIGN,makeAny(dbaui::mapTextAllign(pField->GetHorJustify())));
}
if(sDescription != pField->GetDescription())
{
if(xColumn.is() && xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_HELPTEXT))
xColumn->setPropertyValue(PROPERTY_HELPTEXT,makeAny(pField->GetDescription()));
2001-02-14 13:28:01 +00:00
}
if ( aControlDefault != pField->GetControlDefault())
{
if(xColumn.is() && xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_CONTROLDEFAULT))
xColumn->setPropertyValue(PROPERTY_CONTROLDEFAULT,pField->GetControlDefault());
}
2001-02-14 13:28:01 +00:00
}
else if(xColumnFactory.is() && xAlter.is() && nPos < nColumnCount)
2001-07-06 07:16:05 +00:00
{ // we can't find the column so we could try it with the index before we drop and append a new column
try
{
Reference<XPropertySet> xNewColumn;
xNewColumn = xColumnFactory->createDataDescriptor();
::dbaui::setColumnProperties(xNewColumn,pField);
xAlter->alterColumnByIndex(nPos,xNewColumn);
if(xColumns->hasByName(pField->GetName()))
{ // ask for the append by name
aColumns[pField->GetName()] = sal_True;
xColumns->getByName(pField->GetName()) >>= xColumn;
if(xColumn.is())
dbaui::setColumnUiProperties(xColumn,pField);
2001-07-06 07:16:05 +00:00
}
else
2001-02-14 13:28:01 +00:00
{
2001-07-06 07:16:05 +00:00
OSL_ENSURE(sal_False, "OTableController::alterColumns: invalid column (2)!");
2001-02-14 13:28:01 +00:00
}
}
2001-07-06 07:16:05 +00:00
catch(const SQLException&)
{ // we couldn't alter the column so we have to add new columns
bReload = sal_True;
if(xDrop.is() && xAppend.is())
{
String aMessage(ModuleRes(STR_TABLEDESIGN_ALTER_ERROR));
aMessage.SearchAndReplaceAscii("$column$",pField->GetName());
String sTitle(ModuleRes(STR_STAT_WARNING));
OSQLMessageBox aMsg(getView(),sTitle,aMessage,WB_YES_NO|WB_DEF_YES,OSQLMessageBox::Warning);
if ( aMsg.Execute() != RET_YES )
{
continue;
}
}
else
throw;
2001-02-14 13:28:01 +00:00
}
}
else
bReload = sal_True;
2001-02-14 13:28:01 +00:00
}
2001-07-06 07:16:05 +00:00
// second drop all columns which could be found by name
2001-02-14 13:28:01 +00:00
Reference<XNameAccess> xKeyColumns = getKeyColumns();
2001-07-06 07:16:05 +00:00
// now we have to look for the columns who could be deleted
2001-02-14 13:28:01 +00:00
if(xDrop.is())
{
Sequence< ::rtl::OUString> aColumnNames = xColumns->getElementNames();
const ::rtl::OUString* pIter = aColumnNames.getConstArray();
const ::rtl::OUString* pEnd = pIter + aColumnNames.getLength();
for(;pIter != pEnd;++pIter)
2001-02-14 13:28:01 +00:00
{
if(aColumns.find(*pIter) == aColumns.end()) // found a column to delete
2001-02-14 13:28:01 +00:00
{
if(xKeyColumns.is() && xKeyColumns->hasByName(*pIter)) // check if this column is a member of the primary key
2001-02-14 13:28:01 +00:00
{
String aMsgT(ModuleRes(STR_TBL_COLUMN_IS_KEYCOLUMN));
aMsgT.SearchAndReplaceAscii("$column$",*pIter);
2001-02-14 13:28:01 +00:00
String aTitle(ModuleRes(STR_TBL_COLUMN_IS_KEYCOLUMN_TITLE));
OSQLMessageBox aMsg(getView(),aTitle,aMsgT,WB_YES_NO| WB_DEF_YES);
if(aMsg.Execute() == RET_YES)
{
xKeyColumns = NULL;
dropPrimaryKey();
2001-02-14 13:28:01 +00:00
}
else
{
bReload = sal_True;
continue;
}
}
Reference<XDrop> xDrop(xColumns,UNO_QUERY);
xDrop->dropByName(*pIter);
2001-02-14 13:28:01 +00:00
}
}
}
2001-07-06 07:16:05 +00:00
// third append the new columns
aIter = m_vRowList.begin();
for(;aIter != m_vRowList.end();++aIter)
{
OSL_ENSURE(*aIter,"OTableRow is null!");
OFieldDescription* pField = (*aIter)->GetActFieldDescr();
2002-07-11 06:13:46 +00:00
if ( !pField || (*aIter)->IsReadOnly() )
2001-07-06 07:16:05 +00:00
continue;
Reference<XPropertySet> xColumn;
if(!xColumns->hasByName(pField->GetName()))
{
if(xColumnFactory.is() && xAppend.is())
{// column not found by its name so we assume it is new
// Column is new
xColumn = xColumnFactory->createDataDescriptor();
::dbaui::setColumnProperties(xColumn,pField);
xAppend->appendByDescriptor(xColumn);
if(xColumns->hasByName(pField->GetName()))
{ // ask for the append by name
aColumns[pField->GetName()] = sal_True;
xColumns->getByName(pField->GetName()) >>= xColumn;
if(xColumn.is())
dbaui::setColumnUiProperties(xColumn,pField);
2001-07-06 07:16:05 +00:00
}
else
{
OSL_ENSURE(sal_False, "OTableController::alterColumns: invalid column!");
}
}
}
}
2001-02-14 13:28:01 +00:00
// check if we have to do something with the primary key
sal_Bool bNeedDropKey = sal_False;
sal_Bool bNeedAppendKey = sal_False;
if ( xKeyColumns.is() )
2001-02-14 13:28:01 +00:00
{
aIter = m_vRowList.begin();
for(;aIter != m_vRowList.end();++aIter)
{
OSL_ENSURE(*aIter,"OTableRow is null!");
OFieldDescription* pField = (*aIter)->GetActFieldDescr();
2002-07-25 06:03:59 +00:00
if ( !pField )
2001-02-14 13:28:01 +00:00
continue;
2001-05-04 09:04:23 +00:00
if ( pField->IsPrimaryKey()
&& !xKeyColumns->hasByName( pField->GetName() )
)
{ // new primary key column inserted which isn't already in the columns selection
bNeedDropKey = bNeedAppendKey = sal_True;
2001-05-04 09:04:23 +00:00
break;
}
else if ( !pField->IsPrimaryKey()
&& xKeyColumns->hasByName( pField->GetName() )
)
{ // found a column which currently is in the primary key, but is marked not to be anymore
bNeedDropKey = bNeedAppendKey = sal_True;
2001-02-14 13:28:01 +00:00
break;
}
}
}
else
{ // no primary key available so we check if we should create one
bNeedAppendKey = sal_True;
}
if ( bNeedDropKey )
dropPrimaryKey();
if ( bNeedAppendKey )
{
Reference< XKeysSupplier > xKeySup( m_xTable, UNO_QUERY );
appendPrimaryKey( xKeySup ,sal_False);
2001-02-14 13:28:01 +00:00
}
reSyncRows();
if ( bReload )
2001-07-06 07:16:05 +00:00
reload();
2001-02-14 13:28:01 +00:00
}
// -----------------------------------------------------------------------------
void OTableController::dropPrimaryKey()
2001-02-14 13:28:01 +00:00
{
Reference<XKeysSupplier> xKeySup(m_xTable,UNO_QUERY);
Reference<XIndexAccess> xKeys;
if(xKeySup.is())
xKeys = xKeySup->getKeys();
if(xKeys.is())
{
Reference<XPropertySet> xProp;
for(sal_Int32 i=0;i< xKeys->getCount();++i)
{
xKeys->getByIndex(i) >>= xProp;
sal_Int32 nKeyType = 0;
xProp->getPropertyValue(PROPERTY_TYPE) >>= nKeyType;
if(KeyType::PRIMARY == nKeyType)
{
Reference<XNameAccess> xKeyColumns = getKeyColumns();
Sequence< ::rtl::OUString> aColumnNames = xKeyColumns->getElementNames();
xKeyColumns = NULL;
2001-02-14 13:28:01 +00:00
Reference<XDrop> xDrop(xKeys,UNO_QUERY);
xDrop->dropByIndex(i); // delete the key
::std::vector<OTableRow*>::iterator aIter = m_vRowList.begin();
::std::vector<OTableRow*>::iterator aEnd = m_vRowList.end();
for(;aIter != aEnd;++aIter)
{
OSL_ENSURE(*aIter,"OTableRow is null!");
OFieldDescription* pField = (*aIter)->GetActFieldDescr();
if ( !pField )
continue;
::rtl::OUString sName = pField->GetName();
const ::rtl::OUString* pIter = aColumnNames.getConstArray();
const ::rtl::OUString* pEnd = pIter + aColumnNames.getLength();
for(;pIter != pEnd && *pIter != sName;++pIter)
;
if ( pIter != pEnd )
pField->SetPrimaryKey(sal_False);
}
2001-02-14 13:28:01 +00:00
break;
}
}
}
}
// -----------------------------------------------------------------------------
2001-03-12 13:06:25 +00:00
void OTableController::assignTable()
{
::rtl::OUString sComposedName;
2001-03-12 13:06:25 +00:00
// get the table
if(m_sName.getLength())
{
Reference<XNameAccess> xNameAccess;
Reference<XTablesSupplier> xSup(getConnection(),UNO_QUERY);
2001-03-12 13:06:25 +00:00
if(xSup.is())
{
xNameAccess = xSup->getTables();
OSL_ENSURE(xNameAccess.is(),"no nameaccess for the queries!");
Reference<XPropertySet> xProp;
if(xNameAccess->hasByName(m_sName) && ::cppu::extractInterface(xProp,xNameAccess->getByName(m_sName)) && xProp.is())
{
m_xTable = xProp;
startTableListening();
// check if we set the table editable
Reference<XDatabaseMetaData> xMeta = getConnection()->getMetaData();
setEditable( xMeta.is() && !xMeta->isReadOnly() && (isAlterAllowed() || isDropAllowed() || isAddAllowed()) );
2002-08-19 07:01:32 +00:00
if(!isEditable())
{
::std::vector<OTableRow*>::iterator aIter = m_vRowList.begin();
for(; aIter != m_vRowList.end(); ++aIter)
(*aIter)->SetReadOnly(sal_True);
}
2001-03-12 13:06:25 +00:00
m_bNew = sal_False;
// be notified when the table is in disposing
InvalidateAll();
2001-03-12 13:06:25 +00:00
}
}
}
updateTitle();
2001-03-12 13:06:25 +00:00
}
// -----------------------------------------------------------------------------
sal_Bool OTableController::isAddAllowed() const
{
Reference<XColumnsSupplier> xColsSup(m_xTable,UNO_QUERY);
sal_Bool bAddAllowed = !m_xTable.is();
if(xColsSup.is())
bAddAllowed = Reference<XAppend>(xColsSup->getColumns(),UNO_QUERY).is();
Reference< XDatabaseMetaData > xMetaData = getMetaData( );
bAddAllowed = bAddAllowed || ( xMetaData.is() && xMetaData->supportsAlterTableWithAddColumn());
return bAddAllowed;
}
// -----------------------------------------------------------------------------
sal_Bool OTableController::isDropAllowed() const
{
Reference<XColumnsSupplier> xColsSup(m_xTable,UNO_QUERY);
sal_Bool bDropAllowed = !m_xTable.is();
if(xColsSup.is())
{
Reference<XNameAccess> xNameAccess = xColsSup->getColumns();
bDropAllowed = Reference<XDrop>(xNameAccess,UNO_QUERY).is() && xNameAccess->hasElements();
}
2001-02-14 13:28:01 +00:00
Reference< XDatabaseMetaData> xMetaData = getMetaData( );
bDropAllowed = bDropAllowed || ( xMetaData.is() && xMetaData->supportsAlterTableWithDropColumn());
return bDropAllowed;
}
// -----------------------------------------------------------------------------
sal_Bool OTableController::isAlterAllowed() const
{
sal_Bool bAllowed(!m_xTable.is() || Reference<XAlterTable>(m_xTable,UNO_QUERY).is());
return bAllowed;
}
// -----------------------------------------------------------------------------
void OTableController::reSyncRows()
{
sal_Bool bAlterAllowed = isAlterAllowed();
sal_Bool bAddAllowed = isAddAllowed();
::std::vector<OTableRow*>::iterator aIter = m_vRowList.begin();
for(;aIter != m_vRowList.end();++aIter)
{
OSL_ENSURE(*aIter,"OTableRow is null!");
OFieldDescription* pField = (*aIter)->GetActFieldDescr();
2002-07-25 06:03:59 +00:00
if ( pField )
(*aIter)->SetReadOnly(!bAlterAllowed);
else
(*aIter)->SetReadOnly(!bAddAllowed);
}
static_cast<OTableDesignView*>(getView())->reSync(); // show the windows and fill with our informations
getUndoMgr()->Clear(); // clear all undo redo things
setModified(sal_False); // and we are not modified yet
}
// -----------------------------------------------------------------------------
2001-04-11 10:36:03 +00:00
::rtl::OUString OTableController::createUniqueName(const ::rtl::OUString& _rName)
{
::rtl::OUString sName = _rName;
Reference< XDatabaseMetaData> xMetaData = getMetaData( );
2001-04-11 10:36:03 +00:00
::comphelper::UStringMixEqual bCase(xMetaData.is() ? xMetaData->supportsMixedCaseQuotedIdentifiers() : sal_True);
2001-04-11 10:36:03 +00:00
::std::vector<OTableRow*>::const_iterator aIter = m_vRowList.begin();
for(sal_Int32 i=0;aIter != m_vRowList.end();++aIter)
{
OFieldDescription* pFieldDesc = (*aIter)->GetActFieldDescr();
if (pFieldDesc && pFieldDesc->GetName().getLength() && bCase(sName,pFieldDesc->GetName()))
{ // found a second name of _rName so we need another
sName = _rName + ::rtl::OUString::valueOf(++i);
aIter = m_vRowList.begin(); // and retry
}
}
return sName;
}
// -----------------------------------------------------------------------------
void OTableController::updateTitle()
2001-04-24 13:32:28 +00:00
{
try
{
::rtl::OUString sTitle;
// get the table
if ( m_sName.getLength() && getConnection().is() )
{
if ( m_xTable.is() )
sTitle = ::dbtools::composeTableName(getConnection()->getMetaData(),m_xTable,sal_False,::dbtools::eInDataManipulation);
else
sTitle = m_sName;
}
::rtl::OUString sName = String(ModuleRes(STR_TABLEDESIGN_TITLE));
if(sTitle.getLength())
sName = sTitle + sName;
else
{
::rtl::OUString sTemp(getDataSourceName());
sName = ::dbaui::getStrippedDatabaseName(getDataSource(),sTemp) + sName;
}
OGenericUnoController::setTitle(sName);
}
catch(Exception)
{
OSL_ENSURE(0,"Exception catched while setting the title!");
}
}
// -----------------------------------------------------------------------------
2001-07-06 07:16:05 +00:00
void OTableController::reload()
{
loadData(); // fill the column information form the table
static_cast<OTableDesignView*>(getView())->reSync(); // show the windows and fill with our informations
getUndoMgr()->Clear(); // clear all undo redo things
setModified(sal_False); // and we are not modified yet
static_cast<OTableDesignView*>(getView())->Invalidate();
}
// -----------------------------------------------------------------------------
sal_Int32 OTableController::getFirstEmptyRowPosition() const
{
sal_Int32 nRet = -1;
::std::vector<OTableRow*>::const_iterator aIter = m_vRowList.begin();
::std::vector<OTableRow*>::const_iterator aEnd = m_vRowList.end();
for(;aIter != aEnd;++aIter)
{
if ( !*aIter || !(*aIter)->GetActFieldDescr() || !(*aIter)->GetActFieldDescr()->GetName().getLength() )
{
nRet = aIter - m_vRowList.begin();
break;
}
}
return nRet;
}
// -----------------------------------------------------------------------------
2001-02-14 13:28:01 +00:00