/************************************************************** * * 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 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ #if ! defined(COMPHELPER_UNWRAPARGS_HXX_INCLUDED) #define COMPHELPER_UNWRAPARGS_HXX_INCLUDED #if ! defined(_RTL_USTRBUF_HXX_) #include "rtl/ustrbuf.hxx" #endif #include "com/sun/star/uno/Sequence.hxx" #if ! defined(_COM_SUN_STAR_LANG_ILLEGALARGUMENTEXCEPTION_HPP_) #include "com/sun/star/lang/IllegalArgumentException.hpp" #endif #include "boost/optional.hpp" #include "boost/preprocessor/cat.hpp" #include "boost/preprocessor/repetition.hpp" #include "boost/preprocessor/arithmetic/add.hpp" #include "cppu/unotype.hxx" namespace comphelper { // // generating helper functions to unwrap the service's argument sequence: // /// @internal namespace detail { template inline void extract( ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Any> const& seq, sal_Int32 nArg, T & v, ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface> const& xErrorContext ) { if (nArg >= seq.getLength()) { throw ::com::sun::star::lang::IllegalArgumentException( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "No such argument available!") ), xErrorContext, static_cast(nArg) ); } if (! (seq[nArg] >>= v)) { ::rtl::OUStringBuffer buf; buf.appendAscii( RTL_CONSTASCII_STRINGPARAM("Cannot extract ANY { ") ); buf.append( seq[nArg].getValueType().getTypeName() ); buf.appendAscii( RTL_CONSTASCII_STRINGPARAM(" } to ") ); buf.append( ::cppu::UnoType::get().getTypeName() ); buf.append( static_cast('!') ); throw ::com::sun::star::lang::IllegalArgumentException( buf.makeStringAndClear(), xErrorContext, static_cast(nArg) ); } } template inline void extract( ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Any> const& seq, sal_Int32 nArg, ::boost::optional & v, ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface> const& xErrorContext ) { if (nArg < seq.getLength()) { T t; extract( seq, nArg, t, xErrorContext ); v.reset( t ); } } } // namespace detail #define COMPHELPER_UNWRAPARGS_extract(z_, n_, unused_) \ detail::extract( seq, n_, BOOST_PP_CAT(v, n_), xErrorContext ); #define COMPHELPER_UNWRAPARGS_args(z_, n_, unused_) \ BOOST_PP_CAT(T, n_) & BOOST_PP_CAT(v, n_) /** The following preprocessor repetitions generate functions like
        template 
        inline void unwrapArgs(
            uno::Sequence const& seq,
            T0 & v0, T1 & v1, ...,
            css::uno::Reference const& xErrorContext =
            css::uno::Reference() );
    
(full namespace qualification ::com::sun::star has been omitted for brevity) which unwraps the passed sequence's elements, assigning them to the referenced values. Specify optional arguments as boost::optional. If the length of the sequence is greater than the count of arguments, then the latter sequence elements are ignored. If too few arguments are given in the sequence and a missing argument is no boost::optional, then an lang::IllegalArgumentException is thrown with the specified xErrorContext (defaults to null-ref). The maximum number of service declarations can be set by defining COMPHELPER_UNWRAPARGS_MAX_ARGS; its default is 12. */ #define COMPHELPER_UNWRAPARGS_make(z_, n_, unused_) \ template < BOOST_PP_ENUM_PARAMS( BOOST_PP_ADD(n_, 1), typename T) > \ inline void unwrapArgs( \ ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Any > const& seq, \ BOOST_PP_ENUM(BOOST_PP_ADD(n_, 1), COMPHELPER_UNWRAPARGS_args, ~), \ ::com::sun::star::uno::Reference< \ ::com::sun::star::uno::XInterface> const& xErrorContext = \ ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface>() ) \ { \ BOOST_PP_REPEAT(BOOST_PP_ADD(n_, 1), COMPHELPER_UNWRAPARGS_extract, ~) \ } #if ! defined(COMPHELPER_UNWRAPARGS_MAX_ARGS) #define COMPHELPER_UNWRAPARGS_MAX_ARGS 12 #endif BOOST_PP_REPEAT(COMPHELPER_UNWRAPARGS_MAX_ARGS, COMPHELPER_UNWRAPARGS_make, ~) #undef COMPHELPER_UNWRAPARGS_MAX_ARGS #undef COMPHELPER_UNWRAPARGS_make #undef COMPHELPER_UNWRAPARGS_args #undef COMPHELPER_UNWRAPARGS_extract } // namespace comphelper #endif // ! defined(COMPHELPER_UNWRAPARGS_HXX_INCLUDED)