// The contents of this file are subject to the Mozilla Public License // Version 1.0 (the "License"); you may not use this file except in // compliance with the License. You may obtain a copy of the License at // http://www.mozilla.org/MPL/ // // Software distributed under the License is distributed on an "AS IS" // basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the // License for the specific language governing rights and limitations // under the License. // // The Original Code is the Berkeley Open Infrastructure for Network Computing. // // The Initial Developer of the Original Code is the SETI@home project. // Portions created by the SETI@home project are Copyright (C) 2002 // University of California at Berkeley. All Rights Reserved. // // Contributor(s): // // read "in", convert to UC, write to "out" // command line options: // -run_slow: app will sleep 1 second after each character, useful for // debugging // -cpu_time: app will chew up some CPU cycles after each character, // used for testing CPU time reporting // // This version does one char/second, // and writes its state to disk every so often #include #include #include #include "filesys.h" #include "boinc_api.h" #define CHECKPOINT_FILE "upper_case_state" int run_slow=0,cpu_time=0; time_t my_start_time; int do_checkpoint(MFILE& mf, int nchars) { int retval; char resolved_name[512],res_name2[512]; FILE *app_time, *client_time; APP_INIT_DATA aid; if (cpu_time) { app_time = fopen("../../app.time", "w"), client_time = fopen("../../client.time", "w"); boinc_get_init_data(aid); } boinc_resolve_filename( "temp", resolved_name ); FILE* f = fopen(resolved_name, "w"); if (!f) return 1; fprintf(f, "%d", nchars); fclose(f); fprintf(stderr, "APP: upper_case checkpointing\n"); // hopefully atomic part starts here retval = mf.flush(); if (retval) return retval; boinc_resolve_filename( CHECKPOINT_FILE, res_name2 ); retval = boinc_rename(resolved_name, res_name2); if (retval) return retval; // hopefully atomic part ends here if (cpu_time) { // print our own information about cpu time fprintf(app_time, "%f\n", difftime(time(0), my_start_time)); fflush(app_time); fclose(app_time); // print what the client thinks is our cpu time fprintf(client_time, "%f\n", aid.wu_cpu_time + boinc_cpu_time()); fflush(client_time); fclose(client_time); } return 0; } #ifdef _WIN32 #include int WINAPI WinMain(HINSTANCE hInst, HINSTANCE hPrevInst, LPSTR Args, int WinMode) { LPWSTR command_line; LPWSTR *args; char* argv[100]; int i, argc; command_line = GetCommandLineW(); args = CommandLineToArgvW(command_line, &argc); // uh, why did MS have to "improve" on char*? for (i=0; i