* Removed the obsolescent [B]Reference[able] API and replaced the remaining

uses. Fixes the gcc 2 acpi build.
* Renamed WeakReferenceable::{Add,Remove}Reference() to
  {Acquire,Release}Reference() for consistency.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@39871 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Ingo Weinhold 2010-12-16 16:35:42 +00:00
parent 88e38c178a
commit 756b64fd83
17 changed files with 47 additions and 170 deletions

View File

@ -1,5 +1,5 @@
/*
* Copyright 2004-2009, Ingo Weinhold, ingo_weinhold@gmx.de.
* Copyright 2004-2010, Ingo Weinhold, ingo_weinhold@gmx.de.
* Distributed under the terms of the MIT License.
*/
#ifndef _REFERENCEABLE_H
@ -9,13 +9,12 @@
#include <SupportDefs.h>
// #pragma mark - BReferenceable
class BReferenceable {
public:
BReferenceable(
bool deleteWhenUnreferenced = true);
// TODO: The parameter is deprecated.
// Override LastReferenceReleased()
// instead!
BReferenceable();
virtual ~BReferenceable();
void AcquireReference();
@ -25,35 +24,18 @@ public:
int32 CountReferences() const
{ return fReferenceCount; }
// deprecate aliases
inline void AddReference();
inline bool RemoveReference();
protected:
virtual void FirstReferenceAcquired();
virtual void LastReferenceReleased();
protected:
vint32 fReferenceCount;
bool fDeleteWhenUnreferenced;
};
void
BReferenceable::AddReference()
{
AcquireReference();
}
// #pragma mark - BReference
bool
BReferenceable::RemoveReference()
{
return ReleaseReference();
}
// BReference
template<typename Type = BReferenceable>
class BReference {
public:
@ -145,107 +127,4 @@ private:
};
// #pragma mark Obsolete API
// TODO: To be phased out!
namespace BPrivate {
// Reference
template<typename Type = BReferenceable>
class Reference {
public:
Reference()
: fObject(NULL)
{
}
Reference(Type* object, bool alreadyHasReference = false)
: fObject(NULL)
{
SetTo(object, alreadyHasReference);
}
Reference(const Reference<Type>& other)
: fObject(NULL)
{
SetTo(other.fObject);
}
~Reference()
{
Unset();
}
void SetTo(Type* object, bool alreadyHasReference = false)
{
if (object != NULL && !alreadyHasReference)
object->AddReference();
Unset();
fObject = object;
}
void Unset()
{
if (fObject) {
fObject->RemoveReference();
fObject = NULL;
}
}
Type* Get() const
{
return fObject;
}
Type* Detach()
{
Type* object = fObject;
fObject = NULL;
return object;
}
Type& operator*() const
{
return *fObject;
}
Type* operator->() const
{
return fObject;
}
Reference& operator=(const Reference<Type>& other)
{
SetTo(other.fObject);
return *this;
}
bool operator==(const Reference<Type>& other) const
{
return (fObject == other.fObject);
}
bool operator!=(const Reference<Type>& other) const
{
return (fObject != other.fObject);
}
private:
Type* fObject;
};
typedef BReferenceable Referenceable;
} // namespace BPrivate
using BPrivate::Referenceable;
using BPrivate::Reference;
#endif // _REFERENCEABLE_H

View File

@ -14,7 +14,7 @@ namespace BPrivate {
template<typename Type> class WeakReferenceable;
template<typename Type>
class WeakPointer : public Referenceable {
class WeakPointer : public BReferenceable {
public:
Type* Get();
bool Put();
@ -41,10 +41,10 @@ public:
WeakReferenceable(Type* object);
~WeakReferenceable();
void AddReference()
void AcquireReference()
{ fPointer->_GetUnchecked(); }
bool RemoveReference()
bool ReleaseReference()
{ return fPointer->Put(); }
int32 CountReferences() const
@ -119,7 +119,7 @@ public:
if (pointer != NULL) {
fPointer = pointer;
fPointer->AddReference();
fPointer->AcquireReference();
fObject = pointer->Get();
}
}
@ -131,7 +131,7 @@ public:
fPointer->Put();
fObject = NULL;
}
fPointer->RemoveReference();
fPointer->ReleaseReference();
fPointer = NULL;
}
}
@ -287,7 +287,7 @@ template<typename Type>
inline
WeakReferenceable<Type>::~WeakReferenceable()
{
fPointer->RemoveReference();
fPointer->ReleaseReference();
}
@ -295,7 +295,7 @@ template<typename Type>
inline WeakPointer<Type>*
WeakReferenceable<Type>::GetWeakPointer()
{
fPointer->AddReference();
fPointer->AcquireReference();
return fPointer;
}

