2008-08-06 18:36:30 +00:00
|
|
|
// This file is part of BOINC.
|
2005-01-20 23:22:22 +00:00
|
|
|
// http://boinc.berkeley.edu
|
2008-08-06 18:36:30 +00:00
|
|
|
// Copyright (C) 2008 University of California
|
2003-06-11 22:42:49 +00:00
|
|
|
//
|
2008-08-06 18:36:30 +00:00
|
|
|
// BOINC is free software; you can redistribute it and/or modify it
|
|
|
|
// under the terms of the GNU Lesser General Public License
|
|
|
|
// as published by the Free Software Foundation,
|
|
|
|
// either version 3 of the License, or (at your option) any later version.
|
2003-06-11 22:42:49 +00:00
|
|
|
//
|
2008-08-06 18:36:30 +00:00
|
|
|
// BOINC is distributed in the hope that it will be useful,
|
2005-01-20 23:22:22 +00:00
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
// See the GNU Lesser General Public License for more details.
|
2003-06-11 22:42:49 +00:00
|
|
|
//
|
2008-08-06 18:36:30 +00:00
|
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
|
|
// along with BOINC. If not, see <http://www.gnu.org/licenses/>.
|
2003-06-11 22:42:49 +00:00
|
|
|
|
2004-03-05 04:37:53 +00:00
|
|
|
#ifdef _WIN32
|
2004-06-16 23:16:08 +00:00
|
|
|
#include "boinc_win.h"
|
2005-11-21 18:34:44 +00:00
|
|
|
#else
|
|
|
|
#include "config.h"
|
2004-07-13 13:54:09 +00:00
|
|
|
#include <cstdarg>
|
2007-12-21 21:09:40 +00:00
|
|
|
#include <cstring>
|
2004-09-30 21:41:09 +00:00
|
|
|
#include <deque>
|
2004-04-08 08:15:23 +00:00
|
|
|
#endif
|
2008-08-12 22:30:37 +00:00
|
|
|
#include "str_util.h"
|
2004-03-05 04:37:53 +00:00
|
|
|
|
2004-09-30 21:41:09 +00:00
|
|
|
using std::deque;
|
|
|
|
|
2003-06-11 22:42:49 +00:00
|
|
|
#include "log_flags.h"
|
2005-01-28 19:01:08 +00:00
|
|
|
#include "client_types.h"
|
2004-04-08 08:15:23 +00:00
|
|
|
#include "client_msgs.h"
|
2003-06-11 22:42:49 +00:00
|
|
|
|
2004-06-17 04:49:34 +00:00
|
|
|
#define MAX_SAVED_MESSAGES 1000
|
|
|
|
|
2008-08-12 19:06:35 +00:00
|
|
|
// a cache of MAX_SAVED_MESSAGES most recent messages,
|
2004-09-30 21:41:09 +00:00
|
|
|
// stored in newest-first order
|
|
|
|
//
|
|
|
|
deque<MESSAGE_DESC*> message_descs;
|
2004-04-08 08:15:23 +00:00
|
|
|
|
|
|
|
// Takes a printf style formatted string, inserts the proper values,
|
|
|
|
// and passes it to show_message
|
|
|
|
// TODO: add translation functionality
|
|
|
|
//
|
2005-02-16 23:17:43 +00:00
|
|
|
void msg_printf(PROJECT *p, int priority, const char *fmt, ...) {
|
2004-08-12 12:44:55 +00:00
|
|
|
char buf[8192]; // output can be much longer than format
|
2004-04-08 08:15:23 +00:00
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
if (fmt == NULL) return;
|
|
|
|
|
2008-08-12 19:06:35 +00:00
|
|
|
va_start(ap, fmt);
|
|
|
|
vsnprintf(buf, sizeof(buf), fmt, ap);
|
|
|
|
buf[sizeof(buf)-1] = 0;
|
|
|
|
va_end(ap);
|
2004-04-08 08:15:23 +00:00
|
|
|
|
|
|
|
show_message(p, buf, priority);
|
|
|
|
}
|
2004-06-17 04:49:34 +00:00
|
|
|
|
2008-08-12 19:06:35 +00:00
|
|
|
// add message to cache, and delete old messages if cache too big
|
2004-06-17 04:49:34 +00:00
|
|
|
//
|
|
|
|
void record_message(PROJECT* p, int priority, int now, char* message) {
|
|
|
|
MESSAGE_DESC* mdp = new MESSAGE_DESC;
|
|
|
|
static int seqno = 1;
|
2005-01-28 19:01:08 +00:00
|
|
|
strcpy(mdp->project_name, "");
|
|
|
|
if (p) {
|
2008-08-12 19:06:35 +00:00
|
|
|
strlcpy(
|
2008-08-12 22:19:50 +00:00
|
|
|
mdp->project_name, p->get_project_name(), sizeof(mdp->project_name)
|
2008-08-12 19:06:35 +00:00
|
|
|
);
|
2005-01-28 19:01:08 +00:00
|
|
|
}
|
2004-06-17 04:49:34 +00:00
|
|
|
mdp->priority = priority;
|
|
|
|
mdp->timestamp = now;
|
|
|
|
mdp->seqno = seqno++;
|
|
|
|
mdp->message = message;
|
|
|
|
while (message_descs.size() > MAX_SAVED_MESSAGES) {
|
|
|
|
delete message_descs.back();
|
|
|
|
message_descs.pop_back();
|
|
|
|
}
|
|
|
|
message_descs.push_front(mdp);
|
2004-06-17 05:08:31 +00:00
|
|
|
}
|
2004-12-08 00:40:19 +00:00
|
|
|
|
2005-01-02 18:29:53 +00:00
|
|
|
const char *BOINC_RCSID_9572274f4f = "$Id$";
|