aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llui/llui.cpp
diff options
context:
space:
mode:
authorMcCabe Maxsted2009-06-07 23:14:43 -0700
committerMcCabe Maxsted2009-06-07 23:14:43 -0700
commite0a70bea805cf07b92efabca15ffe56a777f90ac (patch)
tree2c93d38e210832e737d09cff7561373d8d5453b2 /linden/indra/llui/llui.cpp
parent1.1 version final (diff)
parentMerge branch 'sl-base-1.22' into next (diff)
downloadmeta-impy-e0a70bea805cf07b92efabca15ffe56a777f90ac.zip
meta-impy-e0a70bea805cf07b92efabca15ffe56a777f90ac.tar.gz
meta-impy-e0a70bea805cf07b92efabca15ffe56a777f90ac.tar.bz2
meta-impy-e0a70bea805cf07b92efabca15ffe56a777f90ac.tar.xz
Moved base up to 1.22
Diffstat (limited to 'linden/indra/llui/llui.cpp')
-rw-r--r--linden/indra/llui/llui.cpp126
1 files changed, 74 insertions, 52 deletions
diff --git a/linden/indra/llui/llui.cpp b/linden/indra/llui/llui.cpp
index 734aecf..f3e73fd 100644
--- a/linden/indra/llui/llui.cpp
+++ b/linden/indra/llui/llui.cpp
@@ -4,7 +4,7 @@
4 * 4 *
5 * $LicenseInfo:firstyear=2001&license=viewergpl$ 5 * $LicenseInfo:firstyear=2001&license=viewergpl$
6 * 6 *
7 * Copyright (c) 2001-2008, Linden Research, Inc. 7 * Copyright (c) 2001-2009, Linden Research, Inc.
8 * 8 *
9 * Second Life Viewer Source Code 9 * Second Life Viewer Source Code
10 * The source code in this file ("Source Code") is provided by Linden Lab 10 * The source code in this file ("Source Code") is provided by Linden Lab
@@ -30,8 +30,6 @@
30 */ 30 */
31 31
32// Utilities functions the user interface needs 32// Utilities functions the user interface needs
33
34//#include "llviewerprecompiledheaders.h"
35#include "linden_common.h" 33#include "linden_common.h"
36 34
37#include <string> 35#include <string>
@@ -143,11 +141,11 @@ void gl_state_for_2d(S32 width, S32 height)
143 141
144void gl_draw_x(const LLRect& rect, const LLColor4& color) 142void gl_draw_x(const LLRect& rect, const LLColor4& color)
145{ 143{
146 LLGLSNoTexture no_texture; 144 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
147 145
148 gGL.color4fv( color.mV ); 146 gGL.color4fv( color.mV );
149 147
150 gGL.begin( LLVertexBuffer::LINES ); 148 gGL.begin( LLRender::LINES );
151 gGL.vertex2i( rect.mLeft, rect.mTop ); 149 gGL.vertex2i( rect.mLeft, rect.mTop );
152 gGL.vertex2i( rect.mRight, rect.mBottom ); 150 gGL.vertex2i( rect.mRight, rect.mBottom );
153 gGL.vertex2i( rect.mLeft, rect.mBottom ); 151 gGL.vertex2i( rect.mLeft, rect.mBottom );
@@ -183,12 +181,12 @@ void gl_rect_2d_offset_local( S32 left, S32 top, S32 right, S32 bottom, S32 pixe
183void gl_rect_2d(S32 left, S32 top, S32 right, S32 bottom, BOOL filled ) 181void gl_rect_2d(S32 left, S32 top, S32 right, S32 bottom, BOOL filled )
184{ 182{
185 stop_glerror(); 183 stop_glerror();
186 LLGLSNoTexture no_texture; 184 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
187 185
188 // Counterclockwise quad will face the viewer 186 // Counterclockwise quad will face the viewer
189 if( filled ) 187 if( filled )
190 { 188 {
191 gGL.begin( LLVertexBuffer::QUADS ); 189 gGL.begin( LLRender::QUADS );
192 gGL.vertex2i(left, top); 190 gGL.vertex2i(left, top);
193 gGL.vertex2i(left, bottom); 191 gGL.vertex2i(left, bottom);
194 gGL.vertex2i(right, bottom); 192 gGL.vertex2i(right, bottom);
@@ -200,7 +198,7 @@ void gl_rect_2d(S32 left, S32 top, S32 right, S32 bottom, BOOL filled )
200 if( gGLManager.mATIOffsetVerticalLines ) 198 if( gGLManager.mATIOffsetVerticalLines )
201 { 199 {
202 // Work around bug in ATI driver: vertical lines are offset by (-1,-1) 200 // Work around bug in ATI driver: vertical lines are offset by (-1,-1)
203 gGL.begin( LLVertexBuffer::LINES ); 201 gGL.begin( LLRender::LINES );
204 202
205 // Verticals 203 // Verticals
206 gGL.vertex2i(left + 1, top); 204 gGL.vertex2i(left + 1, top);
@@ -223,7 +221,7 @@ void gl_rect_2d(S32 left, S32 top, S32 right, S32 bottom, BOOL filled )
223 { 221 {
224 top--; 222 top--;
225 right--; 223 right--;
226 gGL.begin( LLVertexBuffer::LINE_STRIP ); 224 gGL.begin( LLRender::LINE_STRIP );
227 gGL.vertex2i(left, top); 225 gGL.vertex2i(left, top);
228 gGL.vertex2i(left, bottom); 226 gGL.vertex2i(left, bottom);
229 gGL.vertex2i(right, bottom); 227 gGL.vertex2i(right, bottom);
@@ -254,7 +252,7 @@ void gl_rect_2d( const LLRect& rect, const LLColor4& color, BOOL filled )
254void gl_drop_shadow(S32 left, S32 top, S32 right, S32 bottom, const LLColor4 &start_color, S32 lines) 252void gl_drop_shadow(S32 left, S32 top, S32 right, S32 bottom, const LLColor4 &start_color, S32 lines)
255{ 253{
256 stop_glerror(); 254 stop_glerror();
257 LLGLSNoTexture no_texture; 255 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
258 256
259 // HACK: Overlap with the rectangle by a single pixel. 257 // HACK: Overlap with the rectangle by a single pixel.
260 right--; 258 right--;
@@ -264,7 +262,7 @@ void gl_drop_shadow(S32 left, S32 top, S32 right, S32 bottom, const LLColor4 &st
264 LLColor4 end_color = start_color; 262 LLColor4 end_color = start_color;
265 end_color.mV[VALPHA] = 0.f; 263 end_color.mV[VALPHA] = 0.f;
266 264
267 gGL.begin(LLVertexBuffer::QUADS); 265 gGL.begin(LLRender::QUADS);
268 266
269 // Right edge, CCW faces screen 267 // Right edge, CCW faces screen
270 gGL.color4fv(start_color.mV); 268 gGL.color4fv(start_color.mV);
@@ -324,9 +322,9 @@ void gl_line_2d(S32 x1, S32 y1, S32 x2, S32 y2 )
324 y2++; 322 y2++;
325 } 323 }
326 324
327 LLGLSNoTexture no_texture; 325 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
328 326
329 gGL.begin(LLVertexBuffer::LINES); 327 gGL.begin(LLRender::LINES);
330 gGL.vertex2i(x1, y1); 328 gGL.vertex2i(x1, y1);
331 gGL.vertex2i(x2, y2); 329 gGL.vertex2i(x2, y2);
332 gGL.end(); 330 gGL.end();
@@ -343,11 +341,11 @@ void gl_line_2d(S32 x1, S32 y1, S32 x2, S32 y2, const LLColor4 &color )
343 y2++; 341 y2++;
344 } 342 }
345 343
346 LLGLSNoTexture no_texture; 344 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
347 345
348 gGL.color4fv( color.mV ); 346 gGL.color4fv( color.mV );
349 347
350 gGL.begin(LLVertexBuffer::LINES); 348 gGL.begin(LLRender::LINES);
351 gGL.vertex2i(x1, y1); 349 gGL.vertex2i(x1, y1);
352 gGL.vertex2i(x2, y2); 350 gGL.vertex2i(x2, y2);
353 gGL.end(); 351 gGL.end();
@@ -355,17 +353,17 @@ void gl_line_2d(S32 x1, S32 y1, S32 x2, S32 y2, const LLColor4 &color )
355 353
356void gl_triangle_2d(S32 x1, S32 y1, S32 x2, S32 y2, S32 x3, S32 y3, const LLColor4& color, BOOL filled) 354void gl_triangle_2d(S32 x1, S32 y1, S32 x2, S32 y2, S32 x3, S32 y3, const LLColor4& color, BOOL filled)
357{ 355{
358 LLGLSNoTexture no_texture; 356 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
359 357
360 gGL.color4fv(color.mV); 358 gGL.color4fv(color.mV);
361 359
362 if (filled) 360 if (filled)
363 { 361 {
364 gGL.begin(LLVertexBuffer::TRIANGLES); 362 gGL.begin(LLRender::TRIANGLES);
365 } 363 }
366 else 364 else
367 { 365 {
368 gGL.begin(LLVertexBuffer::LINE_LOOP); 366 gGL.begin(LLRender::LINE_LOOP);
369 } 367 }
370 gGL.vertex2i(x1, y1); 368 gGL.vertex2i(x1, y1);
371 gGL.vertex2i(x2, y2); 369 gGL.vertex2i(x2, y2);
@@ -375,11 +373,11 @@ void gl_triangle_2d(S32 x1, S32 y1, S32 x2, S32 y2, S32 x3, S32 y3, const LLColo
375 373
376void gl_corners_2d(S32 left, S32 top, S32 right, S32 bottom, S32 length, F32 max_frac) 374void gl_corners_2d(S32 left, S32 top, S32 right, S32 bottom, S32 length, F32 max_frac)
377{ 375{
378 LLGLSNoTexture no_texture; 376 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
379 377
380 length = llmin((S32)(max_frac*(right - left)), length); 378 length = llmin((S32)(max_frac*(right - left)), length);
381 length = llmin((S32)(max_frac*(top - bottom)), length); 379 length = llmin((S32)(max_frac*(top - bottom)), length);
382 gGL.begin(LLVertexBuffer::LINES); 380 gGL.begin(LLRender::LINES);
383 gGL.vertex2i(left, top); 381 gGL.vertex2i(left, top);
384 gGL.vertex2i(left + length, top); 382 gGL.vertex2i(left + length, top);
385 383
@@ -496,11 +494,11 @@ void gl_draw_scaled_image_with_border(S32 x, S32 y, S32 width, S32 height, LLIma
496 { 494 {
497 gGL.translatef((F32)x, (F32)y, 0.f); 495 gGL.translatef((F32)x, (F32)y, 0.f);
498 496
499 image->bind(); 497 gGL.getTexUnit(0)->bind(image);
500 498
501 gGL.color4fv(color.mV); 499 gGL.color4fv(color.mV);
502 500
503 gGL.begin(LLVertexBuffer::QUADS); 501 gGL.begin(LLRender::QUADS);
504 { 502 {
505 // draw bottom left 503 // draw bottom left
506 gGL.texCoord2f(uv_rect.mLeft, uv_rect.mBottom); 504 gGL.texCoord2f(uv_rect.mLeft, uv_rect.mBottom);
@@ -656,11 +654,11 @@ void gl_draw_scaled_rotated_image(S32 x, S32 y, S32 width, S32 height, F32 degre
656 gGL.translatef( -offset_x, -offset_y, 0.f ); 654 gGL.translatef( -offset_x, -offset_y, 0.f );
657 } 655 }
658 656
659 image->bind(); 657 gGL.getTexUnit(0)->bind(image);
660 658
661 gGL.color4fv(color.mV); 659 gGL.color4fv(color.mV);
662 660
663 gGL.begin(LLVertexBuffer::QUADS); 661 gGL.begin(LLRender::QUADS);
664 { 662 {
665 gGL.texCoord2f(uv_rect.mRight, uv_rect.mTop); 663 gGL.texCoord2f(uv_rect.mRight, uv_rect.mTop);
666 gGL.vertex2i(width, height ); 664 gGL.vertex2i(width, height );
@@ -694,11 +692,11 @@ void gl_draw_scaled_image_inverted(S32 x, S32 y, S32 width, S32 height, LLImageG
694 { 692 {
695 gGL.translatef((F32)x, (F32)y, 0.f); 693 gGL.translatef((F32)x, (F32)y, 0.f);
696 694
697 image->bind(); 695 gGL.getTexUnit(0)->bind(image);
698 696
699 gGL.color4fv(color.mV); 697 gGL.color4fv(color.mV);
700 698
701 gGL.begin(LLVertexBuffer::QUADS); 699 gGL.begin(LLRender::QUADS);
702 { 700 {
703 gGL.texCoord2f(uv_rect.mRight, uv_rect.mBottom); 701 gGL.texCoord2f(uv_rect.mRight, uv_rect.mBottom);
704 gGL.vertex2i(width, height ); 702 gGL.vertex2i(width, height );
@@ -733,7 +731,7 @@ void gl_stippled_line_3d( const LLVector3& start, const LLVector3& end, const LL
733 glLineWidth(2.5f); 731 glLineWidth(2.5f);
734 glLineStipple(2, 0x3333 << shift); 732 glLineStipple(2, 0x3333 << shift);
735 733
736 gGL.begin(LLVertexBuffer::LINES); 734 gGL.begin(LLRender::LINES);
737 { 735 {
738 gGL.vertex3fv( start.mV ); 736 gGL.vertex3fv( start.mV );
739 gGL.vertex3fv( end.mV ); 737 gGL.vertex3fv( end.mV );
@@ -750,7 +748,7 @@ void gl_rect_2d_xor(S32 left, S32 top, S32 right, S32 bottom)
750 glLogicOp( GL_XOR ); 748 glLogicOp( GL_XOR );
751 stop_glerror(); 749 stop_glerror();
752 750
753 gGL.begin(LLVertexBuffer::QUADS); 751 gGL.begin(LLRender::QUADS);
754 gGL.vertex2i(left, top); 752 gGL.vertex2i(left, top);
755 gGL.vertex2i(left, bottom); 753 gGL.vertex2i(left, bottom);
756 gGL.vertex2i(right, bottom); 754 gGL.vertex2i(right, bottom);
@@ -782,14 +780,14 @@ void gl_arc_2d(F32 center_x, F32 center_y, F32 radius, S32 steps, BOOL filled, F
782 780
783 if (filled) 781 if (filled)
784 { 782 {
785 gGL.begin(LLVertexBuffer::TRIANGLE_FAN); 783 gGL.begin(LLRender::TRIANGLE_FAN);
786 gGL.vertex2f(0.f, 0.f); 784 gGL.vertex2f(0.f, 0.f);
787 // make sure circle is complete 785 // make sure circle is complete
788 steps += 1; 786 steps += 1;
789 } 787 }
790 else 788 else
791 { 789 {
792 gGL.begin(LLVertexBuffer::LINE_STRIP); 790 gGL.begin(LLRender::LINE_STRIP);
793 } 791 }
794 792
795 while( steps-- ) 793 while( steps-- )
@@ -809,7 +807,7 @@ void gl_circle_2d(F32 center_x, F32 center_y, F32 radius, S32 steps, BOOL filled
809{ 807{
810 gGL.pushMatrix(); 808 gGL.pushMatrix();
811 { 809 {
812 LLGLSNoTexture gls_no_texture; 810 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
813 gGL.translatef(center_x, center_y, 0.f); 811 gGL.translatef(center_x, center_y, 0.f);
814 812
815 // Inexact, but reasonably fast. 813 // Inexact, but reasonably fast.
@@ -821,14 +819,14 @@ void gl_circle_2d(F32 center_x, F32 center_y, F32 radius, S32 steps, BOOL filled
821 819
822 if (filled) 820 if (filled)
823 { 821 {
824 gGL.begin(LLVertexBuffer::TRIANGLE_FAN); 822 gGL.begin(LLRender::TRIANGLE_FAN);
825 gGL.vertex2f(0.f, 0.f); 823 gGL.vertex2f(0.f, 0.f);
826 // make sure circle is complete 824 // make sure circle is complete
827 steps += 1; 825 steps += 1;
828 } 826 }
829 else 827 else
830 { 828 {
831 gGL.begin(LLVertexBuffer::LINE_LOOP); 829 gGL.begin(LLRender::LINE_LOOP);
832 } 830 }
833 831
834 while( steps-- ) 832 while( steps-- )
@@ -850,7 +848,7 @@ void gl_deep_circle( F32 radius, F32 depth, S32 steps )
850 F32 x = radius; 848 F32 x = radius;
851 F32 y = 0.f; 849 F32 y = 0.f;
852 F32 angle_delta = F_TWO_PI / (F32)steps; 850 F32 angle_delta = F_TWO_PI / (F32)steps;
853 gGL.begin( LLVertexBuffer::TRIANGLE_STRIP ); 851 gGL.begin( LLRender::TRIANGLE_STRIP );
854 { 852 {
855 S32 step = steps + 1; // An extra step to close the circle. 853 S32 step = steps + 1; // An extra step to close the circle.
856 while( step-- ) 854 while( step-- )
@@ -905,7 +903,7 @@ void gl_rect_2d_checkerboard(const LLRect& rect)
905 first = FALSE; 903 first = FALSE;
906 } 904 }
907 905
908 LLGLSNoTexture gls_no_texture; 906 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
909 907
910 // ...white squares 908 // ...white squares
911 gGL.color3f( 1.f, 1.f, 1.f ); 909 gGL.color3f( 1.f, 1.f, 1.f );
@@ -935,9 +933,9 @@ void gl_washer_2d(F32 outer_radius, F32 inner_radius, S32 steps, const LLColor4&
935 F32 x2 = inner_radius; 933 F32 x2 = inner_radius;
936 F32 y2 = 0.f; 934 F32 y2 = 0.f;
937 935
938 LLGLSNoTexture gls_no_texture; 936 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
939 937
940 gGL.begin( LLVertexBuffer::TRIANGLE_STRIP ); 938 gGL.begin( LLRender::TRIANGLE_STRIP );
941 { 939 {
942 steps += 1; // An extra step to close the circle. 940 steps += 1; // An extra step to close the circle.
943 while( steps-- ) 941 while( steps-- )
@@ -972,8 +970,8 @@ void gl_washer_segment_2d(F32 outer_radius, F32 inner_radius, F32 start_radians,
972 F32 x2 = inner_radius * cos( start_radians ); 970 F32 x2 = inner_radius * cos( start_radians );
973 F32 y2 = inner_radius * sin( start_radians ); 971 F32 y2 = inner_radius * sin( start_radians );
974 972
975 LLGLSNoTexture gls_no_texture; 973 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
976 gGL.begin( LLVertexBuffer::TRIANGLE_STRIP ); 974 gGL.begin( LLRender::TRIANGLE_STRIP );
977 { 975 {
978 steps += 1; // An extra step to close the circle. 976 steps += 1; // An extra step to close the circle.
979 while( steps-- ) 977 while( steps-- )
@@ -1008,9 +1006,9 @@ void gl_washer_spokes_2d(F32 outer_radius, F32 inner_radius, S32 count, const LL
1008 F32 x2 = inner_radius * cos( HALF_DELTA ); 1006 F32 x2 = inner_radius * cos( HALF_DELTA );
1009 F32 y2 = inner_radius * sin( HALF_DELTA ); 1007 F32 y2 = inner_radius * sin( HALF_DELTA );
1010 1008
1011 LLGLSNoTexture gls_no_texture; 1009 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
1012 1010
1013 gGL.begin( LLVertexBuffer::LINES ); 1011 gGL.begin( LLRender::LINES );
1014 { 1012 {
1015 while( count-- ) 1013 while( count-- )
1016 { 1014 {
@@ -1033,7 +1031,7 @@ void gl_washer_spokes_2d(F32 outer_radius, F32 inner_radius, S32 count, const LL
1033 1031
1034void gl_rect_2d_simple_tex( S32 width, S32 height ) 1032void gl_rect_2d_simple_tex( S32 width, S32 height )
1035{ 1033{
1036 gGL.begin( LLVertexBuffer::QUADS ); 1034 gGL.begin( LLRender::QUADS );
1037 1035
1038 gGL.texCoord2f(1.f, 1.f); 1036 gGL.texCoord2f(1.f, 1.f);
1039 gGL.vertex2i(width, height); 1037 gGL.vertex2i(width, height);
@@ -1052,7 +1050,7 @@ void gl_rect_2d_simple_tex( S32 width, S32 height )
1052 1050
1053void gl_rect_2d_simple( S32 width, S32 height ) 1051void gl_rect_2d_simple( S32 width, S32 height )
1054{ 1052{
1055 gGL.begin( LLVertexBuffer::QUADS ); 1053 gGL.begin( LLRender::QUADS );
1056 gGL.vertex2i(width, height); 1054 gGL.vertex2i(width, height);
1057 gGL.vertex2i(0, height); 1055 gGL.vertex2i(0, height);
1058 gGL.vertex2i(0, 0); 1056 gGL.vertex2i(0, 0);
@@ -1094,7 +1092,7 @@ void gl_segmented_rect_2d_tex(const S32 left,
1094 LLVector2 width_vec((F32)width, 0.f); 1092 LLVector2 width_vec((F32)width, 0.f);
1095 LLVector2 height_vec(0.f, (F32)height); 1093 LLVector2 height_vec(0.f, (F32)height);
1096 1094
1097 gGL.begin(LLVertexBuffer::QUADS); 1095 gGL.begin(LLRender::QUADS);
1098 { 1096 {
1099 // draw bottom left 1097 // draw bottom left
1100 gGL.texCoord2f(0.f, 0.f); 1098 gGL.texCoord2f(0.f, 0.f);
@@ -1262,7 +1260,7 @@ void gl_segmented_rect_2d_fragment_tex(const S32 left,
1262 LLVector2 x_min; 1260 LLVector2 x_min;
1263 LLVector2 x_max; 1261 LLVector2 x_max;
1264 1262
1265 gGL.begin(LLVertexBuffer::QUADS); 1263 gGL.begin(LLRender::QUADS);
1266 { 1264 {
1267 if (start_fragment < middle_start) 1265 if (start_fragment < middle_start)
1268 { 1266 {
@@ -1419,7 +1417,7 @@ void gl_segmented_rect_3d_tex(const LLVector2& border_scale, const LLVector3& bo
1419 LLVector3 bottom_border_height = ((edges & (~(U32)ROUNDED_RECT_TOP)) != 0) ? border_height : LLVector3::zero; 1417 LLVector3 bottom_border_height = ((edges & (~(U32)ROUNDED_RECT_TOP)) != 0) ? border_height : LLVector3::zero;
1420 1418
1421 1419
1422 gGL.begin(LLVertexBuffer::QUADS); 1420 gGL.begin(LLRender::QUADS);
1423 { 1421 {
1424 // draw bottom left 1422 // draw bottom left
1425 gGL.texCoord2f(0.f, 0.f); 1423 gGL.texCoord2f(0.f, 0.f);
@@ -1575,7 +1573,7 @@ void LLUI::initClass(LLControlGroup* config,
1575void LLUI::cleanupClass() 1573void LLUI::cleanupClass()
1576{ 1574{
1577 sImageProvider->cleanUp(); 1575 sImageProvider->cleanUp();
1578 LLLineEditor::cleanupClass(); 1576 LLLineEditor::cleanupLineEditor();
1579} 1577}
1580 1578
1581 1579
@@ -1647,6 +1645,34 @@ void LLUI::setCursorPositionLocal(const LLView* viewp, S32 x, S32 y)
1647 setCursorPositionScreen(screen_x, screen_y); 1645 setCursorPositionScreen(screen_x, screen_y);
1648} 1646}
1649 1647
1648// On Windows, the user typically sets the language when they install the
1649// app (by running it with a shortcut that sets InstallLanguage). On Mac,
1650// or on Windows if the SecondLife.exe executable is run directly, the
1651// language follows the OS language. In all cases the user can override
1652// the language manually in preferences. JC
1653// static
1654std::string LLUI::getLanguage()
1655{
1656 std::string language = "en-us";
1657 if (sConfigGroup)
1658 {
1659 language = sConfigGroup->getString("Language");
1660 if (language.empty() || language == "default")
1661 {
1662 language = sConfigGroup->getString("InstallLanguage");
1663 }
1664 if (language.empty() || language == "default")
1665 {
1666 language = sConfigGroup->getString("SystemLanguage");
1667 }
1668 if (language.empty() || language == "default")
1669 {
1670 language = "en-us";
1671 }
1672 }
1673 return language;
1674}
1675
1650//static 1676//static
1651std::string LLUI::locateSkin(const std::string& filename) 1677std::string LLUI::locateSkin(const std::string& filename)
1652{ 1678{
@@ -1660,11 +1686,7 @@ std::string LLUI::locateSkin(const std::string& filename)
1660 { 1686 {
1661 if (!gDirUtilp->fileExists(found_file)) 1687 if (!gDirUtilp->fileExists(found_file))
1662 { 1688 {
1663 std::string localization(sConfigGroup->getString("Language")); 1689 std::string localization = getLanguage();
1664 if(localization == "default")
1665 {
1666 localization = sConfigGroup->getString("SystemLanguage");
1667 }
1668 std::string local_skin = "xui" + slash + localization + slash + filename; 1690 std::string local_skin = "xui" + slash + localization + slash + filename;
1669 found_file = gDirUtilp->findSkinnedFilename(local_skin); 1691 found_file = gDirUtilp->findSkinnedFilename(local_skin);
1670 } 1692 }