summaryrefslogtreecommitdiff
path: root/extensions/source/propctrlr/pcrcommon.hxx
diff options
context:
space:
mode:
Diffstat (limited to 'extensions/source/propctrlr/pcrcommon.hxx')
-rw-r--r--extensions/source/propctrlr/pcrcommon.hxx155
1 files changed, 155 insertions, 0 deletions
diff --git a/extensions/source/propctrlr/pcrcommon.hxx b/extensions/source/propctrlr/pcrcommon.hxx
new file mode 100644
index 000000000000..f6a601528160
--- /dev/null
+++ b/extensions/source/propctrlr/pcrcommon.hxx
@@ -0,0 +1,155 @@
+/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2000, 2010 Oracle and/or its affiliates.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * This file is part of OpenOffice.org.
+ *
+ * OpenOffice.org is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License version 3
+ * only, as published by the Free Software Foundation.
+ *
+ * OpenOffice.org is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Lesser General Public License version 3 for more details
+ * (a copy is included in the LICENSE file that accompanied this code).
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * version 3 along with OpenOffice.org. If not, see
+ * <http://www.openoffice.org/license.html>
+ * for a copy of the LGPLv3 License.
+ *
+ ************************************************************************/
+
+#ifndef _EXTENSIONS_PROPCTRLR_PCRCOMMON_HXX_
+#define _EXTENSIONS_PROPCTRLR_PCRCOMMON_HXX_
+
+#define EDITOR_LIST_APPEND (sal_uInt16)-1
+#define EDITOR_LIST_REPLACE_EXISTING (sal_uInt16)-1
+
+/** === begin UNO includes === **/
+#include <com/sun/star/uno/Sequence.hxx>
+#include <com/sun/star/beans/XPropertyChangeListener.hpp>
+#include <com/sun/star/beans/PropertyChangeEvent.hpp>
+/** === end UNO includes === **/
+
+#include <vcl/smartid.hxx>
+#include <tools/string.hxx>
+#include <toolkit/helper/vclunohelper.hxx>
+#include <comphelper/listenernotification.hxx>
+
+//............................................................................
+namespace pcr
+{
+//............................................................................
+
+ #define OWN_PROPERTY_ID_INTROSPECTEDOBJECT 0x0010
+ #define OWN_PROPERTY_ID_CURRENTPAGE 0x0011
+ #define OWN_PROPERTY_ID_CONTROLCONTEXT 0x0012
+ #define OWN_PROPERTY_ID_TABBINGMODEL 0x0013
+
+ //========================================================================
+ //= types
+ //========================================================================
+ typedef ::comphelper::OSimpleListenerContainer < ::com::sun::star::beans::XPropertyChangeListener
+ , ::com::sun::star::beans::PropertyChangeEvent
+ > PropertyChangeListeners;
+
+ //========================================================================
+ //= helper
+ //========================================================================
+ // small helper to make the "swap" call on an STL container a single-line call, which
+ // in it's canonic form "aFoo.swap( Container() )" doesn't compile with GCC
+ template< class CONTAINER >
+ void clearContainer( CONTAINER& _rContainer )
+ {
+ CONTAINER aEmpty;
+ _rContainer.swap( aEmpty );
+ }
+
+ //========================================================================
+ //= HelpIdUrl
+ //========================================================================
+ /// small helper to translate help ids into help urls
+ class HelpIdUrl
+ {
+ public:
+ static SmartId getHelpId( const ::rtl::OUString& _rHelpURL );
+ static ::rtl::OUString getHelpURL( sal_uInt32 _nHelpId );
+ };
+
+ //====================================================================
+ //= StlSyntaxSequence
+ //====================================================================
+ template< class ELEMENT >
+ class StlSyntaxSequence : public ::com::sun::star::uno::Sequence< ELEMENT >
+ {
+ private:
+ typedef ::com::sun::star::uno::Sequence< ELEMENT > UnoBase;
+
+ public:
+ inline StlSyntaxSequence() : UnoBase() { }
+ inline StlSyntaxSequence( const UnoBase& rSeq ) : UnoBase( rSeq ) { }
+ inline StlSyntaxSequence( const ELEMENT* pElements, sal_Int32 len ) : UnoBase( pElements, len ) { }
+ inline StlSyntaxSequence( sal_Int32 len ) : UnoBase( len ) { }
+
+ operator const UnoBase&() const { return *this; }
+ operator UnoBase&() { return *this; }
+
+ typedef const ELEMENT* const_iterator;
+ typedef ELEMENT* iterator;
+
+ inline const_iterator begin() const { return UnoBase::getConstArray(); }
+ inline const_iterator end() const { return UnoBase::getConstArray() + UnoBase::getLength(); }
+
+ inline iterator begin() { return UnoBase::getArray(); }
+ inline iterator end() { return UnoBase::getArray() + UnoBase::getLength(); }
+
+ inline sal_Int32 size() const { return UnoBase::getLength(); }
+ inline bool empty() const { return UnoBase::getLength() == 0; }
+
+ inline void resize( size_t _newSize ) { UnoBase::realloc( _newSize ); }
+
+ inline iterator erase( iterator _pos )
+ {
+ iterator loop = end();
+ while ( --loop != _pos )
+ *( loop - 1 ) = *loop;
+ resize( size() - 1 );
+ }
+ };
+
+ //========================================================================
+ //= UNO helpers
+ //========================================================================
+#define DECLARE_XCOMPONENT() \
+ virtual void SAL_CALL dispose( ) throw (::com::sun::star::uno::RuntimeException); \
+ virtual void SAL_CALL addEventListener( const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XEventListener >& xListener ) throw (::com::sun::star::uno::RuntimeException); \
+ virtual void SAL_CALL removeEventListener( const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XEventListener >& aListener ) throw (::com::sun::star::uno::RuntimeException);
+
+#define IMPLEMENT_FORWARD_XCOMPONENT( classname, baseclass ) \
+ void SAL_CALL classname::dispose( ) throw (::com::sun::star::uno::RuntimeException) \
+ { \
+ baseclass::WeakComponentImplHelperBase::dispose(); \
+ } \
+ void SAL_CALL classname::addEventListener( const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XEventListener >& _Listener ) throw (::com::sun::star::uno::RuntimeException) \
+ { \
+ baseclass::WeakComponentImplHelperBase::addEventListener( _Listener ); \
+ } \
+ void SAL_CALL classname::removeEventListener( const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XEventListener >& _Listener ) throw (::com::sun::star::uno::RuntimeException) \
+ { \
+ baseclass::WeakComponentImplHelperBase::removeEventListener( _Listener ); \
+ } \
+
+//............................................................................
+} // namespace pcr
+//............................................................................
+
+#endif // _EXTENSIONS_PROPCTRLR_PCRCOMMON_HXX_
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */