aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llwindow
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--linden/indra/llwindow/llwindow_vc8.vcproj240
-rw-r--r--linden/indra/llwindow/llwindowsdl.cpp288
-rw-r--r--linden/indra/llwindow/llwindowwin32.cpp53
-rw-r--r--linden/indra/llwindow/llwindowwin32.h2
4 files changed, 404 insertions, 179 deletions
diff --git a/linden/indra/llwindow/llwindow_vc8.vcproj b/linden/indra/llwindow/llwindow_vc8.vcproj
index b04477f..4d6bbcb 100644
--- a/linden/indra/llwindow/llwindow_vc8.vcproj
+++ b/linden/indra/llwindow/llwindow_vc8.vcproj
@@ -4,6 +4,7 @@
4 Version="8.00" 4 Version="8.00"
5 Name="llwindow" 5 Name="llwindow"
6 ProjectGUID="{B5B53617-416F-404A-BF10-22EBCCA0E4FB}" 6 ProjectGUID="{B5B53617-416F-404A-BF10-22EBCCA0E4FB}"
7 RootNamespace="llwindow"
7 Keyword="Win32Proj" 8 Keyword="Win32Proj"
8 > 9 >
9 <Platforms> 10 <Platforms>
@@ -40,17 +41,15 @@
40 <Tool 41 <Tool
41 Name="VCCLCompilerTool" 42 Name="VCCLCompilerTool"
42 Optimization="0" 43 Optimization="0"
43 AdditionalIncludeDirectories="..\llcommon;..\llmath;..\llxml;..\llvfs;..\llmessage;..\llscene;..\llimage;..\..\libraries\i686-win32\include;..\..\libraries\include\" 44 AdditionalIncludeDirectories="..\llcommon;..\llmath;..\llxml;..\llvfs;..\llmessage;..\llscene;..\llimage;&quot;..\..\libraries\i686-win32\include&quot;;..\..\libraries\include\;Logitech_LCD;Logitech_LCD\LCDUI"
44 PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_DEBUG" 45 PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;LL_DEBUG"
45 MinimalRebuild="true" 46 MinimalRebuild="true"
46 BasicRuntimeChecks="3" 47 BasicRuntimeChecks="3"
47 RuntimeLibrary="1" 48 RuntimeLibrary="1"
48 StructMemberAlignment="4" 49 StructMemberAlignment="4"
49 TreatWChar_tAsBuiltInType="false"
50 ForceConformanceInForLoopScope="true" 50 ForceConformanceInForLoopScope="true"
51 UsePrecompiledHeader="0" 51 UsePrecompiledHeader="0"
52 WarningLevel="3" 52 WarningLevel="3"
53 WarnAsError="true"
54 Detect64BitPortabilityProblems="false" 53 Detect64BitPortabilityProblems="false"
55 DebugInformationFormat="4" 54 DebugInformationFormat="4"
56 /> 55 />
@@ -108,16 +107,12 @@
108 /> 107 />
109 <Tool 108 <Tool
110 Name="VCCLCompilerTool" 109 Name="VCCLCompilerTool"
111 AdditionalIncludeDirectories="..\llcommon;..\llmath;..\llxml;..\llvfs;..\llmessage;..\llscene;..\llimage;..\..\libraries\i686-win32\include;..\..\libraries\include\" 110 AdditionalIncludeDirectories="..\llcommon;..\llmath;..\llxml;..\llvfs;..\llmessage;..\llscene;..\llimage;&quot;..\..\libraries\i686-win32\include&quot;;..\..\libraries\include\;Logitech_LCD;Logitech_LCD\LCDUI"
112 PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" 111 PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE"
113 RuntimeLibrary="0"
114 StructMemberAlignment="0"
115 TreatWChar_tAsBuiltInType="false" 112 TreatWChar_tAsBuiltInType="false"
116 ForceConformanceInForLoopScope="true" 113 ForceConformanceInForLoopScope="true"
117 UsePrecompiledHeader="0"
118 WarningLevel="3" 114 WarningLevel="3"
119 WarnAsError="true" 115 WarnAsError="true"
120 Detect64BitPortabilityProblems="false"
121 DebugInformationFormat="3" 116 DebugInformationFormat="3"
122 /> 117 />
123 <Tool 118 <Tool
@@ -175,8 +170,8 @@
175 <Tool 170 <Tool
176 Name="VCCLCompilerTool" 171 Name="VCCLCompilerTool"
177 Optimization="0" 172 Optimization="0"
178 AdditionalIncludeDirectories="..\llcommon;..\llmath;..\llxml;..\llvfs;..\llmessage;..\llscene;..\llimage;..\..\libraries\i686-win32\include;..\..\libraries\include\GLMESA;..\..\libraries\i686-win32\include;..\..\libraries\include\" 173 AdditionalIncludeDirectories="..\llcommon;..\llmath;..\llxml;..\llvfs;..\llmessage;..\llscene;..\llimage;&quot;..\..\libraries\i686-win32\include&quot;;..\..\libraries\include\GLMESA;..\..\libraries\include\;Logitech_LCD;Logitech_LCD\LCDUI"
179 PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_DEBUG;LL_MESA;LL_MESA_HEADLESS" 174 PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;LL_DEBUG;LL_MESA;LL_MESA_HEADLESS"
180 MinimalRebuild="true" 175 MinimalRebuild="true"
181 BasicRuntimeChecks="3" 176 BasicRuntimeChecks="3"
182 RuntimeLibrary="1" 177 RuntimeLibrary="1"
@@ -184,7 +179,6 @@
184 ForceConformanceInForLoopScope="true" 179 ForceConformanceInForLoopScope="true"
185 UsePrecompiledHeader="0" 180 UsePrecompiledHeader="0"
186 WarningLevel="3" 181 WarningLevel="3"
187 WarnAsError="true"
188 Detect64BitPortabilityProblems="false" 182 Detect64BitPortabilityProblems="false"
189 DebugInformationFormat="4" 183 DebugInformationFormat="4"
190 /> 184 />
@@ -243,15 +237,13 @@
243 <Tool 237 <Tool
244 Name="VCCLCompilerTool" 238 Name="VCCLCompilerTool"
245 Optimization="0" 239 Optimization="0"
246 AdditionalIncludeDirectories="..\llcommon;..\llmath;..\llxml;..\llvfs;..\llmessage;..\llscene;..\llimage;..\..\libraries\i686-win32\include;..\..\libraries\include\" 240 AdditionalIncludeDirectories="..\llcommon;..\llmath;..\llxml;..\llvfs;..\llmessage;..\llscene;..\llimage;&quot;..\..\libraries\i686-win32\include&quot;;..\..\libraries\include\;Logitech_LCD;Logitech_LCD\LCDUI"
247 PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" 241 PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE"
248 RuntimeLibrary="0" 242 RuntimeLibrary="0"
249 StructMemberAlignment="0" 243 StructMemberAlignment="0"
250 TreatWChar_tAsBuiltInType="false"
251 ForceConformanceInForLoopScope="true" 244 ForceConformanceInForLoopScope="true"
252 UsePrecompiledHeader="0" 245 UsePrecompiledHeader="0"
253 WarningLevel="3" 246 WarningLevel="3"
254 WarnAsError="true"
255 Detect64BitPortabilityProblems="false" 247 Detect64BitPortabilityProblems="false"
256 DebugInformationFormat="3" 248 DebugInformationFormat="3"
257 /> 249 />
@@ -386,6 +378,222 @@
386 UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}" 378 UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}"
387 > 379 >
388 </Filter> 380 </Filter>
381 <Filter
382 Name="Logitech LCD"
383 >
384 <Filter
385 Name="Header Files"
386 >
387 <File
388 RelativePath=".\Logitech_LCD\EZ_LCD.h"
389 >
390 </File>
391 <File
392 RelativePath=".\Logitech_LCD\EZ_LCD_Defines.h"
393 >
394 </File>
395 <File
396 RelativePath=".\Logitech_LCD\EZ_LCD_Page.h"
397 >
398 </File>
399 <File
400 RelativePath=".\Logitech_LCD\LCD.h"
401 >
402 </File>
403 <File
404 RelativePath=".\Logitech_LCD\lglcd.h"
405 >
406 </File>
407 </Filter>
408 <Filter
409 Name="Source Files"
410 >
411 <File
412 RelativePath=".\Logitech_LCD\EZ_LCD.cpp"
413 >
414 </File>
415 <File
416 RelativePath=".\Logitech_LCD\EZ_LCD_Page.cpp"
417 >
418 </File>
419 <File
420 RelativePath=".\Logitech_LCD\LCD.cpp"
421 >
422 </File>
423 </Filter>
424 <Filter
425 Name="SDK"
426 >
427 <Filter
428 Name="Header Files"
429 >
430 <File
431 RelativePath=".\Logitech_LCD\LCDUI\LCDAnimatedBitmap.h"
432 >
433 </File>
434 <File
435 RelativePath=".\Logitech_LCD\LCDUI\LCDBase.h"
436 >
437 </File>
438 <File
439 RelativePath=".\Logitech_LCD\LCDUI\LCDBitmap.h"
440 >
441 </File>
442 <File
443 RelativePath=".\Logitech_LCD\LCDUI\LCDCollection.h"
444 >
445 </File>
446 <File
447 RelativePath=".\Logitech_LCD\LCDUI\LCDGfx.h"
448 >
449 </File>
450 <File
451 RelativePath=".\Logitech_LCD\LCDUI\LCDIcon.h"
452 >
453 </File>
454 <File
455 RelativePath=".\Logitech_LCD\LCDUI\LCDManager.h"
456 >
457 </File>
458 <File
459 RelativePath=".\Logitech_LCD\LCDUI\LCDOutput.h"
460 >
461 </File>
462 <File
463 RelativePath=".\Logitech_LCD\LCDUI\LCDProgressBar.h"
464 >
465 </File>
466 <File
467 RelativePath=".\Logitech_LCD\LCDUI\LCDScrollingText.h"
468 >
469 </File>
470 <File
471 RelativePath=".\Logitech_LCD\LCDUI\LCDStreamingText.h"
472 >
473 </File>
474 <File
475 RelativePath=".\Logitech_LCD\LCDUI\LCDText.h"
476 >
477 </File>
478 </Filter>
479 <Filter
480 Name="Source Files"
481 >
482 <File
483 RelativePath=".\Logitech_LCD\LCDUI\LCDAnimatedBitmap.cpp"
484 >
485 </File>
486 <File
487 RelativePath=".\Logitech_LCD\LCDUI\LCDBase.cpp"
488 >
489 </File>
490 <File
491 RelativePath=".\Logitech_LCD\LCDUI\LCDBitmap.cpp"
492 >
493 </File>
494 <File
495 RelativePath=".\Logitech_LCD\LCDUI\LCDCollection.cpp"
496 >
497 </File>
498 <File
499 RelativePath=".\Logitech_LCD\LCDUI\LCDGfx.cpp"
500 >
501 </File>
502 <File
503 RelativePath=".\Logitech_LCD\LCDUI\LCDIcon.cpp"
504 >
505 </File>
506 <File
507 RelativePath=".\Logitech_LCD\LCDUI\LCDManager.cpp"
508 >
509 </File>
510 <File
511 RelativePath=".\Logitech_LCD\LCDUI\LCDOutput.cpp"
512 >
513 </File>
514 <File
515 RelativePath=".\Logitech_LCD\LCDUI\LCDProgressBar.cpp"
516 >
517 </File>
518 <File
519 RelativePath=".\Logitech_LCD\LCDUI\LCDScrollingText.cpp"
520 >
521 </File>
522 <File
523 RelativePath=".\Logitech_LCD\LCDUI\LCDStreamingText.cpp"
524 >
525 <FileConfiguration
526 Name="Debug|Win32"
527 >
528 <Tool
529 Name="VCCLCompilerTool"
530 WarningLevel="0"
531 />
532 </FileConfiguration>
533 <FileConfiguration
534 Name="Release|Win32"
535 >
536 <Tool
537 Name="VCCLCompilerTool"
538 WarningLevel="0"
539 />
540 </FileConfiguration>
541 <FileConfiguration
542 Name="DebugMesaHeadless|Win32"
543 >
544 <Tool
545 Name="VCCLCompilerTool"
546 WarningLevel="0"
547 />
548 </FileConfiguration>
549 <FileConfiguration
550 Name="ReleaseNoOpt|Win32"
551 >
552 <Tool
553 Name="VCCLCompilerTool"
554 WarningLevel="0"
555 />
556 </FileConfiguration>
557 </File>
558 <File
559 RelativePath=".\Logitech_LCD\LCDUI\LCDText.cpp"
560 >
561 <FileConfiguration
562 Name="Debug|Win32"
563 >
564 <Tool
565 Name="VCCLCompilerTool"
566 WarningLevel="0"
567 />
568 </FileConfiguration>
569 <FileConfiguration
570 Name="Release|Win32"
571 >
572 <Tool
573 Name="VCCLCompilerTool"
574 WarningLevel="0"
575 />
576 </FileConfiguration>
577 <FileConfiguration
578 Name="DebugMesaHeadless|Win32"
579 >
580 <Tool
581 Name="VCCLCompilerTool"
582 WarningLevel="0"
583 />
584 </FileConfiguration>
585 <FileConfiguration
586 Name="ReleaseNoOpt|Win32"
587 >
588 <Tool
589 Name="VCCLCompilerTool"
590 WarningLevel="0"
591 />
592 </FileConfiguration>
593 </File>
594 </Filter>
595 </Filter>
596 </Filter>
389 </Files> 597 </Files>
390 <Globals> 598 <Globals>
391 </Globals> 599 </Globals>
diff --git a/linden/indra/llwindow/llwindowsdl.cpp b/linden/indra/llwindow/llwindowsdl.cpp
index c375e32..f7b4071 100644
--- a/linden/indra/llwindow/llwindowsdl.cpp
+++ b/linden/indra/llwindow/llwindowsdl.cpp
@@ -1,6 +1,6 @@
1/** 1/**
2 * @file llwindowsdl.cpp 2 * @file llwindowsdl.cpp
3 * @brief Platform-dependent implementation of llwindow 3 * @brief SDL implementation of LLWindow class
4 * 4 *
5 * Copyright (c) 2001-2007, Linden Research, Inc. 5 * Copyright (c) 2001-2007, Linden Research, Inc.
6 * 6 *
@@ -55,12 +55,6 @@
55 55
56extern BOOL gDebugWindowProc; 56extern BOOL gDebugWindowProc;
57 57
58// culled from winuser.h
59//const S32 WHEEL_DELTA = 120; /* Value for rolling one detent */
60// On the Mac, the scroll wheel reports a delta of 1 for each detent.
61// There's also acceleration for faster scrolling, based on a slider in the system preferences.
62const S32 WHEEL_DELTA = 1; /* Value for rolling one detent */
63const S32 BITS_PER_PIXEL = 32;
64const S32 MAX_NUM_RESOLUTIONS = 32; 58const S32 MAX_NUM_RESOLUTIONS = 32;
65 59
66// 60//
@@ -74,37 +68,11 @@ const S32 MAX_NUM_RESOLUTIONS = 32;
74// TOFU HACK -- (*exactly* the same hack as LLWindowMacOSX for a similar 68// TOFU HACK -- (*exactly* the same hack as LLWindowMacOSX for a similar
75// set of reasons): Stash a pointer to the LLWindowSDL object here and 69// set of reasons): Stash a pointer to the LLWindowSDL object here and
76// maintain in the constructor and destructor. This assumes that there will 70// maintain in the constructor and destructor. This assumes that there will
77// be only one object of this class at any time. Hopefully this is true. 71// be only one object of this class at any time. Currently this is true.
78static LLWindowSDL *gWindowImplementation = NULL; 72static LLWindowSDL *gWindowImplementation = NULL;
79 73
80static BOOL was_fullscreen = FALSE; 74static BOOL was_fullscreen = FALSE;
81 75
82// Cross-platform bits:
83
84void show_window_creation_error(const char* title)
85{
86 llwarns << title << llendl;
87 shell_open( "help/window_creation_error.html");
88 /*
89 OSMessageBox(
90 "Second Life is unable to run because it can't set up your display.\n"
91 "We need to be able to make a 32-bit color window at 1024x768, with\n"
92 "an 8 bit alpha channel.\n"
93 "\n"
94 "First, be sure your monitor is set to True Color (32-bit) in\n"
95 "Start -> Control Panels -> Display -> Settings.\n"
96 "\n"
97 "Otherwise, this may be due to video card driver issues.\n"
98 "Please make sure you have the latest video card drivers installed.\n"
99 "ATI drivers are available at http://www.ati.com/\n"
100 "nVidia drivers are available at http://www.nvidia.com/\n"
101 "\n"
102 "If you continue to receive this message, contact customer service.",
103 title,
104 OSMB_OK);
105 */
106}
107
108 76
109void maybe_lock_display(void) 77void maybe_lock_display(void)
110{ 78{
@@ -275,7 +243,7 @@ LLWindowSDL::LLWindowSDL(char *title, S32 x, S32 y, S32 width,
275#endif // LL_GTK 243#endif // LL_GTK
276 244
277 // Get the original aspect ratio of the main device. 245 // Get the original aspect ratio of the main device.
278 mOriginalAspectRatio = 1024.0 / 768.0; // !!! FIXME //(double)CGDisplayPixelsWide(mDisplay) / (double)CGDisplayPixelsHigh(mDisplay); 246 mOriginalAspectRatio = 1024.0 / 768.0; // !!! *FIX: ? //(double)CGDisplayPixelsWide(mDisplay) / (double)CGDisplayPixelsHigh(mDisplay);
279 247
280 if (!title) 248 if (!title)
281 title = "SDL Window"; // *FIX: (???) 249 title = "SDL Window"; // *FIX: (???)
@@ -325,6 +293,105 @@ static SDL_Surface *Load_BMP_Resource(const char *basename)
325 return SDL_LoadBMP(path_buffer); 293 return SDL_LoadBMP(path_buffer);
326} 294}
327 295
296#if LL_X11
297// This is an XFree86/XOrg-specific hack for detecting the amount of Video RAM
298// on this machine. It works by searching /var/log/var/log/Xorg.?.log or
299// /var/log/XFree86.?.log for a ': VideoRAM: (%d+) kB' regex, where '?' is
300// the X11 display number derived from $DISPLAY
301static int x11_detect_VRAM_kb_fp(FILE *fp)
302{
303 const int line_buf_size = 1000;
304 char line_buf[line_buf_size];
305 while (fgets(line_buf, line_buf_size, fp))
306 {
307 //lldebugs << "XLOG: " << line_buf << llendl;
308
309 // Why the ad-hoc parser instead of using a regex? Our
310 // favourite regex implementation - libboost_regex - is
311 // quite a heavy and troublesome dependency for the client, so
312 // it seems a shame to introduce it for such a simple task.
313 const char part1_template[] = ": VideoRAM: ";
314 const char part2_template[] = " kB";
315 char *part1 = strstr(line_buf, part1_template);
316 if (part1) // found start of matching line
317 {
318 part1 = &part1[strlen(part1_template)]; // -> after
319 char *part2 = strstr(part1, part2_template);
320 if (part2) // found end of matching line
321 {
322 // now everything between part1 and part2 is
323 // supposed to be numeric, describing the
324 // number of kB of Video RAM supported
325 int rtn = 0;
326 for (; part1 < part2; ++part1)
327 {
328 //lldebugs << "kB" << *part1 << llendl;
329 if (*part1 < '0' || *part1 > '9')
330 {
331 // unexpected char, abort parse
332 rtn = 0;
333 break;
334 }
335 rtn *= 10;
336 rtn += (*part1) - '0';
337 }
338 if (rtn > 0)
339 {
340 // got the kB number. return it now.
341 return rtn;
342 }
343 }
344 }
345 }
346 return 0; // 'could not detect'
347}
348static int x11_detect_VRAM_kb()
349{
350 std::string x_log_location("/var/log/");
351 std::string fname;
352 int rtn = 0; // 'could not detect'
353 int display_num = 0;
354 FILE *fp;
355 char *display_env = getenv("DISPLAY"); // e.g. :0 or :0.0 or :1.0 etc
356 // parse DISPLAY number so we can go grab the right log file
357 if (display_env[0] == ':' &&
358 display_env[1] >= '0' && display_env[1] <= '9')
359 {
360 display_num = display_env[1] - '0';
361 }
362
363 // *TODO: we could be smarter and see which of Xorg/XFree86 has the
364 // freshest time-stamp.
365
366 // Try XOrg log first
367 fname = x_log_location;
368 fname += "Xorg.";
369 fname += ('0' + display_num);
370 fname += ".log";
371 fp = fopen(fname.c_str(), "r");
372 if (fp)
373 {
374 rtn = x11_detect_VRAM_kb_fp(fp);
375 fclose(fp);
376 }
377 // Try old XFree86 log otherwise
378 if (rtn == 0)
379 {
380 fname = x_log_location;
381 fname += "XFree86.";
382 fname += ('0' + display_num);
383 fname += ".log";
384 fp = fopen(fname.c_str(), "r");
385 if (fp)
386 {
387 rtn = x11_detect_VRAM_kb_fp(fp);
388 fclose(fp);
389 }
390 }
391 return rtn;
392}
393#endif // LL_X11
394
328BOOL LLWindowSDL::createContext(int x, int y, int width, int height, int bits, BOOL fullscreen, BOOL disable_vsync) 395BOOL LLWindowSDL::createContext(int x, int y, int width, int height, int bits, BOOL fullscreen, BOOL disable_vsync)
329{ 396{
330 //bool glneedsinit = false; 397 //bool glneedsinit = false;
@@ -511,67 +578,40 @@ BOOL LLWindowSDL::createContext(int x, int y, int width, int height, int bits, B
511 { 578 {
512 llinfos << "createContext: SKIPPING - !fullscreen, but +mWindow " << width << "x" << height << "x" << bits << llendl; 579 llinfos << "createContext: SKIPPING - !fullscreen, but +mWindow " << width << "x" << height << "x" << bits << llendl;
513 } 580 }
514 581
515 /*if (!load_all_glsyms(gllibname)) 582 // Detect video memory size.
516 { 583# if LL_X11
517 SDL_QuitSubSystem(SDL_INIT_VIDEO); 584 gGLManager.mVRAM = x11_detect_VRAM_kb() / 1024;
518 return FALSE;
519 }*/
520
521 gGLManager.mVRAM = videoInfo->video_mem / 1024;
522 if (gGLManager.mVRAM != 0) 585 if (gGLManager.mVRAM != 0)
523 { 586 {
524 llinfos << "Detected " << gGLManager.mVRAM << "MB VRAM." << llendl; 587 llinfos << "X11 log-parser detected " << gGLManager.mVRAM << "MB VRAM." << llendl;
525 } 588 } else
526 // If VRAM is not detected, that is handled later 589# endif // LL_X11
527 590 {
528#if 0 // *FIX: all video cards suck under Linux. :) 591 // fallback to letting SDL detect VRAM.
529 // Since we just created the context, it needs to be set up. 592 // note: I've not seen SDL's detection ever actually find
530 glNeedsInit = TRUE; 593 // VRAM != 0, but if SDL *does* detect it then that's a bonus.
531 if(glNeedsInit) 594 gGLManager.mVRAM = videoInfo->video_mem / 1024;
532 { 595 if (gGLManager.mVRAM != 0)
533 // Check for some explicitly unsupported cards.
534 const char* RENDERER = (const char*) glGetString(GL_RENDERER);
535
536 const char* CARD_LIST[] =
537 { "RAGE 128",
538 "RIVA TNT2",
539 "Intel 810",
540 "3Dfx/Voodoo3",
541 "Radeon 7000",
542 "Radeon 7200",
543 "Radeon 7500",
544 "Radeon DDR",
545 "Radeon VE",
546 "GDI Generic" };
547 const S32 CARD_COUNT = sizeof(CARD_LIST)/sizeof(char*);
548
549 // Future candidates:
550 // ProSavage/Twister
551 // SuperSavage
552
553 S32 i;
554 for (i = 0; i < CARD_COUNT; i++)
555 { 596 {
556 if (check_for_card(RENDERER, CARD_LIST[i])) 597 llinfos << "SDL detected " << gGLManager.mVRAM << "MB VRAM." << llendl;
557 {
558 close();
559 shell_open( "help/unsupported_card.html" );
560 return FALSE;
561 }
562 } 598 }
563 } 599 }
564#endif 600 // If VRAM is not detected, that is handled later
565 601
566 GLint depthBits, stencilBits, redBits, greenBits, blueBits, alphaBits; 602 // *TODO: Now would be an appropriate time to check for some
603 // explicitly unsupported cards.
604 //const char* RENDERER = (const char*) glGetString(GL_RENDERER);
567 605
568 glGetIntegerv(GL_RED_BITS, &redBits); 606 GLint depthBits, stencilBits, redBits, greenBits, blueBits, alphaBits;
569 glGetIntegerv(GL_GREEN_BITS, &greenBits);
570 glGetIntegerv(GL_BLUE_BITS, &blueBits);
571 glGetIntegerv(GL_ALPHA_BITS, &alphaBits);
572 glGetIntegerv(GL_DEPTH_BITS, &depthBits);
573 glGetIntegerv(GL_STENCIL_BITS, &stencilBits);
574 607
608 glGetIntegerv(GL_RED_BITS, &redBits);
609 glGetIntegerv(GL_GREEN_BITS, &greenBits);
610 glGetIntegerv(GL_BLUE_BITS, &blueBits);
611 glGetIntegerv(GL_ALPHA_BITS, &alphaBits);
612 glGetIntegerv(GL_DEPTH_BITS, &depthBits);
613 glGetIntegerv(GL_STENCIL_BITS, &stencilBits);
614
575 llinfos << "GL buffer:" << llendl 615 llinfos << "GL buffer:" << llendl
576 llinfos << " Red Bits " << S32(redBits) << llendl 616 llinfos << " Red Bits " << S32(redBits) << llendl
577 llinfos << " Green Bits " << S32(greenBits) << llendl 617 llinfos << " Green Bits " << S32(greenBits) << llendl
@@ -1022,7 +1062,9 @@ void LLWindowSDL::beforeDialog()
1022 { 1062 {
1023 // Everything that we/SDL asked for should happen before we 1063 // Everything that we/SDL asked for should happen before we
1024 // potentially hand control over to GTK. 1064 // potentially hand control over to GTK.
1065 maybe_lock_display();
1025 XSync(mSDL_Display, False); 1066 XSync(mSDL_Display, False);
1067 maybe_unlock_display();
1026 } 1068 }
1027#endif // LL_X11 1069#endif // LL_X11
1028 1070
@@ -1066,6 +1108,7 @@ void LLWindowSDL::x11_set_urgent(BOOL urgent)
1066 1108
1067 llinfos << "X11 hint for urgency, " << urgent << llendl; 1109 llinfos << "X11 hint for urgency, " << urgent << llendl;
1068 1110
1111 maybe_lock_display();
1069 wm_hints = XGetWMHints(mSDL_Display, mSDL_XWindowID); 1112 wm_hints = XGetWMHints(mSDL_Display, mSDL_XWindowID);
1070 if (!wm_hints) 1113 if (!wm_hints)
1071 wm_hints = XAllocWMHints(); 1114 wm_hints = XAllocWMHints();
@@ -1078,6 +1121,7 @@ void LLWindowSDL::x11_set_urgent(BOOL urgent)
1078 XSetWMHints(mSDL_Display, mSDL_XWindowID, wm_hints); 1121 XSetWMHints(mSDL_Display, mSDL_XWindowID, wm_hints);
1079 XFree(wm_hints); 1122 XFree(wm_hints);
1080 XSync(mSDL_Display, False); 1123 XSync(mSDL_Display, False);
1124 maybe_unlock_display();
1081 } 1125 }
1082} 1126}
1083#endif // LL_X11 1127#endif // LL_X11
@@ -1782,10 +1826,12 @@ BOOL LLWindowSDL::SDLReallyCaptureInput(BOOL capture)
1782 { 1826 {
1783 //llinfos << "X11 POINTER GRABBY" << llendl; 1827 //llinfos << "X11 POINTER GRABBY" << llendl;
1784 //newmode = SDL_WM_GrabInput(wantmode); 1828 //newmode = SDL_WM_GrabInput(wantmode);
1829 maybe_lock_display();
1785 result = XGrabPointer(mSDL_Display, mSDL_XWindowID, 1830 result = XGrabPointer(mSDL_Display, mSDL_XWindowID,
1786 True, 0, GrabModeAsync, 1831 True, 0, GrabModeAsync,
1787 GrabModeAsync, 1832 GrabModeAsync,
1788 None, None, CurrentTime); 1833 None, None, CurrentTime);
1834 maybe_unlock_display();
1789 if (GrabSuccess == result) 1835 if (GrabSuccess == result)
1790 newmode = SDL_GRAB_ON; 1836 newmode = SDL_GRAB_ON;
1791 else 1837 else
@@ -1795,10 +1841,12 @@ BOOL LLWindowSDL::SDLReallyCaptureInput(BOOL capture)
1795 //llinfos << "X11 POINTER UNGRABBY" << llendl; 1841 //llinfos << "X11 POINTER UNGRABBY" << llendl;
1796 newmode = SDL_GRAB_OFF; 1842 newmode = SDL_GRAB_OFF;
1797 //newmode = SDL_WM_GrabInput(SDL_GRAB_OFF); 1843 //newmode = SDL_WM_GrabInput(SDL_GRAB_OFF);
1798 1844
1845 maybe_lock_display();
1799 XUngrabPointer(mSDL_Display, CurrentTime); 1846 XUngrabPointer(mSDL_Display, CurrentTime);
1800 // Make sure the ungrab happens RIGHT NOW. 1847 // Make sure the ungrab happens RIGHT NOW.
1801 XSync(mSDL_Display, False); 1848 XSync(mSDL_Display, False);
1849 maybe_unlock_display();
1802 } else 1850 } else
1803 { 1851 {
1804 newmode = SDL_GRAB_QUERY; // neutral 1852 newmode = SDL_GRAB_QUERY; // neutral
@@ -1875,7 +1923,7 @@ void LLWindowSDL::gatherInput()
1875 std::string saved_locale = setlocale(LC_ALL, NULL); 1923 std::string saved_locale = setlocale(LC_ALL, NULL);
1876 1924
1877 // Do a limited number of pumps so SL doesn't starve! 1925 // Do a limited number of pumps so SL doesn't starve!
1878 // FIXME - this should ideally be time-limited, not count-limited. 1926 // *TODO: this should ideally be time-limited, not count-limited.
1879 gtk_main_iteration_do(0); // Always do one non-blocking pump 1927 gtk_main_iteration_do(0); // Always do one non-blocking pump
1880 for (int iter=0; iter<10; ++iter) 1928 for (int iter=0; iter<10; ++iter)
1881 if (gtk_events_pending()) 1929 if (gtk_events_pending())
@@ -2101,8 +2149,8 @@ static SDL_Cursor *makeSDLCursorFromBMP(const char *filename, int hotx, int hoty
2101 if (bmpsurface && bmpsurface->w%8==0) 2149 if (bmpsurface && bmpsurface->w%8==0)
2102 { 2150 {
2103 SDL_Surface *cursurface; 2151 SDL_Surface *cursurface;
2104 llinfos << "Loaded cursor file " << filename << " " 2152 lldebugs << "Loaded cursor file " << filename << " "
2105 << bmpsurface->w << "x" << bmpsurface->h << llendl; 2153 << bmpsurface->w << "x" << bmpsurface->h << llendl;
2106 cursurface = SDL_CreateRGBSurface (SDL_SWSURFACE, 2154 cursurface = SDL_CreateRGBSurface (SDL_SWSURFACE,
2107 bmpsurface->w, 2155 bmpsurface->w,
2108 bmpsurface->h, 2156 bmpsurface->h,
@@ -2282,14 +2330,14 @@ void LLWindowSDL::hideCursor()
2282{ 2330{
2283 if(!mCursorHidden) 2331 if(!mCursorHidden)
2284 { 2332 {
2285 // llinfos << "hideCursor: hiding" << llendl; 2333 // llinfos << "hideCursor: hiding" << llendl;
2286 mCursorHidden = TRUE; 2334 mCursorHidden = TRUE;
2287 mHideCursorPermanent = TRUE; 2335 mHideCursorPermanent = TRUE;
2288 SDL_ShowCursor(0); 2336 SDL_ShowCursor(0);
2289 } 2337 }
2290 else 2338 else
2291 { 2339 {
2292 // llinfos << "hideCursor: already hidden" << llendl; 2340 // llinfos << "hideCursor: already hidden" << llendl;
2293 } 2341 }
2294 2342
2295 adjustCursorDecouple(); 2343 adjustCursorDecouple();
@@ -2299,14 +2347,14 @@ void LLWindowSDL::showCursor()
2299{ 2347{
2300 if(mCursorHidden) 2348 if(mCursorHidden)
2301 { 2349 {
2302 // llinfos << "showCursor: showing" << llendl; 2350 // llinfos << "showCursor: showing" << llendl;
2303 mCursorHidden = FALSE; 2351 mCursorHidden = FALSE;
2304 mHideCursorPermanent = FALSE; 2352 mHideCursorPermanent = FALSE;
2305 SDL_ShowCursor(1); 2353 SDL_ShowCursor(1);
2306 } 2354 }
2307 else 2355 else
2308 { 2356 {
2309 // llinfos << "showCursor: already visible" << llendl; 2357 // llinfos << "showCursor: already visible" << llendl;
2310 } 2358 }
2311 2359
2312 adjustCursorDecouple(); 2360 adjustCursorDecouple();
@@ -2332,7 +2380,8 @@ void LLWindowSDL::hideCursorUntilMouseMove()
2332 2380
2333 2381
2334// 2382//
2335// LLSplashScreenSDL 2383// LLSplashScreenSDL - I don't think we'll bother to implement this; it's
2384// fairly obsolete at this point.
2336// 2385//
2337LLSplashScreenSDL::LLSplashScreenSDL() 2386LLSplashScreenSDL::LLSplashScreenSDL()
2338{ 2387{
@@ -2350,7 +2399,6 @@ void LLSplashScreenSDL::updateImpl(const char* mesg)
2350{ 2399{
2351} 2400}
2352 2401
2353
2354void LLSplashScreenSDL::hideImpl() 2402void LLSplashScreenSDL::hideImpl()
2355{ 2403{
2356} 2404}
@@ -2438,7 +2486,7 @@ S32 OSMessageBoxSDL(const char* text, const char* caption, U32 type)
2438 G_CALLBACK (response_callback), 2486 G_CALLBACK (response_callback),
2439 &response); 2487 &response);
2440 2488
2441 // we should be able to us a gtk_dialog_run(), but it's 2489 // we should be able to use a gtk_dialog_run(), but it's
2442 // apparently not written to exist in a world without a higher 2490 // apparently not written to exist in a world without a higher
2443 // gtk_main(), so we manage its signal/destruction outselves. 2491 // gtk_main(), so we manage its signal/destruction outselves.
2444 gtk_widget_show_all (win); 2492 gtk_widget_show_all (win);
@@ -2460,7 +2508,7 @@ S32 OSMessageBoxSDL(const char* text, const char* caption, U32 type)
2460 } 2508 }
2461 else 2509 else
2462 { 2510 {
2463 fprintf(stderr, "MSGBOX: %s: %s\n", caption, text); 2511 llinfos << "MSGBOX: " << caption << ": " << text << llendl;
2464 llinfos << "Skipping dialog because we're in fullscreen mode or GTK is not happy." << llendl; 2512 llinfos << "Skipping dialog because we're in fullscreen mode or GTK is not happy." << llendl;
2465 rtn = OSBTN_OK; 2513 rtn = OSBTN_OK;
2466 } 2514 }
@@ -2556,7 +2604,7 @@ BOOL LLWindowSDL::dialog_color_picker ( F32 *r, F32 *g, F32 *b)
2556#else 2604#else
2557S32 OSMessageBoxSDL(const char* text, const char* caption, U32 type) 2605S32 OSMessageBoxSDL(const char* text, const char* caption, U32 type)
2558{ 2606{
2559 fprintf(stderr, "MSGBOX: %s: %s\n", caption, text); 2607 llinfos << "MSGBOX: " << caption << ": " << text << llendl;
2560 return 0; 2608 return 0;
2561} 2609}
2562 2610
@@ -2573,11 +2621,15 @@ void spawn_web_browser(const char* escaped_url)
2573 llinfos << "spawn_web_browser: " << escaped_url << llendl; 2621 llinfos << "spawn_web_browser: " << escaped_url << llendl;
2574 2622
2575#if LL_LINUX 2623#if LL_LINUX
2576# if LL_X11 2624# if LL_X11
2577 if (gWindowImplementation && 2625 if (gWindowImplementation && gWindowImplementation->mSDL_Display)
2578 gWindowImplementation->mSDL_Display) // Just in case - before forking. 2626 {
2627 maybe_lock_display();
2628 // Just in case - before forking.
2579 XSync(gWindowImplementation->mSDL_Display, False); 2629 XSync(gWindowImplementation->mSDL_Display, False);
2580# endif // LL_X11 2630 maybe_unlock_display();
2631 }
2632# endif // LL_X11
2581 2633
2582 std::string cmd; 2634 std::string cmd;
2583 cmd = gDirUtilp->getAppRODataDir().c_str(); 2635 cmd = gDirUtilp->getAppRODataDir().c_str();
@@ -2615,8 +2667,8 @@ void spawn_web_browser(const char* escaped_url)
2615 2667
2616void shell_open( const char* file_path ) 2668void shell_open( const char* file_path )
2617{ 2669{
2618 // *FIX: (???) 2670 // *TODO: This function is deprecated and should probably go away.
2619 fprintf(stderr, "shell_open: %s\n", file_path); 2671 llwarns << "Deprecated shell_open(): " << file_path << llendl;
2620} 2672}
2621 2673
2622void *LLWindowSDL::getPlatformWindow() 2674void *LLWindowSDL::getPlatformWindow()
@@ -2624,18 +2676,14 @@ void *LLWindowSDL::getPlatformWindow()
2624#if LL_GTK && LL_LIBXUL_ENABLED 2676#if LL_GTK && LL_LIBXUL_ENABLED
2625 if (ll_try_gtk_init()) 2677 if (ll_try_gtk_init())
2626 { 2678 {
2679 maybe_lock_display();
2627 GtkWidget *win = gtk_window_new(GTK_WINDOW_TOPLEVEL); 2680 GtkWidget *win = gtk_window_new(GTK_WINDOW_TOPLEVEL);
2628 2681
2629 // These hacks were attempts to get Gecko to see the keyboard,
2630 // but I think they're doomed to fail.
2631 //GdkWindow *gdkwin = gdk_window_foreign_new(SDL_XWindowID);
2632 //GTK_WIDGET(win)->window = gdkwin;
2633 //gtk_widget_set_parent_window(win, gdkwin);
2634
2635 // show the hidden-widget while debugging (needs mozlib change) 2682 // show the hidden-widget while debugging (needs mozlib change)
2636 //gtk_widget_show_all(GTK_WIDGET(win)); 2683 //gtk_widget_show_all(GTK_WIDGET(win));
2637 2684
2638 gtk_widget_realize(GTK_WIDGET(win)); 2685 gtk_widget_realize(GTK_WIDGET(win));
2686 maybe_unlock_display();
2639 return win; 2687 return win;
2640 } 2688 }
2641#endif // LL_GTK && LL_LIBXUL_ENABLED 2689#endif // LL_GTK && LL_LIBXUL_ENABLED
@@ -2645,8 +2693,18 @@ void *LLWindowSDL::getPlatformWindow()
2645 2693
2646void LLWindowSDL::bringToFront() 2694void LLWindowSDL::bringToFront()
2647{ 2695{
2648 // *FIX: (???) 2696 // This is currently used when we are 'launched' to a specific
2649 fprintf(stderr, "bringToFront\n"); 2697 // map position externally.
2698 llinfos << "bringToFront" << llendl;
2699#if LL_X11
2700 if (mSDL_Display && !mFullscreen)
2701 {
2702 maybe_lock_display();
2703 XRaiseWindow(mSDL_Display, mSDL_XWindowID);
2704 XSync(mSDL_Display, False);
2705 maybe_unlock_display();
2706 }
2707#endif // LL_X11
2650} 2708}
2651 2709
2652#endif // LL_SDL 2710#endif // LL_SDL
diff --git a/linden/indra/llwindow/llwindowwin32.cpp b/linden/indra/llwindow/llwindowwin32.cpp
index 7c3ec01..3c2e730 100644
--- a/linden/indra/llwindow/llwindowwin32.cpp
+++ b/linden/indra/llwindow/llwindowwin32.cpp
@@ -54,8 +54,12 @@
54#include "indra_constants.h" 54#include "indra_constants.h"
55 55
56// culled from winuser.h 56// culled from winuser.h
57#ifndef WM_MOUSEWHEEL /* Added to be compatible with later SDK's */
57const S32 WM_MOUSEWHEEL = 0x020A; 58const S32 WM_MOUSEWHEEL = 0x020A;
59#endif
60#ifndef WHEEL_DELTA /* Added to be compatible with later SDK's */
58const S32 WHEEL_DELTA = 120; /* Value for rolling one detent */ 61const S32 WHEEL_DELTA = 120; /* Value for rolling one detent */
62#endif
59const S32 MAX_MESSAGE_PER_UPDATE = 20; 63const S32 MAX_MESSAGE_PER_UPDATE = 20;
60const S32 BITS_PER_PIXEL = 32; 64const S32 BITS_PER_PIXEL = 32;
61const S32 MAX_NUM_RESOLUTIONS = 32; 65const S32 MAX_NUM_RESOLUTIONS = 32;
@@ -1646,7 +1650,7 @@ void LLWindowWin32::setCursor(ECursorType cursor)
1646 } 1650 }
1647} 1651}
1648 1652
1649ECursorType LLWindowWin32::getCursor() 1653ECursorType LLWindowWin32::getCursor() const
1650{ 1654{
1651 return mCurrentCursor; 1655 return mCurrentCursor;
1652} 1656}
@@ -2299,7 +2303,7 @@ BOOL LLWindowWin32::convertCoords(LLCoordGL from, LLCoordScreen *to)
2299 2303
2300BOOL LLWindowWin32::isClipboardTextAvailable() 2304BOOL LLWindowWin32::isClipboardTextAvailable()
2301{ 2305{
2302 return IsClipboardFormatAvailable(CF_UNICODETEXT) || IsClipboardFormatAvailable( CF_TEXT ); 2306 return IsClipboardFormatAvailable(CF_UNICODETEXT);
2303} 2307}
2304 2308
2305 2309
@@ -2326,27 +2330,6 @@ BOOL LLWindowWin32::pasteTextFromClipboard(LLWString &dst)
2326 CloseClipboard(); 2330 CloseClipboard();
2327 } 2331 }
2328 } 2332 }
2329 else if (IsClipboardFormatAvailable(CF_TEXT))
2330 {
2331 // This must be an OLD OS. We don't do non-ASCII for old OSes
2332 if (OpenClipboard(mWindowHandle))
2333 {
2334 HGLOBAL h_data = GetClipboardData(CF_TEXT);
2335 if (h_data)
2336 {
2337 char* str = (char*) GlobalLock(h_data);
2338 if (str)
2339 {
2340 // Strip non-ASCII characters
2341 dst = utf8str_to_wstring(mbcsstring_makeASCII(str));
2342 LLWString::removeCRLF(dst);
2343 GlobalUnlock(h_data);
2344 success = TRUE;
2345 }
2346 }
2347 CloseClipboard();
2348 }
2349 }
2350 2333
2351 return success; 2334 return success;
2352} 2335}
@@ -2383,30 +2366,6 @@ BOOL LLWindowWin32::copyTextToClipboard(const LLWString& wstr)
2383 } 2366 }
2384 } 2367 }
2385 2368
2386 // Also provide a copy as raw ASCII text.
2387 LLWString ascii_string(wstr);
2388 LLWString::_makeASCII(ascii_string);
2389 LLWString::addCRLF(ascii_string);
2390 std::string out_s = wstring_to_utf8str(ascii_string);
2391 const size_t size = (out_s.length() + 1) * sizeof(char);
2392
2393 // Memory is allocated and then ownership of it is transfered to the system.
2394 HGLOBAL hglobal_copy = GlobalAlloc(GMEM_MOVEABLE, size);
2395 if (hglobal_copy)
2396 {
2397 char* copy = (char*) GlobalLock(hglobal_copy);
2398 if( copy )
2399 {
2400 memcpy(copy, out_s.c_str(), size); /* Flawfinder: ignore */
2401 GlobalUnlock(hglobal_copy);
2402
2403 if (SetClipboardData(CF_TEXT, hglobal_copy))
2404 {
2405 success = TRUE;
2406 }
2407 }
2408 }
2409
2410 CloseClipboard(); 2369 CloseClipboard();
2411 } 2370 }
2412 2371
diff --git a/linden/indra/llwindow/llwindowwin32.h b/linden/indra/llwindow/llwindowwin32.h
index 040c9ab..691c648 100644
--- a/linden/indra/llwindow/llwindowwin32.h
+++ b/linden/indra/llwindow/llwindowwin32.h
@@ -65,7 +65,7 @@ public:
65 /*virtual*/ void hideCursorUntilMouseMove(); 65 /*virtual*/ void hideCursorUntilMouseMove();
66 /*virtual*/ BOOL isCursorHidden(); 66 /*virtual*/ BOOL isCursorHidden();
67 /*virtual*/ void setCursor(ECursorType cursor); 67 /*virtual*/ void setCursor(ECursorType cursor);
68 /*virtual*/ ECursorType getCursor(); 68 /*virtual*/ ECursorType getCursor() const;
69 /*virtual*/ void captureMouse(); 69 /*virtual*/ void captureMouse();
70 /*virtual*/ void releaseMouse(); 70 /*virtual*/ void releaseMouse();
71 /*virtual*/ void setMouseClipping( BOOL b ); 71 /*virtual*/ void setMouseClipping( BOOL b );