View File

@ -148,7 +148,7 @@ net_socket_private::RemoveFromParent()
{
ASSERT(!is_in_socket_list && parent != NULL);
parent->RemoveReference();
parent->ReleaseReference();
parent = NULL;
mutex_lock(&sSocketLock);
@ -157,7 +157,7 @@ net_socket_private::RemoveFromParent()
is_in_socket_list = true;
RemoveReference();
ReleaseReference();
}
@ -458,7 +458,7 @@ socket_free(net_socket* _socket)
{
net_socket_private* socket = (net_socket_private*)_socket;
socket->first_info->free(socket->first_protocol);
socket->RemoveReference();
socket->ReleaseReference();
}
@ -674,7 +674,7 @@ socket_acquire(net_socket* _socket)
if (socket->CountReferences() == 0)
return false;
socket->AddReference();
socket->AcquireReference();
return true;
}
@ -683,7 +683,7 @@ bool
socket_release(net_socket* _socket)
{
net_socket_private* socket = (net_socket_private*)_socket;
return socket->RemoveReference();
return socket->ReleaseReference();
}
@ -739,7 +739,7 @@ socket_dequeue_connected(net_socket* _parent, net_socket** _socket)
net_socket_private* socket = parent->connected_children.RemoveHead();
if (socket != NULL) {
socket->AddReference();
socket->AcquireReference();
socket->RemoveFromParent();
parent->child_count--;
*_socket = socket;

View File

@ -35,7 +35,7 @@ PLItemsCommand::_CleanUp(PlaylistItem**& items, int32 count, bool deleteItems)
return;
if (deleteItems) {
for (int32 i = 0; i < count; i++)
items[i]->RemoveReference();
items[i]->ReleaseReference();
}
delete[] items;
items = NULL;

View File

@ -235,7 +235,7 @@ Playlist::MakeEmpty(bool deleteItems)
PlaylistItem* item = RemoveItem(i, false);
_NotifyItemRemoved(i);
if (deleteItems)
item->RemoveReference();
item->ReleaseReference();
}
SetCurrentItemIndex(-1);
}

View File

