"failstar" sounds like a name for a cruise liner from the 80s. As "*" isn't a desirable part of directory names, just name the whole thing "fail/", the core parts being stored in "fail/core/". Additionally fixing two build system dependency issues: - missing jobserver -> protomessages dependency - broken bochs -> fail dependency (add_custom_target DEPENDS only allows plain file dependencies ... cmake for the win) git-svn-id: https://www4.informatik.uni-erlangen.de/i4svn/danceos/trunk/devel/fail@956 8c4709b5-6ec9-48aa-a5cd-a96041d1645a
55 lines
1.1 KiB
Plaintext
55 lines
1.1 KiB
Plaintext
#ifndef __NONVERBOSE_AH__
|
|
#define __NONVERBOSE_AH__
|
|
|
|
#include "../../AspectConfig.hpp"
|
|
|
|
#if CONFIG_STFU == 1
|
|
|
|
#include "bochs.h"
|
|
|
|
// Doesn't work because AspectC++ doesn't deal properly with variadic parameter
|
|
// lists:
|
|
/*
|
|
aspect nonverbose {
|
|
// needed to suppress Bochs output *before* a state restore finished
|
|
// FIXME ac++ segfaults if we use call() instead of execution()
|
|
advice execution("% logfunctions::debug(...)")
|
|
|| execution("% logfunctions::info(...)")
|
|
|| execution("% logfunctions::pass(...)")
|
|
|| execution("% logfunctions::error(...)")
|
|
: around () {
|
|
}
|
|
};
|
|
*/
|
|
|
|
aspect nonverbose {
|
|
// needed to suppress Bochs output *before* a state restore finished
|
|
advice call("int logfunctions::get_default_action(int)")
|
|
: around () {
|
|
int action;
|
|
switch (*(tjp->arg<0>())) {
|
|
case LOGLEV_DEBUG:
|
|
case LOGLEV_PASS:
|
|
case LOGLEV_INFO:
|
|
action = ACT_IGNORE;
|
|
break;
|
|
case LOGLEV_ERROR:
|
|
action = ACT_REPORT;
|
|
break;
|
|
case LOGLEV_PANIC:
|
|
default:
|
|
action = ACT_FATAL;
|
|
}
|
|
*(tjp->result()) = action;
|
|
}
|
|
|
|
// no credits header
|
|
advice call("void bx_print_header()")
|
|
: around () {
|
|
}
|
|
};
|
|
|
|
#endif
|
|
|
|
#endif
|