fix some more bugs in scripting handling, this seems to never end

Having canna input method installed shouldn't crash Haiku anymore


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@17810 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Jérôme Duval 2006-06-12 23:45:55 +00:00
parent 4b25c48853
commit da08acb8bf
3 changed files with 236 additions and 280 deletions

View File

@ -52,8 +52,8 @@ static property_info sShelfPropertyList[] = {
{ B_INDEX_SPECIFIER, B_REVERSE_INDEX_SPECIFIER, B_NAME_SPECIFIER, B_ID_SPECIFIER }, { B_INDEX_SPECIFIER, B_REVERSE_INDEX_SPECIFIER, B_NAME_SPECIFIER, B_ID_SPECIFIER },
"... of Replicant {index | name | id} of ...", 0, "... of Replicant {index | name | id} of ...", 0,
}, },
{} { 0, { 0 }, { 0 }, 0, 0 }
}; };
static property_info sReplicantPropertyList[] = { static property_info sReplicantPropertyList[] = {
@ -90,7 +90,9 @@ static property_info sReplicantPropertyList[] = {
{ }, { },
{ B_DIRECT_SPECIFIER }, { B_DIRECT_SPECIFIER },
NULL, 0, NULL, 0,
} },
{ 0, { 0 }, { 0 }, 0, 0 }
}; };

View File

