2010-10-14 08:30:07 +02:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2006-07-26 06:42:32 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 09:36:28 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2006-07-26 06:42:32 +00:00
|
|
|
*
|
2010-02-12 15:01:35 +01:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2006-07-26 06:42:32 +00:00
|
|
|
*
|
2008-04-10 09:36:28 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2006-07-26 06:42:32 +00:00
|
|
|
*
|
2008-04-10 09:36:28 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2006-07-26 06:42:32 +00:00
|
|
|
*
|
2008-04-10 09:36:28 +00:00
|
|
|
* 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.
|
2006-07-26 06:42:32 +00:00
|
|
|
*
|
2008-04-10 09:36:28 +00:00
|
|
|
* 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).
|
2006-07-26 06:42:32 +00:00
|
|
|
*
|
2008-04-10 09:36:28 +00:00
|
|
|
* 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.
|
2006-07-26 06:42:32 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
2012-07-14 05:37:24 +02:00
|
|
|
#ifndef INCLUDED_RTL_ALLOCATOR_HXX
|
2006-07-26 06:42:32 +00:00
|
|
|
#define INCLUDED_RTL_ALLOCATOR_HXX
|
|
|
|
|
|
|
|
#include "sal/types.h"
|
|
|
|
#include "rtl/alloc.h"
|
|
|
|
#include <cstddef>
|
|
|
|
|
2012-01-05 19:40:38 +01:00
|
|
|
/// @cond INTERNAL
|
|
|
|
|
2006-07-26 06:42:32 +00:00
|
|
|
//######################################################
|
|
|
|
// This is no general purpose STL allocator but one
|
|
|
|
// necessary to use STL for some implementation but
|
|
|
|
// avoid linking sal against the STLPort library!!!
|
|
|
|
// For more information on when and how to define a
|
|
|
|
// custom stl allocator have a look at Scott Meyers:
|
|
|
|
// "Effective STL", Nicolai M. Josuttis:
|
|
|
|
// "The C++ Standard Library - A Tutorial and Reference"
|
|
|
|
// and at http://www.josuttis.com/cppcode/allocator.html
|
|
|
|
|
|
|
|
namespace rtl {
|
|
|
|
|
|
|
|
template<class T>
|
|
|
|
class Allocator
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
typedef T value_type;
|
|
|
|
typedef T* pointer;
|
|
|
|
typedef const T* const_pointer;
|
|
|
|
typedef T& reference;
|
|
|
|
typedef const T& const_reference;
|
|
|
|
typedef ::std::size_t size_type;
|
|
|
|
typedef ::std::ptrdiff_t difference_type;
|
|
|
|
|
|
|
|
//-----------------------------------------
|
|
|
|
template<class U>
|
|
|
|
struct rebind
|
|
|
|
{
|
|
|
|
typedef Allocator<U> other;
|
|
|
|
};
|
|
|
|
|
|
|
|
//-----------------------------------------
|
|
|
|
pointer address (reference value) const
|
|
|
|
{
|
|
|
|
return &value;
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------
|
|
|
|
const_pointer address (const_reference value) const
|
|
|
|
{
|
|
|
|
return &value;
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------
|
|
|
|
Allocator() SAL_THROW(())
|
|
|
|
{}
|
|
|
|
|
|
|
|
//-----------------------------------------
|
|
|
|
template<class U>
|
2012-01-21 15:21:16 +01:00
|
|
|
Allocator (SAL_UNUSED_PARAMETER const Allocator<U>&) SAL_THROW(())
|
2006-07-26 06:42:32 +00:00
|
|
|
{}
|
|
|
|
|
|
|
|
//-----------------------------------------
|
|
|
|
Allocator(const Allocator&) SAL_THROW(())
|
|
|
|
{}
|
|
|
|
|
|
|
|
//-----------------------------------------
|
|
|
|
~Allocator() SAL_THROW(())
|
|
|
|
{}
|
|
|
|
|
|
|
|
//-----------------------------------------
|
|
|
|
size_type max_size() const SAL_THROW(())
|
|
|
|
{
|
|
|
|
return size_type(-1)/sizeof(T);
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------
|
|
|
|
/* Normally the code for allocate should
|
|
|
|
throw a std::bad_alloc exception if the
|
|
|
|
requested memory could not be allocated:
|
|
|
|
(C++ standard 20.4.1.1):
|
|
|
|
|
|
|
|
pointer allocate (size_type n, const void* hint = 0)
|
|
|
|
{
|
|
|
|
pointer p = reinterpret_cast<pointer>(
|
|
|
|
rtl_allocateMemory(sal_uInt32(n * sizeof(T))));
|
|
|
|
|
|
|
|
if (NULL == p)
|
|
|
|
throw ::std::bad_alloc();
|
|
|
|
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
but some compilers do not compile it if exceptions
|
|
|
|
are not enabled, e.g. GCC under Linux and it is
|
|
|
|
in general not desired to compile sal with exceptions
|
|
|
|
enabled. */
|
2012-01-21 15:21:16 +01:00
|
|
|
pointer allocate (size_type n, SAL_UNUSED_PARAMETER const void* = 0)
|
2006-07-26 06:42:32 +00:00
|
|
|
{
|
|
|
|
return reinterpret_cast<pointer>(
|
|
|
|
rtl_allocateMemory(sal_uInt32(n * sizeof(T))));
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------
|
2012-01-21 15:21:16 +01:00
|
|
|
void deallocate (pointer p, SAL_UNUSED_PARAMETER size_type /* n */)
|
2006-07-26 06:42:32 +00:00
|
|
|
{
|
|
|
|
rtl_freeMemory(p);
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------
|
|
|
|
void construct (pointer p, const T& value)
|
|
|
|
{
|
|
|
|
new ((void*)p)T(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------
|
|
|
|
void destroy (pointer p)
|
|
|
|
{
|
|
|
|
p->~T();
|
2011-03-06 20:39:05 +00:00
|
|
|
(void)p; //MSVC2005 annoyingly warns this is unused
|
2006-07-26 06:42:32 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
//######################################################
|
|
|
|
// Custom STL allocators must be stateless (see
|
|
|
|
// references above) that's why the operators below
|
|
|
|
// return always true or false
|
|
|
|
|
2012-01-21 15:21:16 +01:00
|
|
|
template<class T, class U> inline bool operator ==(
|
|
|
|
SAL_UNUSED_PARAMETER const Allocator<T>&,
|
|
|
|
SAL_UNUSED_PARAMETER const Allocator<U>&) SAL_THROW(())
|
2006-07-26 06:42:32 +00:00
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class T, class U>
|
|
|
|
inline bool operator!= (const Allocator<T>&, const Allocator<U>&) SAL_THROW(())
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
} /* namespace rtl */
|
|
|
|
|
|
|
|
/** REQUIRED BY STLPort (see stlport '_alloc.h'):
|
|
|
|
Hack for compilers that do not support member
|
|
|
|
template classes (e.g. MSVC 6)
|
|
|
|
*/
|
|
|
|
namespace _STL
|
|
|
|
{
|
|
|
|
template<class T, class U>
|
|
|
|
inline ::rtl::Allocator<U> & __stl_alloc_rebind (::rtl::Allocator<T> & a, U const *)
|
|
|
|
{
|
|
|
|
return (::rtl::Allocator<U>&)(a);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-01-05 19:40:38 +01:00
|
|
|
/// @endcond
|
|
|
|
|
2006-07-26 06:42:32 +00:00
|
|
|
#endif /* INCLUDED_RTL_ALLOCATOR_HXX */
|
|
|
|
|
2010-10-14 08:30:07 +02:00
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|