Made the (BHandler*, BLooper*,) constructor more robust. Now the looper list is locked and the looper checked for validity.

git-svn-id: file:///srv/svn/repos/haiku/trunk/current@3581 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Ingo Weinhold 2003-06-20 00:18:56 +00:00
parent adf43596d6
commit 37faaaded5

View File

@ -47,6 +47,7 @@
// Project Includes ------------------------------------------------------------
#include <AppMisc.h>
#include <MessageUtils.h>
#include "ObjectLocker.h"
#include "TokenSpace.h"
// Local Includes --------------------------------------------------------------
@ -56,6 +57,9 @@
// Globals ---------------------------------------------------------------------
using BPrivate::gDefaultTokens;
using BPrivate::gLooperList;
using BPrivate::BLooperList;
using BPrivate::BObjectLocker;
enum {
NOT_IMPLEMENTED = B_ERROR,
@ -131,23 +135,17 @@ BMessenger::BMessenger(const BHandler *handler, const BLooper *looper,
if (looper == NULL)
error = B_MISMATCHED_VALUES;
}
}
// set port, token,...
if (error == B_OK) {
BObjectLocker<BLooperList> locker(gLooperList);
if (locker.IsLocked() && gLooperList.IsLooperValid(looper)) {
fPort = looper->fMsgPort;
fHandlerToken = _get_object_token_(handler);
fPreferredTarget = false;
}
} else { // handler == NULL (=> looper != NULL)
fPort = looper->fMsgPort;
fHandlerToken = false;
fPreferredTarget = true;
}
// get and set the team ID
if (error == B_OK) {
thread_info info;
error = get_thread_info(find_thread(NULL), &info);
if (error == B_OK)
fTeam = info.team;
fHandlerToken = (handler ? _get_object_token_(handler) : -1);
fPreferredTarget = !handler;
fTeam = looper->Team();
} else
error = B_BAD_VALUE;
}
}
if (result)