office-gobmx/include/ucbhelper/propertyvalueset.hxx
Norbert Thiebaud 3d12a3339b fdo#65108 inter-module includes <> include/ucbhelper
Change-Id: I355c0873ef51b92f39dd7cc0d696075f54f890d9
2013-11-09 18:48:48 -06:00

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: */