3d12a3339b
Change-Id: I355c0873ef51b92f39dd7cc0d696075f54f890d9
275 lines
11 KiB
C++
275 lines
11 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 .
|
|
*/
|
|
|
|
#ifndef INCLUDED_UCBHELPER_PROPERTYVALUESET_HXX
|
|
#define INCLUDED_UCBHELPER_PROPERTYVALUESET_HXX
|
|
|
|
#include <com/sun/star/lang/XTypeProvider.hpp>
|
|
#include <com/sun/star/sdbc/XColumnLocate.hpp>
|
|
#include <com/sun/star/sdbc/XRow.hpp>
|
|
#include <com/sun/star/beans/Property.hpp>
|
|
#include <cppuhelper/weak.hxx>
|
|
|
|
#include <osl/mutex.hxx>
|
|
#include <ucbhelper/macros.hxx>
|
|
#include <ucbhelper/ucbhelperdllapi.h>
|
|
|
|
namespace com { namespace sun { namespace star { namespace script {
|
|
class XTypeConverter;
|
|
} } } }
|
|
|
|
namespace com { namespace sun { namespace star { namespace beans {
|
|
struct PropertyValue;
|
|
class XPropertySet;
|
|
} } } }
|
|
|
|
namespace ucbhelper {
|
|
|
|
class PropertyValues;
|
|
|
|
//=========================================================================
|
|
|
|
/**
|
|
* This class implements the interface XRow. After construction of a valueset
|
|
* the user can append properties ( incl. its values ) to the set. This class
|
|
* is useful when implementing the command "getPropertyValues", because the
|
|
* values to return can easyly appended to a valueset object. That object can
|
|
* directly be returned by the implementation of the command.
|
|
*/
|
|
class UCBHELPER_DLLPUBLIC PropertyValueSet :
|
|
public cppu::OWeakObject,
|
|
public com::sun::star::lang::XTypeProvider,
|
|
public com::sun::star::sdbc::XRow,
|
|
public com::sun::star::sdbc::XColumnLocate
|
|
{
|
|
com::sun::star::uno::Reference< com::sun::star::uno::XComponentContext >
|
|
m_xContext;
|
|
com::sun::star::uno::Reference< com::sun::star::script::XTypeConverter >
|
|
m_xTypeConverter;
|
|
osl::Mutex m_aMutex;
|
|
PropertyValues* m_pValues;
|
|
sal_Bool m_bWasNull;
|
|
sal_Bool m_bTriedToGetTypeConverter;
|
|
|
|
private:
|
|
UCBHELPER_DLLPRIVATE const com::sun::star::uno::Reference<
|
|
com::sun::star::script::XTypeConverter >&
|
|
getTypeConverter();
|
|
|
|
public:
|
|
PropertyValueSet(
|
|
const com::sun::star::uno::Reference<
|
|
com::sun::star::uno::XComponentContext >& rxContext );
|
|
virtual ~PropertyValueSet();
|
|
|
|
// XInterface
|
|
XINTERFACE_DECL()
|
|
|
|
// XTypeProvider
|
|
XTYPEPROVIDER_DECL()
|
|
|
|
// XRow
|
|
virtual sal_Bool SAL_CALL
|
|
wasNull()
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual OUString SAL_CALL
|
|
getString( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual sal_Bool SAL_CALL
|
|
getBoolean( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual sal_Int8 SAL_CALL
|
|
getByte( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual sal_Int16 SAL_CALL
|
|
getShort( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual sal_Int32 SAL_CALL
|
|
getInt( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual sal_Int64 SAL_CALL
|
|
getLong( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual float SAL_CALL
|
|
getFloat( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual double SAL_CALL
|
|
getDouble( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual ::com::sun::star::uno::Sequence< sal_Int8 > SAL_CALL
|
|
getBytes( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual ::com::sun::star::util::Date SAL_CALL
|
|
getDate( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual ::com::sun::star::util::Time SAL_CALL
|
|
getTime( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual ::com::sun::star::util::DateTime SAL_CALL
|
|
getTimestamp( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual ::com::sun::star::uno::Reference<
|
|
::com::sun::star::io::XInputStream > SAL_CALL
|
|
getBinaryStream( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual ::com::sun::star::uno::Reference<
|
|
::com::sun::star::io::XInputStream > SAL_CALL
|
|
getCharacterStream( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual ::com::sun::star::uno::Any SAL_CALL
|
|
getObject( sal_Int32 columnIndex,
|
|
const ::com::sun::star::uno::Reference<
|
|
::com::sun::star::container::XNameAccess >& typeMap )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual ::com::sun::star::uno::Reference<
|
|
::com::sun::star::sdbc::XRef > SAL_CALL
|
|
getRef( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual ::com::sun::star::uno::Reference<
|
|
::com::sun::star::sdbc::XBlob > SAL_CALL
|
|
getBlob( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual ::com::sun::star::uno::Reference<
|
|
::com::sun::star::sdbc::XClob > SAL_CALL
|
|
getClob( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
virtual ::com::sun::star::uno::Reference<
|
|
::com::sun::star::sdbc::XArray > SAL_CALL
|
|
getArray( sal_Int32 columnIndex )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
|
|
// XColumnLocate
|
|
virtual sal_Int32 SAL_CALL
|
|
findColumn( const OUString& columnName )
|
|
throw( ::com::sun::star::sdbc::SQLException,
|
|
::com::sun::star::uno::RuntimeException );
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
// Non-interface methods
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
void appendString( const OUString& rPropName, const OUString& rValue );
|
|
void appendString( const sal_Char* pAsciiPropName, const OUString& rValue )
|
|
{
|
|
appendString( OUString::createFromAscii( pAsciiPropName ), rValue );
|
|
}
|
|
void appendString( const ::com::sun::star::beans::Property& rProp, const OUString& rValue )
|
|
{
|
|
appendString( rProp.Name, rValue );
|
|
}
|
|
|
|
void appendBoolean( const OUString& rPropName, sal_Bool bValue );
|
|
void appendBoolean( const sal_Char* pAsciiPropName, sal_Bool bValue )
|
|
{
|
|
appendBoolean( OUString::createFromAscii( pAsciiPropName ), bValue );
|
|
}
|
|
void appendBoolean( const ::com::sun::star::beans::Property& rProp, sal_Bool bValue )
|
|
{
|
|
appendBoolean( rProp.Name, bValue );
|
|
}
|
|
|
|
void appendLong( const OUString& rPropName, sal_Int64 nValue );
|
|
void appendLong( const sal_Char* pAsciiPropName, sal_Int64 nValue )
|
|
{
|
|
appendLong( OUString::createFromAscii( pAsciiPropName ), nValue );
|
|
}
|
|
void appendLong( const ::com::sun::star::beans::Property& rProp, sal_Int64 nValue )
|
|
{
|
|
appendLong( rProp.Name, nValue );
|
|
}
|
|
|
|
void appendTimestamp( const OUString& rPropName, const ::com::sun::star::util::DateTime& rValue );
|
|
void appendTimestamp( const sal_Char* pAsciiPropName, const ::com::sun::star::util::DateTime& rValue )
|
|
{
|
|
appendTimestamp( OUString::createFromAscii( pAsciiPropName ), rValue );
|
|
}
|
|
void appendTimestamp( const ::com::sun::star::beans::Property& rProp, const ::com::sun::star::util::DateTime& rValue )
|
|
{
|
|
appendTimestamp( rProp.Name, rValue );
|
|
}
|
|
|
|
void appendObject( const OUString& rPropName, const ::com::sun::star::uno::Any& rValue );
|
|
void appendObject( const sal_Char* pAsciiPropName, const ::com::sun::star::uno::Any& rValue )
|
|
{
|
|
appendObject( OUString::createFromAscii( pAsciiPropName ), rValue );
|
|
}
|
|
void appendObject( const ::com::sun::star::beans::Property& rProp, const ::com::sun::star::uno::Any& rValue )
|
|
{
|
|
appendObject( rProp.Name, rValue );
|
|
}
|
|
|
|
void appendVoid( const OUString& rPropName );
|
|
void appendVoid( const sal_Char* pAsciiPropName)
|
|
{
|
|
appendVoid( OUString::createFromAscii( pAsciiPropName ) );
|
|
}
|
|
void appendVoid( const ::com::sun::star::beans::Property& rProp )
|
|
{
|
|
appendVoid( rProp.Name );
|
|
}
|
|
|
|
/**
|
|
* This method tries to append all property values contained in a
|
|
* property set to the value set.
|
|
*
|
|
* @param rSet is a property set containing the property values.
|
|
*/
|
|
void appendPropertySet( const ::com::sun::star::uno::Reference<
|
|
::com::sun::star::beans::XPropertySet >& rSet );
|
|
|
|
/** This method tries to append a single property value contained in a
|
|
* property set to the value set.
|
|
*
|
|
* @param rSet is a property set containing the property values.
|
|
* @param rProperty is the property for that the value shall be obtained
|
|
* from the given property set.
|
|
* @return False, if the property value cannot be obtained from the
|
|
* given property pet. True, otherwise.
|
|
*/
|
|
sal_Bool appendPropertySetValue(
|
|
const ::com::sun::star::uno::Reference<
|
|
::com::sun::star::beans::XPropertySet >& rSet,
|
|
const ::com::sun::star::beans::Property& rProperty );
|
|
};
|
|
|
|
}
|
|
|
|
#endif /* ! INCLUDED_UCBHELPER_PROPERTYVALUESET_HXX */
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|