#include #include #include using std::string; using std::vector; #define GUI_RPC_PORT 31416 struct PROJECT; struct FILE_INFO { string name; bool generated_locally; bool uploaded; bool upload_when_present; bool sticky; bool pers_xfer_active; bool xfer_active; int num_retries; double bytes_xferred; double file_offset; double xfer_speed; string hostname; PROJECT* project; int parse(FILE*); void print(); }; struct PROJECT { string master_url; double resource_share; string project_name; string user_name; string team_name; double user_total_credit; double user_expavg_credit; double host_total_credit; // as reported by server double host_expavg_credit; // as reported by server int nrpc_failures; // # of consecutive times we've failed to // contact all scheduling servers int master_fetch_failures; int min_rpc_time; // earliest time to contact any server bool master_url_fetch_pending; // need to fetch and parse the master URL bool sched_rpc_pending; // contact scheduling server for preferences bool tentative; // master URL and account ID not confirmed int parse(FILE*); void print(); }; struct APP { string name; PROJECT* project; int parse(FILE*); void print(); }; struct APP_VERSION { string app_name; int version_num; APP* app; PROJECT* project; int parse(FILE*); void print(); }; struct WORKUNIT { string name; string app_name; int version_num; double rsc_fpops_est; double rsc_fpops_bound; double rsc_memory_bound; double rsc_disk_bound; PROJECT* project; APP* app; APP_VERSION* avp; int parse(FILE*); void print(); }; struct RESULT { string name; string wu_name; int report_deadline; bool ready_to_report; bool got_server_ack; double final_cpu_time; int state; int exit_status; int signal; int active_task_state; string stderr_out; APP* app; WORKUNIT* wup; PROJECT* project; int parse(FILE*); void print(); }; struct ACTIVE_TASK { string result_name; int app_version_num; double checkpoint_cpu_time; double current_cpu_time; double fraction_done; PROJECT* project; RESULT* result; int parse(FILE*); void print(); }; struct PROXY_INFO { bool use_http_proxy; bool use_socks_proxy; int socks_version; char socks_server_name[256]; char http_server_name[256]; int socks_server_port; int http_server_port; char socks5_user_name[256]; char socks5_user_passwd[256]; }; struct MESSAGE_DESC { string project; int priority; int timestamp; string body; }; class RPC_CLIENT { int sock; FILE* fin; FILE* fout; public: vector projects; vector file_infos; vector apps; vector app_versions; vector wus; vector results; vector active_tasks; APP* lookup_app(string&); WORKUNIT* lookup_wu(string&); APP_VERSION* lookup_app_version(string&, int); RESULT* lookup_result(string&); void link(); ~RPC_CLIENT(); int init(char*); int get_state(); int result_show_graphics(RESULT&); int project_reset(PROJECT&); int project_attach(char* url, char* auth); int project_detach(PROJECT&); int project_update(PROJECT&); int set_run_mode(int mode); int run_benchmarks(); int set_proxy_settings(PROXY_INFO&); int get_messages(int nmessages, int offset, vector&); void print(); };