blob: 1f289b4a0bb4d9dc4cbbdbf956add08eae5781da [file] [log] [blame]
/*
* 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.
*/
/*
* $Id$
*/
// ---------------------------------------------------------------------------
// Includes
// ---------------------------------------------------------------------------
#if defined(XERCES_TMPLSINC)
#include <xercesc/util/Janitor.hpp>
#endif
XERCES_CPP_NAMESPACE_BEGIN
// ---------------------------------------------------------------------------
// Janitor: Constructors and Destructor
// ---------------------------------------------------------------------------
template <class T> Janitor<T>::Janitor(T* const toDelete) :
fData(toDelete)
{
}
template <class T> Janitor<T>::~Janitor()
{
reset();
}
// ---------------------------------------------------------------------------
// Janitor: Public, non-virtual methods
// ---------------------------------------------------------------------------
template <class T> void
Janitor<T>::orphan()
{
release();
}
template <class T> T&
Janitor<T>::operator*() const
{
return *fData;
}
template <class T> T*
Janitor<T>::operator->() const
{
return fData;
}
template <class T> T*
Janitor<T>::get() const
{
return fData;
}
template <class T> T*
Janitor<T>::release()
{
T* p = fData;
fData = 0;
return p;
}
template <class T> void Janitor<T>::reset(T* p)
{
if (fData)
delete fData;
fData = p;
}
template <class T> bool Janitor<T>::isDataNull()
{
return (fData == 0);
}
// -----------------------------------------------------------------------
// ArrayJanitor: Constructors and Destructor
// -----------------------------------------------------------------------
template <class T> ArrayJanitor<T>::ArrayJanitor(T* const toDelete) :
fData(toDelete)
, fMemoryManager(0)
{
}
template <class T>
ArrayJanitor<T>::ArrayJanitor(T* const toDelete,
MemoryManager* const manager) :
fData(toDelete)
, fMemoryManager(manager)
{
}
template <class T> ArrayJanitor<T>::~ArrayJanitor()
{
reset();
}
// -----------------------------------------------------------------------
// ArrayJanitor: Public, non-virtual methods
// -----------------------------------------------------------------------
template <class T> void
ArrayJanitor<T>::orphan()
{
release();
}
// Look, Ma! No hands! Don't call this with null data!
template <class T> T&
ArrayJanitor<T>::operator[](XMLSize_t index) const
{
// TODO: Add appropriate exception
return fData[index];
}
template <class T> T*
ArrayJanitor<T>::get() const
{
return fData;
}
template <class T> T*
ArrayJanitor<T>::release()
{
T* p = fData;
fData = 0;
return p;
}
template <class T> void
ArrayJanitor<T>::reset(T* p)
{
if (fData) {
if (fMemoryManager)
fMemoryManager->deallocate((void*)fData);
else
delete [] fData;
}
fData = p;
fMemoryManager = 0;
}
template <class T> void
ArrayJanitor<T>::reset(T* p, MemoryManager* const manager)
{
if (fData) {
if (fMemoryManager)
fMemoryManager->deallocate((void*)fData);
else
delete [] fData;
}
fData = p;
fMemoryManager = manager;
}
//
// JanitorMemFunCall
//
template <class T>
JanitorMemFunCall<T>::JanitorMemFunCall(
T* object,
MFPT toCall) :
fObject(object),
fToCall(toCall)
{
}
template <class T>
JanitorMemFunCall<T>::~JanitorMemFunCall()
{
reset ();
}
template <class T>
T& JanitorMemFunCall<T>::operator*() const
{
return *fObject;
}
template <class T>
T* JanitorMemFunCall<T>::operator->() const
{
return fObject;
}
template <class T>
T* JanitorMemFunCall<T>::get() const
{
return fObject;
}
template <class T>
T* JanitorMemFunCall<T>::release()
{
T* p = fObject;
fObject = 0;
return p;
}
template <class T>
void JanitorMemFunCall<T>::reset(T* p)
{
if (fObject != 0 && fToCall != 0)
(fObject->*fToCall)();
fObject = p;
}
XERCES_CPP_NAMESPACE_END