* Replaced the useless InitCheck() method in {Open,Multi}HashTable (it

always returned B_OK) by a Init() method, which sets the initial size
  and returns an error, if that fails.
* Adjusted code using the classes accordingly. Replaced a few
  InitCheck() methods in the network code by Init().


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@26127 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Ingo Weinhold 2008-06-24 22:23:57 +00:00
parent 55c692b304
commit 276aa463ef
12 changed files with 47 additions and 43 deletions

View File

@ -31,14 +31,16 @@ public:
typedef typename Definition::KeyType KeyType;
typedef typename Definition::ValueType ValueType;
MultiHashTable(size_t initialSize = HashTable::kMinimumSize)
: HashTable(initialSize) {}
MultiHashTable()
: HashTable() {}
MultiHashTable(const Definition& definition,
size_t initialSize = HashTable::kMinimumSize)
: HashTable(definition, initialSize) {}
MultiHashTable(const Definition& definition)
: HashTable(definition) {}
status_t InitCheck() const { return HashTable::InitCheck(); }
status_t Init(size_t initialSize = HashTable::kMinimumSize)
{
return HashTable::Init(initialSize);
}
void Insert(ValueType *value)
{
@ -103,9 +105,13 @@ public:
ValueIterator Lookup(const KeyType &key) const
{
size_t index = HashTable::fDefinition.HashKey(key)
& (HashTable::fTableSize - 1);
ValueType *slot = HashTable::fTable[index];
size_t index = 0;
ValueType *slot = NULL;
if (HashTable::fTableSize > 0) {
index = HashTable::fDefinition.HashKey(key)
& (HashTable::fTableSize - 1);
slot = HashTable::fTable[index];
}
while (slot) {
if (HashTable::fDefinition.Compare(key, slot))

View File

@ -59,26 +59,21 @@ public:
// regrowth factor: 200 / 256 = 78.125%
// 50 / 256 = 19.53125%
OpenHashTable(size_t initialSize = kMinimumSize)
OpenHashTable()
:
fTableSize(0),
fItemCount(0),
fTable(NULL)
{
if (initialSize > 0)
_Resize(initialSize);
}
OpenHashTable(const Definition& definition,
size_t initialSize = kMinimumSize)
OpenHashTable(const Definition& definition)
:
fDefinition(definition),
fTableSize(0),
fItemCount(0),
fTable(NULL)
{
if (initialSize > 0)
_Resize(initialSize);
}
~OpenHashTable()
@ -86,9 +81,11 @@ public:
delete [] fTable;
}
status_t InitCheck() const
status_t Init(size_t initialSize = kMinimumSize)
{
return (fTableSize == 0 || fTable) ? B_OK : B_NO_MEMORY;
if (initialSize > 0 && !_Resize(initialSize))
return B_NO_MEMORY;
return B_OK;
}
ValueType *Lookup(const KeyType &key) const

View File

@ -1596,7 +1596,7 @@ init_ipv4()
goto err4;
}
status = sMulticastState->InitCheck();
status = sMulticastState->Init();
if (status < B_OK)
goto err5;

View File

@ -142,7 +142,7 @@ MulticastGroupInterface<Addressing>::FilterAccepts(net_buffer *buffer) const
template<typename Addressing>
MulticastFilter<Addressing>::MulticastFilter(ProtocolType *socket)
: fParent(socket), fStates((size_t)0)
: fParent(socket), fStates()
{
}

View File

@ -232,11 +232,11 @@ EndpointManager::~EndpointManager()
status_t
EndpointManager::InitCheck() const
EndpointManager::Init()
{
status_t status = fConnectionHash.InitCheck();
status_t status = fConnectionHash.Init();
if (status == B_OK)
status = fEndpointHash.InitCheck();
status = fEndpointHash.Init();
return status;
}

View File

@ -70,7 +70,7 @@ public:
EndpointManager(net_domain* domain);
~EndpointManager();
status_t InitCheck() const;
status_t Init();
TCPEndpoint* FindConnection(sockaddr* local, sockaddr* peer);

View File

@ -286,9 +286,15 @@ get_endpoint_manager(net_domain* domain)
return endpointManager;
endpointManager = new (std::nothrow) EndpointManager(domain);
if (endpointManager)
sEndpointManagers.Add(endpointManager);
if (endpointManager == NULL)
return NULL;
if (endpointManager->Init() != B_OK) {
delete endpointManager;
return NULL;
}
sEndpointManagers.Add(endpointManager);
return endpointManager;
}

View File

@ -157,7 +157,7 @@ public:
UdpDomainSupport(net_domain *domain);
~UdpDomainSupport();
status_t InitCheck() const;
status_t Init();
net_domain *Domain() const { return fDomain; }
@ -245,7 +245,7 @@ net_stack_module_info *gStackModule;
UdpDomainSupport::UdpDomainSupport(net_domain *domain)
:
fDomain(domain),
fActiveEndpoints(domain->address_module, kNumHashBuckets),
fActiveEndpoints(domain->address_module),
fEndpointCount(0)
{
mutex_init(&fLock, "udp domain");
@ -261,9 +261,9 @@ UdpDomainSupport::~UdpDomainSupport()
status_t
UdpDomainSupport::InitCheck() const
UdpDomainSupport::Init()
{
return fActiveEndpoints.InitCheck();
return fActiveEndpoints.Init(kNumHashBuckets);
}
@ -766,7 +766,7 @@ UdpEndpointManager::_GetDomain(net_domain *domain, bool create)
UdpDomainSupport *domainSupport =
new (std::nothrow) UdpDomainSupport(domain);
if (domainSupport == NULL || domainSupport->InitCheck() < B_OK) {
if (domainSupport == NULL || domainSupport->Init() < B_OK) {
delete domainSupport;
return NULL;
}

View File

@ -52,11 +52,7 @@ public:
status_t Init()
{
status_t error = fBoundEndpoints.InitCheck();
if (error != B_OK)
return error;
return B_OK;
return fBoundEndpoints.Init();
}
bool Lock()

View File

@ -156,7 +156,7 @@ NotificationManager::_Init()
{
mutex_init(&fLock, "notification manager");
return fServiceHash.InitCheck();
return fServiceHash.Init();
}

View File

@ -327,10 +327,9 @@ ConditionVariable::_NotifyChecked(bool all, status_t result)
void
condition_variable_init()
{
new(&sConditionVariableHash) ConditionVariableHash(
kConditionVariableHashSize);
new(&sConditionVariableHash) ConditionVariableHash;
status_t error = sConditionVariableHash.InitCheck();
status_t error = sConditionVariableHash.Init(kConditionVariableHashSize);
if (error != B_OK) {
panic("condition_variable_init(): Failed to init hash table: %s",
strerror(error));

View File

@ -316,10 +316,10 @@ public:
status_t Init()
{
status_t error = fNamedSemaphores.InitCheck();
status_t error = fNamedSemaphores.Init();
if (error != B_OK)
return error;
return fUnnamedSemaphores.InitCheck();
return fUnnamedSemaphores.Init();
}
status_t OpenNamedSem(const char* name, int openFlags, mode_t mode,
@ -569,7 +569,7 @@ struct realtime_sem_context {
status_t Init()
{
fNextPrivateSemID = -1;
return fSemaphores.InitCheck();
return fSemaphores.Init();
}
realtime_sem_context* Clone()