SCR: Enable V6 style applications, screensaver is no longer

compatible with v5 style graphics.
    
    clientscr/
        screensaver.cpp, .h
        screensaver_win.cpp, .h

svn path=/trunk/boinc/; revision=13318
This commit is contained in:
Rom Walton 2007-08-14 17:23:30 +00:00
parent 539aa0f1e8
commit f841b17404
7 changed files with 236 additions and 222 deletions

View File

@ -7805,3 +7805,11 @@ Charlie 14 Aug 2007
boinc_logo.xpm
lib/
filesys.C, h
Rom 14 Aug 2007
SCR: Enable V6 style applications, screensaver is no longer
compatible with v5 style graphics.
clientscr/
screensaver.cpp, .h
screensaver_win.cpp, .h

View File

@ -235,7 +235,7 @@ void CViewWork::OnWorkShowGraphics( wxCommandEvent& WXUNUSED(event) ) {
if (!result->graphics_exec_path.empty()) {
// V6 Graphics
char* argv[2];
argv[0] = "graphics";
argv[0] = "--graphics";
argv[1] = 0;
#ifdef __WXMSW__
HANDLE id;

43
clientscr/screensaver.cpp Normal file
View File

@ -0,0 +1,43 @@
// Berkeley Open Infrastructure for Network Computing
// http://boinc.berkeley.edu
// Copyright (C) 2005 University of California
//
// 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.
//
// 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.
//
// 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
//
#ifdef _WIN32
#include "boinc_win.h"
#endif
#include "diagnostics.h"
#include "common_defs.h"
#include "util.h"
#include "gui_rpc_client.h"
#include "screensaver.h"
// Choose a random graphics application out of the vector.
// NOTE: Right now it just selects the first graphics app
// found.
RESULT* random_graphics_app(RESULTS& results) {
for (unsigned i=0; i < results.results.size(); i++) {
if (results.results[i]->graphics_exec_path.size() > 0) {
return results.results[i];
}
}
return NULL;
}

28
clientscr/screensaver.h Normal file
View File

@ -0,0 +1,28 @@
// Berkeley Open Infrastructure for Network Computing
// http://boinc.berkeley.edu
// Copyright (C) 2005 University of California
//
// 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.
//
// 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.
//
// 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
//
#ifndef __SCREENSAVER_H__
#define __SCREENSAVER_H__
// Choose a ramdom graphics application from the vector that
// was passed in.
extern RESULT* random_graphics_app(RESULTS& results);
#endif

View File

@ -35,6 +35,8 @@
#include "diagnostics.h"
#include "common_defs.h"
#include "util.h"
#include "gui_rpc_client.h"
#include "screensaver.h"
#include "screensaver_win.h"
#ifdef _DEBUG
@ -175,12 +177,13 @@ CScreensaver::CScreensaver() {
LoadString(NULL, IDS_DESCRIPTION, m_strWindowTitle, 200);
m_bPaintingInitialized = FALSE;
m_bCoreNotified = FALSE;
m_bResetCoreState = TRUE;
m_iStatus = 0;
m_dwBlankScreen = 0;
m_dwBlankTime = 0;
m_hDataManagementThread = NULL;
m_hGraphicsApplication = NULL;
m_bScreensaverStarted = FALSE;
m_bResetCoreState = TRUE;
m_bBOINCConfigChecked = FALSE;
m_bBOINCStartupConfigured = FALSE;
@ -403,9 +406,9 @@ SaverMode CScreensaver::ParseCommandLine(TCHAR* pstrCommandLine) {
}
if (isdigit(*pstrCommandLine)) {
#ifdef _WIN64
m_hWndParent = HWND(_atoi64(pstrCommandLine));
m_hWndParent = (HWND)_atoi64(pstrCommandLine);
#else
m_hWndParent = HWND(_ttol(pstrCommandLine));
m_hWndParent = (HWND)_ttol(pstrCommandLine);
#endif
} else {
m_hWndParent = NULL;
@ -425,9 +428,9 @@ SaverMode CScreensaver::ParseCommandLine(TCHAR* pstrCommandLine) {
}
if (isdigit(*pstrCommandLine)) {
#ifdef _WIN64
m_hWndParent = HWND(_atoi64(pstrCommandLine));
m_hWndParent = (HWND)_atoi64(pstrCommandLine);
#else
m_hWndParent = HWND(_ttol(pstrCommandLine));
m_hWndParent = (HWND)_ttol(pstrCommandLine);
#endif
}
return sm_preview;
@ -441,9 +444,9 @@ SaverMode CScreensaver::ParseCommandLine(TCHAR* pstrCommandLine) {
}
if (isdigit(*pstrCommandLine)) {
#ifdef _WIN64
m_hWndParent = HWND(_atoi64(pstrCommandLine));
m_hWndParent = (HWND)_atoi64(pstrCommandLine);
#else
m_hWndParent = HWND(_ttol(pstrCommandLine));
m_hWndParent = (HWND)_ttol(pstrCommandLine);
#endif
}
return sm_passwordchange;
@ -869,8 +872,8 @@ VOID CScreensaver::UpdateErrorBoxText() {
bool bIsActive = false;
bool bIsExecuting = false;
bool bIsDownloaded = false;
int iResultCount = 0;
int iIndex = 0;
size_t iResultCount = 0;
size_t iIndex = 0;
// Load error string
@ -997,9 +1000,7 @@ BOOL CScreensaver::DestoryDataManagementThread() {
// to the user
//
DWORD WINAPI CScreensaver::DataManagementProc() {
BOOL bErrorMode;
BOOL bForegroundWindowIsScreensaver;
HRESULT hrError;
HWND hwndBOINCGraphicsWindow = NULL;
HWND hwndForeWindow = NULL;
HWND hwndForeParent = NULL;
@ -1017,11 +1018,11 @@ DWORD WINAPI CScreensaver::DataManagementProc() {
while(1) {
bScreenSaverStarting = (10 >= (time(0) - tThreadCreateTime));
BOINCTRACE(_T("CScreensaver::DataManagementProc - Start Status = '%d', CoreNotified = '%d', ErrorMode = '%d', ErrorCode = '%x'\n"), m_iStatus, m_bCoreNotified, m_bErrorMode, m_hrError);
BOINCTRACE(_T("CScreensaver::DataManagementProc - ErrorMode = '%d', ErrorCode = '%x'\n"), m_bErrorMode, m_hrError);
// Lets try and get the current state of the CC
if (m_bResetCoreState && m_bCoreNotified) {
if (m_bResetCoreState) {
iReturnValue = rpc.get_state(state);
if (0 == iReturnValue) {
m_bResetCoreState = FALSE;
@ -1031,14 +1032,13 @@ DWORD WINAPI CScreensaver::DataManagementProc() {
}
iReturnValue = rpc.get_screensaver_mode(m_iStatus);
BOINCTRACE(_T("CScreensaver::DataManagementProc - get_screensaver_mode iReturnValue = '%d'\n"), iReturnValue);
iReturnValue = rpc.get_results(results);
BOINCTRACE(_T("CScreensaver::DataManagementProc - get_results iReturnValue = '%d'\n"), iReturnValue);
if (0 != iReturnValue) {
// Attempt to reinitialize the RPC client and state
rpc.close();
rpc.init(NULL);
m_bResetCoreState = TRUE;
m_bCoreNotified = FALSE;
if (!m_bBOINCConfigChecked) {
m_bBOINCConfigChecked = TRUE;
@ -1054,10 +1054,53 @@ DWORD WINAPI CScreensaver::DataManagementProc() {
}
} else {
// Reset the error state.
SetError(FALSE, 0);
if (m_bCoreNotified) {
switch (m_iStatus) {
case SS_STATUS_ENABLED:
// Start the screensaver if it hasn't been started already.
if (!m_bScreensaverStarted) {
// Choose a random graphics application to start.
RESULT* rp = random_graphics_app(results);
if (rp) {
int retval = 0;
char* argv[2];
argv[0] = "--fullscreen";
argv[1] = 0;
retval = run_program(
rp->slot_path.c_str(),
rp->graphics_exec_path.c_str(),
1,
argv,
0,
m_hGraphicsApplication
);
if (!retval) {
m_bScreensaverStarted = TRUE;
}
} else {
if (state.projects.size() == 0) {
// We are not attached to any projects
SetError(TRUE, SCRAPPERR_BOINCNOPROJECTSDETECTED);
} else if (results.results.size() == 0) {
// We currently do not have any applications to run
SetError(TRUE, SCRAPPERR_BOINCNOAPPSEXECUTING);
} else {
// We currently do not have any graphics capable application
SetError(TRUE, SCRAPPERR_BOINCNOGRAPHICSAPPSEXECUTING);
}
}
} else {
// Is the graphics app still running?
DWORD dwStatus;
GetExitCodeProcess(m_hGraphicsApplication, &dwStatus);
if (dwStatus != STILL_ACTIVE) {
// Something has happened to the previously selected screensaver
// application. Start a different one.
m_bScreensaverStarted = FALSE;
} else {
// When running in screensaver mode the only two valid conditions for z-order
// is that either the screensaver or graphics application is the foreground
// application. If this is not true, then blow out of the screensaver.
@ -1137,48 +1180,16 @@ DWORD WINAPI CScreensaver::DataManagementProc() {
// screensaver mode.
BOINCTRACE(_T("CScreensaver::DataManagementProc - Unknown foreground window detected, shutdown the screensaver.\n"));
SetError(TRUE, SCRAPPERR_BOINCSHUTDOWNEVENT);
kill_program(m_hGraphicsApplication);
SendMessage(m_Monitors[0].hWnd, WM_INTERRUPTSAVER, NULL, NULL);
}
}
break;
case SS_STATUS_BLANKED:
break;
case SS_STATUS_BOINCSUSPENDED:
SetError(TRUE, SCRAPPERR_BOINCSUSPENDED);
break;
case SS_STATUS_NOAPPSEXECUTING:
SetError(TRUE, SCRAPPERR_BOINCNOAPPSEXECUTING);
break;
case SS_STATUS_NOPROJECTSDETECTED:
SetError(TRUE, SCRAPPERR_BOINCNOPROJECTSDETECTED);
break;
case SS_STATUS_DAEMONALLOWSNOGRAPHICS:
SetError(TRUE, SCRAPPERR_DAEMONALLOWSNOGRAPHICS);
break;
case SS_STATUS_NOGRAPHICSAPPSEXECUTING:
SetError(TRUE, SCRAPPERR_BOINCNOGRAPHICSAPPSEXECUTING);
break;
}
}
}
GetError(bErrorMode, hrError, NULL, 0);
if (SS_STATUS_QUIT == m_iStatus && m_bCoreNotified) {
BOINCTRACE(_T("CScreensaver::DataManagementProc - Shutdown BOINC Screensaver\n"));
SendMessage(m_Monitors[0].hWnd, WM_INTERRUPTSAVER, NULL, NULL);
} else {
if (!bErrorMode && !m_bCoreNotified) {
BOINCTRACE(_T("CScreensaver::DataManagementProc - Startup BOINC Screensaver\n"));
StartupBOINC();
}
}
BOINCTRACE(_T("CScreensaver::SaverProc - End Status = '%d', CoreNotified = '%d', ErrorMode = '%d', ErrorCode = '%x'\n"), m_iStatus, m_bCoreNotified, m_bErrorMode, m_hrError);
if (bScreenSaverStarting || (SS_STATUS_ENABLED != m_iStatus)) {
BOINCTRACE(_T("CScreensaver::SaverProc - ErrorMode = '%d', ErrorCode = '%x'\n"), m_bErrorMode, m_hrError);
Sleep(1000);
} else {
Sleep(10000);
}
}
}
@ -1195,79 +1206,6 @@ DWORD WINAPI CScreensaver::DataManagementProcStub(LPVOID UNUSED(lpParam)) {
// Notifies BOINC that it has to start the screensaver in full screen mode.
//
VOID CScreensaver::StartupBOINC() {
if (m_SaverMode != sm_preview) {
if ((NULL != m_Monitors[0].hWnd) && (m_bCoreNotified == FALSE)) {
DISPLAY_INFO di;
BOOL bReturnValue;
int iReturnValue;
if (!m_bIs9x) {
// Retrieve the current window station and desktop names
bReturnValue = GetUserObjectInformation(
GetProcessWindowStation(),
UOI_NAME,
di.window_station,
sizeof(di.window_station),
NULL
);
if (!bReturnValue) {
BOINCTRACE(_T("Failed to retrieve the current window station.\n"));
}
bReturnValue = GetUserObjectInformation(
GetThreadDesktop(GetCurrentThreadId()),
UOI_NAME,
di.desktop,
sizeof(di.desktop),
NULL
);
if (!bReturnValue) {
BOINCTRACE(_T("Failed to retrieve the current desktop.\n"));
}
}
// Tell the boinc client to start the screen saver
BOINCTRACE(_T("CScreensaver::StartupBOINC - Calling set_screensaver_mode - WindowStation = '%s', Desktop = '%s', BlankScreen = '%d', BlankTime = '%d'.\n"), di.window_station, di.desktop, m_dwBlankScreen, m_dwBlankTime);
if (0 == m_dwBlankScreen) {
iReturnValue = rpc.set_screensaver_mode(true, 0, di);
} else {
iReturnValue = rpc.set_screensaver_mode(true, m_dwBlankTime, di);
}
BOINCTRACE(_T("CScreensaver::StartupBOINC - set_screensaver_mode iReturnValue = '%d'\n"), iReturnValue);
// We have now notified the boinc client
if (0 == iReturnValue) {
m_bCoreNotified = TRUE;
} else {
SetError(TRUE, SCRAPPERR_BOINCNOTDETECTED);
}
}
}
}
// Notifies BOINC that it has to lose the screensaver.
//
VOID CScreensaver::ShutdownBOINC() {
if (m_bCoreNotified) {
DISPLAY_INFO di;
// Tell the boinc client to stop the screen saver
rpc.set_screensaver_mode(false, 0.0, di);
// We have now notified the boinc client
m_bCoreNotified = FALSE;
}
}
// Register and create the appropriate window(s)
//
HRESULT CScreensaver::CreateSaverWindow() {
@ -1637,8 +1575,6 @@ VOID CScreensaver::ShutdownSaver() {
SystemParametersInfo(SPI_SCREENSAVERRUNNING, FALSE, &bUnused, 0);
}
ShutdownBOINC();
// Post message to drop out of message loop
// This can be called from the data management thread, so specifically
// lookup and post to the primary window instead of calling PostQuitMessage
@ -1841,7 +1777,7 @@ VOID CScreensaver::DoPaint(HWND hwnd, HDC hdc, LPPAINTSTRUCT lpps) {
// If the screensaver has switched to a blanked state or not in an error mode,
// we should exit here so the screen has been erased to black.
if ((SS_STATUS_BLANKED == m_iStatus) || !bErrorMode) {
if (!bErrorMode) {
return;
}

View File

@ -4,11 +4,8 @@
// Microsoft Knowledge Base Article - 79212
//
#ifndef _BOINC_H
#define _BOINC_H
#include "gui_rpc_client.h"
#ifndef _SCREENSAVER_WIN_H
#define _SCREENSAVER_WIN_H
//-----------------------------------------------------------------------------
// Error codes
@ -177,17 +174,14 @@ protected:
DWORD WINAPI DataManagementProc();
static DWORD WINAPI DataManagementProcStub( LPVOID lpParam );
VOID StartupBOINC();
VOID ShutdownBOINC();
RPC_CLIENT rpc;
CC_STATE state;
RESULTS results;
HANDLE m_hDataManagementThread;
BOOL m_bCoreNotified;
HANDLE m_hGraphicsApplication;
BOOL m_bScreensaverStarted;
BOOL m_bResetCoreState;
int m_iStatus;
//

View File

@ -63,9 +63,8 @@
ObjectFile="$(IntDir)\"
ProgramDataBaseFileName="$(IntDir)\vc80.pdb"
BrowseInformation="1"
WarningLevel="4"
WarningLevel="3"
SuppressStartupBanner="true"
Detect64BitPortabilityProblems="true"
DebugInformationFormat="3"
CompileAs="2"
DisableSpecificWarnings="4127;4702;4244"
@ -282,9 +281,8 @@
AssemblerListingLocation=""
ObjectFile="$(IntDir)\"
ProgramDataBaseFileName="$(IntDir)\vc80.pdb"
WarningLevel="4"
WarningLevel="3"
SuppressStartupBanner="true"
Detect64BitPortabilityProblems="true"
DebugInformationFormat="3"
CompileAs="2"
DisableSpecificWarnings="4127;4702;4244"
@ -498,9 +496,8 @@
AssemblerListingLocation=""
ObjectFile="$(IntDir)\"
ProgramDataBaseFileName="$(IntDir)\vc80.pdb"
WarningLevel="4"
WarningLevel="3"
SuppressStartupBanner="true"
Detect64BitPortabilityProblems="true"
DebugInformationFormat="3"
CompileAs="2"
DisableSpecificWarnings="4127;4702;4244"
@ -730,6 +727,10 @@
RelativePath="..\lib\prefs.C"
>
</File>
<File
RelativePath="..\clientscr\screensaver.cpp"
>
</File>
<File
RelativePath="..\clientscr\screensaver_win.cpp"
>
@ -807,6 +808,10 @@
RelativePath="..\lib\prefs.h"
>
</File>
<File
RelativePath="..\clientscr\screensaver.h"
>
</File>
<File
RelativePath="..\clientscr\screensaver_win.h"
>