Style fixes to BMessageRunner, no functional changes intended
This commit is contained in:
parent
2eb2dcfabe
commit
1f4de50d39
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2001-2010, Haiku, Inc.
|
||||
* Copyright 2001-2010 Haiku, Inc. All rights reserved.
|
||||
* Distributed under the terms of the MIT License.
|
||||
*/
|
||||
#ifndef _MESSAGE_RUNNER_H
|
||||
@ -41,8 +41,7 @@ public:
|
||||
|
||||
private:
|
||||
BMessageRunner(const BMessageRunner &);
|
||||
BMessageRunner &operator=(
|
||||
const BMessageRunner &);
|
||||
BMessageRunner& operator=(const BMessageRunner&);
|
||||
|
||||
static int32 _RegisterRunner(BMessenger target,
|
||||
const BMessage* message, bigtime_t interval,
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2001-2010, Haiku, Inc.
|
||||
* Copyright 2001-2010 Haiku, Inc. All rights reserved.
|
||||
* Distributed under the terms of the MIT License.
|
||||
*
|
||||
* Authors:
|
||||
@ -19,25 +19,6 @@
|
||||
using namespace BPrivate;
|
||||
|
||||
|
||||
/*! \brief Creates and initializes a new BMessageRunner.
|
||||
|
||||
The target for replies to the delivered message(s) is \c be_app_messenger.
|
||||
|
||||
The success of the initialization can (and should) be asked for via
|
||||
InitCheck(). This object will not take ownership of the \a message, you
|
||||
may freely change or delete it after creation.
|
||||
|
||||
\note As soon as the last message has been sent, the message runner
|
||||
becomes unusable. InitCheck() will still return \c B_OK, but
|
||||
SetInterval(), SetCount() and GetInfo() will fail.
|
||||
|
||||
\param target Target of the message(s).
|
||||
\param message The message to be sent to the target.
|
||||
\param interval Period of time before the first message is sent and
|
||||
between messages (if more than one shall be sent) in microseconds.
|
||||
\param count Specifies how many times the message shall be sent.
|
||||
A value less than \c 0 for an unlimited number of repetitions.
|
||||
*/
|
||||
BMessageRunner::BMessageRunner(BMessenger target, const BMessage* message,
|
||||
bigtime_t interval, int32 count)
|
||||
:
|
||||
@ -47,25 +28,6 @@ BMessageRunner::BMessageRunner(BMessenger target, const BMessage* message,
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Creates and initializes a new BMessageRunner.
|
||||
|
||||
The target for replies to the delivered message(s) is \c be_app_messenger.
|
||||
|
||||
The success of the initialization can (and should) be asked for via
|
||||
InitCheck(). This object will not take ownership of the \a message, you
|
||||
may freely change or delete it after creation.
|
||||
|
||||
\note As soon as the last message has been sent, the message runner
|
||||
becomes unusable. InitCheck() will still return \c B_OK, but
|
||||
SetInterval(), SetCount() and GetInfo() will fail.
|
||||
|
||||
\param target Target of the message(s).
|
||||
\param message The message to be sent to the target.
|
||||
\param interval Period of time before the first message is sent and
|
||||
between messages (if more than one shall be sent) in microseconds.
|
||||
\param count Specifies how many times the message shall be sent.
|
||||
A value less than \c 0 for an unlimited number of repetitions.
|
||||
*/
|
||||
BMessageRunner::BMessageRunner(BMessenger target, const BMessage& message,
|
||||
bigtime_t interval, int32 count)
|
||||
:
|
||||
@ -75,27 +37,6 @@ BMessageRunner::BMessageRunner(BMessenger target, const BMessage& message,
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Creates and initializes a new BMessageRunner.
|
||||
|
||||
This constructor version additionally allows to specify the target for
|
||||
replies to the delivered message(s).
|
||||
|
||||
The success of the initialization can (and should) be asked for via
|
||||
InitCheck(). This object will not take ownership of the \a message, you
|
||||
may freely change or delete it after creation.
|
||||
|
||||
\note As soon as the last message has been sent, the message runner
|
||||
becomes unusable. InitCheck() will still return \c B_OK, but
|
||||
SetInterval(), SetCount() and GetInfo() will fail.
|
||||
|
||||
\param target Target of the message(s).
|
||||
\param message The message to be sent to the target.
|
||||
\param interval Period of time before the first message is sent and
|
||||
between messages (if more than one shall be sent) in microseconds.
|
||||
\param count Specifies how many times the message shall be sent.
|
||||
A value less than \c 0 for an unlimited number of repetitions.
|
||||
\param replyTo Target replies to the delivered message(s) shall be sent to.
|
||||
*/
|
||||
BMessageRunner::BMessageRunner(BMessenger target, const BMessage* message,
|
||||
bigtime_t interval, int32 count, BMessenger replyTo)
|
||||
:
|
||||
@ -105,27 +46,6 @@ BMessageRunner::BMessageRunner(BMessenger target, const BMessage* message,
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Creates and initializes a new BMessageRunner.
|
||||
|
||||
This constructor version additionally allows to specify the target for
|
||||
replies to the delivered message(s).
|
||||
|
||||
The success of the initialization can (and should) be asked for via
|
||||
InitCheck(). This object will not take ownership of the \a message, you
|
||||
may freely change or delete it after creation.
|
||||
|
||||
\note As soon as the last message has been sent, the message runner
|
||||
becomes unusable. InitCheck() will still return \c B_OK, but
|
||||
SetInterval(), SetCount() and GetInfo() will fail.
|
||||
|
||||
\param target Target of the message(s).
|
||||
\param message The message to be sent to the target.
|
||||
\param interval Period of time before the first message is sent and
|
||||
between messages (if more than one shall be sent) in microseconds.
|
||||
\param count Specifies how many times the message shall be sent.
|
||||
A value less than \c 0 for an unlimited number of repetitions.
|
||||
\param replyTo Target replies to the delivered message(s) shall be sent to.
|
||||
*/
|
||||
BMessageRunner::BMessageRunner(BMessenger target, const BMessage& message,
|
||||
bigtime_t interval, int32 count, BMessenger replyTo)
|
||||
:
|
||||
@ -135,8 +55,6 @@ BMessageRunner::BMessageRunner(BMessenger target, const BMessage& message,
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Frees all resources associated with the object.
|
||||
*/
|
||||
BMessageRunner::~BMessageRunner()
|
||||
{
|
||||
if (fToken < B_OK)
|
||||
@ -144,26 +62,17 @@ BMessageRunner::~BMessageRunner()
|
||||
|
||||
// compose the request message
|
||||
BMessage request(B_REG_UNREGISTER_MESSAGE_RUNNER);
|
||||
status_t error = request.AddInt32("token", fToken);
|
||||
status_t result = request.AddInt32("token", fToken);
|
||||
|
||||
// send the request
|
||||
BMessage reply;
|
||||
if (error == B_OK)
|
||||
error = BRoster::Private().SendTo(&request, &reply, false);
|
||||
if (result == B_OK)
|
||||
result = BRoster::Private().SendTo(&request, &reply, false);
|
||||
|
||||
// ignore the reply, we can't do anything anyway
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Returns the status of the initialization.
|
||||
|
||||
\note As soon as the last message has been sent, the message runner
|
||||
becomes unusable. InitCheck() will still return \c B_OK, but
|
||||
SetInterval(), SetCount() and GetInfo() will fail.
|
||||
|
||||
\return \c B_OK, if the object is properly initialized, an error code
|
||||
otherwise.
|
||||
*/
|
||||
status_t
|
||||
BMessageRunner::InitCheck() const
|
||||
{
|
||||
@ -171,14 +80,6 @@ BMessageRunner::InitCheck() const
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Sets the interval of time between messages.
|
||||
\param interval The new interval in microseconds.
|
||||
\return
|
||||
- \c B_OK: Everything went fine.
|
||||
- \c B_NO_INIT: The message runner is not properly initialized.
|
||||
- \c B_BAD_VALUE: \a interval is \c 0 or negative, or the message runner
|
||||
has already sent all messages to be sent and has become unusable.
|
||||
*/
|
||||
status_t
|
||||
BMessageRunner::SetInterval(bigtime_t interval)
|
||||
{
|
||||
@ -186,15 +87,6 @@ BMessageRunner::SetInterval(bigtime_t interval)
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Sets the number of times message shall be sent.
|
||||
\param count Specifies how many times the message shall be sent.
|
||||
A value less than \c 0 for an unlimited number of repetitions.
|
||||
- \c B_BAD_VALUE: The message runner has already sent all messages to be
|
||||
sent and has become unusable.
|
||||
\return
|
||||
- \c B_OK: Everything went fine.
|
||||
- \c B_NO_INIT: The message runner is not properly initialized.
|
||||
*/
|
||||
status_t
|
||||
BMessageRunner::SetCount(int32 count)
|
||||
{
|
||||
@ -202,104 +94,67 @@ BMessageRunner::SetCount(int32 count)
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Returns the time interval between two messages and the number of
|
||||
times the message has still to be sent.
|
||||
|
||||
Both parameters (\a interval and \a count) may be \c NULL.
|
||||
|
||||
\param interval Pointer to a pre-allocated bigtime_t variable to be set
|
||||
to the time interval. May be \c NULL.
|
||||
\param count Pointer to a pre-allocated int32 variable to be set
|
||||
to the number of times the message has still to be sent.
|
||||
May be \c NULL.
|
||||
\return
|
||||
- \c B_OK: Everything went fine.
|
||||
- \c B_BAD_VALUE: The message runner is not longer valid. All the
|
||||
messages that had to be sent have already been sent.
|
||||
*/
|
||||
status_t
|
||||
BMessageRunner::GetInfo(bigtime_t* interval, int32* count) const
|
||||
{
|
||||
status_t error = (fToken >= 0 ? B_OK : B_BAD_VALUE);
|
||||
status_t result = fToken >= 0 ? B_OK : B_BAD_VALUE;
|
||||
|
||||
// compose the request message
|
||||
BMessage request(B_REG_GET_MESSAGE_RUNNER_INFO);
|
||||
if (error == B_OK)
|
||||
error = request.AddInt32("token", fToken);
|
||||
if (result == B_OK)
|
||||
result = request.AddInt32("token", fToken);
|
||||
|
||||
// send the request
|
||||
BMessage reply;
|
||||
if (error == B_OK)
|
||||
error = BRoster::Private().SendTo(&request, &reply, false);
|
||||
if (result == B_OK)
|
||||
result = BRoster::Private().SendTo(&request, &reply, false);
|
||||
|
||||
// evaluate the reply
|
||||
if (error == B_OK) {
|
||||
if (result == B_OK) {
|
||||
if (reply.what == B_REG_SUCCESS) {
|
||||
// count
|
||||
int32 _count;
|
||||
if (reply.FindInt32("count", &_count) == B_OK) {
|
||||
if (count)
|
||||
if (count != 0)
|
||||
*count = _count;
|
||||
} else
|
||||
error = B_ERROR;
|
||||
result = B_ERROR;
|
||||
|
||||
// interval
|
||||
bigtime_t _interval;
|
||||
if (reply.FindInt64("interval", &_interval) == B_OK) {
|
||||
if (interval)
|
||||
if (interval != 0)
|
||||
*interval = _interval;
|
||||
} else
|
||||
error = B_ERROR;
|
||||
result = B_ERROR;
|
||||
} else {
|
||||
if (reply.FindInt32("error", &error) != B_OK)
|
||||
error = B_ERROR;
|
||||
if (reply.FindInt32("error", &result) != B_OK)
|
||||
result = B_ERROR;
|
||||
}
|
||||
}
|
||||
return error;
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Creates and initializes a detached BMessageRunner.
|
||||
|
||||
You cannot alter the runner after the creation, and it will be deleted
|
||||
automatically once it is done.
|
||||
The target for replies to the delivered message(s) is \c be_app_messenger.
|
||||
|
||||
\param target Target of the message(s).
|
||||
\param message The message to be sent to the target.
|
||||
\param interval Period of time before the first message is sent and
|
||||
between messages (if more than one shall be sent) in microseconds.
|
||||
\param count Specifies how many times the message shall be sent.
|
||||
A value less than \c 0 for an unlimited number of repetitions.
|
||||
*/
|
||||
/*static*/ status_t
|
||||
BMessageRunner::StartSending(BMessenger target, const BMessage* message,
|
||||
bigtime_t interval, int32 count)
|
||||
{
|
||||
int32 token = _RegisterRunner(target, message, interval, count, true,
|
||||
be_app_messenger);
|
||||
|
||||
return token >= B_OK ? B_OK : token;
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Creates and initializes a detached BMessageRunner.
|
||||
|
||||
You cannot alter the runner after the creation, and it will be deleted
|
||||
automatically once it is done.
|
||||
|
||||
\param target Target of the message(s).
|
||||
\param message The message to be sent to the target.
|
||||
\param interval Period of time before the first message is sent and
|
||||
between messages (if more than one shall be sent) in microseconds.
|
||||
\param count Specifies how many times the message shall be sent.
|
||||
A value less than \c 0 for an unlimited number of repetitions.
|
||||
\param replyTo Target replies to the delivered message(s) shall be sent to.
|
||||
*/
|
||||
/*static*/ status_t
|
||||
BMessageRunner::StartSending(BMessenger target, const BMessage* message,
|
||||
bigtime_t interval, int32 count, BMessenger replyTo)
|
||||
{
|
||||
int32 token = _RegisterRunner(target, message, interval, count, true, replyTo);
|
||||
int32 token = _RegisterRunner(target, message, interval, count, true,
|
||||
replyTo);
|
||||
|
||||
return token >= B_OK ? B_OK : token;
|
||||
}
|
||||
|
||||
@ -313,38 +168,37 @@ void BMessageRunner::_ReservedMessageRunner5() {}
|
||||
void BMessageRunner::_ReservedMessageRunner6() {}
|
||||
|
||||
|
||||
/*! \brief Privatized copy constructor to prevent usage.
|
||||
*/
|
||||
//! Privatized copy constructor to prevent usage.
|
||||
BMessageRunner::BMessageRunner(const BMessageRunner &)
|
||||
: fToken(-1)
|
||||
:
|
||||
fToken(-1)
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Privatized assignment operator to prevent usage.
|
||||
*/
|
||||
BMessageRunner &
|
||||
BMessageRunner::operator=(const BMessageRunner &)
|
||||
//! Privatized assignment operator to prevent usage.
|
||||
BMessageRunner&
|
||||
BMessageRunner::operator=(const BMessageRunner&)
|
||||
{
|
||||
return* this;
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Initializes the BMessageRunner.
|
||||
/*! Initializes the BMessageRunner.
|
||||
|
||||
The success of the initialization can (and should) be asked for via
|
||||
InitCheck().
|
||||
|
||||
\note As soon as the last message has been sent, the message runner
|
||||
becomes unusable. InitCheck() will still return \c B_OK, but
|
||||
SetInterval(), SetCount() and GetInfo() will fail.
|
||||
becomes unusable. InitCheck() will still return \c B_OK, but
|
||||
SetInterval(), SetCount() and GetInfo() will fail.
|
||||
|
||||
\param target Target of the message(s).
|
||||
\param message The message to be sent to the target.
|
||||
\param interval Period of time before the first message is sent and
|
||||
between messages (if more than one shall be sent) in microseconds.
|
||||
between messages (if more than one shall be sent) in microseconds.
|
||||
\param count Specifies how many times the message shall be sent.
|
||||
A value less than \c 0 for an unlimited number of repetitions.
|
||||
A value less than \c 0 for an unlimited number of repetitions.
|
||||
\param replyTo Target replies to the delivered message(s) shall be sent to.
|
||||
*/
|
||||
void
|
||||
@ -355,68 +209,73 @@ BMessageRunner::_InitData(BMessenger target, const BMessage* message,
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Registers the BMessageRunner in the registrar.
|
||||
/*! Registers the BMessageRunner in the registrar.
|
||||
|
||||
\param target Target of the message(s).
|
||||
\param message The message to be sent to the target.
|
||||
\param interval Period of time before the first message is sent and
|
||||
between messages (if more than one shall be sent) in microseconds.
|
||||
between messages (if more than one shall be sent) in microseconds.
|
||||
\param count Specifies how many times the message shall be sent.
|
||||
A value less than \c 0 for an unlimited number of repetitions.
|
||||
A value less than \c 0 for an unlimited number of repetitions.
|
||||
\param replyTo Target replies to the delivered message(s) shall be sent to.
|
||||
|
||||
\return The token the message runner is registered with, or the error code
|
||||
while trying to register it.
|
||||
while trying to register it.
|
||||
*/
|
||||
/*static*/ int32
|
||||
BMessageRunner::_RegisterRunner(BMessenger target, const BMessage* message,
|
||||
bigtime_t interval, int32 count, bool detach, BMessenger replyTo)
|
||||
{
|
||||
status_t error = B_OK;
|
||||
status_t result = B_OK;
|
||||
if (message == NULL || count == 0 || (count < 0 && detach))
|
||||
error = B_BAD_VALUE;
|
||||
result = B_BAD_VALUE;
|
||||
|
||||
// compose the request message
|
||||
BMessage request(B_REG_REGISTER_MESSAGE_RUNNER);
|
||||
if (error == B_OK)
|
||||
error = request.AddInt32("team", BPrivate::current_team());
|
||||
if (error == B_OK)
|
||||
error = request.AddMessenger("target", target);
|
||||
if (error == B_OK)
|
||||
error = request.AddMessage("message", message);
|
||||
if (error == B_OK)
|
||||
error = request.AddInt64("interval", interval);
|
||||
if (error == B_OK)
|
||||
error = request.AddInt32("count", count);
|
||||
if (error == B_OK)
|
||||
error = request.AddMessenger("reply_target", replyTo);
|
||||
if (result == B_OK)
|
||||
result = request.AddInt32("team", BPrivate::current_team());
|
||||
|
||||
if (result == B_OK)
|
||||
result = request.AddMessenger("target", target);
|
||||
|
||||
if (result == B_OK)
|
||||
result = request.AddMessage("message", message);
|
||||
|
||||
if (result == B_OK)
|
||||
result = request.AddInt64("interval", interval);
|
||||
|
||||
if (result == B_OK)
|
||||
result = request.AddInt32("count", count);
|
||||
|
||||
if (result == B_OK)
|
||||
result = request.AddMessenger("reply_target", replyTo);
|
||||
|
||||
// send the request
|
||||
BMessage reply;
|
||||
if (error == B_OK)
|
||||
error = BRoster::Private().SendTo(&request, &reply, false);
|
||||
if (result == B_OK)
|
||||
result = BRoster::Private().SendTo(&request, &reply, false);
|
||||
|
||||
int32 token;
|
||||
|
||||
// evaluate the reply
|
||||
if (error == B_OK) {
|
||||
if (result == B_OK) {
|
||||
if (reply.what == B_REG_SUCCESS) {
|
||||
if (reply.FindInt32("token", &token) != B_OK)
|
||||
error = B_ERROR;
|
||||
result = B_ERROR;
|
||||
} else {
|
||||
if (reply.FindInt32("error", &error) != B_OK)
|
||||
error = B_ERROR;
|
||||
if (reply.FindInt32("error", &result) != B_OK)
|
||||
result = B_ERROR;
|
||||
}
|
||||
}
|
||||
|
||||
if (error == B_OK)
|
||||
if (result == B_OK)
|
||||
return token;
|
||||
|
||||
return error;
|
||||
return result;
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Sets the message runner's interval and count parameters.
|
||||
/*! Sets the message runner's interval and count parameters.
|
||||
|
||||
The parameters \a resetInterval and \a resetCount specify whether
|
||||
the interval or the count parameter respectively shall be reset.
|
||||
@ -425,17 +284,18 @@ BMessageRunner::_RegisterRunner(BMessenger target, const BMessage* message,
|
||||
\c B_BAD_VALUE.
|
||||
|
||||
\param resetInterval \c true, if the interval shall be reset, \c false
|
||||
otherwise -- then \a interval is ignored.
|
||||
otherwise -- then \a interval is ignored.
|
||||
\param interval The new interval in microseconds.
|
||||
\param resetCount \c true, if the count shall be reset, \c false
|
||||
otherwise -- then \a count is ignored.
|
||||
otherwise -- then \a count is ignored.
|
||||
\param count Specifies how many times the message shall be sent.
|
||||
A value less than \c 0 for an unlimited number of repetitions.
|
||||
\return
|
||||
- \c B_OK: Everything went fine.
|
||||
- \c B_BAD_VALUE: The message runner is not longer valid. All the
|
||||
messages that had to be sent have already been sent. Or both
|
||||
\a resetInterval and \a resetCount are \c false.
|
||||
A value less than \c 0 for an unlimited number of repetitions.
|
||||
|
||||
\return A status code.
|
||||
\retval B_OK Everything went fine.
|
||||
\retval B_BAD_VALUE The message runner is not longer valid. All the
|
||||
messages that had to be sent have already been sent. Or both
|
||||
\a resetInterval and \a resetCount are \c false.
|
||||
*/
|
||||
status_t
|
||||
BMessageRunner::_SetParams(bool resetInterval, bigtime_t interval,
|
||||
@ -446,23 +306,25 @@ BMessageRunner::_SetParams(bool resetInterval, bigtime_t interval,
|
||||
|
||||
// compose the request message
|
||||
BMessage request(B_REG_SET_MESSAGE_RUNNER_PARAMS);
|
||||
status_t error = request.AddInt32("token", fToken);
|
||||
if (error == B_OK && resetInterval)
|
||||
error = request.AddInt64("interval", interval);
|
||||
if (error == B_OK && resetCount)
|
||||
error = request.AddInt32("count", count);
|
||||
status_t result = request.AddInt32("token", fToken);
|
||||
if (result == B_OK && resetInterval)
|
||||
result = request.AddInt64("interval", interval);
|
||||
|
||||
if (result == B_OK && resetCount)
|
||||
result = request.AddInt32("count", count);
|
||||
|
||||
// send the request
|
||||
BMessage reply;
|
||||
if (error == B_OK)
|
||||
error = BRoster::Private().SendTo(&request, &reply, false);
|
||||
if (result == B_OK)
|
||||
result = BRoster::Private().SendTo(&request, &reply, false);
|
||||
|
||||
// evaluate the reply
|
||||
if (error == B_OK) {
|
||||
if (result == B_OK) {
|
||||
if (reply.what != B_REG_SUCCESS) {
|
||||
if (reply.FindInt32("error", &error) != B_OK)
|
||||
error = B_ERROR;
|
||||
if (reply.FindInt32("error", &result) != B_OK)
|
||||
result = B_ERROR;
|
||||
}
|
||||
}
|
||||
return error;
|
||||
|
||||
return result;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user