@ -3499,11 +3499,10 @@ BView::ResolveSpecifier(BMessage *msg, int32 index, BMessage *specifier,
return this; return this;
BPropertyInfo propertyInfo(sViewPropInfo); BPropertyInfo propertyInfo(sViewPropInfo);
status_t err = B_BAD_SCRIPT_SYNTAX;
BMessage replyMsg(B_REPLY);
switch (propertyInfo.FindMatch(msg, index, specifier, what, property)) { switch (propertyInfo.FindMatch(msg, index, specifier, what, property)) {
case B_ERROR:
break;
case 0: case 0:
case 1: case 1:
case 2: case 2:
@ -3515,87 +3514,75 @@ BView::ResolveSpecifier(BMessage *msg, int32 index, BMessage *specifier,
if (fShelf) { if (fShelf) {
msg->PopSpecifier(); msg->PopSpecifier();
return fShelf; return fShelf;
} else {
BMessage replyMsg(B_MESSAGE_NOT_UNDERSTOOD);
replyMsg.AddInt32("error", B_NAME_NOT_FOUND);
replyMsg.AddString("message", "This window doesn't have a shelf");
msg->SendReply(&replyMsg);
return NULL;
} }
err = B_NAME_NOT_FOUND;
replyMsg.AddString("message", "This window doesn't have a shelf");
break; break;
case 6: case 6: {
case 7: if (!fFirstChild) {
case 8: err = B_NAME_NOT_FOUND;
{
if (fFirstChild) {
BView *child;
switch (msg->what) {
case B_INDEX_SPECIFIER:
{
int32 index;
msg->FindInt32("data", &index);
child = ChildAt(index);
break;
}
case B_REVERSE_INDEX_SPECIFIER:
{
int32 rindex;
msg->FindInt32("data", &rindex);
child = ChildAt(CountChildren() - rindex);
break;
}
case B_NAME_SPECIFIER:
{
const char *name;
msg->FindString("data", &name);
child = FindView(name);
break;
}
default:
child = NULL;
break;
}
if (child != NULL) {
msg->PopSpecifier();
return child;
} else {
BMessage replyMsg(B_MESSAGE_NOT_UNDERSTOOD);
replyMsg.AddInt32("error", B_BAD_INDEX);
replyMsg.AddString("message", "Cannot find view at/with specified index/name.");
msg->SendReply(&replyMsg);
return NULL;
}
} else {
BMessage replyMsg(B_MESSAGE_NOT_UNDERSTOOD);
replyMsg.AddInt32("error", B_NAME_NOT_FOUND);
replyMsg.AddString("message", "This window doesn't have children."); replyMsg.AddString("message", "This window doesn't have children.");
msg->SendReply(&replyMsg); break;
return NULL;
} }
BView *child = NULL;
switch (what) {
case B_INDEX_SPECIFIER: {
int32 index;
err = specifier->FindInt32("index", &index);
if (err == B_OK)
child = ChildAt(index);
break;
}
case B_REVERSE_INDEX_SPECIFIER: {
int32 rindex;
err = specifier->FindInt32("index", &rindex);
if (err == B_OK)
child = ChildAt(CountChildren() - rindex);
break;
}
case B_NAME_SPECIFIER: {
const char *name;
err = specifier->FindString("name", &name);
if (err == B_OK)
child = FindView(name);
break;
}
}
if (child != NULL) {
msg->PopSpecifier();
return child;
}
if (err == B_OK)
err = B_BAD_INDEX;
replyMsg.AddString("message", "Cannot find view at/with specified index/name.");
break; break;
} }
default: default:
break; return BHandler::ResolveSpecifier(msg, index, specifier, what, property);
} }
return BHandler::ResolveSpecifier(msg, index, specifier, what, property); if (err == B_BAD_SCRIPT_SYNTAX) {
replyMsg.what = B_MESSAGE_NOT_UNDERSTOOD;
replyMsg.AddString("message", "Didn't understand the specifier(s)");
} else if (err < B_OK) {
replyMsg.what = B_ERROR;
replyMsg.AddString("message", strerror(err));
}
replyMsg.AddInt32("error", err);
msg->SendReply(&replyMsg);
return NULL;
} }
void void
BView::MessageReceived(BMessage *msg) BView::MessageReceived(BMessage *msg)
{ {
BMessage specifier;
int32 what;
const char *prop;
int32 index;
status_t err;
if (!msg->HasSpecifiers()) { if (!msg->HasSpecifiers()) {
switch (msg->what) { switch (msg->what) {
case B_VIEW_RESIZED: case B_VIEW_RESIZED:
@ -3652,90 +3639,66 @@ BView::MessageReceived(BMessage *msg)
} }
default: default:
BHandler::MessageReceived(msg); return BHandler::MessageReceived(msg);
break;
} }
return; return;
} }
err = msg->GetCurrentSpecifier(&index, &specifier, &what, &prop); BMessage replyMsg(B_REPLY);
if (err == B_OK) { status_t err = B_BAD_SCRIPT_SYNTAX;
BMessage replyMsg; int32 index;
BMessage specifier;
switch (msg->what) { int32 what;
case B_GET_PROPERTY: const char *prop;
{
replyMsg.what = B_NO_ERROR; if (msg->GetCurrentSpecifier(&index, &specifier, &what, &prop) != B_OK)
replyMsg.AddInt32("error", B_OK); return BHandler::MessageReceived(msg);
if (strcmp(prop, "Frame") == 0) BPropertyInfo propertyInfo(sViewPropInfo);
replyMsg.AddRect("result", Frame()); switch (propertyInfo.FindMatch(msg, index, &specifier, what, prop)) {
else if (strcmp(prop, "Hidden") == 0) case 0:
replyMsg.AddBool( "result", IsHidden()); err = replyMsg.AddRect("result", Frame());
break; break;
case 1: {
BRect newFrame;
err = msg->FindRect("data", &newFrame);
if (err == B_OK) {
MoveTo(newFrame.LeftTop());
ResizeTo(newFrame.right, newFrame.bottom);
} }
break;
case B_SET_PROPERTY: }
{ case 2:
if (strcmp(prop, "Frame") == 0) { err = replyMsg.AddBool( "result", IsHidden());
BRect newFrame; break;
if (msg->FindRect("data", &newFrame) == B_OK) { case 3: {
MoveTo(newFrame.LeftTop()); bool newHiddenState;
ResizeTo(newFrame.right, newFrame.bottom); err = msg->FindBool("data", &newHiddenState);
if (err == B_OK) {
replyMsg.what = B_NO_ERROR; if (!IsHidden() && newHiddenState == true)
replyMsg.AddInt32("error", B_OK); Hide();
} else { else if (IsHidden() && newHiddenState == false)
replyMsg.what = B_MESSAGE_NOT_UNDERSTOOD; Show();
replyMsg.AddInt32("error", B_BAD_SCRIPT_SYNTAX);
replyMsg.AddString("message", "Didn't understand the specifier(s)");
}
} else if (strcmp(prop, "Hidden") == 0) {
bool newHiddenState;
if (msg->FindBool("data", &newHiddenState) == B_OK) {
if (!IsHidden() && newHiddenState == true) {
Hide();
replyMsg.what = B_NO_ERROR;
replyMsg.AddInt32( "error", B_OK);
}
else if (IsHidden() && newHiddenState == false) {
Show();
replyMsg.what = B_NO_ERROR;
replyMsg.AddInt32("error", B_OK);
} else {
replyMsg.what = B_MESSAGE_NOT_UNDERSTOOD;
replyMsg.AddInt32("error", B_BAD_SCRIPT_SYNTAX);
replyMsg.AddString("message", "Didn't understand the specifier(s)");
}
} else {
replyMsg.what = B_MESSAGE_NOT_UNDERSTOOD;
replyMsg.AddInt32("error", B_BAD_SCRIPT_SYNTAX);
replyMsg.AddString("message", "Didn't understand the specifier(s)");
}
}
break;
} }
case B_COUNT_PROPERTIES:
if (strcmp(prop, "View") == 0) {
replyMsg.what = B_NO_ERROR;
replyMsg.AddInt32("error", B_OK);
replyMsg.AddInt32("result", CountChildren());
}
break;
} }
case 5:
msg->SendReply(&replyMsg); err = replyMsg.AddInt32("result", CountChildren());
} else { break;
BMessage replyMsg(B_MESSAGE_NOT_UNDERSTOOD); default:
replyMsg.AddInt32("error" , B_BAD_SCRIPT_SYNTAX); return BHandler::MessageReceived(msg);
replyMsg.AddString("message", "Didn't understand the specifier(s)");
msg->SendReply(&replyMsg);
} }
if (err == B_BAD_SCRIPT_SYNTAX) {
replyMsg.what = B_MESSAGE_NOT_UNDERSTOOD;
replyMsg.AddString("message", "Didn't understand the specifier(s)");
} else if (err < B_OK) {
replyMsg.what = B_ERROR;
replyMsg.AddString("message", strerror(err));
}
replyMsg.AddInt32("error", err);
msg->SendReply(&replyMsg);
} }

