aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llappviewerwin32.cpp
diff options
context:
space:
mode:
authorJacek Antonelli2008-08-15 23:45:42 -0500
committerJacek Antonelli2008-08-15 23:45:42 -0500
commitce28e056c20bf2723f565bbf464b87781ec248a2 (patch)
treeef7b0501c4de4b631a916305cbc2a5fdc125e52d /linden/indra/newview/llappviewerwin32.cpp
parentSecond Life viewer sources 1.19.1.4b (diff)
downloadmeta-impy-ce28e056c20bf2723f565bbf464b87781ec248a2.zip
meta-impy-ce28e056c20bf2723f565bbf464b87781ec248a2.tar.gz
meta-impy-ce28e056c20bf2723f565bbf464b87781ec248a2.tar.bz2
meta-impy-ce28e056c20bf2723f565bbf464b87781ec248a2.tar.xz
Second Life viewer sources 1.20.2
Diffstat (limited to 'linden/indra/newview/llappviewerwin32.cpp')
-rw-r--r--linden/indra/newview/llappviewerwin32.cpp92
1 files changed, 27 insertions, 65 deletions
diff --git a/linden/indra/newview/llappviewerwin32.cpp b/linden/indra/newview/llappviewerwin32.cpp
index b665cb4..a2d89a3 100644
--- a/linden/indra/newview/llappviewerwin32.cpp
+++ b/linden/indra/newview/llappviewerwin32.cpp
@@ -55,41 +55,13 @@
55#include "llviewernetwork.h" 55#include "llviewernetwork.h"
56#include "llmd5.h" 56#include "llmd5.h"
57 57
58void fill_args(int& argc, char** argv, const S32 max_args, LPSTR cmd_line) 58#include "llcommandlineparser.h"
59{
60 char *token = NULL;
61 if( cmd_line[0] == '\"' )
62 {
63 // Exe name is enclosed in quotes
64 token = strtok( cmd_line, "\"" );
65 argv[argc++] = token;
66 token = strtok( NULL, " \t," );
67 }
68 else
69 {
70 // Exe name is not enclosed in quotes
71 token = strtok( cmd_line, " \t," );
72 }
73 59
74 while( (token != NULL) && (argc < max_args) )
75 {
76 argv[argc++] = token;
77 /* Get next token: */
78 if (*(token + strlen(token) + 1) == '\"') /* Flawfinder: ignore*/
79 {
80 token = strtok( NULL, "\"");
81 }
82 else
83 {
84 token = strtok( NULL, " \t," );
85 }
86 }
87}
88
89// *NOTE:Mani - this code is stolen from LLApp, where its never actually used.
90LONG WINAPI viewer_windows_exception_handler(struct _EXCEPTION_POINTERS *exception_infop) 60LONG WINAPI viewer_windows_exception_handler(struct _EXCEPTION_POINTERS *exception_infop)
91{ 61{
92 // Translate the signals/exceptions into cross-platform stuff 62 // *NOTE:Mani - this code is stolen from LLApp, where its never actually used.
63
64 // Translate the signals/exceptions into cross-platform stuff
93 // Windows implementation 65 // Windows implementation
94 llinfos << "Entering Windows Exception Handler..." << llendl; 66 llinfos << "Entering Windows Exception Handler..." << llendl;
95 67
@@ -144,21 +116,7 @@ int APIENTRY WINMAIN(HINSTANCE hInstance,
144 // *FIX: global 116 // *FIX: global
145 gIconResource = MAKEINTRESOURCE(IDI_LL_ICON); 117 gIconResource = MAKEINTRESOURCE(IDI_LL_ICON);
146 118
147 // In Win32, we need to generate argc and argv ourselves... 119 LLAppViewerWin32* viewer_app_ptr = new LLAppViewerWin32(lpCmdLine);
148 // Note: GetCommandLine() returns a potentially return a LPTSTR
149 // which can resolve to a LPWSTR (unicode string).
150 // (That's why it's different from lpCmdLine which is a LPSTR.)
151 // We don't currently do unicode, so call the non-unicode version
152 // directly.
153 LPSTR cmd_line_including_exe_name = GetCommandLineA();
154
155 const S32 MAX_ARGS = 100;
156 int argc = 0;
157 char* argv[MAX_ARGS]; /* Flawfinder: ignore */
158
159 fill_args(argc, argv, MAX_ARGS, cmd_line_including_exe_name);
160
161 LLAppViewerWin32* viewer_app_ptr = new LLAppViewerWin32();
162 120
163 // *FIX:Mani This method is poorly named, since the exception 121 // *FIX:Mani This method is poorly named, since the exception
164 // is now handled by LLApp. 122 // is now handled by LLApp.
@@ -180,13 +138,6 @@ int APIENTRY WINMAIN(HINSTANCE hInstance,
180 138
181 viewer_app_ptr->setErrorHandler(LLAppViewer::handleViewerCrash); 139 viewer_app_ptr->setErrorHandler(LLAppViewer::handleViewerCrash);
182 140
183 ok = viewer_app_ptr->tempStoreCommandOptions(argc, argv);
184 if(!ok)
185 {
186 llwarns << "Unable to parse command line." << llendl;
187 return -1;
188 }
189
190 ok = viewer_app_ptr->init(); 141 ok = viewer_app_ptr->init();
191 if(!ok) 142 if(!ok)
192 { 143 {
@@ -308,7 +259,8 @@ void create_console()
308 setvbuf( stderr, NULL, _IONBF, 0 ); 259 setvbuf( stderr, NULL, _IONBF, 0 );
309} 260}
310 261
311LLAppViewerWin32::LLAppViewerWin32() 262LLAppViewerWin32::LLAppViewerWin32(const char* cmd_line) :
263 mCmdLine(cmd_line)
312{ 264{
313} 265}
314 266
@@ -339,15 +291,11 @@ bool LLAppViewerWin32::cleanup()
339 return result; 291 return result;
340} 292}
341 293
342bool LLAppViewerWin32::initWindow() 294void LLAppViewerWin32::initConsole()
343{ 295{
344 // pop up debug console if necessary 296 // pop up debug console
345 if (gUseConsole && gSavedSettings.getBOOL("ShowConsoleWindow")) 297 create_console();
346 { 298 return LLAppViewer::initConsole();
347 create_console();
348 }
349
350 return LLAppViewer::initWindow();
351} 299}
352 300
353void write_debug_dx(const char* str) 301void write_debug_dx(const char* str)
@@ -368,10 +316,14 @@ bool LLAppViewerWin32::initHardwareTest()
368 // Do driver verification and initialization based on DirectX 316 // Do driver verification and initialization based on DirectX
369 // hardware polling and driver versions 317 // hardware polling and driver versions
370 // 318 //
371 if (gProbeHardware) 319 if (FALSE == gSavedSettings.getBOOL("NoHardwareProbe"))
372 { 320 {
373 BOOL vram_only = !gSavedSettings.getBOOL("ProbeHardwareOnStartup"); 321 BOOL vram_only = !gSavedSettings.getBOOL("ProbeHardwareOnStartup");
374 322
323 // per DEV-11631 - disable hardware probing for everything
324 // but vram.
325 vram_only = TRUE;
326
375 LLSplashScreen::update("Detecting hardware..."); 327 LLSplashScreen::update("Detecting hardware...");
376 328
377 llinfos << "Attempting to poll DirectX for hardware info" << llendl; 329 llinfos << "Attempting to poll DirectX for hardware info" << llendl;
@@ -431,6 +383,16 @@ bool LLAppViewerWin32::initHardwareTest()
431 return true; 383 return true;
432} 384}
433 385
386bool LLAppViewerWin32::initParseCommandLine(LLCommandLineParser& clp)
387{
388 return clp.parseCommandLineString(mCmdLine);
389}
390
391void LLAppViewerWin32::handleSyncCrashTrace()
392{
393 // do nothing
394}
395
434void LLAppViewerWin32::handleCrashReporting() 396void LLAppViewerWin32::handleCrashReporting()
435{ 397{
436 // Windows only behaivor. Spawn win crash reporter. 398 // Windows only behaivor. Spawn win crash reporter.
@@ -486,4 +448,4 @@ std::string LLAppViewerWin32::generateSerialNumber()
486 llwarns << "GetVolumeInformation failed" << llendl; 448 llwarns << "GetVolumeInformation failed" << llendl;
487 } 449 }
488 return serial_md5; 450 return serial_md5;
489} \ No newline at end of file 451}