1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include <sal/config.h>
24 #include <errobject.hxx>
25 #include <sbxbase.hxx>
27 #include <cppuhelper/implbase.hxx>
28 #include <com/sun/star/script/XDefaultProperty.hpp>
29 #include <sbintern.hxx>
30 #include <runtime.hxx>
32 using namespace ::com::sun::star
;
33 using namespace ::ooo
;
35 class ErrObject
: public ::cppu::WeakImplHelper
< vba::XErrObject
,
36 script::XDefaultProperty
>
40 OUString m_sDescription
;
42 sal_Int32 m_nHelpContext
;
48 virtual ::sal_Int32 SAL_CALL
getNumber() override
;
49 virtual void SAL_CALL
setNumber( ::sal_Int32 _number
) override
;
50 virtual ::sal_Int32 SAL_CALL
getHelpContext() override
;
51 virtual void SAL_CALL
setHelpContext( ::sal_Int32 _helpcontext
) override
;
52 virtual OUString SAL_CALL
getHelpFile() override
;
53 virtual void SAL_CALL
setHelpFile( const OUString
& _helpfile
) override
;
54 virtual OUString SAL_CALL
getDescription() override
;
55 virtual void SAL_CALL
setDescription( const OUString
& _description
) override
;
56 virtual OUString SAL_CALL
getSource() override
;
57 virtual void SAL_CALL
setSource( const OUString
& _source
) override
;
60 virtual void SAL_CALL
Clear( ) override
;
61 virtual void SAL_CALL
Raise( const uno::Any
& Number
, const uno::Any
& Source
, const uno::Any
& Description
, const uno::Any
& HelpFile
, const uno::Any
& HelpContext
) override
;
63 virtual OUString SAL_CALL
getDefaultPropertyName( ) override
;
66 /// @throws css::uno::RuntimeException
67 void setData( const uno::Any
& Number
, const uno::Any
& Source
, const uno::Any
& Description
,
68 const uno::Any
& HelpFile
, const uno::Any
& HelpContext
);
71 ErrObject::ErrObject() : m_nNumber(0), m_nHelpContext(0)
76 ErrObject::getNumber()
82 ErrObject::setNumber( ::sal_Int32 _number
)
84 GetSbData()->pInst
->setErrorVB( _number
);
85 OUString _description
= GetSbData()->pInst
->GetErrorMsg();
86 setData( uno::Any( _number
), uno::Any(), uno::Any( _description
), uno::Any(), uno::Any() );
90 ErrObject::getHelpContext()
92 return m_nHelpContext
;
95 ErrObject::setHelpContext( ::sal_Int32 _helpcontext
)
97 m_nHelpContext
= _helpcontext
;
101 ErrObject::getHelpFile()
107 ErrObject::setHelpFile( const OUString
& _helpfile
)
109 m_sHelpFile
= _helpfile
;
113 ErrObject::getDescription()
115 return m_sDescription
;
119 ErrObject::setDescription( const OUString
& _description
)
121 m_sDescription
= _description
;
125 ErrObject::getSource()
131 ErrObject::setSource( const OUString
& _source
)
141 m_sSource
= m_sHelpFile
;
142 m_sDescription
= m_sSource
;
148 ErrObject::Raise( const uno::Any
& Number
, const uno::Any
& Source
, const uno::Any
& Description
, const uno::Any
& HelpFile
, const uno::Any
& HelpContext
)
150 setData( Number
, Source
, Description
, HelpFile
, HelpContext
);
152 GetSbData()->pInst
->ErrorVB( m_nNumber
, m_sDescription
);
157 ErrObject::getDefaultPropertyName( )
162 void ErrObject::setData( const uno::Any
& Number
, const uno::Any
& Source
, const uno::Any
& Description
, const uno::Any
& HelpFile
, const uno::Any
& HelpContext
)
164 if ( !Number
.hasValue() )
165 throw uno::RuntimeException("Missing Required Parameter" );
166 Number
>>= m_nNumber
;
167 Description
>>= m_sDescription
;
168 Source
>>= m_sSource
;
169 HelpFile
>>= m_sHelpFile
;
170 HelpContext
>>= m_nHelpContext
;
174 SbxErrObject::SbxErrObject( const OUString
& rName
, const uno::Any
& rUnoObj
)
175 : SbUnoObject( rName
, rUnoObj
)
176 , m_pErrObject( nullptr )
181 SetDfltProperty( uno::Reference
< script::XDefaultProperty
>( m_xErr
, uno::UNO_QUERY_THROW
)->getDefaultPropertyName() ) ;
182 m_pErrObject
= static_cast< ErrObject
* >( m_xErr
.get() );
186 SbxErrObject::~SbxErrObject()
190 uno::Reference
< vba::XErrObject
> const &
191 SbxErrObject::getUnoErrObject()
193 SbxErrObject
* pGlobErr
= static_cast< SbxErrObject
* >( getErrObject().get() );
194 return pGlobErr
->m_xErr
;
197 SbxVariableRef
const &
198 SbxErrObject::getErrObject()
200 SbxVariableRef
& rGlobErr
= GetSbxData_Impl().m_aGlobErr
;
202 static std::mutex aMutex
;
203 std::scoped_lock
aGuard(aMutex
);
205 rGlobErr
= new SbxErrObject("Err",
206 uno::Any(uno::Reference
<vba::XErrObject
>(new ErrObject())));
211 void SbxErrObject::setNumberAndDescription( ::sal_Int32 _number
, const OUString
& _description
)
213 if( m_pErrObject
!= nullptr )
215 m_pErrObject
->setData( uno::Any( _number
), uno::Any(), uno::Any( _description
), uno::Any(), uno::Any() );
219 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */