SCR: Fix trace statements in screensaver.cpp; enable diagnostics in Mac screensaver

svn path=/trunk/boinc/; revision=15967
This commit is contained in:
Charlie Fenton 2008-09-05 02:47:10 +00:00
parent 37b3e3724f
commit 229650ec15
6 changed files with 66 additions and 9 deletions

View File

@ -7214,3 +7214,16 @@ David 4 Sep 2008
lib/
crypt.C,h
crypt_prog.C
Charlie 4 Sep 2008
SCR: Fix trace statements in screensaver.cpp; enable diagnostics in
Mac screensaver.
clientscr/
mac_saver_module.cpp
Mac_Saver_Module.h
Mac_Saver_ModuleView.m
screensaver.cpp
mac_build/
boinc.xcodeproj/
project.pbxproj

View File

@ -24,7 +24,9 @@
#include <Carbon/Carbon.h>
#ifdef _DEBUG
#define _T(x) x
#endif
#ifdef __cplusplus
extern "C" {
@ -36,6 +38,7 @@ void drawPreview(CGContextRef myContext);
void closeBOINCSaver(void);
void print_to_log_file(const char *format, ...);
void strip_cr(char *buf);
void PrintBacktrace(void);
#ifdef __cplusplus
} // extern "C"

View File

@ -211,7 +211,9 @@ int signof(float x) {
NSRect windowFrame = [ myWindow frame ];
if ( (windowFrame.origin.x != 0) || (windowFrame.origin.y != 0) ) {
// Hide window on second display to aid in debugging
// [[[ NSView focusView] window ] setLevel:kCGMinimumWindowLevel ];
#ifdef _DEBUG
[[[ NSView focusView] window ] setLevel:kCGMinimumWindowLevel ];
#endif
return; // We draw only to main screen
}

View File

@ -37,6 +37,7 @@
#include "util.h"
#include "Mac_Saver_Module.h"
#include "screensaver.h"
#include "diagnostics.h"
//#include <drivers/event_status_driver.h>
@ -96,6 +97,19 @@ const char * ScreenSaverAppStartingMsg = "Starting screensaver graphics.\nPleas
// Returns desired Animation Frequency (per second) or 0 for no change
int initBOINCSaver(Boolean ispreview) {
#ifdef _DEBUG
char buf1[256], buf2[256];
strcpy(buf1, getenv("HOME"));
strcat(buf1, "/Documents/ss_stdout");
strcpy(buf2, getenv("HOME"));
strcat(buf2, "/Documents/ss_stderr");
diagnostics_init(BOINC_DIAG_REDIRECTSTDOUTOVERWRITE
| BOINC_DIAG_REDIRECTSTDERROVERWRITE
| BOINC_DIAG_TRACETOSTDOUT, buf1, buf2
);
#endif
if (ispreview)
return 8;
@ -166,6 +180,10 @@ int CScreensaver::Create() {
// occur when the screensaver is run normally (from the screensaver
// engine.) So we just display a message and don't access the core
// client.
// With V6 graphics when using gfx_switcher, the graphics application
// fails to run and stderr shows the message:
// "The process has forked and you cannot use this CoreFoundation
// functionality safely. You MUST exec()"
GetCurrentProcess(&psn);
memset(&pInfo, 0, sizeof(pInfo));
pInfo.processInfoLength = sizeof( ProcessInfoRec );
@ -315,8 +333,9 @@ int CScreensaver::getSSMessage(char **theMessage, int* coveredFreq) {
// Take care of the possible race condition where the Core Client was in the
// process of shutting down just as ScreenSaver started, so initBOINCApp()
// found it already running but now it has shut down.
if (m_wasAlreadyRunning) // If we launched it, then just wait for it to start
if (m_wasAlreadyRunning) { // If we launched it, then just wait for it to start
saverState = SaverState_RelaunchCoreClient;
}
break;
case SaverState_CoreClientRunning:
@ -773,4 +792,8 @@ void strip_cr(char *buf)
*theCR = '\0';
}
#endif // CREATE_LOG
void PrintBacktrace(void) {
}
const char *BOINC_RCSID_7ce0778d35="$Id$";

View File

@ -442,7 +442,8 @@ void *CScreensaver::DataManagementProc() {
// V6 graphics only: if worker application has stopped running, terminate_screensaver
if ((graphics_app_result_ptr == NULL) && (m_hGraphicsApplication != 0)) {
if (previous_result_ptr) {
BOINCTRACE(_T("CScreensaver::DataManagementProc - %s finished\n"), previous_result.name.c_str());
BOINCTRACE(_T("CScreensaver::DataManagementProc - %s finished\n"),
previous_result.graphics_exec_path.c_str());
}
terminate_screensaver(m_hGraphicsApplication, previous_result_ptr);
previous_result_ptr = NULL;
@ -452,7 +453,8 @@ void *CScreensaver::DataManagementProc() {
if (last_change_time && ((dtime() - last_change_time) > GFX_CHANGE_PERIOD)) {
if (count_active_graphic_apps(results, previous_result_ptr) > 0) {
if (previous_result_ptr) {
BOINCTRACE(_T("CScreensaver::DataManagementProc - time to change: %s\n"), previous_result.name.c_str());
BOINCTRACE(_T("CScreensaver::DataManagementProc - time to change: %s / %s\n"),
previous_result.name.c_str(), previous_result.graphics_exec_path.c_str());
}
terminate_screensaver(m_hGraphicsApplication, graphics_app_result_ptr);
if (m_hGraphicsApplication == 0) {
@ -491,7 +493,8 @@ void *CScreensaver::DataManagementProc() {
previous_result = *graphics_app_result_ptr;
previous_result_ptr = &previous_result;
if (previous_result_ptr) {
BOINCTRACE(_T("CScreensaver::DataManagementProc - launching %s\n"), previous_result.name.c_str());
BOINCTRACE(_T("CScreensaver::DataManagementProc - launching %s\n"),
previous_result.graphics_exec_path.c_str());
}
}
} else {

View File

@ -183,6 +183,7 @@
DD67F8140ADB9DD000B0015E /* wxPieCtrl.cpp in Sources */ = {isa = PBXBuildFile; fileRef = DD40E75D0ADB87BC00214518 /* wxPieCtrl.cpp */; };
DD6802300E701ACD0067D009 /* cert_sig.C in Sources */ = {isa = PBXBuildFile; fileRef = DD68022E0E701ACD0067D009 /* cert_sig.C */; };
DD6802310E701ACD0067D009 /* cert_sig.C in Sources */ = {isa = PBXBuildFile; fileRef = DD68022E0E701ACD0067D009 /* cert_sig.C */; };
DD6803440E70A61D0067D009 /* diagnostics.C in Sources */ = {isa = PBXBuildFile; fileRef = DD344BA207C5AE5A0043025C /* diagnostics.C */; };
DD69FEF508416C6B00C01361 /* gui_rpc_client.C in Sources */ = {isa = PBXBuildFile; fileRef = DD81C5CC07C5D7D90098A04D /* gui_rpc_client.C */; };
DD69FEF708416C9A00C01361 /* boinc_cmd.C in Sources */ = {isa = PBXBuildFile; fileRef = DD69FEF608416C9A00C01361 /* boinc_cmd.C */; };
DD69FF0C084171CF00C01361 /* network.C in Sources */ = {isa = PBXBuildFile; fileRef = DD6D0A8507E9A61B007F882B /* network.C */; };
@ -2406,6 +2407,7 @@
DDB873990C85072500E0DE1F /* mac_saver_module.cpp in Sources */,
DDB8739A0C85072500E0DE1F /* Mac_Saver_ModuleView.m in Sources */,
DD7AEB4A0C87CE1300AC3B5C /* screensaver.cpp in Sources */,
DD6803440E70A61D0067D009 /* diagnostics.C in Sources */,
);
runOnlyForDeploymentPostprocessing = 0;
};
@ -4266,11 +4268,22 @@
OTHER_CFLAGS = (
"-DMAC_OS_X_VERSION_MAX_ALLOWED=1040",
"-D_THREAD_SAFE",
"-D_DEBUG",
"-include",
../clientgui/mac/config.h,
);
OTHER_CFLAGS_i386 = "-DMAC_OS_X_VERSION_MAX_ALLOWED=1040 -D_THREAD_SAFE -include ../clientgui/mac/config.h";
OTHER_CFLAGS_ppc = "-DMAC_OS_X_VERSION_MAX_ALLOWED=1030 -D_THREAD_SAFE -include ../clientgui/mac/config.h";
"OTHER_CFLAGS[arch=x86_64]" = (
"-DMAC_OS_X_VERSION_MAX_ALLOWED=1050",
"-D_THREAD_SAFE",
"-DDEBUG",
"-D_DEBUG",
"-DSANDBOX",
"-include",
../clientgui/mac/config.h,
);
OTHER_CFLAGS_i386 = "-DMAC_OS_X_VERSION_MAX_ALLOWED=1040 -D_THREAD_SAFE -D_DEBUG -include ../clientgui/mac/config.h";
OTHER_CFLAGS_ppc = "-DMAC_OS_X_VERSION_MAX_ALLOWED=1030 -D_THREAD_SAFE -D_DEBUG -include ../clientgui/mac/config.h";
OTHER_CFLAGS_x86_64 = "-DMAC_OS_X_VERSION_MAX_ALLOWED=1050 -D_THREAD_SAFE -D_DEBUG -DSANDBOX -include ../clientgui/mac/config.h";
OTHER_LDFLAGS = (
"-framework",
Foundation,