/* -*- 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 .
*/
#pragma once
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include "definitioncontainer.hxx"
namespace dbtools
{
class WarningsContainer;
}
namespace dbaccess
{
typedef ::cppu::ImplHelper5 < css::container::XContainerListener
, css::container::XContainerApproveListener
, css::sdbcx::XDataDescriptorFactory
, css::sdbcx::XAppend
, css::sdbcx::XDrop
> OQueryContainer_Base;
// OQueryContainer
class OQueryContainer : public ODefinitionContainer
, public OQueryContainer_Base
{
private:
::dbtools::WarningsContainer* m_pWarnings;
css::uno::Reference< css::container::XNameContainer >
m_xCommandDefinitions;
css::uno::Reference< css::sdbc::XConnection >
m_xConnection;
// possible actions on our "aggregate"
enum class AggregateAction { NONE, Inserting };
AggregateAction m_eDoingCurrently;
/** a class which automatically resets m_eDoingCurrently in its destructor
*/
class OAutoActionReset; // just for the following friend declaration
friend class OAutoActionReset;
class OAutoActionReset
{
OQueryContainer& m_rActor;
public:
OAutoActionReset(OQueryContainer& _rActor) : m_rActor(_rActor) { }
~OAutoActionReset() { m_rActor.m_eDoingCurrently = AggregateAction::NONE; }
};
// ODefinitionContainer
virtual css::uno::Reference< css::ucb::XContent > createObject( const OUString& _rName) override;
virtual bool checkExistence(const OUString& _rName) override;
// helper
virtual void SAL_CALL disposing() override;
virtual ~OQueryContainer() override;
/** ctor of the container. The parent has to support the XConnection
interface.
@param _pWarnings
specifies a warnings container (May be )
Any errors which occur during the lifetime of the query container,
which cannot be reported as exceptions (for instance in methods where throwing an SQLException is
not allowed) will be appended to this container.
The caller is responsible for ensuring the lifetime of the object pointed to by this parameter.
*/
OQueryContainer(
const css::uno::Reference< css::container::XNameContainer >& _rxCommandDefinitions,
const css::uno::Reference< css::sdbc::XConnection >& _rxConn,
const css::uno::Reference< css::uno::XComponentContext >& _rxORB,
::dbtools::WarningsContainer* _pWarnings
);
void init();
public:
static rtl::Reference create(
const css::uno::Reference< css::container::XNameContainer >& _rxCommandDefinitions,
const css::uno::Reference< css::sdbc::XConnection >& _rxConn,
const css::uno::Reference< css::uno::XComponentContext >& _rxORB,
::dbtools::WarningsContainer* _pWarnings
);
DECLARE_XINTERFACE( )
DECLARE_XTYPEPROVIDER( )
DECLARE_SERVICE_INFO();
// css::container::XContainerListener
virtual void SAL_CALL elementInserted( const css::container::ContainerEvent& Event ) override;
virtual void SAL_CALL elementRemoved( const css::container::ContainerEvent& Event ) override;
virtual void SAL_CALL elementReplaced( const css::container::ContainerEvent& Event ) override;
// XContainerApproveListener
virtual css::uno::Reference< css::util::XVeto > SAL_CALL approveInsertElement( const css::container::ContainerEvent& Event ) override;
virtual css::uno::Reference< css::util::XVeto > SAL_CALL approveReplaceElement( const css::container::ContainerEvent& Event ) override;
virtual css::uno::Reference< css::util::XVeto > SAL_CALL approveRemoveElement( const css::container::ContainerEvent& Event ) override;
// css::lang::XEventListener
virtual void SAL_CALL disposing( const css::lang::EventObject& Source ) override;
// css::sdbcx::XDataDescriptorFactory
virtual css::uno::Reference< css::beans::XPropertySet > SAL_CALL createDataDescriptor( ) override;
// css::sdbcx::XAppend
virtual void SAL_CALL appendByDescriptor( const css::uno::Reference< css::beans::XPropertySet >& descriptor ) override;
// css::sdbcx::XDrop
virtual void SAL_CALL dropByName( const OUString& elementName ) override;
virtual void SAL_CALL dropByIndex( sal_Int32 index ) override;
// css::container::XElementAccess
virtual sal_Bool SAL_CALL hasElements( ) override;
// css::container::XIndexAccess
virtual sal_Int32 SAL_CALL getCount( ) override;
// css::container::XNameAccess
virtual css::uno::Sequence< OUString > SAL_CALL getElementNames( ) override;
private:
// OContentHelper overridables
virtual OUString determineContentType() const override;
// helper
/** create a query object wrapping a CommandDefinition given by name. To retrieve the object, the CommandDescription
container will be asked for the given name.
The returned object is acquired once.
*/
css::uno::Reference< css::ucb::XContent > implCreateWrapper(const OUString& _rName);
/// create a query object wrapping a CommandDefinition. The returned object is acquired once.
css::uno::Reference< css::ucb::XContent > implCreateWrapper(const css::uno::Reference< css::ucb::XContent >& _rxCommandDesc);
};
} // namespace dbaccess
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */