/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org 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 version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_dbaccess.hxx" #include "xmlDataSource.hxx" #include "xmlLogin.hxx" #include "xmlTableFilterList.hxx" #include "xmlDataSourceInfo.hxx" #include "xmlDataSourceSettings.hxx" #include "xmlDataSourceSetting.hxx" #include "xmlfilter.hxx" #include #include #include #include "xmlEnums.hxx" #include "xmlstrings.hrc" #include #include #include "xmlConnectionData.hxx" namespace dbaxml { using namespace ::com::sun::star::uno; using namespace ::com::sun::star::xml::sax; DBG_NAME(OXMLDataSource) OXMLDataSource::OXMLDataSource( ODBFilter& rImport, sal_uInt16 nPrfx, const ::rtl::OUString& _sLocalName, const Reference< XAttributeList > & _xAttrList, const UsedFor _eUsedFor ) : SvXMLImportContext( rImport, nPrfx, _sLocalName ) { DBG_CTOR(OXMLDataSource,NULL); OSL_ENSURE(_xAttrList.is(),"Attribute list is NULL!"); const SvXMLNamespaceMap& rMap = rImport.GetNamespaceMap(); const SvXMLTokenMap& rTokenMap = rImport.GetDataSourceElemTokenMap(); Reference xDataSource = rImport.getDataSource(); PropertyValue aProperty; bool bFoundParamNameSubstitution = false; bool bFoundTableNameLengthLimited = false; bool bFoundAppendTableAliasName = false; bool bFoundSuppressVersionColumns = false; const sal_Int16 nLength = (xDataSource.is() && _xAttrList.is()) ? _xAttrList->getLength() : 0; static const ::rtl::OUString s_sTRUE = ::xmloff::token::GetXMLToken(XML_TRUE); for(sal_Int16 i = 0; i < nLength; ++i) { ::rtl::OUString sLocalName; rtl::OUString sAttrName = _xAttrList->getNameByIndex( i ); sal_uInt16 nPrefix = rMap.GetKeyByAttrName( sAttrName,&sLocalName ); rtl::OUString sValue = _xAttrList->getValueByIndex( i ); aProperty.Name = ::rtl::OUString(); aProperty.Value = Any(); switch( rTokenMap.Get( nPrefix, sLocalName ) ) { case XML_TOK_CONNECTION_RESOURCE: try { xDataSource->setPropertyValue(PROPERTY_URL,makeAny(sValue)); } catch(Exception) { DBG_UNHANDLED_EXCEPTION(); } break; case XML_TOK_SUPPRESS_VERSION_COLUMNS: try { xDataSource->setPropertyValue(PROPERTY_SUPPRESSVERSIONCL,makeAny(sValue == s_sTRUE ? sal_True : sal_False)); bFoundSuppressVersionColumns = true; } catch(Exception) { DBG_UNHANDLED_EXCEPTION(); } break; case XML_TOK_JAVA_DRIVER_CLASS: aProperty.Name = INFO_JDBCDRIVERCLASS; break; case XML_TOK_EXTENSION: aProperty.Name = INFO_TEXTFILEEXTENSION; break; case XML_TOK_IS_FIRST_ROW_HEADER_LINE: aProperty.Name = INFO_TEXTFILEHEADER; aProperty.Value <<= (sValue == s_sTRUE ? sal_True : sal_False); break; case XML_TOK_SHOW_DELETED: aProperty.Name = INFO_SHOWDELETEDROWS; aProperty.Value <<= (sValue == s_sTRUE ? sal_True : sal_False); break; case XML_TOK_IS_TABLE_NAME_LENGTH_LIMITED: aProperty.Name = INFO_ALLOWLONGTABLENAMES; aProperty.Value <<= (sValue == s_sTRUE ? sal_True : sal_False); bFoundTableNameLengthLimited = true; break; case XML_TOK_SYSTEM_DRIVER_SETTINGS: aProperty.Name = INFO_ADDITIONALOPTIONS; break; case XML_TOK_ENABLE_SQL92_CHECK: aProperty.Name = PROPERTY_ENABLESQL92CHECK; aProperty.Value <<= (sValue == s_sTRUE ? sal_True : sal_False); break; case XML_TOK_APPEND_TABLE_ALIAS_NAME: aProperty.Name = INFO_APPEND_TABLE_ALIAS; aProperty.Value <<= (sValue == s_sTRUE ? sal_True : sal_False); bFoundAppendTableAliasName = true; break; case XML_TOK_PARAMETER_NAME_SUBSTITUTION: aProperty.Name = INFO_PARAMETERNAMESUBST; aProperty.Value <<= (sValue == s_sTRUE ? sal_True : sal_False); bFoundParamNameSubstitution = true; break; case XML_TOK_IGNORE_DRIVER_PRIVILEGES: aProperty.Name = INFO_IGNOREDRIVER_PRIV; aProperty.Value <<= (sValue == s_sTRUE ? sal_True : sal_False); break; case XML_TOK_BOOLEAN_COMPARISON_MODE: aProperty.Name = PROPERTY_BOOLEANCOMPARISONMODE; if ( sValue.equalsAscii("equal-integer") ) aProperty.Value <<= sal_Int32(0); else if ( sValue.equalsAscii("is-boolean") ) aProperty.Value <<= sal_Int32(1); else if ( sValue.equalsAscii("equal-boolean") ) aProperty.Value <<= sal_Int32(2); else if ( sValue.equalsAscii("equal-use-only-zero") ) aProperty.Value <<= sal_Int32(3); break; case XML_TOK_USE_CATALOG: aProperty.Name = INFO_USECATALOG; aProperty.Value <<= (sValue == s_sTRUE ? sal_True : sal_False); break; case XML_TOK_BASE_DN: aProperty.Name = INFO_CONN_LDAP_BASEDN; break; case XML_TOK_MAX_ROW_COUNT: aProperty.Name = INFO_CONN_LDAP_ROWCOUNT; aProperty.Value <<= sValue.toInt32(); break; case XML_TOK_JAVA_CLASSPATH: aProperty.Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("JavaDriverClassPath")); break; } if ( aProperty.Name.getLength() ) { if ( !aProperty.Value.hasValue() ) aProperty.Value <<= sValue; rImport.addInfo(aProperty); } } if ( rImport.isNewFormat() ) { if ( !bFoundTableNameLengthLimited && ( _eUsedFor == eAppSettings ) ) { aProperty.Name = INFO_ALLOWLONGTABLENAMES; aProperty.Value <<= sal_True; rImport.addInfo(aProperty); } if ( !bFoundParamNameSubstitution && ( _eUsedFor == eDriverSettings ) ) { aProperty.Name = INFO_PARAMETERNAMESUBST; aProperty.Value <<= sal_True; rImport.addInfo(aProperty); } if ( !bFoundAppendTableAliasName && ( _eUsedFor == eAppSettings ) ) { aProperty.Name = INFO_APPEND_TABLE_ALIAS; aProperty.Value <<= sal_True; rImport.addInfo(aProperty); } if ( !bFoundSuppressVersionColumns && ( _eUsedFor == eAppSettings ) ) { try { xDataSource->setPropertyValue(PROPERTY_SUPPRESSVERSIONCL,makeAny(sal_True)); } catch(Exception) { DBG_UNHANDLED_EXCEPTION(); } } } } // ----------------------------------------------------------------------------- OXMLDataSource::~OXMLDataSource() { DBG_DTOR(OXMLDataSource,NULL); } // ----------------------------------------------------------------------------- SvXMLImportContext* OXMLDataSource::CreateChildContext( sal_uInt16 nPrefix, const ::rtl::OUString& rLocalName, const Reference< XAttributeList > & xAttrList ) { SvXMLImportContext *pContext = 0; const SvXMLTokenMap& rTokenMap = GetOwnImport().GetDataSourceElemTokenMap(); const sal_uInt16 nToken = rTokenMap.Get( nPrefix, rLocalName ); switch( nToken ) { case XML_TOK_LOGIN: GetOwnImport().GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); pContext = new OXMLLogin( GetOwnImport(), nPrefix, rLocalName,xAttrList ); break; case XML_TOK_TABLE_FILTER: case XML_TOK_TABLE_TYPE_FILTER: GetOwnImport().GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); pContext = new OXMLTableFilterList( GetImport(), nPrefix, rLocalName ); break; case XML_TOK_AUTO_INCREMENT: case XML_TOK_DELIMITER: case XML_TOK_FONT_CHARSET: case XML_TOK_CHARACTER_SET: GetOwnImport().GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); pContext = new OXMLDataSourceInfo( GetOwnImport(), nPrefix, rLocalName,xAttrList,nToken); break; case XML_TOK_DATA_SOURCE_SETTINGS: GetOwnImport().GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); pContext = new OXMLDataSourceSettings( GetOwnImport(), nPrefix, rLocalName); break; case XML_TOK_CONNECTION_DATA: GetOwnImport().GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); pContext = new OXMLConnectionData( GetOwnImport(), nPrefix, rLocalName); break; case XML_TOK_DRIVER_SETTINGS: GetOwnImport().GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); pContext = new OXMLDataSource( GetOwnImport(), nPrefix, rLocalName, xAttrList, OXMLDataSource::eDriverSettings ); break; case XML_TOK_APPLICATION_CONNECTION_SETTINGS: GetOwnImport().GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); pContext = new OXMLDataSource( GetOwnImport(), nPrefix, rLocalName, xAttrList, OXMLDataSource::eAppSettings ); break; } if( !pContext ) pContext = new SvXMLImportContext( GetImport(), nPrefix, rLocalName ); return pContext; } // ----------------------------------------------------------------------------- ODBFilter& OXMLDataSource::GetOwnImport() { return static_cast(GetImport()); } // ----------------------------------------------------------------------------- //---------------------------------------------------------------------------- } // namespace dbaxml // ----------------------------------------------------------------------------- /* vim:set shiftwidth=4 softtabstop=4 expandtab: */