Fixed the setlogmask*() functions; the priority mask is only set if the

parameter is not 0, and it returns the old mask as well.
Also fixed the initial log mask for the team context; it's now set to -1
(enable all priorities) by default.


git-svn-id: file:///srv/svn/repos/haiku/trunk/current@5329 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2003-11-12 14:44:31 +00:00
parent 8c894b6039
commit 41c6e8cc55

View File

@ -20,7 +20,11 @@ struct syslog_context {
int32 options; int32 options;
}; };
static syslog_context sTeamContext; static syslog_context sTeamContext = {
"",
-1,
0
};
static int32 sThreadContextSlot = -1; static int32 sThreadContextSlot = -1;
@ -128,7 +132,8 @@ send_syslog_message(syslog_context *context, int priority, const char *text, va_
// #pragma mark - // #pragma mark -
// public API // public Be API
// ToDo: it would probably be better to export these symbols as weak symbols only
void void
@ -151,7 +156,12 @@ openlog_team(const char *ident, int options, int facility)
int int
setlogmask_team(int priorityMask) setlogmask_team(int priorityMask)
{ {
int oldMask = sTeamContext.mask;
if (priorityMask != 0)
sTeamContext.mask = priorityMask; sTeamContext.mask = priorityMask;
return oldMask;
} }
@ -193,7 +203,12 @@ int
setlogmask_thread(int priorityMask) setlogmask_thread(int priorityMask)
{ {
syslog_context *context = get_context(); syslog_context *context = get_context();
int oldMask = context->mask;
if (priorityMask != 0)
context->mask = priorityMask; context->mask = priorityMask;
return oldMask;
} }
@ -229,7 +244,7 @@ openlog(const char *ident, int options, int facility)
int int
setlogmask(int priorityMask) setlogmask(int priorityMask)
{ {
setlogmask_thread(priorityMask); return setlogmask_thread(priorityMask);
} }