diff options
-rw-r--r-- | cui/source/options/optlingu.cxx | 1 | ||||
-rw-r--r-- | editeng/inc/pch/precompiled_editeng.hxx | 1 | ||||
-rw-r--r-- | starmath/inc/symbol.hxx | 1 | ||||
-rw-r--r-- | starmath/source/math_pch.cxx | 1 | ||||
-rw-r--r-- | svtools/source/filter/wmf/winmtf.hxx | 1 | ||||
-rw-r--r-- | svx/inc/pch/precompiled_svx.hxx | 1 | ||||
-rw-r--r-- | tools/Package_inc.mk | 1 | ||||
-rw-r--r-- | tools/inc/tools/dynary.hxx | 105 |
8 files changed, 112 insertions, 0 deletions
diff --git a/cui/source/options/optlingu.cxx b/cui/source/options/optlingu.cxx index d716f7f51464..61ce1b230518 100644 --- a/cui/source/options/optlingu.cxx +++ b/cui/source/options/optlingu.cxx @@ -32,6 +32,7 @@ #include <vcl/field.hxx> #include <vcl/fixed.hxx> #include <tools/shl.hxx> +#include <tools/dynary.hxx> #include <i18npool/mslangid.hxx> #include <unotools/lingucfg.hxx> #include <editeng/unolingu.hxx> diff --git a/editeng/inc/pch/precompiled_editeng.hxx b/editeng/inc/pch/precompiled_editeng.hxx index 450f381c8882..81f0cc6ad79b 100644 --- a/editeng/inc/pch/precompiled_editeng.hxx +++ b/editeng/inc/pch/precompiled_editeng.hxx @@ -785,6 +785,7 @@ #include "tools/contnr.hxx" #include "tools/debug.hxx" #include "tools/diagnose_ex.h" +#include "tools/dynary.hxx" #include "tools/errcode.hxx" #include "tools/errinf.hxx" #include "tools/fract.hxx" diff --git a/starmath/inc/symbol.hxx b/starmath/inc/symbol.hxx index 21f2c5cc91dc..d72df3416415 100644 --- a/starmath/inc/symbol.hxx +++ b/starmath/inc/symbol.hxx @@ -30,6 +30,7 @@ #define SYMBOL_HXX #include <vcl/font.hxx> +#include <tools/dynary.hxx> #include <svl/lstner.hxx> #include <svl/svarray.hxx> diff --git a/starmath/source/math_pch.cxx b/starmath/source/math_pch.cxx index e85359be5a83..0c3e56011ee8 100644 --- a/starmath/source/math_pch.cxx +++ b/starmath/source/math_pch.cxx @@ -134,6 +134,7 @@ #include <osl/thread.hxx> #include <osl/thread.h> #include <vcl/apptypes.hxx> +#include <tools/dynary.hxx> #include <vcl/svapp.hxx> #include <vcl/timer.hxx> #include <sfx2/app.hxx> diff --git a/svtools/source/filter/wmf/winmtf.hxx b/svtools/source/filter/wmf/winmtf.hxx index 58bb5bf25153..6dced919f643 100644 --- a/svtools/source/filter/wmf/winmtf.hxx +++ b/svtools/source/filter/wmf/winmtf.hxx @@ -38,6 +38,7 @@ #include <tools/debug.hxx> #include <tools/stack.hxx> #include <tools/table.hxx> +#include <tools/dynary.hxx> #include <vcl/graph.hxx> #include <vcl/virdev.hxx> #include <tools/poly.hxx> diff --git a/svx/inc/pch/precompiled_svx.hxx b/svx/inc/pch/precompiled_svx.hxx index 64d1f7cd76e6..19b303405aa5 100644 --- a/svx/inc/pch/precompiled_svx.hxx +++ b/svx/inc/pch/precompiled_svx.hxx @@ -855,6 +855,7 @@ #include "tools/contnr.hxx" #include "tools/debug.hxx" #include "tools/diagnose_ex.h" +#include "tools/dynary.hxx" #include "tools/errcode.hxx" #include "tools/errinf.hxx" #include "tools/fract.hxx" diff --git a/tools/Package_inc.mk b/tools/Package_inc.mk index d1ca76b12bf0..22f034c6e257 100644 --- a/tools/Package_inc.mk +++ b/tools/Package_inc.mk @@ -39,6 +39,7 @@ $(eval $(call gb_Package_add_file,tools_inc,inc/tools/date.hxx,tools/date.hxx)) $(eval $(call gb_Package_add_file,tools_inc,inc/tools/datetime.hxx,tools/datetime.hxx)) $(eval $(call gb_Package_add_file,tools_inc,inc/tools/debug.hxx,tools/debug.hxx)) $(eval $(call gb_Package_add_file,tools_inc,inc/tools/diagnose_ex.h,tools/diagnose_ex.h)) +$(eval $(call gb_Package_add_file,tools_inc,inc/tools/dynary.hxx,tools/dynary.hxx)) $(eval $(call gb_Package_add_file,tools_inc,inc/tools/errcode.hxx,tools/errcode.hxx)) $(eval $(call gb_Package_add_file,tools_inc,inc/tools/errinf.hxx,tools/errinf.hxx)) $(eval $(call gb_Package_add_file,tools_inc,inc/tools/extendapplicationenvironment.hxx,tools/extendapplicationenvironment.hxx)) diff --git a/tools/inc/tools/dynary.hxx b/tools/inc/tools/dynary.hxx new file mode 100644 index 000000000000..7e174555c1eb --- /dev/null +++ b/tools/inc/tools/dynary.hxx @@ -0,0 +1,105 @@ +/* -*- 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 _DYNARY_HXX +#define _DYNARY_HXX + +#include <tools/solar.h> +#include <tools/contnr.hxx> + +// ------------ +// - DynArray - +// ------------ + +#define DYNARRAY_ENTRY_NOTFOUND CONTAINER_ENTRY_NOTFOUND + +class DynArray : private Container +{ +public: + using Container::SetSize; + using Container::GetSize; + using Container::Clear; + + DynArray( sal_uIntPtr nSize = 16 ) : Container( nSize ) {} + DynArray( const DynArray& rAry ) : Container( rAry ) {} + + void* Put( sal_uIntPtr nIndex, void* p ) + { return Container::Replace( p, nIndex ); } + void* Get( sal_uIntPtr nIndex ) const + { return Container::GetObject( nIndex ); } + + sal_uIntPtr GetIndex( const void* p ) const + { return Container::GetPos( p ); } + + DynArray& operator =( const DynArray& rAry ) + { Container::operator =( rAry ); return *this; } + + sal_Bool operator ==( const DynArray& rAry ) const + { return Container::operator ==( rAry ); } + sal_Bool operator !=( const DynArray& rAry ) const + { return Container::operator !=( rAry ); } +}; + +// -------------------- +// - DECLARE_DYNARRAY - +// -------------------- + +#define DECLARE_DYNARRAY( ClassName, Type ) \ +class ClassName : private DynArray \ +{ \ +public: \ + using DynArray::SetSize; \ + using DynArray::GetSize; \ + using DynArray::Clear; \ + \ + ClassName( sal_uIntPtr nSize = 16 ) : \ + DynArray( nSize ) {} \ + ClassName( const ClassName& rClassName ) : \ + DynArray( rClassName ) {} \ + \ + Type Put( sal_uIntPtr nIndex, Type p ) \ + { return (Type)DynArray::Put( nIndex, (void*)p ); } \ + Type Get( sal_uIntPtr nIndex ) const \ + { return (Type)DynArray::Get( nIndex ); } \ + \ + sal_uIntPtr GetIndex( const Type p ) const \ + { return DynArray::GetIndex( (const void*)p ); } \ + \ + ClassName& operator =( const ClassName& rClassName ) \ + { DynArray::operator =( rClassName ); \ + return *this; } \ + \ + sal_Bool operator ==( const ClassName& rAry ) const \ + { return DynArray::operator ==( rAry ); } \ + sal_Bool operator !=( const ClassName& rAry ) const \ + { return DynArray::operator !=( rAry ); } \ +}; + +#endif // _DYNARY_HXX + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |