2005-01-20 23:22:22 +00:00
|
|
|
// Berkeley Open Infrastructure for Network Computing
|
|
|
|
// http://boinc.berkeley.edu
|
|
|
|
// Copyright (C) 2005 University of California
|
2004-07-13 13:54:09 +00:00
|
|
|
//
|
2005-01-20 23:22:22 +00:00
|
|
|
// This 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 2.1 of the License, or (at your option) any later version.
|
2004-07-13 13:54:09 +00:00
|
|
|
//
|
2005-01-20 23:22:22 +00:00
|
|
|
// This software is distributed in the hope that it will be useful,
|
|
|
|
// 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.
|
2002-04-30 22:22:54 +00:00
|
|
|
//
|
2005-01-20 23:22:22 +00:00
|
|
|
// To view the GNU Lesser General Public License visit
|
|
|
|
// http://www.gnu.org/copyleft/lesser.html
|
|
|
|
// or write to the Free Software Foundation, Inc.,
|
|
|
|
// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
2002-04-30 22:22:54 +00:00
|
|
|
|
2003-10-16 19:03:49 +00:00
|
|
|
#include "cpp.h"
|
2004-03-04 11:41:43 +00:00
|
|
|
|
|
|
|
#ifdef _WIN32
|
2004-06-16 23:16:08 +00:00
|
|
|
#include "boinc_win.h"
|
2004-03-04 11:41:43 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef _WIN32
|
2005-11-21 18:34:44 +00:00
|
|
|
#include "config.h"
|
2004-07-13 13:54:09 +00:00
|
|
|
#include <cstdio>
|
|
|
|
#include <cstring>
|
2004-03-04 11:41:43 +00:00
|
|
|
#endif
|
2002-04-30 22:22:54 +00:00
|
|
|
|
|
|
|
#include "error_numbers.h"
|
2006-09-01 21:06:30 +00:00
|
|
|
#include "common_defs.h"
|
2002-08-12 23:18:47 +00:00
|
|
|
#include "file_names.h"
|
2004-04-08 08:15:23 +00:00
|
|
|
#include "client_msgs.h"
|
2002-04-30 22:22:54 +00:00
|
|
|
#include "parse.h"
|
2004-03-01 19:11:12 +00:00
|
|
|
#include "filesys.h"
|
2002-04-30 22:22:54 +00:00
|
|
|
|
|
|
|
LOG_FLAGS log_flags;
|
2006-05-21 21:11:28 +00:00
|
|
|
CONFIG config;
|
2002-04-30 22:22:54 +00:00
|
|
|
|
|
|
|
LOG_FLAGS::LOG_FLAGS() {
|
2003-03-13 21:49:52 +00:00
|
|
|
|
2006-06-22 19:40:30 +00:00
|
|
|
memset(this, 0, sizeof(LOG_FLAGS));
|
|
|
|
|
2007-04-26 21:57:42 +00:00
|
|
|
defaults();
|
|
|
|
}
|
|
|
|
|
|
|
|
void LOG_FLAGS::defaults() {
|
2006-06-22 19:40:30 +00:00
|
|
|
// on by default
|
|
|
|
// (others are off by default)
|
2003-03-13 21:49:52 +00:00
|
|
|
//
|
2006-06-22 19:40:30 +00:00
|
|
|
task = true;
|
2003-03-13 21:49:52 +00:00
|
|
|
file_xfer = true;
|
|
|
|
sched_ops = true;
|
2007-04-26 21:57:42 +00:00
|
|
|
|
|
|
|
// off by default; intended for developers and testers
|
|
|
|
//
|
|
|
|
cpu_sched = false;
|
|
|
|
cpu_sched_debug = false;
|
|
|
|
rr_simulation = false;
|
|
|
|
debt_debug = false;
|
|
|
|
task_debug = false;
|
|
|
|
work_fetch_debug = false;
|
|
|
|
unparsed_xml = false;
|
|
|
|
state_debug = false;
|
|
|
|
file_xfer_debug = false;
|
|
|
|
sched_op_debug = false;
|
|
|
|
http_debug = false;
|
|
|
|
proxy_debug = false;
|
|
|
|
time_debug = false;
|
|
|
|
http_xfer_debug = false;
|
|
|
|
benchmark_debug = false;
|
|
|
|
poll_debug = false;
|
|
|
|
guirpc_debug = false;
|
|
|
|
scrsave_debug = false;
|
|
|
|
app_msg_send = false;
|
|
|
|
app_msg_receive = false;
|
|
|
|
mem_usage_debug = false;
|
|
|
|
network_status_debug = false;
|
|
|
|
checkpoint_debug = false;
|
|
|
|
}
|
2002-04-30 22:22:54 +00:00
|
|
|
|
2002-07-15 23:21:20 +00:00
|
|
|
// Parse log flag preferences
|
|
|
|
//
|
2006-08-21 22:25:21 +00:00
|
|
|
int LOG_FLAGS::parse(XML_PARSER& xp) {
|
|
|
|
char tag[1024];
|
|
|
|
bool is_tag;
|
|
|
|
|
2006-08-23 03:34:30 +00:00
|
|
|
while (!xp.get(tag, sizeof(tag), is_tag)) {
|
2006-08-21 22:25:21 +00:00
|
|
|
if (!is_tag) {
|
2007-01-25 23:39:06 +00:00
|
|
|
msg_printf(NULL, MSG_USER_ERROR,
|
2006-08-21 22:25:21 +00:00
|
|
|
"Unexpected text %s in %s", tag, CONFIG_FILE
|
|
|
|
);
|
|
|
|
continue;
|
|
|
|
}
|
2006-06-21 22:08:20 +00:00
|
|
|
if (!strcmp(tag, "/log_flags")) return 0;
|
2006-08-21 22:25:21 +00:00
|
|
|
else if (xp.parse_bool(tag, "task", task)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "file_xfer", file_xfer)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "sched_ops", sched_ops)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "cpu_sched", cpu_sched)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "cpu_sched_debug", cpu_sched_debug)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "rr_simulation", rr_simulation)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "debt_debug", debt_debug)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "task_debug", task_debug)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "work_fetch_debug", work_fetch_debug)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "unparsed_xml", unparsed_xml)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "state_debug", state_debug)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "file_xfer_debug", file_xfer_debug)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "sched_op_debug", sched_op_debug)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "http_debug", http_debug)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "proxy_debug", proxy_debug)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "time_debug", time_debug)) continue;
|
2006-08-29 18:18:36 +00:00
|
|
|
else if (xp.parse_bool(tag, "http_xfer_debug", http_xfer_debug)) continue;
|
2007-02-06 20:43:54 +00:00
|
|
|
else if (xp.parse_bool(tag, "benchmark_debug", benchmark_debug)) continue;
|
2006-08-21 22:25:21 +00:00
|
|
|
else if (xp.parse_bool(tag, "poll_debug", poll_debug)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "guirpc_debug", guirpc_debug)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "scrsave_debug", scrsave_debug)) continue;
|
2006-11-21 00:45:22 +00:00
|
|
|
else if (xp.parse_bool(tag, "app_msg_send", app_msg_send)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "app_msg_receive", app_msg_receive)) continue;
|
2006-08-28 18:22:07 +00:00
|
|
|
else if (xp.parse_bool(tag, "mem_usage_debug", mem_usage_debug)) continue;
|
2006-08-29 18:18:36 +00:00
|
|
|
else if (xp.parse_bool(tag, "network_status_debug", network_status_debug)) continue;
|
2007-02-22 16:33:37 +00:00
|
|
|
else if (xp.parse_bool(tag, "checkpoint_debug", checkpoint_debug)) continue;
|
2006-06-21 22:08:20 +00:00
|
|
|
else {
|
2007-01-25 23:39:06 +00:00
|
|
|
msg_printf(NULL, MSG_USER_ERROR, "Unrecognized tag in %s: <%s>\n",
|
2006-06-21 22:08:20 +00:00
|
|
|
CONFIG_FILE, tag
|
|
|
|
);
|
|
|
|
}
|
2006-05-21 21:11:28 +00:00
|
|
|
}
|
|
|
|
return ERR_XML_PARSE;
|
|
|
|
}
|
|
|
|
|
2006-09-07 17:38:54 +00:00
|
|
|
static void show_flag(char* buf, bool flag, const char* flag_name) {
|
|
|
|
if (!flag) return;
|
2006-09-07 18:19:25 +00:00
|
|
|
int n = (int)strlen(buf);
|
2006-09-07 17:38:54 +00:00
|
|
|
if (!n) {
|
|
|
|
strcpy(buf, flag_name);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
strcat(buf, ", ");
|
|
|
|
strcat(buf, flag_name);
|
|
|
|
if (strlen(buf) > 60) {
|
|
|
|
msg_printf(NULL, MSG_INFO, "log flags: %s", buf);
|
|
|
|
strcpy(buf, "");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void LOG_FLAGS::show() {
|
|
|
|
char buf[256];
|
|
|
|
strcpy(buf, "");
|
|
|
|
show_flag(buf, task, "task");
|
|
|
|
show_flag(buf, file_xfer, "file_xfer");
|
|
|
|
show_flag(buf, sched_ops, "sched_ops");
|
|
|
|
show_flag(buf, cpu_sched, "cpu_sched");
|
|
|
|
show_flag(buf, cpu_sched_debug, "cpu_sched_debug");
|
|
|
|
show_flag(buf, rr_simulation, "rr_simulation");
|
|
|
|
show_flag(buf, debt_debug, "debt_debug");
|
|
|
|
show_flag(buf, task_debug, "task_debug");
|
|
|
|
show_flag(buf, work_fetch_debug, "work_fetch_debug");
|
|
|
|
show_flag(buf, unparsed_xml, "unparsed_xml");
|
|
|
|
show_flag(buf, state_debug, "state_debug");
|
|
|
|
show_flag(buf, file_xfer_debug, "file_xfer_debug");
|
|
|
|
show_flag(buf, sched_op_debug, "sched_op_debug");
|
|
|
|
show_flag(buf, http_debug, "http_debug");
|
|
|
|
show_flag(buf, proxy_debug, "proxy_debug");
|
|
|
|
show_flag(buf, time_debug, "time_debug");
|
|
|
|
show_flag(buf, http_xfer_debug, "http_xfer_debug");
|
2007-02-06 20:43:54 +00:00
|
|
|
show_flag(buf, benchmark_debug, "benchmark_debug");
|
2006-09-07 17:38:54 +00:00
|
|
|
show_flag(buf, poll_debug, "poll_debug");
|
|
|
|
show_flag(buf, guirpc_debug, "guirpc_debug");
|
|
|
|
show_flag(buf, scrsave_debug, "scrsave_debug");
|
2006-11-21 00:45:22 +00:00
|
|
|
show_flag(buf, app_msg_send, "app_msg_send");
|
|
|
|
show_flag(buf, app_msg_receive, "app_msg_receive");
|
2006-09-07 17:38:54 +00:00
|
|
|
show_flag(buf, mem_usage_debug, "mem_usage_debug");
|
|
|
|
show_flag(buf, network_status_debug, "network_status_debug");
|
2007-02-22 16:33:37 +00:00
|
|
|
show_flag(buf, checkpoint_debug, "checkpoint_debug");
|
2006-09-07 17:38:54 +00:00
|
|
|
if (strlen(buf)) {
|
|
|
|
msg_printf(NULL, MSG_INFO, "log flags: %s", buf);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-05-21 21:11:28 +00:00
|
|
|
CONFIG::CONFIG() {
|
2006-07-13 23:40:10 +00:00
|
|
|
memset(this, 0, sizeof(CONFIG));
|
2007-04-26 21:57:42 +00:00
|
|
|
|
|
|
|
defaults();
|
|
|
|
}
|
|
|
|
|
|
|
|
void CONFIG::defaults() {
|
2006-05-22 09:54:31 +00:00
|
|
|
dont_check_file_sizes = false;
|
2007-04-26 21:57:42 +00:00
|
|
|
http_1_0 = false;
|
2006-05-21 21:11:28 +00:00
|
|
|
save_stats_days = 30;
|
2006-10-25 16:54:47 +00:00
|
|
|
max_file_xfers = MAX_FILE_XFERS;
|
|
|
|
max_file_xfers_per_project = MAX_FILE_XFERS_PER_PROJECT;
|
2006-05-21 21:11:28 +00:00
|
|
|
}
|
|
|
|
|
2006-08-21 22:25:21 +00:00
|
|
|
int CONFIG::parse_options(XML_PARSER& xp) {
|
|
|
|
char tag[1024];
|
|
|
|
bool is_tag;
|
|
|
|
|
2006-08-23 03:34:30 +00:00
|
|
|
while (!xp.get(tag, sizeof(tag), is_tag)) {
|
2006-08-21 22:25:21 +00:00
|
|
|
if (!is_tag) {
|
2007-01-25 23:39:06 +00:00
|
|
|
msg_printf(NULL, MSG_USER_ERROR,
|
2006-08-21 22:25:21 +00:00
|
|
|
"Unexpected text %s in %s", tag, CONFIG_FILE
|
|
|
|
);
|
|
|
|
continue;
|
|
|
|
}
|
2006-07-11 22:52:17 +00:00
|
|
|
if (!strcmp(tag, "/options")) {
|
|
|
|
return 0;
|
2006-08-21 22:25:21 +00:00
|
|
|
}
|
|
|
|
else if (xp.parse_int(tag, "save_stats_days", save_stats_days)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "dont_check_file_sizes", dont_check_file_sizes)) continue;
|
2006-12-19 17:41:30 +00:00
|
|
|
else if (xp.parse_bool(tag, "http_1_0", http_1_0)) continue;
|
2006-08-21 22:25:21 +00:00
|
|
|
else if (xp.parse_int(tag, "ncpus", ncpus)) continue;
|
2006-10-25 16:54:47 +00:00
|
|
|
else if (xp.parse_int(tag, "max_file_xfers", max_file_xfers)) continue;
|
|
|
|
else if (xp.parse_int(tag, "max_file_xfers_per_project", max_file_xfers_per_project)) continue;
|
2007-03-13 19:33:27 +00:00
|
|
|
else if (xp.parse_bool(tag, "suppress_net_info", suppress_net_info)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "disallow_attach", disallow_attach)) continue;
|
|
|
|
else if (xp.parse_bool(tag, "os_random_only", os_random_only)) continue;
|
2007-05-07 19:38:27 +00:00
|
|
|
else if (xp.parse_bool(tag, "no_alt_platform", no_alt_platform)) continue;
|
2006-08-21 22:25:21 +00:00
|
|
|
else {
|
2007-01-25 23:39:06 +00:00
|
|
|
msg_printf(NULL, MSG_USER_ERROR, "Unparsed tag in %s: <%s>\n",
|
2006-07-11 22:52:17 +00:00
|
|
|
CONFIG_FILE, tag
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ERR_XML_PARSE;
|
|
|
|
}
|
|
|
|
|
2006-06-21 22:08:20 +00:00
|
|
|
int CONFIG::parse(FILE* f) {
|
2006-07-11 23:27:32 +00:00
|
|
|
char tag[256];
|
2006-08-22 21:52:44 +00:00
|
|
|
MIOFILE mf;
|
|
|
|
XML_PARSER xp(&mf);
|
2006-08-21 22:25:21 +00:00
|
|
|
bool is_tag;
|
|
|
|
|
2006-08-22 21:52:44 +00:00
|
|
|
mf.init_file(f);
|
2006-09-11 19:03:00 +00:00
|
|
|
if (!xp.parse_start("cc_config")) {
|
2007-01-25 23:39:06 +00:00
|
|
|
msg_printf(NULL, MSG_USER_ERROR, "Missing start tag in %s", CONFIG_FILE);
|
2006-09-11 19:03:00 +00:00
|
|
|
return ERR_XML_PARSE;
|
|
|
|
}
|
2006-08-23 03:34:30 +00:00
|
|
|
while (!xp.get(tag, sizeof(tag), is_tag)) {
|
2006-08-21 22:25:21 +00:00
|
|
|
if (!is_tag) {
|
2007-01-25 23:39:06 +00:00
|
|
|
msg_printf(NULL, MSG_USER_ERROR,
|
2006-08-21 22:25:21 +00:00
|
|
|
"Unexpected text %s in %s", tag, CONFIG_FILE
|
|
|
|
);
|
|
|
|
continue;
|
|
|
|
}
|
2006-06-21 22:08:20 +00:00
|
|
|
if (!strcmp(tag, "/cc_config")) return 0;
|
|
|
|
if (!strcmp(tag, "log_flags")) {
|
2006-08-21 22:25:21 +00:00
|
|
|
log_flags.parse(xp);
|
2006-05-21 21:11:28 +00:00
|
|
|
continue;
|
2006-07-11 22:52:17 +00:00
|
|
|
} else if (!strcmp(tag, "options")) {
|
2006-08-21 22:25:21 +00:00
|
|
|
parse_options(xp);
|
2006-06-21 22:08:20 +00:00
|
|
|
} else {
|
2007-01-25 23:39:06 +00:00
|
|
|
msg_printf(NULL, MSG_USER_ERROR, "Unparsed tag in %s: <%s>\n",
|
2006-06-21 22:08:20 +00:00
|
|
|
CONFIG_FILE, tag
|
|
|
|
);
|
2006-05-21 21:11:28 +00:00
|
|
|
}
|
2002-04-30 22:22:54 +00:00
|
|
|
}
|
2007-01-25 23:39:06 +00:00
|
|
|
msg_printf(NULL, MSG_USER_ERROR, "Missing end tag in %s", CONFIG_FILE);
|
2002-04-30 22:22:54 +00:00
|
|
|
return ERR_XML_PARSE;
|
|
|
|
}
|
2002-08-12 23:18:47 +00:00
|
|
|
|
2006-12-17 02:48:19 +00:00
|
|
|
int read_config_file() {
|
2002-08-12 23:18:47 +00:00
|
|
|
FILE* f;
|
|
|
|
|
2007-04-26 21:57:42 +00:00
|
|
|
log_flags.defaults();
|
|
|
|
config.defaults();
|
|
|
|
|
2006-06-21 22:08:20 +00:00
|
|
|
f = boinc_fopen(CONFIG_FILE, "r");
|
2006-12-17 02:48:19 +00:00
|
|
|
if (!f) return ERR_FOPEN;
|
2006-06-21 22:08:20 +00:00
|
|
|
config.parse(f);
|
|
|
|
fclose(f);
|
2006-12-17 02:48:19 +00:00
|
|
|
return 0;
|
2002-08-12 23:18:47 +00:00
|
|
|
}
|
2004-12-08 00:40:19 +00:00
|
|
|
|
2005-01-02 18:29:53 +00:00
|
|
|
const char *BOINC_RCSID_5f23de6652 = "$Id$";
|