@ -46,7 +46,7 @@ protected:
};
class PowerStatusDriverInterface : public Monitor, public Referenceable {
class PowerStatusDriverInterface : public Monitor, public BReferenceable {
public:
PowerStatusDriverInterface();
~PowerStatusDriverInterface();

View File

@ -30,7 +30,7 @@ enum {
};
class BitmapOwner : public Referenceable {
class BitmapOwner : public BReferenceable {
public:
BitmapOwner(BBitmap* bitmap);
virtual ~BitmapOwner();

View File

@ -16,11 +16,11 @@ Image::Image(SharedImage* image, const image_info& info, team_id owner,
fCreationEvent(creationEvent),
fDeletionEvent(-1)
{
fImage->AddReference();
fImage->AcquireReference();
}
Image::~Image()
{
fImage->RemoveReference();
fImage->ReleaseReference();
}

View File

@ -8,7 +8,7 @@
#include "SharedImage.h"
class Image : public Referenceable {
class Image : public BReferenceable {
public:
Image(SharedImage* image,
const image_info& info, team_id owner,

View File

@ -32,13 +32,13 @@ ImageProfileResult::ImageProfileResult(SharedImage* image, image_id id)
fTotalHits(0),
fImageID(id)
{
fImage->AddReference();
fImage->AcquireReference();
}
ImageProfileResult::~ImageProfileResult()
{
fImage->RemoveReference();
fImage->ReleaseReference();
}

View File

@ -45,7 +45,7 @@ struct SymbolComparator {
};
class SharedImage : public Referenceable {
class SharedImage : public BReferenceable {
public:
SharedImage();
~SharedImage();

View File

@ -51,7 +51,7 @@ Team::~Team()
remove_team_debugger(fID);
for (int32 i = 0; Image* image = fImages.ItemAt(i); i++)
image->RemoveReference();
image->ReleaseReference();
}
@ -277,5 +277,5 @@ Team::_RemoveImage(int32 index, int32 event)
}
image->SetDeletionEvent(event);
image->RemoveReference();
image->ReleaseReference();
}

View File

@ -113,7 +113,7 @@ public:
{
// release image references
for (ImageMap::iterator it = fImages.begin(); it != fImages.end(); ++it)
it->second->RemoveReference();
it->second->ReleaseReference();
if (fSummaryProfileResult != NULL)
fSummaryProfileResult->ReleaseReference();

View File

@ -16,10 +16,9 @@
#endif
BReferenceable::BReferenceable(bool deleteWhenUnreferenced)
BReferenceable::BReferenceable()
:
fReferenceCount(1),
fDeleteWhenUnreferenced(deleteWhenUnreferenced)
fReferenceCount(1)
{
}
@ -59,6 +58,5 @@ BReferenceable::FirstReferenceAcquired()
void
BReferenceable::LastReferenceReleased()
{
if (fDeleteWhenUnreferenced)
delete this;
}

View File

@ -38,7 +38,7 @@ FontCache::~FontCache()
{
FontMap::Iterator iterator = fFontCacheEntries.GetIterator();
while (iterator.HasNext())
iterator.Next().value->RemoveReference();
iterator.Next().value->ReleaseReference();
}
// Default
@ -62,7 +62,7 @@ FontCache::FontCacheEntryFor(const ServerFont& font)
if (entry) {
// the entry was already there
entry->AddReference();
entry->AcquireReference();
//printf("FontCacheEntryFor(%ld): %p\n", font.GetFamilyAndStyle(), entry);
return entry;
}
@ -95,7 +95,7 @@ FontCache::FontCacheEntryFor(const ServerFont& font)
}
//printf("FontCacheEntryFor(%ld): %p (insert)\n", font.GetFamilyAndStyle(), entry);
entry->AddReference();
entry->AcquireReference();
return entry;
}
@ -107,7 +107,7 @@ FontCache::Recycle(FontCacheEntry* entry)
if (!entry)
return;
entry->UpdateUsage();
entry->RemoveReference();
entry->ReleaseReference();
}
static const int32 kMaxEntryCount = 30;
@ -154,7 +154,7 @@ FontCache::_ConstrainEntryCount()
while (iterator.HasNext()) {
if (iterator.Next().value == leastUsedEntry) {
iterator.Remove();
leastUsedEntry->RemoveReference();
leastUsedEntry->ReleaseReference();
break;
}
}

View File

@ -938,7 +938,7 @@ ServerPicture::SetOwner(ServerApp* owner)
// May remove the last reference and then we will self-destruct right then.
// Setting fOwner to NULL would access free'd memory. If owner is another
// ServerApp, it's expected to already have a reference of course.
Reference<ServerPicture> _(this);
BReference<ServerPicture> _(this);
if (fOwner != NULL)
fOwner->RemovePicture(this);

View File

@ -159,10 +159,10 @@ SingleMessagingTargetSet::Rewind()
Besides the flattened message it also stores the when the message was
created and when the delivery attempts shall time out.
*/
class MessageDeliverer::Message : public Referenceable {
class MessageDeliverer::Message : public BReferenceable {
public:
Message(void *data, int32 dataSize, bigtime_t timeout)
: Referenceable(true),
: BReferenceable(),
fData(data),
fDataSize(dataSize),
fCreationTime(system_time()),
@ -243,13 +243,13 @@ public:
fToken(token)
{
if (fMessage)
fMessage->AddReference();
fMessage->AcquireReference();
}
~TargetMessage()
{
if (fMessage)
fMessage->RemoveReference();
fMessage->ReleaseReference();
}
Message *GetMessage() const
@ -653,7 +653,7 @@ MessageDeliverer::DeliverMessage(const void *messageData, int32 messageSize,
free(data);
return B_NO_MEMORY;
}
Reference<Message> _(message, true);
BReference<Message> _(message, true);
// add the message to the respective target ports
BAutolock locker(fLock);