View File

@ -661,141 +661,132 @@ BWindow::MessageReceived(BMessage *msg)
BMessage replyMsg(B_REPLY); BMessage replyMsg(B_REPLY);
bool handled = false; bool handled = false;
switch (msg->what) {
case B_GET_PROPERTY: BMessage specifier;
case B_SET_PROPERTY: int32 what;
case B_CREATE_PROPERTY: const char *prop;
case B_DELETE_PROPERTY: int32 index;
case B_COUNT_PROPERTIES:
case B_EXECUTE_PROPERTY:
case B_GET_SUPPORTED_SUITES: {
BMessage specifier;
int32 what;
const char *prop;
int32 index;
if (msg->GetCurrentSpecifier(&index, &specifier, &what, &prop) != B_OK) if (msg->GetCurrentSpecifier(&index, &specifier, &what, &prop) != B_OK)
return BLooper::MessageReceived(msg); return BLooper::MessageReceived(msg);
BPropertyInfo propertyInfo(sWindowPropInfo); BPropertyInfo propertyInfo(sWindowPropInfo);
switch (propertyInfo.FindMatch(msg, index, &specifier, what, prop)) { switch (propertyInfo.FindMatch(msg, index, &specifier, what, prop)) {
case 0: case 0:
if (msg->what == B_GET_PROPERTY) { if (msg->what == B_GET_PROPERTY) {
replyMsg.AddBool("result", IsActive()); replyMsg.AddBool("result", IsActive());
handled = true; handled = true;
} else if (msg->what == B_SET_PROPERTY) { } else if (msg->what == B_SET_PROPERTY) {
bool newActive; bool newActive;
if (msg->FindBool("data", &newActive) == B_OK) { if (msg->FindBool("data", &newActive) == B_OK) {
Activate(newActive); Activate(newActive);
handled = true; handled = true;
} }
}
break;
case 1:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddInt32("result", (uint32)Feel());
handled = true;
} else {
uint32 newFeel;
if (msg->FindInt32("data", (int32 *)&newFeel) == B_OK) {
SetFeel((window_feel)newFeel);
handled = true;
}
}
break;
case 2:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddInt32("result", Flags());
handled = true;
} else {
uint32 newFlags;
if (msg->FindInt32("data", (int32 *)&newFlags) == B_OK) {
SetFlags(newFlags);
handled = true;
}
}
break;
case 3:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddRect("result", Frame());
handled = true;
} else {
BRect newFrame;
if (msg->FindRect("data", &newFrame) == B_OK) {
MoveTo(newFrame.LeftTop());
ResizeTo(newFrame.Width(), newFrame.Height());
handled = true;
}
}
break;
case 4:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddBool("result", IsHidden());
handled = true;
} else {
bool hide;
if (msg->FindBool("data", &hide) == B_OK) {
if (hide) {
if (!IsHidden())
Hide();
} else if (IsHidden())
Show();
handled = true;
}
}
break;
case 5:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddInt32("result", (uint32)Look());
handled = true;
} else {
uint32 newLook;
if (msg->FindInt32("data", (int32 *)&newLook) == B_OK) {
SetLook((window_look)newLook);
handled = true;
}
}
break;
case 6:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddString("result", Title());
handled = true;
} else {
const char *newTitle = NULL;
if (msg->FindString("data", &newTitle) == B_OK) {
SetTitle(newTitle);
handled = true;
}
}
break;
case 7:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddInt32( "result", Workspaces());
handled = true;
} else {
uint32 newWorkspaces;
if (msg->FindInt32("data", (int32 *)&newWorkspaces) == B_OK) {
SetWorkspaces(newWorkspaces);
handled = true;
}
}
break;
case 11:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddBool("result", IsMinimized());
handled = true;
} else {
bool minimize;
if (msg->FindBool("data", &minimize) == B_OK) {
Minimize(minimize);
handled = true;
}
}
break;
default:
return BLooper::MessageReceived(msg);
} }
} break;
case 1:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddInt32("result", (uint32)Feel());
handled = true;
} else {
uint32 newFeel;
if (msg->FindInt32("data", (int32 *)&newFeel) == B_OK) {
SetFeel((window_feel)newFeel);
handled = true;
}
}
break;
case 2:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddInt32("result", Flags());
handled = true;
} else {
uint32 newFlags;
if (msg->FindInt32("data", (int32 *)&newFlags) == B_OK) {
SetFlags(newFlags);
handled = true;
}
}
break;
case 3:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddRect("result", Frame());
handled = true;
} else {
BRect newFrame;
if (msg->FindRect("data", &newFrame) == B_OK) {
MoveTo(newFrame.LeftTop());
ResizeTo(newFrame.Width(), newFrame.Height());
handled = true;
}
}
break;
case 4:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddBool("result", IsHidden());
handled = true;
} else {
bool hide;
if (msg->FindBool("data", &hide) == B_OK) {
if (hide) {
if (!IsHidden())
Hide();
} else if (IsHidden())
Show();
handled = true;
}
}
break;
case 5:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddInt32("result", (uint32)Look());
handled = true;
} else {
uint32 newLook;
if (msg->FindInt32("data", (int32 *)&newLook) == B_OK) {
SetLook((window_look)newLook);
handled = true;
}
}
break;
case 6:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddString("result", Title());
handled = true;
} else {
const char *newTitle = NULL;
if (msg->FindString("data", &newTitle) == B_OK) {
SetTitle(newTitle);
handled = true;
}
}
break;
case 7:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddInt32( "result", Workspaces());
handled = true;
} else {
uint32 newWorkspaces;
if (msg->FindInt32("data", (int32 *)&newWorkspaces) == B_OK) {
SetWorkspaces(newWorkspaces);
handled = true;
}
}
break;
case 11:
if (msg->what == B_GET_PROPERTY) {
replyMsg.AddBool("result", IsMinimized());
handled = true;
} else {
bool minimize;
if (msg->FindBool("data", &minimize) == B_OK) {
Minimize(minimize);
handled = true;
}
}
break;
default:
return BLooper::MessageReceived(msg);
} }
if (handled) { if (handled) {