now handles also the case when all specifiers are solved, and behaves as if we were asked the Messenger

git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@17837 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Jérôme Duval 2006-06-14 12:40:27 +00:00
parent c4dde2f738
commit a58450492a

View File

@ -184,26 +184,24 @@ BHandler::MessageReceived(BMessage *message)
const char *prop; const char *prop;
status_t err = message->GetCurrentSpecifier(&cur, &specifier, &form, &prop); status_t err = message->GetCurrentSpecifier(&cur, &specifier, &form, &prop);
if (err == B_OK) { bool known = false;
bool known = false; if (index < 0 || (strcmp(prop, "Messenger") == 0)) {
if (strcmp(prop, "Suites") == 0) { err = reply.AddMessenger("result", this);
err = GetSupportedSuites(&reply); known = true;
known = true; } else if (strcmp(prop, "Suites") == 0) {
} else if (strcmp(prop, "Messenger") == 0) { err = GetSupportedSuites(&reply);
err = reply.AddMessenger("result", this); known = true;
known = true; } else if (strcmp(prop, "InternalName") == 0) {
} else if (strcmp(prop, "InternalName") == 0) { err = reply.AddString("result", Name());
err = reply.AddString("result", Name()); known = true;
known = true;
}
if (known) {
reply.AddInt32("error", B_OK);
message->SendReply(&reply);
return;
}
// let's try next handler
} }
if (known) {
reply.AddInt32("error", B_OK);
message->SendReply(&reply);
return;
}
// let's try next handler
break; break;
} }