YetAnotherUselessDebugToolIWrote

git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@28766 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
François Revol 2008-12-03 02:38:26 +00:00
parent 30ed37c845
commit 01f3ea96af

221
src/bin/spybmessage.cpp Normal file
View File

@ -0,0 +1,221 @@
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <OS.h>
#include <image.h>
#include <Application.h>
#include <StorageDefs.h>
#include <MessageFilter.h>
#include <MessageRunner.h>
#include <List.h>
#include <Window.h>
extern char **original_argv;
extern char **argv_save;
extern char **__libc_argv;
extern int original_argc;
extern int __libc_argc;
#define MAX_VIEWS 10
int gStartWin = 0;
char *gMatchViewNames[MAX_VIEWS];
int gNumViewNames = 0;
char gExePath[B_PATH_NAME_LENGTH];
image_id gExeImg = -1;
int (*gExeMainProc)(int argc, char **argv);
thread_id gWaitForBAppThID = -1;
sem_id gStdoutLock;
//extern "C" EnqueueMessage__Q28BPrivate13BLooperTargetP8BMessage(BLooper *_this, BMessage *message);
//EnqueueMessage__Q28BPrivate13BLooperTargetP8BMessage(BLooper *_this, BMessage *message);
BMessageFilter *gAppFilter;
bool quitting = false;
filter_result bapp_filter(BMessage *message,
BHandler **target,
BMessageFilter *filter)
{
if (message->what == 'plop') /* our doesn't count */
return B_DISPATCH_MESSAGE;
acquire_sem(gStdoutLock);
fprintf(stdout, "\033[31mMessage for BApplication:\033[0m\n");
message->PrintToStream();
release_sem(gStdoutLock);
return B_DISPATCH_MESSAGE;
}
filter_result bwin_filter(BMessage *message,
BHandler **target,
BMessageFilter *filter)
{
BWindow *win;
BHandler *hand = NULL;
if (target)
hand = *target;
win = dynamic_cast<BWindow *>(filter->Looper());
acquire_sem(gStdoutLock);
fprintf(stdout,
"\033[31mMessage for View \"%s\" of Window \"%s\":\033[0m\n",
hand?hand->Name():NULL,
win?win->Title():NULL);
message->PrintToStream();
release_sem(gStdoutLock);
return B_DISPATCH_MESSAGE;
}
class MyHandler : public BHandler {
public:
MyHandler();
~MyHandler();
void MessageReceived(BMessage *msg);
private:
BList fWindowList;
};
MyHandler::MyHandler()
:BHandler("spying handler")
{
fWindowList.MakeEmpty();
}
MyHandler::~MyHandler()
{
}
void MyHandler::MessageReceived(BMessage *msg)
{
int i;
BMessageFilter *afilter;
switch (msg->what) {
case 'plop':
i = be_app->CountWindows();
for (; i; i--) {
BWindow *win = be_app->WindowAt(i-1);
if (win && !fWindowList.HasItem(win)) {
fWindowList.AddItem(win);
afilter = new BMessageFilter(B_ANY_DELIVERY,
B_ANY_SOURCE,
bwin_filter);
win->Lock();
win->AddCommonFilter(afilter);
win->Unlock();
}
}
break;
}
BHandler::MessageReceived(msg);
}
int32 wait_for_loopers(void *arg)
{
MyHandler *myh;
/* wait for BApplication */
while (!be_app)
snooze(50000);
gAppFilter = new BMessageFilter(B_ANY_DELIVERY, B_ANY_SOURCE, bapp_filter);
myh = new MyHandler;
be_app->Lock();
be_app->AddCommonFilter(gAppFilter);
be_app->AddHandler(myh);
be_app->Unlock();
new BMessageRunner(BMessenger(myh), new BMessage('plop'), 100000);
return 0;
}
static int usage(char *argv0)
{
printf("usage:\n");
printf("%s app [args...]\n", argv0);
return 0;
}
int main(int argc, char **argv)
{
int i;
status_t err;
char *trapp_name;
if (argc < 2)
return usage(argv[0]);
trapp_name = argv[0];
for (i = 1; i < argc; i++) {
if (strncmp(argv[i], "-", 1))
break;
else if (!strcmp(argv[i], "-view")) {
if (gNumViewNames >= MAX_VIEWS) {
printf("too many view names\n");
return 1;
}
i++;
if (i >= argc) {
printf("missing arg to -view\n");
return 1;
}
gMatchViewNames[gNumViewNames] = argv[i];
gNumViewNames++;
} else if (!strcmp(argv[i], "-firstw")) {
i++;
if (i >= argc) {
printf("missing arg to -firstw\n");
return 1;
}
gStartWin = atoi(argv[i]);
} else {
return usage(argv[0]);
}
}
if (argc - i < 1)
return usage(argv[0]);
argv += i;
argc -= i;
for (i = 0; i < argc; i++)
printf("argv[%d] = %s\n", i, argv[i]);
gExePath[0] = '\0';
if (strncmp(argv[0], "/", 1)) {
getcwd(gExePath, B_PATH_NAME_LENGTH-10);
strcat(gExePath, "/");
}
strncat(gExePath, argv[0], B_PATH_NAME_LENGTH-1-strlen(gExePath));
printf("cmd = %s\n", gExePath);
gExeImg = load_add_on(gExePath);
if (gExeImg < B_OK) {
fprintf(stderr, "load_add_on: %s\n", strerror(gExeImg));
return 1;
}
// original are static...
//printf("original: %d; %s\n", original_argc, *original_argv);
fprintf(stderr, "libc: %d; %s\n", __libc_argc, *__libc_argv);
fprintf(stderr, "save: %s\n", *argv_save);
//argv[0] = trapp_name;
__libc_argv = argv;
__libc_argc = argc;
argv_save = argv;
gStdoutLock = create_sem(1, "spybmsg_stdout_lock");
err = get_image_symbol(gExeImg, "main", B_SYMBOL_TYPE_TEXT, (void **)&gExeMainProc);
if (err < B_OK) {
fprintf(stderr, "get_image_symbol(main): %s\n", strerror(gExeImg));
return 1;
}
printf("main @ %p\n", gExeMainProc);
resume_thread(spawn_thread(wait_for_loopers,
"waiting for BLoopers",
B_NORMAL_PRIORITY, NULL));
i = gExeMainProc(argc, argv);
return i;
}