diff options
author | Jacek Antonelli | 2008-08-15 23:44:48 -0500 |
---|---|---|
committer | Jacek Antonelli | 2008-08-15 23:44:48 -0500 |
commit | 9b4f54c826ffa4f94efa866068c9d6ecdfb4b424 (patch) | |
tree | 2f8ae193ab487088962e628f1ee9dee2f5901f01 /linden/indra | |
parent | Second Life viewer sources 1.13.2.12 (diff) | |
download | meta-impy-9b4f54c826ffa4f94efa866068c9d6ecdfb4b424.zip meta-impy-9b4f54c826ffa4f94efa866068c9d6ecdfb4b424.tar.gz meta-impy-9b4f54c826ffa4f94efa866068c9d6ecdfb4b424.tar.bz2 meta-impy-9b4f54c826ffa4f94efa866068c9d6ecdfb4b424.tar.xz |
Second Life viewer sources 1.13.2.15
Diffstat (limited to 'linden/indra')
104 files changed, 807 insertions, 493 deletions
diff --git a/linden/indra/SConstruct b/linden/indra/SConstruct index d9c53b9..f94f661 100644 --- a/linden/indra/SConstruct +++ b/linden/indra/SConstruct | |||
@@ -57,7 +57,7 @@ opts.Add(EnumOption('DISTCC', 'Enabled distcc', 'yes', | |||
57 | opts.Add(EnumOption('COLORGCC', 'Enabled colorgcc', 'yes', | 57 | opts.Add(EnumOption('COLORGCC', 'Enabled colorgcc', 'yes', |
58 | allowed_values=('yes', 'no'))) | 58 | allowed_values=('yes', 'no'))) |
59 | opts.Add(EnumOption('GRID', 'Client package\'s default grid', 'default', | 59 | opts.Add(EnumOption('GRID', 'Client package\'s default grid', 'default', |
60 | allowed_values=('default', 'aditi', 'agni', 'dmz', 'durga', 'ganga', 'shakti', 'siva', 'soma', 'uma', 'vaak'))) | 60 | allowed_values=('default', 'aditi', 'agni', 'dmz', 'durga', 'firstlook', 'ganga', 'shakti', 'siva', 'soma', 'uma', 'vaak'))) |
61 | opts.Add(EnumOption('OPENSOURCE', 'Build using only non-proprietary dependencies', | 61 | opts.Add(EnumOption('OPENSOURCE', 'Build using only non-proprietary dependencies', |
62 | 'yes',# OPENSOURCE: do not edit this line | 62 | 'yes',# OPENSOURCE: do not edit this line |
63 | allowed_values=('yes', 'no'))) | 63 | allowed_values=('yes', 'no'))) |
@@ -179,7 +179,6 @@ for build_target in targets: | |||
179 | if platform == 'linux': | 179 | if platform == 'linux': |
180 | # Linux-only flags | 180 | # Linux-only flags |
181 | flags += '-DLL_LINUX=1 ' | 181 | flags += '-DLL_LINUX=1 ' |
182 | system_link_flags += '-Wl,--version-script=newview/linux_tools/hidesymbols.ver ' | ||
183 | if build_target == 'client': | 182 | if build_target == 'client': |
184 | flags += '-DAPPID=secondlife -DLL_SDL=1 -DLL_X11=1 ' | 183 | flags += '-DAPPID=secondlife -DLL_SDL=1 -DLL_X11=1 ' |
185 | flags += '-DLL_GTK=1 ' | 184 | flags += '-DLL_GTK=1 ' |
@@ -210,6 +209,17 @@ for build_target in targets: | |||
210 | # logger backtraces deteriorates. | 209 | # logger backtraces deteriorates. |
211 | strip_cmd = 'strip -S -o $TARGET $SOURCE' | 210 | strip_cmd = 'strip -S -o $TARGET $SOURCE' |
212 | 211 | ||
212 | # hidesyms_cmd is something which copies an executable while 'hiding' | ||
213 | # all of its exposed symbols except a very few desired ones. This is | ||
214 | # used mainly to hide the symbols of the many common libraries we | ||
215 | # static-link, which otherwise cause hard-to-trace fatal crashes due | ||
216 | # to clashes in the run-time symbol namespace. | ||
217 | if platform == 'linux': | ||
218 | exposed_symbols_file = 'newview/linux_tools/exposed-symbols.txt' | ||
219 | hidesyms_cmd = 'objcopy --keep-global-symbols ' + exposed_symbols_file + ' $SOURCE $TARGET' | ||
220 | else: | ||
221 | hidesyms_cmd = 'cp -f $SOURCE $TARGET' | ||
222 | |||
213 | if build_target != 'client': | 223 | if build_target != 'client': |
214 | gcc_bin = 'g++-3.3' | 224 | gcc_bin = 'g++-3.3' |
215 | 225 | ||
@@ -366,7 +376,8 @@ for build_target in targets: | |||
366 | output_crashlogger_bin = 'linux_crash_logger/linux-crash-logger-' + arch + '-bin' | 376 | output_crashlogger_bin = 'linux_crash_logger/linux-crash-logger-' + arch + '-bin' |
367 | external_libs = net_external_libs + [ 'db-4.2', 'gtk-x11-2.0' ] | 377 | external_libs = net_external_libs + [ 'db-4.2', 'gtk-x11-2.0' ] |
368 | internal_libs = [ 'llvfs', 'llmath', 'llcommon' ] | 378 | internal_libs = [ 'llvfs', 'llmath', 'llcommon' ] |
369 | create_executable(output_crashlogger_bin, 'linux_crash_logger', internal_libs + external_libs) | 379 | create_executable(output_crashlogger_bin + '-globalsyms', 'linux_crash_logger', internal_libs + external_libs) |
380 | env.Command(output_crashlogger_bin, output_crashlogger_bin + '-globalsyms', hidesyms_cmd) | ||
370 | 381 | ||
371 | create_static_module('llaudio') | 382 | create_static_module('llaudio') |
372 | create_static_module('llmedia') | 383 | create_static_module('llmedia') |
@@ -389,7 +400,8 @@ for build_target in targets: | |||
389 | 'llcharacter', 'llaudio', 'llui', 'llxml', | 400 | 'llcharacter', 'llaudio', 'llui', 'llxml', |
390 | 'llmessage', 'llvfs', 'llmath', 'llcommon' ] | 401 | 'llmessage', 'llvfs', 'llmath', 'llcommon' ] |
391 | 402 | ||
392 | create_executable(output_bin, 'newview', internal_libs + external_libs) | 403 | create_executable(output_bin + '-globalsyms', 'newview', internal_libs + external_libs) |
404 | env.Command(output_bin, output_bin + '-globalsyms', hidesyms_cmd) | ||
393 | 405 | ||
394 | if buildtype == 'releasefordownload': | 406 | if buildtype == 'releasefordownload': |
395 | 407 | ||
@@ -398,7 +410,6 @@ for build_target in targets: | |||
398 | ####################### | 410 | ####################### |
399 | 411 | ||
400 | if platform == 'linux': | 412 | if platform == 'linux': |
401 | |||
402 | env.Command(output_bin + '-stripped', output_bin, strip_cmd) | 413 | env.Command(output_bin + '-stripped', output_bin, strip_cmd) |
403 | env.Command(output_crashlogger_bin + '-stripped', output_crashlogger_bin, strip_cmd) | 414 | env.Command(output_crashlogger_bin + '-stripped', output_crashlogger_bin, strip_cmd) |
404 | manifest_file = 'linux_tools/client-manifest-' + arch | 415 | manifest_file = 'linux_tools/client-manifest-' + arch |
diff --git a/linden/indra/indra_complete/indra_complete.sln b/linden/indra/indra_complete/indra_complete.sln index d0c31ea..f4a8647 100644 --- a/linden/indra/indra_complete/indra_complete.sln +++ b/linden/indra/indra_complete/indra_complete.sln | |||
@@ -217,6 +217,7 @@ EndProject | |||
217 | {4B19F64E-AB97-4FB9-8E1D-74A8104DE0C4} = {4B19F64E-AB97-4FB9-8E1D-74A8104DE0C4} | 217 | {4B19F64E-AB97-4FB9-8E1D-74A8104DE0C4} = {4B19F64E-AB97-4FB9-8E1D-74A8104DE0C4} |
218 | {E5D94794-5671-4BD6-A16D-26EC18F3DB34} = {E5D94794-5671-4BD6-A16D-26EC18F3DB34} | 218 | {E5D94794-5671-4BD6-A16D-26EC18F3DB34} = {E5D94794-5671-4BD6-A16D-26EC18F3DB34} |
219 | {E87FD9BE-BE42-4EA3-BF4D-D992223046D9} = {E87FD9BE-BE42-4EA3-BF4D-D992223046D9} | 219 | {E87FD9BE-BE42-4EA3-BF4D-D992223046D9} = {E87FD9BE-BE42-4EA3-BF4D-D992223046D9} |
220 | {D37774F4-253D-4760-BF64-372A943224A1} = {D37774F4-253D-4760-BF64-372A943224A1} | ||
220 | EndProjectSection | 221 | EndProjectSection |
221 | EndProject | 222 | EndProject |
222 | ProjectSection(ProjectDependencies) = postProject | 223 | ProjectSection(ProjectDependencies) = postProject |
diff --git a/linden/indra/linux_crash_logger/linux_crash_logger.cpp b/linden/indra/linux_crash_logger/linux_crash_logger.cpp index a332ccc..196ff6e 100644 --- a/linden/indra/linux_crash_logger/linux_crash_logger.cpp +++ b/linden/indra/linux_crash_logger/linux_crash_logger.cpp | |||
@@ -238,10 +238,8 @@ int main(int argc, char **argv) | |||
238 | db_filep = new LLFileEncoder("DB", db_file_name.c_str()); | 238 | db_filep = new LLFileEncoder("DB", db_file_name.c_str()); |
239 | 239 | ||
240 | // Get the filename of the SecondLife.log file | 240 | // Get the filename of the SecondLife.log file |
241 | // *TODO tofu - get right MAX_PATH. | 241 | // *NOTE: These buffer sizes are hardcoded into a scanf() below. |
242 | // *FIX: What's up with this? This #define just can't be safe. | 242 | char tmp_sl_name[LL_MAX_PATH]; |
243 | #define MAX_PATH PATH_MAX | ||
244 | char tmp_sl_name[MAX_PATH]; | ||
245 | tmp_sl_name[0] = '\0'; | 243 | tmp_sl_name[0] = '\0'; |
246 | char tmp_space[256]; | 244 | char tmp_space[256]; |
247 | tmp_space[0] = '\0'; | 245 | tmp_space[0] = '\0'; |
@@ -251,7 +249,7 @@ int main(int argc, char **argv) | |||
251 | { | 249 | { |
252 | // This was originally scanning for "SL Log: %[^\r\n]", which happily skipped to the next line | 250 | // This was originally scanning for "SL Log: %[^\r\n]", which happily skipped to the next line |
253 | // on debug logs (which don't have anything after "SL Log:" and tried to open a nonsensical filename. | 251 | // on debug logs (which don't have anything after "SL Log:" and tried to open a nonsensical filename. |
254 | sscanf(db_filep->mBuf.c_str(), "SL Log:%[ ]%[^\r\n]", tmp_space, tmp_sl_name); | 252 | sscanf(db_filep->mBuf.c_str(), "SL Log:%255[ ]%1023[^\r\n]", tmp_space, tmp_sl_name); |
255 | } | 253 | } |
256 | else | 254 | else |
257 | { | 255 | { |
diff --git a/linden/indra/llaudio/audioengine_fmod.cpp b/linden/indra/llaudio/audioengine_fmod.cpp index a4ddd1f..a69212e 100644 --- a/linden/indra/llaudio/audioengine_fmod.cpp +++ b/linden/indra/llaudio/audioengine_fmod.cpp | |||
@@ -1136,7 +1136,7 @@ void * F_CALLBACKAPI windCallback(void *originalbuffer, void *newbuffer, int len | |||
1136 | double nextSample; | 1136 | double nextSample; |
1137 | 1137 | ||
1138 | // start with white noise | 1138 | // start with white noise |
1139 | nextSample = frand(2.0f) - 1.0f; | 1139 | nextSample = llclamp((ll_frand(2.0f) - 1.0f), -1.0f, 1.0f); |
1140 | 1140 | ||
1141 | #if 1 // LLAE_WIND_PINK apply pinking filter | 1141 | #if 1 // LLAE_WIND_PINK apply pinking filter |
1142 | gbuf0 = 0.997f * gbuf0 + 0.0126502f * nextSample; | 1142 | gbuf0 = 0.997f * gbuf0 + 0.0126502f * nextSample; |
diff --git a/linden/indra/llaudio/vorbisencode.cpp b/linden/indra/llaudio/vorbisencode.cpp index 6007940..c8716cc 100644 --- a/linden/indra/llaudio/vorbisencode.cpp +++ b/linden/indra/llaudio/vorbisencode.cpp | |||
@@ -322,7 +322,7 @@ S32 encode_vorbis_file_at(const char *in_fname, const char *out_fname, S32 bitra | |||
322 | /* set up our packet->stream encoder */ | 322 | /* set up our packet->stream encoder */ |
323 | /* pick a random serial number; that way we can more likely build | 323 | /* pick a random serial number; that way we can more likely build |
324 | chained streams just by concatenation */ | 324 | chained streams just by concatenation */ |
325 | ogg_stream_init(&os,(int)frand(0xFFFFFF)); | 325 | ogg_stream_init(&os, ll_rand()); |
326 | 326 | ||
327 | /* Vorbis streams begin with three headers; the initial header (with | 327 | /* Vorbis streams begin with three headers; the initial header (with |
328 | most of the codec setup parameters) which is mandated by the Ogg | 328 | most of the codec setup parameters) which is mandated by the Ogg |
diff --git a/linden/indra/llcharacter/llheadrotmotion.cpp b/linden/indra/llcharacter/llheadrotmotion.cpp index 3bf7be0..1d1771d 100644 --- a/linden/indra/llcharacter/llheadrotmotion.cpp +++ b/linden/indra/llcharacter/llheadrotmotion.cpp | |||
@@ -351,31 +351,31 @@ BOOL LLEyeMotion::onUpdate(F32 time, U8* joint_mask) | |||
351 | //calculate jitter | 351 | //calculate jitter |
352 | if (mEyeJitterTimer.getElapsedTimeF32() > mEyeJitterTime) | 352 | if (mEyeJitterTimer.getElapsedTimeF32() > mEyeJitterTime) |
353 | { | 353 | { |
354 | mEyeJitterTime = EYE_JITTER_MIN_TIME + frand(EYE_JITTER_MAX_TIME - EYE_JITTER_MIN_TIME); | 354 | mEyeJitterTime = EYE_JITTER_MIN_TIME + ll_frand(EYE_JITTER_MAX_TIME - EYE_JITTER_MIN_TIME); |
355 | mEyeJitterYaw = (frand(2.f) - 1.f) * EYE_JITTER_MAX_YAW; | 355 | mEyeJitterYaw = (ll_frand(2.f) - 1.f) * EYE_JITTER_MAX_YAW; |
356 | mEyeJitterPitch = (frand(2.f) - 1.f) * EYE_JITTER_MAX_PITCH; | 356 | mEyeJitterPitch = (ll_frand(2.f) - 1.f) * EYE_JITTER_MAX_PITCH; |
357 | // make sure lookaway time count gets updated, because we're resetting the timer | 357 | // make sure lookaway time count gets updated, because we're resetting the timer |
358 | mEyeLookAwayTime -= llmax(0.f, mEyeJitterTimer.getElapsedTimeF32()); | 358 | mEyeLookAwayTime -= llmax(0.f, mEyeJitterTimer.getElapsedTimeF32()); |
359 | mEyeJitterTimer.reset(); | 359 | mEyeJitterTimer.reset(); |
360 | } | 360 | } |
361 | else if (mEyeJitterTimer.getElapsedTimeF32() > mEyeLookAwayTime) | 361 | else if (mEyeJitterTimer.getElapsedTimeF32() > mEyeLookAwayTime) |
362 | { | 362 | { |
363 | if (frand(1.f) > 0.1f) | 363 | if (ll_frand() > 0.1f) |
364 | { | 364 | { |
365 | // blink while moving eyes some percentage of the time | 365 | // blink while moving eyes some percentage of the time |
366 | mEyeBlinkTime = mEyeBlinkTimer.getElapsedTimeF32(); | 366 | mEyeBlinkTime = mEyeBlinkTimer.getElapsedTimeF32(); |
367 | } | 367 | } |
368 | if (mEyeLookAwayYaw == 0.f && mEyeLookAwayPitch == 0.f) | 368 | if (mEyeLookAwayYaw == 0.f && mEyeLookAwayPitch == 0.f) |
369 | { | 369 | { |
370 | mEyeLookAwayYaw = (frand(2.f) - 1.f) * EYE_LOOK_AWAY_MAX_YAW; | 370 | mEyeLookAwayYaw = (ll_frand(2.f) - 1.f) * EYE_LOOK_AWAY_MAX_YAW; |
371 | mEyeLookAwayPitch = (frand(2.f) - 1.f) * EYE_LOOK_AWAY_MAX_PITCH; | 371 | mEyeLookAwayPitch = (ll_frand(2.f) - 1.f) * EYE_LOOK_AWAY_MAX_PITCH; |
372 | mEyeLookAwayTime = EYE_LOOK_BACK_MIN_TIME + frand(EYE_LOOK_BACK_MAX_TIME - EYE_LOOK_BACK_MIN_TIME); | 372 | mEyeLookAwayTime = EYE_LOOK_BACK_MIN_TIME + ll_frand(EYE_LOOK_BACK_MAX_TIME - EYE_LOOK_BACK_MIN_TIME); |
373 | } | 373 | } |
374 | else | 374 | else |
375 | { | 375 | { |
376 | mEyeLookAwayYaw = 0.f; | 376 | mEyeLookAwayYaw = 0.f; |
377 | mEyeLookAwayPitch = 0.f; | 377 | mEyeLookAwayPitch = 0.f; |
378 | mEyeLookAwayTime = EYE_LOOK_AWAY_MIN_TIME + frand(EYE_LOOK_AWAY_MAX_TIME - EYE_LOOK_AWAY_MIN_TIME); | 378 | mEyeLookAwayTime = EYE_LOOK_AWAY_MIN_TIME + ll_frand(EYE_LOOK_AWAY_MAX_TIME - EYE_LOOK_AWAY_MIN_TIME); |
379 | } | 379 | } |
380 | } | 380 | } |
381 | 381 | ||
@@ -414,7 +414,7 @@ BOOL LLEyeMotion::onUpdate(F32 time, U8* joint_mask) | |||
414 | if (rightEyeBlinkMorph == 0.f) | 414 | if (rightEyeBlinkMorph == 0.f) |
415 | { | 415 | { |
416 | mEyesClosed = FALSE; | 416 | mEyesClosed = FALSE; |
417 | mEyeBlinkTime = EYE_BLINK_MIN_TIME + frand(EYE_BLINK_MAX_TIME - EYE_BLINK_MIN_TIME); | 417 | mEyeBlinkTime = EYE_BLINK_MIN_TIME + ll_frand(EYE_BLINK_MAX_TIME - EYE_BLINK_MIN_TIME); |
418 | mEyeBlinkTimer.reset(); | 418 | mEyeBlinkTimer.reset(); |
419 | } | 419 | } |
420 | } | 420 | } |
diff --git a/linden/indra/llcommon/doublelinkedlist.h b/linden/indra/llcommon/doublelinkedlist.h index ef289b2..833e73c 100644 --- a/linden/indra/llcommon/doublelinkedlist.h +++ b/linden/indra/llcommon/doublelinkedlist.h | |||
@@ -1362,7 +1362,7 @@ void LLDoubleLinkedList<DATA_TYPE>::scramble() | |||
1362 | DATA_TYPE *datap = getFirstData(); | 1362 | DATA_TYPE *datap = getFirstData(); |
1363 | while(datap) | 1363 | while(datap) |
1364 | { | 1364 | { |
1365 | random_number = gLindenLabRandomNumber.llrand() % 5; | 1365 | random_number = ll_rand(5); |
1366 | 1366 | ||
1367 | if (0 == random_number) | 1367 | if (0 == random_number) |
1368 | { | 1368 | { |
diff --git a/linden/indra/llcommon/lldefs.h b/linden/indra/llcommon/lldefs.h index 2bba4f8..c0435fb 100644 --- a/linden/indra/llcommon/lldefs.h +++ b/linden/indra/llcommon/lldefs.h | |||
@@ -132,11 +132,22 @@ const U32 RIGHT_SIDE = 4; | |||
132 | const U32 TOP_SIDE = 5; | 132 | const U32 TOP_SIDE = 5; |
133 | const U32 BOTTOM_SIDE = 6; | 133 | const U32 BOTTOM_SIDE = 6; |
134 | 134 | ||
135 | |||
136 | // | ||
137 | // *NOTE: These values may be used as hard-coded numbers in scanf() variants. | ||
138 | // | ||
139 | // -------------- | ||
140 | // DO NOT CHANGE. | ||
141 | // -------------- | ||
142 | // | ||
135 | const U32 LL_MAX_PATH = 1024; // buffer size of maximum path + filename string length | 143 | const U32 LL_MAX_PATH = 1024; // buffer size of maximum path + filename string length |
136 | 144 | ||
137 | // For strings we send in messages | 145 | // For strings we send in messages |
138 | const U32 STD_STRING_BUF_SIZE = 255; // Buffer size | 146 | const U32 STD_STRING_BUF_SIZE = 255; // Buffer size |
139 | const U32 STD_STRING_STR_LEN = 254; // Length of the string (not including \0) | 147 | const U32 STD_STRING_STR_LEN = 254; // Length of the string (not including \0) |
148 | |||
149 | // *NOTE: This value is used as hard-coded numbers in scanf() variants. | ||
150 | // DO NOT CHANGE. | ||
140 | const U32 MAX_STRING = STD_STRING_BUF_SIZE; // Buffer size | 151 | const U32 MAX_STRING = STD_STRING_BUF_SIZE; // Buffer size |
141 | 152 | ||
142 | const U32 MAXADDRSTR = 17; // 123.567.901.345 = 15 chars + \0 + 1 for good luck | 153 | const U32 MAXADDRSTR = 17; // 123.567.901.345 = 15 chars + \0 + 1 for good luck |
diff --git a/linden/indra/llcommon/llfasttimer.h b/linden/indra/llcommon/llfasttimer.h index e598096..b5e0734 100644 --- a/linden/indra/llcommon/llfasttimer.h +++ b/linden/indra/llcommon/llfasttimer.h | |||
@@ -47,7 +47,11 @@ public: | |||
47 | FTM_IDLE, | 47 | FTM_IDLE, |
48 | FTM_SLEEP, | 48 | FTM_SLEEP, |
49 | 49 | ||
50 | // common simulate components | 50 | // common messaging components |
51 | FTM_PUMP, | ||
52 | FTM_CURL, | ||
53 | |||
54 | // common simulation components | ||
51 | FTM_UPDATE_ANIMATION, | 55 | FTM_UPDATE_ANIMATION, |
52 | FTM_UPDATE_TERRAIN, | 56 | FTM_UPDATE_TERRAIN, |
53 | FTM_UPDATE_PRIMITIVES, | 57 | FTM_UPDATE_PRIMITIVES, |
diff --git a/linden/indra/llcommon/llptrskiplist.h b/linden/indra/llcommon/llptrskiplist.h index bae40b8..df56556 100644 --- a/linden/indra/llcommon/llptrskiplist.h +++ b/linden/indra/llcommon/llptrskiplist.h | |||
@@ -273,7 +273,7 @@ inline BOOL LLPtrSkipList<DATA_TYPE, BINARY_DEPTH>::addData(DATA_TYPE *data) | |||
273 | S32 newlevel; | 273 | S32 newlevel; |
274 | for (newlevel = 1; newlevel <= mLevel && newlevel < BINARY_DEPTH; newlevel++) | 274 | for (newlevel = 1; newlevel <= mLevel && newlevel < BINARY_DEPTH; newlevel++) |
275 | { | 275 | { |
276 | if (frand(1.f) < 0.5f) | 276 | if (ll_frand() < 0.5f) |
277 | break; | 277 | break; |
278 | } | 278 | } |
279 | 279 | ||
diff --git a/linden/indra/llcommon/llptrskipmap.h b/linden/indra/llcommon/llptrskipmap.h index d4e4de3..c4e131f 100644 --- a/linden/indra/llcommon/llptrskipmap.h +++ b/linden/indra/llcommon/llptrskipmap.h | |||
@@ -343,7 +343,7 @@ inline DATA_T &LLPtrSkipMap<INDEX_T, DATA_T, BINARY_DEPTH>::addData(const INDEX_ | |||
343 | S32 newlevel; | 343 | S32 newlevel; |
344 | for (newlevel = 1; newlevel <= mLevel && newlevel < BINARY_DEPTH; newlevel++) | 344 | for (newlevel = 1; newlevel <= mLevel && newlevel < BINARY_DEPTH; newlevel++) |
345 | { | 345 | { |
346 | if (frand(1.f) < 0.5f) | 346 | if (ll_frand() < 0.5f) |
347 | { | 347 | { |
348 | break; | 348 | break; |
349 | } | 349 | } |
@@ -411,7 +411,7 @@ inline DATA_T &LLPtrSkipMap<INDEX_T, DATA_T, BINARY_DEPTH>::addData(const INDEX_ | |||
411 | S32 newlevel; | 411 | S32 newlevel; |
412 | for (newlevel = 1; newlevel <= mLevel && newlevel < BINARY_DEPTH; newlevel++) | 412 | for (newlevel = 1; newlevel <= mLevel && newlevel < BINARY_DEPTH; newlevel++) |
413 | { | 413 | { |
414 | if (frand(1.f) < 0.5f) | 414 | if (ll_frand() < 0.5f) |
415 | break; | 415 | break; |
416 | } | 416 | } |
417 | 417 | ||
@@ -489,7 +489,7 @@ inline DATA_T &LLPtrSkipMap<INDEX_T, DATA_T, BINARY_DEPTH>::getData(const INDEX_ | |||
489 | S32 newlevel; | 489 | S32 newlevel; |
490 | for (newlevel = 1; newlevel <= mLevel && newlevel < BINARY_DEPTH; newlevel++) | 490 | for (newlevel = 1; newlevel <= mLevel && newlevel < BINARY_DEPTH; newlevel++) |
491 | { | 491 | { |
492 | if (frand(1.f) < 0.5f) | 492 | if (ll_frand() < 0.5f) |
493 | break; | 493 | break; |
494 | } | 494 | } |
495 | 495 | ||
diff --git a/linden/indra/llcommon/llskiplist.h b/linden/indra/llcommon/llskiplist.h index 0d85749..bd28cea 100644 --- a/linden/indra/llcommon/llskiplist.h +++ b/linden/indra/llcommon/llskiplist.h | |||
@@ -242,7 +242,7 @@ inline BOOL LLSkipList<DATA_TYPE, BINARY_DEPTH>::addData(const DATA_TYPE& data) | |||
242 | S32 newlevel; | 242 | S32 newlevel; |
243 | for (newlevel = 1; newlevel <= mLevel && newlevel < BINARY_DEPTH; newlevel++) | 243 | for (newlevel = 1; newlevel <= mLevel && newlevel < BINARY_DEPTH; newlevel++) |
244 | { | 244 | { |
245 | if (frand(1.f) < 0.5f) | 245 | if (ll_frand() < 0.5f) |
246 | break; | 246 | break; |
247 | } | 247 | } |
248 | 248 | ||
diff --git a/linden/indra/llcommon/llversion.h b/linden/indra/llcommon/llversion.h index 83477a1..9cb01a3 100644 --- a/linden/indra/llcommon/llversion.h +++ b/linden/indra/llcommon/llversion.h | |||
@@ -34,7 +34,7 @@ | |||
34 | const S32 LL_VERSION_MAJOR = 1; | 34 | const S32 LL_VERSION_MAJOR = 1; |
35 | const S32 LL_VERSION_MINOR = 13; | 35 | const S32 LL_VERSION_MINOR = 13; |
36 | const S32 LL_VERSION_PATCH = 2; | 36 | const S32 LL_VERSION_PATCH = 2; |
37 | const S32 LL_VERSION_BUILD = 12; | 37 | const S32 LL_VERSION_BUILD = 15; |
38 | 38 | ||
39 | 39 | ||
40 | 40 | ||
diff --git a/linden/indra/llinventory/llinventory.cpp b/linden/indra/llinventory/llinventory.cpp index 1f7efb3..3235748 100644 --- a/linden/indra/llinventory/llinventory.cpp +++ b/linden/indra/llinventory/llinventory.cpp | |||
@@ -320,6 +320,8 @@ void LLInventoryObject::setType(LLAssetType::EType type) | |||
320 | // virtual | 320 | // virtual |
321 | BOOL LLInventoryObject::importLegacyStream(std::istream& input_stream) | 321 | BOOL LLInventoryObject::importLegacyStream(std::istream& input_stream) |
322 | { | 322 | { |
323 | // *NOTE: Changing the buffer size will require changing the scanf | ||
324 | // calls below. | ||
323 | char buffer[MAX_STRING]; | 325 | char buffer[MAX_STRING]; |
324 | char keyword[MAX_STRING]; | 326 | char keyword[MAX_STRING]; |
325 | char valuestr[MAX_STRING]; | 327 | char valuestr[MAX_STRING]; |
@@ -358,7 +360,7 @@ BOOL LLInventoryObject::importLegacyStream(std::istream& input_stream) | |||
358 | { | 360 | { |
359 | //strcpy(valuestr, buffer + strlen(keyword) + 3); | 361 | //strcpy(valuestr, buffer + strlen(keyword) + 3); |
360 | // *NOTE: Not ANSI C, but widely supported. | 362 | // *NOTE: Not ANSI C, but widely supported. |
361 | sscanf(buffer, " %254s %[^|]", keyword, valuestr); | 363 | sscanf(buffer, " %254s %254[^|]", keyword, valuestr); |
362 | mName.assign(valuestr); | 364 | mName.assign(valuestr); |
363 | LLString::replaceNonstandardASCII(mName, ' '); | 365 | LLString::replaceNonstandardASCII(mName, ' '); |
364 | LLString::replaceChar(mName, '|', ' '); | 366 | LLString::replaceChar(mName, '|', ' '); |
@@ -681,6 +683,8 @@ BOOL LLInventoryItem::unpackMessage(LLMessageSystem* msg, const char* block, S32 | |||
681 | // virtual | 683 | // virtual |
682 | BOOL LLInventoryItem::importFile(FILE* fp) | 684 | BOOL LLInventoryItem::importFile(FILE* fp) |
683 | { | 685 | { |
686 | // *NOTE: Changing the buffer size will require changing the scanf | ||
687 | // calls below. | ||
684 | char buffer[MAX_STRING]; | 688 | char buffer[MAX_STRING]; |
685 | char keyword[MAX_STRING]; | 689 | char keyword[MAX_STRING]; |
686 | char valuestr[MAX_STRING]; | 690 | char valuestr[MAX_STRING]; |
@@ -769,7 +773,7 @@ BOOL LLInventoryItem::importFile(FILE* fp) | |||
769 | { | 773 | { |
770 | //strcpy(valuestr, buffer + strlen(keyword) + 3); | 774 | //strcpy(valuestr, buffer + strlen(keyword) + 3); |
771 | // *NOTE: Not ANSI C, but widely supported. | 775 | // *NOTE: Not ANSI C, but widely supported. |
772 | sscanf(buffer, " %254s%[\t]%[^|]", keyword, junk, valuestr); | 776 | sscanf(buffer, " %254s%254[\t]%254[^|]", keyword, junk, valuestr); |
773 | 777 | ||
774 | // IW: sscanf chokes and puts | in valuestr if there's no name | 778 | // IW: sscanf chokes and puts | in valuestr if there's no name |
775 | if (valuestr[0] == '|') | 779 | if (valuestr[0] == '|') |
@@ -785,7 +789,7 @@ BOOL LLInventoryItem::importFile(FILE* fp) | |||
785 | { | 789 | { |
786 | //strcpy(valuestr, buffer + strlen(keyword) + 3); | 790 | //strcpy(valuestr, buffer + strlen(keyword) + 3); |
787 | // *NOTE: Not ANSI C, but widely supported. | 791 | // *NOTE: Not ANSI C, but widely supported. |
788 | sscanf(buffer, " %s%[\t]%[^|]", keyword, junk, valuestr); | 792 | sscanf(buffer, " %254s%254[\t]%254[^|]", keyword, junk, valuestr); |
789 | 793 | ||
790 | if (valuestr[0] == '|') | 794 | if (valuestr[0] == '|') |
791 | { | 795 | { |
@@ -875,6 +879,8 @@ BOOL LLInventoryItem::exportFile(FILE* fp, BOOL include_asset_key) const | |||
875 | // virtual | 879 | // virtual |
876 | BOOL LLInventoryItem::importLegacyStream(std::istream& input_stream) | 880 | BOOL LLInventoryItem::importLegacyStream(std::istream& input_stream) |
877 | { | 881 | { |
882 | // *NOTE: Changing the buffer size will require changing the scanf | ||
883 | // calls below. | ||
878 | char buffer[MAX_STRING]; | 884 | char buffer[MAX_STRING]; |
879 | char keyword[MAX_STRING]; | 885 | char keyword[MAX_STRING]; |
880 | char valuestr[MAX_STRING]; | 886 | char valuestr[MAX_STRING]; |
@@ -889,7 +895,7 @@ BOOL LLInventoryItem::importLegacyStream(std::istream& input_stream) | |||
889 | while(success && input_stream.good()) | 895 | while(success && input_stream.good()) |
890 | { | 896 | { |
891 | input_stream.getline(buffer, MAX_STRING); | 897 | input_stream.getline(buffer, MAX_STRING); |
892 | sscanf(buffer, " %s %s", keyword, valuestr); | 898 | sscanf(buffer, " %254s %254s", keyword, valuestr); |
893 | if(!keyword) | 899 | if(!keyword) |
894 | { | 900 | { |
895 | continue; | 901 | continue; |
@@ -963,7 +969,7 @@ BOOL LLInventoryItem::importLegacyStream(std::istream& input_stream) | |||
963 | { | 969 | { |
964 | //strcpy(valuestr, buffer + strlen(keyword) + 3); | 970 | //strcpy(valuestr, buffer + strlen(keyword) + 3); |
965 | // *NOTE: Not ANSI C, but widely supported. | 971 | // *NOTE: Not ANSI C, but widely supported. |
966 | sscanf(buffer, " %s%[\t]%[^|]", keyword, junk, valuestr); | 972 | sscanf(buffer, " %254s%254[\t]%254[^|]", keyword, junk, valuestr); |
967 | 973 | ||
968 | // IW: sscanf chokes and puts | in valuestr if there's no name | 974 | // IW: sscanf chokes and puts | in valuestr if there's no name |
969 | if (valuestr[0] == '|') | 975 | if (valuestr[0] == '|') |
@@ -979,7 +985,7 @@ BOOL LLInventoryItem::importLegacyStream(std::istream& input_stream) | |||
979 | { | 985 | { |
980 | //strcpy(valuestr, buffer + strlen(keyword) + 3); | 986 | //strcpy(valuestr, buffer + strlen(keyword) + 3); |
981 | // *NOTE: Not ANSI C, but widely supported. | 987 | // *NOTE: Not ANSI C, but widely supported. |
982 | sscanf(buffer, " %s%[\t]%[^|]", keyword, junk, valuestr); | 988 | sscanf(buffer, " %254s%254[\t]%254[^|]", keyword, junk, valuestr); |
983 | 989 | ||
984 | if (valuestr[0] == '|') | 990 | if (valuestr[0] == '|') |
985 | { | 991 | { |
@@ -1522,6 +1528,8 @@ void LLInventoryCategory::unpackMessage(LLMessageSystem* msg, | |||
1522 | // virtual | 1528 | // virtual |
1523 | BOOL LLInventoryCategory::importFile(FILE* fp) | 1529 | BOOL LLInventoryCategory::importFile(FILE* fp) |
1524 | { | 1530 | { |
1531 | // *NOTE: Changing the buffer size will require changing the scanf | ||
1532 | // calls below. | ||
1525 | char buffer[MAX_STRING]; | 1533 | char buffer[MAX_STRING]; |
1526 | char keyword[MAX_STRING]; | 1534 | char keyword[MAX_STRING]; |
1527 | char valuestr[MAX_STRING]; | 1535 | char valuestr[MAX_STRING]; |
@@ -1531,7 +1539,7 @@ BOOL LLInventoryCategory::importFile(FILE* fp) | |||
1531 | while(!feof(fp)) | 1539 | while(!feof(fp)) |
1532 | { | 1540 | { |
1533 | fgets(buffer, MAX_STRING, fp); | 1541 | fgets(buffer, MAX_STRING, fp); |
1534 | sscanf(buffer, " %s %s", keyword, valuestr); | 1542 | sscanf(buffer, " %254s %254s", keyword, valuestr); |
1535 | if(!keyword) | 1543 | if(!keyword) |
1536 | { | 1544 | { |
1537 | continue; | 1545 | continue; |
@@ -1564,7 +1572,7 @@ BOOL LLInventoryCategory::importFile(FILE* fp) | |||
1564 | { | 1572 | { |
1565 | //strcpy(valuestr, buffer + strlen(keyword) + 3); | 1573 | //strcpy(valuestr, buffer + strlen(keyword) + 3); |
1566 | // *NOTE: Not ANSI C, but widely supported. | 1574 | // *NOTE: Not ANSI C, but widely supported. |
1567 | sscanf(buffer, " %s %[^|]", keyword, valuestr); | 1575 | sscanf(buffer, " %254s %254[^|]", keyword, valuestr); |
1568 | mName.assign(valuestr); | 1576 | mName.assign(valuestr); |
1569 | LLString::replaceNonstandardASCII(mName, ' '); | 1577 | LLString::replaceNonstandardASCII(mName, ' '); |
1570 | LLString::replaceChar(mName, '|', ' '); | 1578 | LLString::replaceChar(mName, '|', ' '); |
@@ -1597,6 +1605,8 @@ BOOL LLInventoryCategory::exportFile(FILE* fp, BOOL) const | |||
1597 | // virtual | 1605 | // virtual |
1598 | BOOL LLInventoryCategory::importLegacyStream(std::istream& input_stream) | 1606 | BOOL LLInventoryCategory::importLegacyStream(std::istream& input_stream) |
1599 | { | 1607 | { |
1608 | // *NOTE: Changing the buffer size will require changing the scanf | ||
1609 | // calls below. | ||
1600 | char buffer[MAX_STRING]; | 1610 | char buffer[MAX_STRING]; |
1601 | char keyword[MAX_STRING]; | 1611 | char keyword[MAX_STRING]; |
1602 | char valuestr[MAX_STRING]; | 1612 | char valuestr[MAX_STRING]; |
@@ -1606,7 +1616,7 @@ BOOL LLInventoryCategory::importLegacyStream(std::istream& input_stream) | |||
1606 | while(input_stream.good()) | 1616 | while(input_stream.good()) |
1607 | { | 1617 | { |
1608 | input_stream.getline(buffer, MAX_STRING); | 1618 | input_stream.getline(buffer, MAX_STRING); |
1609 | sscanf(buffer, " %s %s", keyword, valuestr); | 1619 | sscanf(buffer, " %254s %254s", keyword, valuestr); |
1610 | if(!keyword) | 1620 | if(!keyword) |
1611 | { | 1621 | { |
1612 | continue; | 1622 | continue; |
@@ -1639,7 +1649,7 @@ BOOL LLInventoryCategory::importLegacyStream(std::istream& input_stream) | |||
1639 | { | 1649 | { |
1640 | //strcpy(valuestr, buffer + strlen(keyword) + 3); | 1650 | //strcpy(valuestr, buffer + strlen(keyword) + 3); |
1641 | // *NOTE: Not ANSI C, but widely supported. | 1651 | // *NOTE: Not ANSI C, but widely supported. |
1642 | sscanf(buffer, " %s %[^|]", keyword, valuestr); | 1652 | sscanf(buffer, " %254s %254[^|]", keyword, valuestr); |
1643 | mName.assign(valuestr); | 1653 | mName.assign(valuestr); |
1644 | LLString::replaceNonstandardASCII(mName, ' '); | 1654 | LLString::replaceNonstandardASCII(mName, ' '); |
1645 | LLString::replaceChar(mName, '|', ' '); | 1655 | LLString::replaceChar(mName, '|', ' '); |
diff --git a/linden/indra/llinventory/lllandmark.cpp b/linden/indra/llinventory/lllandmark.cpp index bca64d1..d7dca20 100644 --- a/linden/indra/llinventory/lllandmark.cpp +++ b/linden/indra/llinventory/lllandmark.cpp | |||
@@ -138,10 +138,12 @@ LLLandmark* LLLandmark::constructFromString(const char *buffer) | |||
138 | } | 138 | } |
139 | else if(version == 2) | 139 | else if(version == 2) |
140 | { | 140 | { |
141 | // *NOTE: Changing the buffer size will require changing the | ||
142 | // scanf call below. | ||
141 | char region_id_str[MAX_STRING]; | 143 | char region_id_str[MAX_STRING]; |
142 | LLVector3 pos; | 144 | LLVector3 pos; |
143 | cur += chars_read; | 145 | cur += chars_read; |
144 | count = sscanf(cur, "region_id %s\n%n", region_id_str, &chars_read); | 146 | count = sscanf(cur, "region_id %254s\n%n", region_id_str, &chars_read); |
145 | if(count != 1) goto error; | 147 | if(count != 1) goto error; |
146 | cur += chars_read; | 148 | cur += chars_read; |
147 | count = sscanf(cur, "local_pos %f %f %f\n%n", pos.mV+VX, pos.mV+VY, pos.mV+VZ, &chars_read); | 149 | count = sscanf(cur, "local_pos %f %f %f\n%n", pos.mV+VX, pos.mV+VY, pos.mV+VZ, &chars_read); |
diff --git a/linden/indra/llinventory/llpermissions.cpp b/linden/indra/llinventory/llpermissions.cpp index 39e7a72..35dbc3e 100644 --- a/linden/indra/llinventory/llpermissions.cpp +++ b/linden/indra/llinventory/llpermissions.cpp | |||
@@ -511,6 +511,8 @@ BOOL LLPermissions::importFile(FILE *fp) | |||
511 | init(LLUUID::null, LLUUID::null, LLUUID::null, LLUUID::null); | 511 | init(LLUUID::null, LLUUID::null, LLUUID::null, LLUUID::null); |
512 | const S32 BUFSIZE = 16384; | 512 | const S32 BUFSIZE = 16384; |
513 | 513 | ||
514 | // *NOTE: Changing the buffer size will require changing the scanf | ||
515 | // calls below. | ||
514 | char buffer[BUFSIZE]; | 516 | char buffer[BUFSIZE]; |
515 | char keyword[256]; | 517 | char keyword[256]; |
516 | char valuestr[256]; | 518 | char valuestr[256]; |
@@ -523,7 +525,7 @@ BOOL LLPermissions::importFile(FILE *fp) | |||
523 | while (!feof(fp)) | 525 | while (!feof(fp)) |
524 | { | 526 | { |
525 | fgets(buffer, BUFSIZE, fp); | 527 | fgets(buffer, BUFSIZE, fp); |
526 | sscanf(buffer, " %s %s", keyword, valuestr); | 528 | sscanf(buffer, " %255s %255s", keyword, valuestr); |
527 | if (!keyword) | 529 | if (!keyword) |
528 | { | 530 | { |
529 | continue; | 531 | continue; |
@@ -571,22 +573,22 @@ BOOL LLPermissions::importFile(FILE *fp) | |||
571 | } | 573 | } |
572 | else if (!strcmp("creator_id", keyword)) | 574 | else if (!strcmp("creator_id", keyword)) |
573 | { | 575 | { |
574 | sscanf(valuestr, "%s", uuid_str); | 576 | sscanf(valuestr, "%255s", uuid_str); |
575 | mCreator.set(uuid_str); | 577 | mCreator.set(uuid_str); |
576 | } | 578 | } |
577 | else if (!strcmp("owner_id", keyword)) | 579 | else if (!strcmp("owner_id", keyword)) |
578 | { | 580 | { |
579 | sscanf(valuestr, "%s", uuid_str); | 581 | sscanf(valuestr, "%255s", uuid_str); |
580 | mOwner.set(uuid_str); | 582 | mOwner.set(uuid_str); |
581 | } | 583 | } |
582 | else if (!strcmp("last_owner_id", keyword)) | 584 | else if (!strcmp("last_owner_id", keyword)) |
583 | { | 585 | { |
584 | sscanf(valuestr, "%s", uuid_str); | 586 | sscanf(valuestr, "%255s", uuid_str); |
585 | mLastOwner.set(uuid_str); | 587 | mLastOwner.set(uuid_str); |
586 | } | 588 | } |
587 | else if (!strcmp("group_id", keyword)) | 589 | else if (!strcmp("group_id", keyword)) |
588 | { | 590 | { |
589 | sscanf(valuestr, "%s", uuid_str); | 591 | sscanf(valuestr, "%255s", uuid_str); |
590 | mGroup.set(uuid_str); | 592 | mGroup.set(uuid_str); |
591 | } | 593 | } |
592 | else if (!strcmp("group_owned", keyword)) | 594 | else if (!strcmp("group_owned", keyword)) |
@@ -644,6 +646,8 @@ BOOL LLPermissions::importLegacyStream(std::istream& input_stream) | |||
644 | init(LLUUID::null, LLUUID::null, LLUUID::null, LLUUID::null); | 646 | init(LLUUID::null, LLUUID::null, LLUUID::null, LLUUID::null); |
645 | const S32 BUFSIZE = 16384; | 647 | const S32 BUFSIZE = 16384; |
646 | 648 | ||
649 | // *NOTE: Changing the buffer size will require changing the scanf | ||
650 | // calls below. | ||
647 | char buffer[BUFSIZE]; | 651 | char buffer[BUFSIZE]; |
648 | char keyword[256]; | 652 | char keyword[256]; |
649 | char valuestr[256]; | 653 | char valuestr[256]; |
@@ -656,7 +660,7 @@ BOOL LLPermissions::importLegacyStream(std::istream& input_stream) | |||
656 | while (input_stream.good()) | 660 | while (input_stream.good()) |
657 | { | 661 | { |
658 | input_stream.getline(buffer, BUFSIZE); | 662 | input_stream.getline(buffer, BUFSIZE); |
659 | sscanf(buffer, " %s %s", keyword, valuestr); | 663 | sscanf(buffer, " %255s %255s", keyword, valuestr); |
660 | if (!keyword) | 664 | if (!keyword) |
661 | { | 665 | { |
662 | continue; | 666 | continue; |
@@ -704,22 +708,22 @@ BOOL LLPermissions::importLegacyStream(std::istream& input_stream) | |||
704 | } | 708 | } |
705 | else if (!strcmp("creator_id", keyword)) | 709 | else if (!strcmp("creator_id", keyword)) |
706 | { | 710 | { |
707 | sscanf(valuestr, "%s", uuid_str); | 711 | sscanf(valuestr, "%255s", uuid_str); |
708 | mCreator.set(uuid_str); | 712 | mCreator.set(uuid_str); |
709 | } | 713 | } |
710 | else if (!strcmp("owner_id", keyword)) | 714 | else if (!strcmp("owner_id", keyword)) |
711 | { | 715 | { |
712 | sscanf(valuestr, "%s", uuid_str); | 716 | sscanf(valuestr, "%255s", uuid_str); |
713 | mOwner.set(uuid_str); | 717 | mOwner.set(uuid_str); |
714 | } | 718 | } |
715 | else if (!strcmp("last_owner_id", keyword)) | 719 | else if (!strcmp("last_owner_id", keyword)) |
716 | { | 720 | { |
717 | sscanf(valuestr, "%s", uuid_str); | 721 | sscanf(valuestr, "%255s", uuid_str); |
718 | mLastOwner.set(uuid_str); | 722 | mLastOwner.set(uuid_str); |
719 | } | 723 | } |
720 | else if (!strcmp("group_id", keyword)) | 724 | else if (!strcmp("group_id", keyword)) |
721 | { | 725 | { |
722 | sscanf(valuestr, "%s", uuid_str); | 726 | sscanf(valuestr, "%255s", uuid_str); |
723 | mGroup.set(uuid_str); | 727 | mGroup.set(uuid_str); |
724 | } | 728 | } |
725 | else if (!strcmp("group_owned", keyword)) | 729 | else if (!strcmp("group_owned", keyword)) |
diff --git a/linden/indra/llinventory/llsaleinfo.cpp b/linden/indra/llinventory/llsaleinfo.cpp index b82bd18..98043d1 100644 --- a/linden/indra/llinventory/llsaleinfo.cpp +++ b/linden/indra/llinventory/llsaleinfo.cpp | |||
@@ -158,6 +158,8 @@ BOOL LLSaleInfo::importFile(FILE* fp, BOOL& has_perm_mask, U32& perm_mask) | |||
158 | { | 158 | { |
159 | has_perm_mask = FALSE; | 159 | has_perm_mask = FALSE; |
160 | 160 | ||
161 | // *NOTE: Changing the buffer size will require changing the scanf | ||
162 | // calls below. | ||
161 | char buffer[MAX_STRING]; | 163 | char buffer[MAX_STRING]; |
162 | char keyword[MAX_STRING]; | 164 | char keyword[MAX_STRING]; |
163 | char valuestr[MAX_STRING]; | 165 | char valuestr[MAX_STRING]; |
@@ -168,7 +170,7 @@ BOOL LLSaleInfo::importFile(FILE* fp, BOOL& has_perm_mask, U32& perm_mask) | |||
168 | while(success && (!feof(fp))) | 170 | while(success && (!feof(fp))) |
169 | { | 171 | { |
170 | fgets(buffer, MAX_STRING, fp); | 172 | fgets(buffer, MAX_STRING, fp); |
171 | sscanf(buffer, " %s %s", keyword, valuestr); | 173 | sscanf(buffer, " %254s %254s", keyword, valuestr); |
172 | if(!keyword) | 174 | if(!keyword) |
173 | { | 175 | { |
174 | continue; | 176 | continue; |
@@ -209,6 +211,8 @@ BOOL LLSaleInfo::importLegacyStream(std::istream& input_stream, BOOL& has_perm_m | |||
209 | { | 211 | { |
210 | has_perm_mask = FALSE; | 212 | has_perm_mask = FALSE; |
211 | 213 | ||
214 | // *NOTE: Changing the buffer size will require changing the scanf | ||
215 | // calls below. | ||
212 | char buffer[MAX_STRING]; | 216 | char buffer[MAX_STRING]; |
213 | char keyword[MAX_STRING]; | 217 | char keyword[MAX_STRING]; |
214 | char valuestr[MAX_STRING]; | 218 | char valuestr[MAX_STRING]; |
@@ -219,7 +223,7 @@ BOOL LLSaleInfo::importLegacyStream(std::istream& input_stream, BOOL& has_perm_m | |||
219 | while(success && input_stream.good()) | 223 | while(success && input_stream.good()) |
220 | { | 224 | { |
221 | input_stream.getline(buffer, MAX_STRING); | 225 | input_stream.getline(buffer, MAX_STRING); |
222 | sscanf(buffer, " %s %s", keyword, valuestr); | 226 | sscanf(buffer, " %254s %254s", keyword, valuestr); |
223 | if(!keyword) | 227 | if(!keyword) |
224 | { | 228 | { |
225 | continue; | 229 | continue; |
diff --git a/linden/indra/llmath/llrand.cpp b/linden/indra/llmath/llrand.cpp index 38e0639..4c214c4 100644 --- a/linden/indra/llmath/llrand.cpp +++ b/linden/indra/llmath/llrand.cpp | |||
@@ -1,6 +1,6 @@ | |||
1 | /** | 1 | /** |
2 | * @file llrand.cpp | 2 | * @file llrand.cpp |
3 | * @brief a few useful math functions. | 3 | * @brief Global random generator. |
4 | * | 4 | * |
5 | * Copyright (c) 2000-2007, Linden Research, Inc. | 5 | * Copyright (c) 2000-2007, Linden Research, Inc. |
6 | * | 6 | * |
@@ -30,45 +30,34 @@ | |||
30 | #include "llrand.h" | 30 | #include "llrand.h" |
31 | #include "lluuid.h" | 31 | #include "lluuid.h" |
32 | 32 | ||
33 | /* Put this back if you re-enabled slamFPCW | 33 | static LLRandLagFib2281 gRandomGenerator(LLUUID::getRandomSeed()); |
34 | #if LL_WINDOWS | ||
35 | #include <float.h> | ||
36 | #else | ||
37 | #include <stdlib.h> | ||
38 | #endif | ||
39 | */ | ||
40 | 34 | ||
41 | void slamFPCW( void ) | 35 | S32 ll_rand() |
42 | { | 36 | { |
43 | /* | 37 | return (S32)(gRandomGenerator() * RAND_MAX); |
44 | #if LL_WINDOWS | ||
45 | // for Intel based CPUs, slam the FP control word directly | ||
46 | WORD wTemp, wSave; | ||
47 | |||
48 | __asm fstcw wSave | ||
49 | if ( (wSave & 0x300) // Not single mode | ||
50 | ||(0x3f != (wSave & 0x3f)) // Exceptions enabled | ||
51 | ||(wSave & 0xC00)) // Not round to nearest mode | ||
52 | { | ||
53 | __asm | ||
54 | { | ||
55 | mov ax, wSave | ||
56 | and ax, not 300h ;; single mode | ||
57 | or ax, 3fh ;; disable all exceptions | ||
58 | and ax, not 0xC00 ;; round to nearest mode | ||
59 | mov wTemp, ax | ||
60 | fldcw wTemp | ||
61 | } | ||
62 | } | ||
63 | #endif | ||
64 | */ | ||
65 | } | 38 | } |
66 | 39 | ||
67 | LLRand gLindenLabRandomNumber(LLUUID::getRandomSeed()); | 40 | S32 ll_rand(S32 val) |
41 | { | ||
42 | return (S32)(gRandomGenerator() * val); | ||
43 | } | ||
44 | |||
45 | F32 ll_frand() | ||
46 | { | ||
47 | return (F32)gRandomGenerator(); | ||
48 | } | ||
68 | 49 | ||
69 | F32 frand(F32 val) | 50 | F32 ll_frand(F32 val) |
70 | { | 51 | { |
71 | // return (val * (F32)rand()/(F32)RAND_MAX); | 52 | return (F32)gRandomGenerator() * val; |
72 | return gLindenLabRandomNumber.llfrand(val); | ||
73 | } | 53 | } |
74 | 54 | ||
55 | F64 ll_drand() | ||
56 | { | ||
57 | return gRandomGenerator(); | ||
58 | } | ||
59 | |||
60 | F64 ll_drand(F64 val) | ||
61 | { | ||
62 | return gRandomGenerator() * val; | ||
63 | } | ||
diff --git a/linden/indra/llmath/llrand.h b/linden/indra/llmath/llrand.h index db9f353..47b5651 100644 --- a/linden/indra/llmath/llrand.h +++ b/linden/indra/llmath/llrand.h | |||
@@ -1,6 +1,6 @@ | |||
1 | /** | 1 | /** |
2 | * @file llrand.h | 2 | * @file llrand.h |
3 | * @brief Some useful math functions. | 3 | * @brief Information, functions, and typedefs for randomness. |
4 | * | 4 | * |
5 | * Copyright (c) 2000-2007, Linden Research, Inc. | 5 | * Copyright (c) 2000-2007, Linden Research, Inc. |
6 | * | 6 | * |
@@ -28,61 +28,101 @@ | |||
28 | #ifndef LL_LLRAND_H | 28 | #ifndef LL_LLRAND_H |
29 | #define LL_LLRAND_H | 29 | #define LL_LLRAND_H |
30 | 30 | ||
31 | // As long as you #include "llviewerprecompiledheaders.h", | 31 | #include "boost/random/lagged_fibonacci.hpp" |
32 | // you can use "gLindenLabRandomNumber.llfrand( range );" which returns a | 32 | #include "boost/random/mersenne_twister.hpp" |
33 | // random number F32 ranging from 0.0f to range. | ||
34 | // -Ventrella - Sept 30, 2005 | ||
35 | 33 | ||
36 | // Slams Intel processors into Single Precision FP mode | 34 | /** |
37 | // (which is not any faster on modern hardware) | 35 | * Use the boost random number generators if you want a stateful |
38 | void slamFPCW( void ); | 36 | * random numbers. If you want more random numbers, use the |
39 | 37 | * c-functions since they will generate faster/better randomness | |
40 | class LLRand | 38 | * across the process. |
41 | { | 39 | * |
42 | public: | 40 | * I tested some of the boost random engines, and picked a good double |
43 | LLRand(U32 seed) : mSeed(seed) {} | 41 | * generator and a good integer generator. I also took some timings |
44 | ~LLRand() {} | 42 | * for them on linux using gcc 3.3.5. The harness also did some other |
45 | 43 | * fairly trivial operations to try to limit compiler optimizations, | |
46 | void seed(U32 seed) { mSeed = seed; } | 44 | * so these numbers are only good for relative comparisons. |
45 | * | ||
46 | * usec/inter algorithm | ||
47 | * 0.21 boost::minstd_rand0 | ||
48 | * 0.039 boost:lagged_fibonacci19937 | ||
49 | * 0.036 boost:lagged_fibonacci607 | ||
50 | * 0.44 boost::hellekalek1995 | ||
51 | * 0.44 boost::ecuyer1988 | ||
52 | * 0.042 boost::rand48 | ||
53 | * 0.043 boost::mt11213b | ||
54 | * 0.028 stdlib random() | ||
55 | * 0.05 stdlib lrand48() | ||
56 | * 0.034 stdlib rand() | ||
57 | * 0.020 the old & lame LLRand | ||
58 | */ | ||
47 | 59 | ||
48 | U32 llrand() | 60 | /** |
49 | { | 61 | *@brief Generate a float from [0, RAND_MAX). |
50 | mSeed = U64L(1664525) * mSeed + U64L(1013904223); | 62 | */ |
51 | return (U32)mSeed; | 63 | S32 ll_rand(); |
52 | } | ||
53 | 64 | ||
54 | U32 llrand(U32 val) | 65 | /** |
55 | { | 66 | *@brief Generate a float from [0, val). |
56 | mSeed = U64L(1664525) * mSeed + U64L(1013904223); | 67 | */ |
57 | return (U32)(mSeed) % val; | 68 | S32 ll_rand(S32 val); |
58 | } | ||
59 | 69 | ||
60 | // val is the maximum | 70 | /** |
61 | F32 llfrand(F32 val) | 71 | *@brief Generate a float from [0, 1.0). |
62 | { | 72 | */ |
63 | const U32 FP_ONE = 0x3f800000; | 73 | F32 ll_frand(); |
64 | const U32 FP_MASK = 0x007fffff; | ||
65 | U32 ir = llrand(); | ||
66 | 74 | ||
67 | ir = FP_ONE | (FP_MASK & ir); | 75 | /** |
68 | 76 | *@brief Generate a float from [0, val). | |
69 | // generate random float | 77 | */ |
70 | F32 fr = (*(F32 *)&ir); | 78 | F32 ll_frand(F32 val); |
71 | 79 | ||
72 | // correct to [0..1) | 80 | /** |
73 | fr -= 1.f; | 81 | *@brief Generate a double from [0, 1.0). |
82 | */ | ||
83 | F64 ll_drand(); | ||
74 | 84 | ||
75 | fr *= val; | 85 | /** |
86 | *@brief Generate a double from [0, val). | ||
87 | */ | ||
88 | F64 ll_drand(F64 val); | ||
76 | 89 | ||
77 | return fr; | 90 | /** |
78 | } | 91 | * @brief typedefs for good boost lagged fibonacci. |
79 | 92 | * @see boost::lagged_fibonacci | |
80 | public: | 93 | * |
81 | U64 mSeed; | 94 | * These generators will quickly generate doubles. Note the memory |
82 | }; | 95 | * requirements, because they are somewhat high. I chose the smallest |
96 | * one, and one comparable in speed but higher periodicity without | ||
97 | * outrageous memory requirements. | ||
98 | * To use: | ||
99 | * LLRandLagFib607 foo((U32)time(NULL)); | ||
100 | * double bar = foo(); | ||
101 | */ | ||
83 | 102 | ||
84 | F32 frand(F32 val); | 103 | typedef boost::lagged_fibonacci607 LLRandLagFib607; |
104 | /**< | ||
105 | * lengh of cycle: 2^32,000 | ||
106 | * memory: 607*sizeof(double) (about 5K) | ||
107 | */ | ||
85 | 108 | ||
86 | extern LLRand gLindenLabRandomNumber; | 109 | typedef boost::lagged_fibonacci2281 LLRandLagFib2281; |
110 | /**< | ||
111 | * lengh of cycle: 2^120,000 | ||
112 | * memory: 2281*sizeof(double) (about 17K) | ||
113 | */ | ||
87 | 114 | ||
115 | /** | ||
116 | * @breif typedefs for a good boost mersenne twister implementation. | ||
117 | * @see boost::mersenne_twister | ||
118 | * | ||
119 | * This fairly quickly generates U32 values | ||
120 | * To use: | ||
121 | * LLRandMT19937 foo((U32)time(NULL)); | ||
122 | * U32 bar = foo(); | ||
123 | * | ||
124 | * lengh of cycle: 2^19,937-1 | ||
125 | * memory: about 2496 bytes | ||
126 | */ | ||
127 | typedef boost::mt11213b LLRandMT19937; | ||
88 | #endif | 128 | #endif |
diff --git a/linden/indra/llmath/lluuid.cpp b/linden/indra/llmath/lluuid.cpp index 216dac9..3fb31a6 100644 --- a/linden/indra/llmath/lluuid.cpp +++ b/linden/indra/llmath/lluuid.cpp | |||
@@ -110,6 +110,40 @@ unsigned int decode( char const * fiveChars ) throw( bad_input_data ) | |||
110 | } | 110 | } |
111 | */ | 111 | */ |
112 | 112 | ||
113 | #define LL_USE_JANKY_RANDOM_NUMBER_GENERATOR 0 | ||
114 | #if LL_USE_JANKY_RANDOM_NUMBER_GENERATOR | ||
115 | /** | ||
116 | * @brief a global for | ||
117 | */ | ||
118 | static U64 sJankyRandomSeed(LLUUID::getRandomSeed()); | ||
119 | |||
120 | /** | ||
121 | * @brief generate a random U32. | ||
122 | */ | ||
123 | U32 janky_fast_random_bytes() | ||
124 | { | ||
125 | sJankyRandomSeed = U64L(1664525) * sJankyRandomSeed + U64L(1013904223); | ||
126 | return (U32)sJankyRandomSeed; | ||
127 | } | ||
128 | |||
129 | /** | ||
130 | * @brief generate a random U32 from [0, val) | ||
131 | */ | ||
132 | U32 janky_fast_random_byes_range(U32 val) | ||
133 | { | ||
134 | sJankyRandomSeed = U64L(1664525) * sJankyRandomSeed + U64L(1013904223); | ||
135 | return (U32)(sJankyRandomSeed) % val; | ||
136 | } | ||
137 | |||
138 | /** | ||
139 | * @brief generate a random U32 from [0, val) | ||
140 | */ | ||
141 | U32 janky_fast_random_seeded_bytes(U32 seed, U32 val) | ||
142 | { | ||
143 | seed = U64L(1664525) * (U64)(seed) + U64L(1013904223); | ||
144 | return (U32)(seed) % val; | ||
145 | } | ||
146 | #endif | ||
113 | 147 | ||
114 | // Common to all UUID implementations | 148 | // Common to all UUID implementations |
115 | void LLUUID::toString(char *out) const | 149 | void LLUUID::toString(char *out) const |
@@ -395,8 +429,16 @@ static void get_random_bytes(void *buf, int nbytes) | |||
395 | int i; | 429 | int i; |
396 | char *cp = (char *) buf; | 430 | char *cp = (char *) buf; |
397 | 431 | ||
432 | // *NOTE: If we are not using the janky generator ll_rand() | ||
433 | // generates at least 3 good bytes of data since it is 0 to | ||
434 | // RAND_MAX. This could be made more efficient by copying all the | ||
435 | // bytes. | ||
398 | for (i=0; i < nbytes; i++) | 436 | for (i=0; i < nbytes; i++) |
399 | *cp++ = gLindenLabRandomNumber.llrand() & 0xFF; | 437 | #if LL_USE_JANKY_RANDOM_NUMBER_GENERATOR |
438 | *cp++ = janky_fast_random_bytes() & 0xFF; | ||
439 | #else | ||
440 | *cp++ = ll_rand() & 0xFF; | ||
441 | #endif | ||
400 | return; | 442 | return; |
401 | } | 443 | } |
402 | 444 | ||
@@ -738,18 +780,18 @@ void LLUUID::getCurrentTime(uuid_time_t *timestamp) | |||
738 | 780 | ||
739 | void LLUUID::generate() | 781 | void LLUUID::generate() |
740 | { | 782 | { |
741 | // Create a UUID. | 783 | // Create a UUID. |
742 | 784 | uuid_time_t timestamp; | |
743 | |||
744 | uuid_time_t timestamp; | ||
745 | 785 | ||
746 | static unsigned char node_id[6]; | 786 | static unsigned char node_id[6]; |
747 | static int has_init = 0; | 787 | static int has_init = 0; |
748 | 788 | ||
749 | // Create a UUID. | 789 | // Create a UUID. |
750 | static uuid_time_t time_last = {0,0}; | 790 | static uuid_time_t time_last = {0,0}; |
751 | static U16 clock_seq = 0; | 791 | static U16 clock_seq = 0; |
752 | static LLRand random_generator(0); // dummy seed. reset it below | 792 | #if LL_USE_JANKY_RANDOM_NUMBER_GENERATOR |
793 | static U32 seed = 0L; // dummy seed. reset it below | ||
794 | #endif | ||
753 | if (!has_init) | 795 | if (!has_init) |
754 | { | 796 | { |
755 | if (getNodeID(node_id) <= 0) | 797 | if (getNodeID(node_id) <= 0) |
@@ -764,8 +806,15 @@ void LLUUID::generate() | |||
764 | } | 806 | } |
765 | 807 | ||
766 | getCurrentTime(&time_last); | 808 | getCurrentTime(&time_last); |
767 | random_generator.seed(time_last.low); | 809 | #if LL_USE_JANKY_RANDOM_NUMBER_GENERATOR |
768 | clock_seq = (U16) random_generator.llrand(65536); | 810 | seed = time_last.low; |
811 | #endif | ||
812 | |||
813 | #if LL_USE_JANKY_RANDOM_NUMBER_GENERATOR | ||
814 | clock_seq = (U16)janky_fast_random_seeded_bytes(seed, 65536); | ||
815 | #else | ||
816 | clock_seq = (U16)ll_rand(65536); | ||
817 | #endif | ||
769 | has_init = 1; | 818 | has_init = 1; |
770 | } | 819 | } |
771 | 820 | ||
diff --git a/linden/indra/llmath/llvolume.cpp b/linden/indra/llmath/llvolume.cpp index 14d4cdf..c527e85 100644 --- a/linden/indra/llmath/llvolume.cpp +++ b/linden/indra/llmath/llvolume.cpp | |||
@@ -725,6 +725,8 @@ BOOL LLProfileParams::importFile(FILE *fp) | |||
725 | { | 725 | { |
726 | const S32 BUFSIZE = 16384; | 726 | const S32 BUFSIZE = 16384; |
727 | char buffer[BUFSIZE]; | 727 | char buffer[BUFSIZE]; |
728 | // *NOTE: changing the size or type of these buffers will require | ||
729 | // changing the sscanf below. | ||
728 | char keyword[256]; | 730 | char keyword[256]; |
729 | char valuestr[256]; | 731 | char valuestr[256]; |
730 | keyword[0] = 0; | 732 | keyword[0] = 0; |
@@ -735,7 +737,7 @@ BOOL LLProfileParams::importFile(FILE *fp) | |||
735 | while (!feof(fp)) | 737 | while (!feof(fp)) |
736 | { | 738 | { |
737 | fgets(buffer, BUFSIZE, fp); | 739 | fgets(buffer, BUFSIZE, fp); |
738 | sscanf(buffer, " %s %s", keyword, valuestr); | 740 | sscanf(buffer, " %255s %255s", keyword, valuestr); |
739 | if (!keyword) | 741 | if (!keyword) |
740 | { | 742 | { |
741 | continue; | 743 | continue; |
@@ -795,6 +797,8 @@ BOOL LLProfileParams::importLegacyStream(std::istream& input_stream) | |||
795 | { | 797 | { |
796 | const S32 BUFSIZE = 16384; | 798 | const S32 BUFSIZE = 16384; |
797 | char buffer[BUFSIZE]; | 799 | char buffer[BUFSIZE]; |
800 | // *NOTE: changing the size or type of these buffers will require | ||
801 | // changing the sscanf below. | ||
798 | char keyword[256]; | 802 | char keyword[256]; |
799 | char valuestr[256]; | 803 | char valuestr[256]; |
800 | keyword[0] = 0; | 804 | keyword[0] = 0; |
@@ -805,7 +809,7 @@ BOOL LLProfileParams::importLegacyStream(std::istream& input_stream) | |||
805 | while (input_stream.good()) | 809 | while (input_stream.good()) |
806 | { | 810 | { |
807 | input_stream.getline(buffer, BUFSIZE); | 811 | input_stream.getline(buffer, BUFSIZE); |
808 | sscanf(buffer, " %s %s", keyword, valuestr); | 812 | sscanf(buffer, " %255s %255s", keyword, valuestr); |
809 | if (!keyword) | 813 | if (!keyword) |
810 | { | 814 | { |
811 | continue; | 815 | continue; |
@@ -1215,6 +1219,8 @@ BOOL LLPathParams::importFile(FILE *fp) | |||
1215 | { | 1219 | { |
1216 | const S32 BUFSIZE = 16384; | 1220 | const S32 BUFSIZE = 16384; |
1217 | char buffer[BUFSIZE]; | 1221 | char buffer[BUFSIZE]; |
1222 | // *NOTE: changing the size or type of these buffers will require | ||
1223 | // changing the sscanf below. | ||
1218 | char keyword[256]; | 1224 | char keyword[256]; |
1219 | char valuestr[256]; | 1225 | char valuestr[256]; |
1220 | keyword[0] = 0; | 1226 | keyword[0] = 0; |
@@ -1227,7 +1233,7 @@ BOOL LLPathParams::importFile(FILE *fp) | |||
1227 | while (!feof(fp)) | 1233 | while (!feof(fp)) |
1228 | { | 1234 | { |
1229 | fgets(buffer, BUFSIZE, fp); | 1235 | fgets(buffer, BUFSIZE, fp); |
1230 | sscanf(buffer, " %s %s", keyword, valuestr); | 1236 | sscanf(buffer, " %255s %255s", keyword, valuestr); |
1231 | if (!keyword) | 1237 | if (!keyword) |
1232 | { | 1238 | { |
1233 | continue; | 1239 | continue; |
@@ -1354,6 +1360,8 @@ BOOL LLPathParams::importLegacyStream(std::istream& input_stream) | |||
1354 | { | 1360 | { |
1355 | const S32 BUFSIZE = 16384; | 1361 | const S32 BUFSIZE = 16384; |
1356 | char buffer[BUFSIZE]; | 1362 | char buffer[BUFSIZE]; |
1363 | // *NOTE: changing the size or type of these buffers will require | ||
1364 | // changing the sscanf below. | ||
1357 | char keyword[256]; | 1365 | char keyword[256]; |
1358 | char valuestr[256]; | 1366 | char valuestr[256]; |
1359 | keyword[0] = 0; | 1367 | keyword[0] = 0; |
@@ -1366,7 +1374,7 @@ BOOL LLPathParams::importLegacyStream(std::istream& input_stream) | |||
1366 | while (input_stream.good()) | 1374 | while (input_stream.good()) |
1367 | { | 1375 | { |
1368 | input_stream.getline(buffer, BUFSIZE); | 1376 | input_stream.getline(buffer, BUFSIZE); |
1369 | sscanf(buffer, " %s %s", keyword, valuestr); | 1377 | sscanf(buffer, " %255s %255s", keyword, valuestr); |
1370 | if (!keyword) | 1378 | if (!keyword) |
1371 | { | 1379 | { |
1372 | continue; | 1380 | continue; |
@@ -3340,13 +3348,15 @@ BOOL LLVolumeParams::importFile(FILE *fp) | |||
3340 | //llinfos << "importing volume" << llendl; | 3348 | //llinfos << "importing volume" << llendl; |
3341 | const S32 BUFSIZE = 16384; | 3349 | const S32 BUFSIZE = 16384; |
3342 | char buffer[BUFSIZE]; | 3350 | char buffer[BUFSIZE]; |
3351 | // *NOTE: changing the size or type of this buffer will require | ||
3352 | // changing the sscanf below. | ||
3343 | char keyword[256]; | 3353 | char keyword[256]; |
3344 | keyword[0] = 0; | 3354 | keyword[0] = 0; |
3345 | 3355 | ||
3346 | while (!feof(fp)) | 3356 | while (!feof(fp)) |
3347 | { | 3357 | { |
3348 | fgets(buffer, BUFSIZE, fp); | 3358 | fgets(buffer, BUFSIZE, fp); |
3349 | sscanf(buffer, " %s", keyword); | 3359 | sscanf(buffer, " %255s", keyword); |
3350 | if (!keyword) | 3360 | if (!keyword) |
3351 | { | 3361 | { |
3352 | continue; | 3362 | continue; |
@@ -3391,6 +3401,8 @@ BOOL LLVolumeParams::importLegacyStream(std::istream& input_stream) | |||
3391 | { | 3401 | { |
3392 | //llinfos << "importing volume" << llendl; | 3402 | //llinfos << "importing volume" << llendl; |
3393 | const S32 BUFSIZE = 16384; | 3403 | const S32 BUFSIZE = 16384; |
3404 | // *NOTE: changing the size or type of this buffer will require | ||
3405 | // changing the sscanf below. | ||
3394 | char buffer[BUFSIZE]; | 3406 | char buffer[BUFSIZE]; |
3395 | char keyword[256]; | 3407 | char keyword[256]; |
3396 | keyword[0] = 0; | 3408 | keyword[0] = 0; |
@@ -3398,7 +3410,7 @@ BOOL LLVolumeParams::importLegacyStream(std::istream& input_stream) | |||
3398 | while (input_stream.good()) | 3410 | while (input_stream.good()) |
3399 | { | 3411 | { |
3400 | input_stream.getline(buffer, BUFSIZE); | 3412 | input_stream.getline(buffer, BUFSIZE); |
3401 | sscanf(buffer, " %s", keyword); | 3413 | sscanf(buffer, " %255s", keyword); |
3402 | if (!keyword) | 3414 | if (!keyword) |
3403 | { | 3415 | { |
3404 | continue; | 3416 | continue; |
diff --git a/linden/indra/llmessage/llcachename.cpp b/linden/indra/llmessage/llcachename.cpp index 9995a6e..3a92812 100644 --- a/linden/indra/llmessage/llcachename.cpp +++ b/linden/indra/llmessage/llcachename.cpp | |||
@@ -284,6 +284,7 @@ void LLCacheName::importFile(FILE* fp) | |||
284 | const S32 BUFFER_SIZE = 1024; | 284 | const S32 BUFFER_SIZE = 1024; |
285 | char buffer[BUFFER_SIZE]; /*Flawfinder: ignore*/ | 285 | char buffer[BUFFER_SIZE]; /*Flawfinder: ignore*/ |
286 | 286 | ||
287 | // *NOTE: These buffer sizes are hardcoded into sscanf() below | ||
287 | char id_string[MAX_STRING]; /*Flawfinder: ignore*/ | 288 | char id_string[MAX_STRING]; /*Flawfinder: ignore*/ |
288 | char firstname[MAX_STRING]; /*Flawfinder: ignore*/ | 289 | char firstname[MAX_STRING]; /*Flawfinder: ignore*/ |
289 | char lastname[MAX_STRING]; /*Flawfinder: ignore*/ | 290 | char lastname[MAX_STRING]; /*Flawfinder: ignore*/ |
@@ -293,9 +294,10 @@ void LLCacheName::importFile(FILE* fp) | |||
293 | char* valid = fgets(buffer, BUFFER_SIZE, fp); | 294 | char* valid = fgets(buffer, BUFFER_SIZE, fp); |
294 | if (!valid) return; | 295 | if (!valid) return; |
295 | 296 | ||
297 | // *NOTE: This buffer size is hardcoded into sscanf() below | ||
296 | char version_string[BUFFER_SIZE]; /*Flawfinder: ignore*/ | 298 | char version_string[BUFFER_SIZE]; /*Flawfinder: ignore*/ |
297 | S32 version = 0; | 299 | S32 version = 0; |
298 | S32 match = sscanf(buffer, "%s %d", version_string, &version); // XXXTBD | 300 | S32 match = sscanf(buffer, "%1023s %d", version_string, &version); |
299 | if ( match != 2 | 301 | if ( match != 2 |
300 | || strcmp(version_string, "version") | 302 | || strcmp(version_string, "version") |
301 | || version != CN_FILE_VERSION) | 303 | || version != CN_FILE_VERSION) |
@@ -314,11 +316,13 @@ void LLCacheName::importFile(FILE* fp) | |||
314 | valid = fgets(buffer, BUFFER_SIZE, fp); | 316 | valid = fgets(buffer, BUFFER_SIZE, fp); |
315 | if (!valid) break; | 317 | if (!valid) break; |
316 | 318 | ||
317 | match = sscanf(buffer, "%s %u %s %s", // XXXTBD | 319 | match = sscanf( |
318 | id_string, | 320 | buffer, |
319 | &create_time, | 321 | "%254s %u %254s %254s", |
320 | firstname, | 322 | id_string, |
321 | lastname); | 323 | &create_time, |
324 | firstname, | ||
325 | lastname); | ||
322 | if (4 != match) continue; | 326 | if (4 != match) continue; |
323 | 327 | ||
324 | LLUUID id(id_string); | 328 | LLUUID id(id_string); |
@@ -409,7 +413,7 @@ BOOL LLCacheName::getName(const LLUUID& id, char* first, char* last) | |||
409 | { | 413 | { |
410 | //The function signature needs to change to pass in the | 414 | //The function signature needs to change to pass in the |
411 | //length of first and last. | 415 | //length of first and last. |
412 | strcpy(first,(frand(1.0f) < HIPPO_PROBABILITY) | 416 | strcpy(first,(ll_frand() < HIPPO_PROBABILITY) |
413 | ? CN_HIPPOS | 417 | ? CN_HIPPOS |
414 | : CN_WAITING); | 418 | : CN_WAITING); |
415 | strcpy(last, ""); | 419 | strcpy(last, ""); |
diff --git a/linden/indra/llmessage/llcircuit.cpp b/linden/indra/llmessage/llcircuit.cpp index 7d3136b..5187948 100644 --- a/linden/indra/llmessage/llcircuit.cpp +++ b/linden/indra/llmessage/llcircuit.cpp | |||
@@ -105,12 +105,12 @@ LLCircuitData::LLCircuitData(const LLHost &host, TPACKETID in_id) | |||
105 | // Need to guarantee that this time is up to date, we may be creating a circuit even though we haven't been | 105 | // Need to guarantee that this time is up to date, we may be creating a circuit even though we haven't been |
106 | // running a message system loop. | 106 | // running a message system loop. |
107 | F64 mt_sec = LLMessageSystem::getMessageTimeSeconds(TRUE); | 107 | F64 mt_sec = LLMessageSystem::getMessageTimeSeconds(TRUE); |
108 | F32 distribution_offset = frand(1.0f); | 108 | F32 distribution_offset = ll_frand(); |
109 | 109 | ||
110 | mPingTime = mt_sec; | 110 | mPingTime = mt_sec; |
111 | mLastPingSendTime = mt_sec + PING_INTERVAL * distribution_offset; | 111 | mLastPingSendTime = mt_sec + PING_INTERVAL * distribution_offset; |
112 | mLastPingReceivedTime = mt_sec; | 112 | mLastPingReceivedTime = mt_sec; |
113 | mNextPingSendTime = mLastPingSendTime + 0.95*PING_INTERVAL + frand(0.1f*PING_INTERVAL); | 113 | mNextPingSendTime = mLastPingSendTime + 0.95*PING_INTERVAL + ll_frand(0.1f*PING_INTERVAL); |
114 | mPeriodTime = mt_sec; | 114 | mPeriodTime = mt_sec; |
115 | 115 | ||
116 | mTimeoutCallback = NULL; | 116 | mTimeoutCallback = NULL; |
@@ -804,7 +804,7 @@ void LLCircuit::updateWatchDogTimers(LLMessageSystem *msgsys) | |||
804 | if (cdp->updateWatchDogTimers(msgsys)) | 804 | if (cdp->updateWatchDogTimers(msgsys)) |
805 | { | 805 | { |
806 | // Randomize our pings a bit by doing some up to 5% early or late | 806 | // Randomize our pings a bit by doing some up to 5% early or late |
807 | F64 dt = 0.95f*PING_INTERVAL + frand(0.1f*PING_INTERVAL); | 807 | F64 dt = 0.95f*PING_INTERVAL + ll_frand(0.1f*PING_INTERVAL); |
808 | 808 | ||
809 | // Remove it, and reinsert it with the new next ping time. | 809 | // Remove it, and reinsert it with the new next ping time. |
810 | // Always remove before changing the sorting key. | 810 | // Always remove before changing the sorting key. |
diff --git a/linden/indra/llmessage/llpacketring.cpp b/linden/indra/llmessage/llpacketring.cpp index 3876d76..6a6a456 100644 --- a/linden/indra/llmessage/llpacketring.cpp +++ b/linden/indra/llmessage/llpacketring.cpp | |||
@@ -166,7 +166,7 @@ S32 LLPacketRing::receivePacket (S32 socket, char *datap) | |||
166 | mActualBitsIn += packetp->getSize() * 8; | 166 | mActualBitsIn += packetp->getSize() * 8; |
167 | 167 | ||
168 | // Fake packet loss | 168 | // Fake packet loss |
169 | if (mDropPercentage && (frand(100.f) < mDropPercentage)) | 169 | if (mDropPercentage && (ll_frand(100.f) < mDropPercentage)) |
170 | { | 170 | { |
171 | mPacketsToDrop++; | 171 | mPacketsToDrop++; |
172 | } | 172 | } |
@@ -221,7 +221,7 @@ S32 LLPacketRing::receivePacket (S32 socket, char *datap) | |||
221 | 221 | ||
222 | if (packet_size) // did we actually get a packet? | 222 | if (packet_size) // did we actually get a packet? |
223 | { | 223 | { |
224 | if (mDropPercentage && (frand(100.f) < mDropPercentage)) | 224 | if (mDropPercentage && (ll_frand(100.f) < mDropPercentage)) |
225 | { | 225 | { |
226 | mPacketsToDrop++; | 226 | mPacketsToDrop++; |
227 | } | 227 | } |
diff --git a/linden/indra/llmessage/llpumpio.cpp b/linden/indra/llmessage/llpumpio.cpp index 853a438..b1495f6 100644 --- a/linden/indra/llmessage/llpumpio.cpp +++ b/linden/indra/llmessage/llpumpio.cpp | |||
@@ -335,6 +335,7 @@ bool LLPumpIO::copyCurrentLinkInfo(links_t& links) const | |||
335 | void LLPumpIO::pump() | 335 | void LLPumpIO::pump() |
336 | { | 336 | { |
337 | LLMemType m1(LLMemType::MTYPE_IO_PUMP); | 337 | LLMemType m1(LLMemType::MTYPE_IO_PUMP); |
338 | LLFastTimer t1(LLFastTimer::FTM_PUMP); | ||
338 | //llinfos << "LLPumpIO::pump()" << llendl; | 339 | //llinfos << "LLPumpIO::pump()" << llendl; |
339 | 340 | ||
340 | // Run any pending runners. | 341 | // Run any pending runners. |
diff --git a/linden/indra/llmessage/llurlrequest.cpp b/linden/indra/llmessage/llurlrequest.cpp index c0d8d27..8ac8d94 100644 --- a/linden/indra/llmessage/llurlrequest.cpp +++ b/linden/indra/llmessage/llurlrequest.cpp | |||
@@ -270,6 +270,7 @@ LLIOPipe::EStatus LLURLRequest::process_impl( | |||
270 | S32 queue; | 270 | S32 queue; |
271 | do | 271 | do |
272 | { | 272 | { |
273 | LLFastTimer t2(LLFastTimer::FTM_CURL); | ||
273 | code = curl_multi_perform(mDetail->mCurlMulti, &queue); | 274 | code = curl_multi_perform(mDetail->mCurlMulti, &queue); |
274 | }while((CURLM_CALL_MULTI_PERFORM == code) && (queue > 0) && count--); | 275 | }while((CURLM_CALL_MULTI_PERFORM == code) && (queue > 0) && count--); |
275 | CURLMsg* curl_msg; | 276 | CURLMsg* curl_msg; |
diff --git a/linden/indra/llmessage/llxfermanager.cpp b/linden/indra/llmessage/llxfermanager.cpp index d10c879..afeeef3 100644 --- a/linden/indra/llmessage/llxfermanager.cpp +++ b/linden/indra/llmessage/llxfermanager.cpp | |||
@@ -1108,7 +1108,7 @@ void process_request_xfer(LLMessageSystem *mesgsys, void **user_data) | |||
1108 | void continue_file_receive(LLMessageSystem *mesgsys, void **user_data) | 1108 | void continue_file_receive(LLMessageSystem *mesgsys, void **user_data) |
1109 | { | 1109 | { |
1110 | #if LL_TEST_XFER_REXMIT | 1110 | #if LL_TEST_XFER_REXMIT |
1111 | if (frand(1.f) > 0.05f) | 1111 | if (ll_frand() > 0.05f) |
1112 | { | 1112 | { |
1113 | #endif | 1113 | #endif |
1114 | gXferManager->processReceiveData(mesgsys,user_data); | 1114 | gXferManager->processReceiveData(mesgsys,user_data); |
diff --git a/linden/indra/llui/llmenugl.cpp b/linden/indra/llui/llmenugl.cpp index 6d70fd1..97069fa 100644 --- a/linden/indra/llui/llmenugl.cpp +++ b/linden/indra/llui/llmenugl.cpp | |||
@@ -491,6 +491,7 @@ BOOL LLMenuItemGL::handleMouseUp( S32 x, S32 y, MASK ) | |||
491 | } | 491 | } |
492 | } | 492 | } |
493 | 493 | ||
494 | |||
494 | void LLMenuItemGL::draw( void ) | 495 | void LLMenuItemGL::draw( void ) |
495 | { | 496 | { |
496 | // *FIX: This can be optimized by using switches. Want to avoid | 497 | // *FIX: This can be optimized by using switches. Want to avoid |
@@ -4123,7 +4124,7 @@ BOOL LLMenuBarGL::handleAcceleratorKey(KEY key, MASK mask) | |||
4123 | 4124 | ||
4124 | BOOL LLMenuBarGL::handleKeyHere(KEY key, MASK mask, BOOL called_from_parent) | 4125 | BOOL LLMenuBarGL::handleKeyHere(KEY key, MASK mask, BOOL called_from_parent) |
4125 | { | 4126 | { |
4126 | if(key == KEY_ALT) | 4127 | if(key == KEY_ALT && !gKeyboard->getKeyRepeated(key) && LLUI::sConfigGroup->getBOOL("UseAltKeyForMenus")) |
4127 | { | 4128 | { |
4128 | mAltKeyTrigger = TRUE; | 4129 | mAltKeyTrigger = TRUE; |
4129 | } | 4130 | } |
diff --git a/linden/indra/llvfs/lldir_linux.cpp b/linden/indra/llvfs/lldir_linux.cpp index 8557901..780fbdb 100644 --- a/linden/indra/llvfs/lldir_linux.cpp +++ b/linden/indra/llvfs/lldir_linux.cpp | |||
@@ -29,7 +29,7 @@ | |||
29 | 29 | ||
30 | #include "lldir_linux.h" | 30 | #include "lldir_linux.h" |
31 | #include "llerror.h" | 31 | #include "llerror.h" |
32 | #include "llrand.h" // for gLindenLabRandomNumber | 32 | #include "llrand.h" |
33 | #include <sys/types.h> | 33 | #include <sys/types.h> |
34 | #include <sys/stat.h> | 34 | #include <sys/stat.h> |
35 | #include <unistd.h> | 35 | #include <unistd.h> |
@@ -286,8 +286,8 @@ BOOL LLDir_Linux::getNextFileInDir(const std::string &dirname, const std::string | |||
286 | // automatically wrap if we've hit the end | 286 | // automatically wrap if we've hit the end |
287 | void LLDir_Linux::getRandomFileInDir(const std::string &dirname, const std::string &mask, std::string &fname) | 287 | void LLDir_Linux::getRandomFileInDir(const std::string &dirname, const std::string &mask, std::string &fname) |
288 | { | 288 | { |
289 | U32 num_files; | 289 | S32 num_files; |
290 | U32 which_file; | 290 | S32 which_file; |
291 | DIR *dirp; | 291 | DIR *dirp; |
292 | dirent *entryp = NULL; | 292 | dirent *entryp = NULL; |
293 | 293 | ||
@@ -299,7 +299,7 @@ void LLDir_Linux::getRandomFileInDir(const std::string &dirname, const std::stri | |||
299 | return; | 299 | return; |
300 | } | 300 | } |
301 | 301 | ||
302 | which_file = gLindenLabRandomNumber.llrand() % num_files; | 302 | which_file = ll_rand(num_files); |
303 | 303 | ||
304 | // llinfos << "Random select file #" << which_file << llendl; | 304 | // llinfos << "Random select file #" << which_file << llendl; |
305 | 305 | ||
diff --git a/linden/indra/llvfs/lldir_mac.cpp b/linden/indra/llvfs/lldir_mac.cpp index 683b961..7f1d2ce 100644 --- a/linden/indra/llvfs/lldir_mac.cpp +++ b/linden/indra/llvfs/lldir_mac.cpp | |||
@@ -287,7 +287,7 @@ BOOL LLDir_Mac::getNextFileInDir(const std::string &dirname, const std::string & | |||
287 | // get a random file in the directory | 287 | // get a random file in the directory |
288 | void LLDir_Mac::getRandomFileInDir(const std::string &dirname, const std::string &mask, std::string &fname) | 288 | void LLDir_Mac::getRandomFileInDir(const std::string &dirname, const std::string &mask, std::string &fname) |
289 | { | 289 | { |
290 | U32 which_file; | 290 | S32 which_file; |
291 | glob_t g; | 291 | glob_t g; |
292 | fname = ""; | 292 | fname = ""; |
293 | 293 | ||
@@ -300,7 +300,7 @@ void LLDir_Mac::getRandomFileInDir(const std::string &dirname, const std::string | |||
300 | if(g.gl_pathc > 0) | 300 | if(g.gl_pathc > 0) |
301 | { | 301 | { |
302 | 302 | ||
303 | which_file = gLindenLabRandomNumber.llrand() % g.gl_pathc; | 303 | which_file = ll_rand(g.gl_pathc); |
304 | 304 | ||
305 | // llinfos << "getRandomFileInDir: returning number " << which_file << ", path is " << g.gl_pathv[which_file] << llendl; | 305 | // llinfos << "getRandomFileInDir: returning number " << which_file << ", path is " << g.gl_pathv[which_file] << llendl; |
306 | // The API wants just the filename, not the full path. | 306 | // The API wants just the filename, not the full path. |
diff --git a/linden/indra/llvfs/lldir_win32.cpp b/linden/indra/llvfs/lldir_win32.cpp index 8dcaa5c..ad72752 100644 --- a/linden/indra/llvfs/lldir_win32.cpp +++ b/linden/indra/llvfs/lldir_win32.cpp | |||
@@ -285,8 +285,8 @@ BOOL LLDir_Win32::getNextFileInDir(const llutf16string &dirname, const std::stri | |||
285 | // automatically wrap if we've hit the end | 285 | // automatically wrap if we've hit the end |
286 | void LLDir_Win32::getRandomFileInDir(const std::string &dirname, const std::string &mask, std::string &fname) | 286 | void LLDir_Win32::getRandomFileInDir(const std::string &dirname, const std::string &mask, std::string &fname) |
287 | { | 287 | { |
288 | U32 num_files; | 288 | S32 num_files; |
289 | U32 which_file; | 289 | S32 which_file; |
290 | HANDLE random_search_h; | 290 | HANDLE random_search_h; |
291 | 291 | ||
292 | fname = ""; | 292 | fname = ""; |
@@ -303,7 +303,7 @@ void LLDir_Win32::getRandomFileInDir(const std::string &dirname, const std::stri | |||
303 | return; | 303 | return; |
304 | } | 304 | } |
305 | 305 | ||
306 | which_file = gLindenLabRandomNumber.llrand() % num_files; | 306 | which_file = ll_rand(num_files); |
307 | 307 | ||
308 | // llinfos << "Random select mp3 #" << which_file << llendl; | 308 | // llinfos << "Random select mp3 #" << which_file << llendl; |
309 | 309 | ||
diff --git a/linden/indra/llwindow/llgl.cpp b/linden/indra/llwindow/llgl.cpp index 547a353..ec22907 100644 --- a/linden/indra/llwindow/llgl.cpp +++ b/linden/indra/llwindow/llgl.cpp | |||
@@ -365,6 +365,7 @@ bool LLGLManager::initGL() | |||
365 | // from being recognized as ATI. | 365 | // from being recognized as ATI. |
366 | if (mGLVendor.substr(0,4) == "ATI ") | 366 | if (mGLVendor.substr(0,4) == "ATI ") |
367 | { | 367 | { |
368 | mGLVendorShort = "ATI"; | ||
368 | BOOL mobile = FALSE; | 369 | BOOL mobile = FALSE; |
369 | if (mGLRenderer.find("MOBILITY") != LLString::npos) | 370 | if (mGLRenderer.find("MOBILITY") != LLString::npos) |
370 | { | 371 | { |
@@ -404,6 +405,7 @@ bool LLGLManager::initGL() | |||
404 | } | 405 | } |
405 | else if (mGLVendor.find("NVIDIA ") != LLString::npos) | 406 | else if (mGLVendor.find("NVIDIA ") != LLString::npos) |
406 | { | 407 | { |
408 | mGLVendorShort = "NVIDIA"; | ||
407 | mIsNVIDIA = TRUE; | 409 | mIsNVIDIA = TRUE; |
408 | if ( mGLRenderer.find("GEFORCE4 MX") != LLString::npos | 410 | if ( mGLRenderer.find("GEFORCE4 MX") != LLString::npos |
409 | || mGLRenderer.find("GEFORCE2") != LLString::npos | 411 | || mGLRenderer.find("GEFORCE2") != LLString::npos |
@@ -428,9 +430,14 @@ bool LLGLManager::initGL() | |||
428 | } | 430 | } |
429 | else if (mGLVendor.find("INTEL") != LLString::npos) | 431 | else if (mGLVendor.find("INTEL") != LLString::npos) |
430 | { | 432 | { |
433 | mGLVendorShort = "INTEL"; | ||
431 | mIsIntel = TRUE; | 434 | mIsIntel = TRUE; |
432 | } | 435 | } |
433 | 436 | else | |
437 | { | ||
438 | mGLVendorShort = "MISC"; | ||
439 | } | ||
440 | |||
434 | // This is called here because it depends on the setting of mIsGF2or4MX, and sets up mHasMultitexture. | 441 | // This is called here because it depends on the setting of mIsGF2or4MX, and sets up mHasMultitexture. |
435 | initExtensions(); | 442 | initExtensions(); |
436 | 443 | ||
diff --git a/linden/indra/llwindow/llgl.h b/linden/indra/llwindow/llgl.h index 1c93b63..c0668ca 100644 --- a/linden/indra/llwindow/llgl.h +++ b/linden/indra/llwindow/llgl.h | |||
@@ -125,6 +125,7 @@ public: | |||
125 | 125 | ||
126 | // In ALL CAPS | 126 | // In ALL CAPS |
127 | LLString mGLVendor; | 127 | LLString mGLVendor; |
128 | LLString mGLVendorShort; | ||
128 | 129 | ||
129 | // In ALL CAPS | 130 | // In ALL CAPS |
130 | LLString mGLRenderer; | 131 | LLString mGLRenderer; |
diff --git a/linden/indra/llwindow/llkeyboard.cpp b/linden/indra/llwindow/llkeyboard.cpp index fd6fcdc..409bb13 100644 --- a/linden/indra/llwindow/llkeyboard.cpp +++ b/linden/indra/llwindow/llkeyboard.cpp | |||
@@ -157,7 +157,6 @@ void LLKeyboard::resetKeys() | |||
157 | if( mKeyLevel[i] ) | 157 | if( mKeyLevel[i] ) |
158 | { | 158 | { |
159 | mKeyLevel[i] = FALSE; | 159 | mKeyLevel[i] = FALSE; |
160 | mKeyLevelFrameCount[i] = 0; | ||
161 | } | 160 | } |
162 | } | 161 | } |
163 | 162 | ||
diff --git a/linden/indra/llwindow/llkeyboardwin32.cpp b/linden/indra/llwindow/llkeyboardwin32.cpp index 531ad87..e166ec2 100644 --- a/linden/indra/llwindow/llkeyboardwin32.cpp +++ b/linden/indra/llwindow/llkeyboardwin32.cpp | |||
@@ -266,7 +266,6 @@ void LLKeyboardWin32::scanKeyboard() | |||
266 | { | 266 | { |
267 | //llinfos << "Key up event missed, resetting" << llendl; | 267 | //llinfos << "Key up event missed, resetting" << llendl; |
268 | mKeyLevel[key] = FALSE; | 268 | mKeyLevel[key] = FALSE; |
269 | mKeyLevelFrameCount[key] = 0; | ||
270 | } | 269 | } |
271 | } | 270 | } |
272 | } | 271 | } |
diff --git a/linden/indra/llwindow/llwindowwin32.cpp b/linden/indra/llwindow/llwindowwin32.cpp index b405bdb..5929fb5 100644 --- a/linden/indra/llwindow/llwindowwin32.cpp +++ b/linden/indra/llwindow/llwindowwin32.cpp | |||
@@ -1969,19 +1969,34 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_ | |||
1969 | // allow system keys, such as ALT-F4 to be processed by Windows | 1969 | // allow system keys, such as ALT-F4 to be processed by Windows |
1970 | eat_keystroke = FALSE; | 1970 | eat_keystroke = FALSE; |
1971 | case WM_KEYDOWN: | 1971 | case WM_KEYDOWN: |
1972 | if (gDebugWindowProc) | ||
1973 | { | ||
1974 | llinfos << "Debug WindowProc WM_KEYDOWN " | ||
1975 | << " key " << S32(w_param) | ||
1976 | << llendl; | ||
1977 | } | ||
1978 | if (gKeyboard->handleKeyDown(w_param, mask) && eat_keystroke) | ||
1979 | { | 1972 | { |
1980 | return 0; | 1973 | if (gDebugWindowProc) |
1974 | { | ||
1975 | llinfos << "Debug WindowProc WM_KEYDOWN " | ||
1976 | << " key " << S32(w_param) | ||
1977 | << llendl; | ||
1978 | } | ||
1979 | // lower 15 bits hold key repeat count | ||
1980 | S32 key_repeat_count = l_param & 0x7fff; | ||
1981 | if (key_repeat_count > 1) | ||
1982 | { | ||
1983 | KEY translated_key; | ||
1984 | gKeyboard->translateKey(w_param, &translated_key); | ||
1985 | if (!gKeyboard->getKeyDown(translated_key)) | ||
1986 | { | ||
1987 | //RN: hack for handling key repeats when we no longer recognize the key as being down | ||
1988 | //This is necessary because we sometimes ignore the message queue and use getAsyncKeyState | ||
1989 | // to clear key level flags before we've processed all key repeat messages | ||
1990 | return 0; | ||
1991 | } | ||
1992 | } | ||
1993 | if(gKeyboard->handleKeyDown(w_param, mask) && eat_keystroke) | ||
1994 | { | ||
1995 | return 0; | ||
1996 | } | ||
1997 | // pass on to windows if we didn't handle it | ||
1998 | break; | ||
1981 | } | 1999 | } |
1982 | // pass on to windows if we didn't handle it | ||
1983 | break; | ||
1984 | |||
1985 | case WM_SYSKEYUP: | 2000 | case WM_SYSKEYUP: |
1986 | eat_keystroke = FALSE; | 2001 | eat_keystroke = FALSE; |
1987 | case WM_KEYUP: | 2002 | case WM_KEYUP: |
diff --git a/linden/indra/lscript/lscript_alloc.h b/linden/indra/lscript/lscript_alloc.h index 67e3dc0..4d69e8e 100644 --- a/linden/indra/lscript/lscript_alloc.h +++ b/linden/indra/lscript/lscript_alloc.h | |||
@@ -246,7 +246,7 @@ inline LLScriptLibData *lsa_bubble_sort(LLScriptLibData *src, S32 stride, S32 as | |||
246 | return retval; | 246 | return retval; |
247 | } | 247 | } |
248 | 248 | ||
249 | LLScriptLibData **sortarray = (LLScriptLibData **)new U32[number]; | 249 | LLScriptLibData **sortarray = new LLScriptLibData*[number]; |
250 | 250 | ||
251 | LLScriptLibData *temp = src->mListp; | 251 | LLScriptLibData *temp = src->mListp; |
252 | while (temp) | 252 | while (temp) |
@@ -290,74 +290,6 @@ inline LLScriptLibData *lsa_bubble_sort(LLScriptLibData *src, S32 stride, S32 as | |||
290 | } | 290 | } |
291 | 291 | ||
292 | 292 | ||
293 | inline LLScriptLibData *lsa_randomize(LLScriptLibData *src, S32 stride) | 293 | LLScriptLibData* lsa_randomize(LLScriptLibData* src, S32 stride); |
294 | { | ||
295 | S32 number = src->getListLength(); | ||
296 | |||
297 | if (number <= 0) | ||
298 | { | ||
299 | return NULL; | ||
300 | } | ||
301 | |||
302 | if (stride <= 0) | ||
303 | { | ||
304 | stride = 1; | ||
305 | } | ||
306 | |||
307 | if (number % stride) | ||
308 | { | ||
309 | LLScriptLibData *retval = src->mListp; | ||
310 | src->mListp = NULL; | ||
311 | return retval; | ||
312 | } | ||
313 | |||
314 | LLScriptLibData **sortarray = (LLScriptLibData **)new U32[number]; | ||
315 | |||
316 | LLScriptLibData *temp = src->mListp; | ||
317 | S32 i = 0; | ||
318 | while (temp) | ||
319 | { | ||
320 | sortarray[i] = temp; | ||
321 | i++; | ||
322 | temp = temp->mListp; | ||
323 | } | ||
324 | |||
325 | S32 k, j, s; | ||
326 | |||
327 | for (k = 0; k < 20; k++) | ||
328 | { | ||
329 | for (i = 0; i < number; i += stride) | ||
330 | { | ||
331 | for (j = i; j < number; j += stride) | ||
332 | { | ||
333 | if (frand(1.f) > 0.5) | ||
334 | { | ||
335 | for (s = 0; s < stride; s++) | ||
336 | { | ||
337 | temp = sortarray[i + s]; | ||
338 | sortarray[i + s] = sortarray[j + s]; | ||
339 | sortarray[j + s] = temp; | ||
340 | } | ||
341 | } | ||
342 | } | ||
343 | } | ||
344 | } | ||
345 | |||
346 | i = 1; | ||
347 | temp = sortarray[0]; | ||
348 | while (i < number) | ||
349 | { | ||
350 | temp->mListp = sortarray[i++]; | ||
351 | temp = temp->mListp; | ||
352 | } | ||
353 | temp->mListp = NULL; | ||
354 | |||
355 | src->mListp = NULL; | ||
356 | |||
357 | LLScriptLibData *ret_value = sortarray[0]; | ||
358 | delete [] sortarray; | ||
359 | |||
360 | return ret_value; | ||
361 | } | ||
362 | 294 | ||
363 | #endif | 295 | #endif |
diff --git a/linden/indra/lscript/lscript_compile/lscript_compile.vcproj b/linden/indra/lscript/lscript_compile/lscript_compile.vcproj index 581fa27..fd03fa0 100644 --- a/linden/indra/lscript/lscript_compile/lscript_compile.vcproj +++ b/linden/indra/lscript/lscript_compile/lscript_compile.vcproj | |||
@@ -19,7 +19,7 @@ | |||
19 | <Tool | 19 | <Tool |
20 | Name="VCCLCompilerTool" | 20 | Name="VCCLCompilerTool" |
21 | Optimization="0" | 21 | Optimization="0" |
22 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath;..\..\llvfs;..\..\llmessage;..\..\llinventory" | 22 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath;..\..\llvfs;..\..\llmessage;..\..\llinventory;"..\..\..\libraries\i686-win32\include";..\..\..\libraries\include" |
23 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;LL_DEBUG" | 23 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;LL_DEBUG" |
24 | MinimalRebuild="TRUE" | 24 | MinimalRebuild="TRUE" |
25 | BasicRuntimeChecks="3" | 25 | BasicRuntimeChecks="3" |
@@ -63,7 +63,7 @@ | |||
63 | CharacterSet="1"> | 63 | CharacterSet="1"> |
64 | <Tool | 64 | <Tool |
65 | Name="VCCLCompilerTool" | 65 | Name="VCCLCompilerTool" |
66 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath;..\..\llvfs;..\..\llmessage;..\..\llinventory" | 66 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath;..\..\llvfs;..\..\llmessage;..\..\llinventory;"..\..\..\libraries\i686-win32\include";..\..\..\libraries\include" |
67 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" | 67 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" |
68 | RuntimeLibrary="0" | 68 | RuntimeLibrary="0" |
69 | StructMemberAlignment="0" | 69 | StructMemberAlignment="0" |
@@ -106,7 +106,7 @@ | |||
106 | <Tool | 106 | <Tool |
107 | Name="VCCLCompilerTool" | 107 | Name="VCCLCompilerTool" |
108 | Optimization="0" | 108 | Optimization="0" |
109 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath;..\..\llvfs;..\..\llmessage;..\..\llinventory" | 109 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath;..\..\llvfs;..\..\llmessage;..\..\llinventory;"..\..\..\libraries\i686-win32\include";..\..\..\libraries\include" |
110 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" | 110 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" |
111 | RuntimeLibrary="0" | 111 | RuntimeLibrary="0" |
112 | StructMemberAlignment="0" | 112 | StructMemberAlignment="0" |
diff --git a/linden/indra/lscript/lscript_execute/lscript_execute.vcproj b/linden/indra/lscript/lscript_execute/lscript_execute.vcproj index 1ae15ea..c61ad89 100644 --- a/linden/indra/lscript/lscript_execute/lscript_execute.vcproj +++ b/linden/indra/lscript/lscript_execute/lscript_execute.vcproj | |||
@@ -19,7 +19,7 @@ | |||
19 | <Tool | 19 | <Tool |
20 | Name="VCCLCompilerTool" | 20 | Name="VCCLCompilerTool" |
21 | Optimization="0" | 21 | Optimization="0" |
22 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath" | 22 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath;"..\..\..\libraries\i686-win32\include";..\..\..\libraries\include" |
23 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;LL_DEBUG" | 23 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;LL_DEBUG" |
24 | MinimalRebuild="TRUE" | 24 | MinimalRebuild="TRUE" |
25 | BasicRuntimeChecks="3" | 25 | BasicRuntimeChecks="3" |
@@ -63,7 +63,7 @@ | |||
63 | CharacterSet="1"> | 63 | CharacterSet="1"> |
64 | <Tool | 64 | <Tool |
65 | Name="VCCLCompilerTool" | 65 | Name="VCCLCompilerTool" |
66 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath" | 66 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath;"..\..\..\libraries\i686-win32\include";..\..\..\libraries\include" |
67 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" | 67 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" |
68 | RuntimeLibrary="0" | 68 | RuntimeLibrary="0" |
69 | StructMemberAlignment="0" | 69 | StructMemberAlignment="0" |
@@ -106,7 +106,7 @@ | |||
106 | <Tool | 106 | <Tool |
107 | Name="VCCLCompilerTool" | 107 | Name="VCCLCompilerTool" |
108 | Optimization="0" | 108 | Optimization="0" |
109 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath" | 109 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath;"..\..\..\libraries\i686-win32\include";..\..\..\libraries\include" |
110 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" | 110 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" |
111 | RuntimeLibrary="0" | 111 | RuntimeLibrary="0" |
112 | StructMemberAlignment="0" | 112 | StructMemberAlignment="0" |
diff --git a/linden/indra/lscript/lscript_library/lscript_alloc.cpp b/linden/indra/lscript/lscript_library/lscript_alloc.cpp index 978d7f2..4636c0b 100644 --- a/linden/indra/lscript/lscript_library/lscript_alloc.cpp +++ b/linden/indra/lscript/lscript_library/lscript_alloc.cpp | |||
@@ -1119,3 +1119,62 @@ S32 lsa_postadd_lists(U8 *buffer, S32 offset1, LLScriptLibData *data, S32 heapsi | |||
1119 | return lsa_heap_add_data(buffer, list1, heapsize, TRUE); | 1119 | return lsa_heap_add_data(buffer, list1, heapsize, TRUE); |
1120 | } | 1120 | } |
1121 | 1121 | ||
1122 | |||
1123 | LLScriptLibData* lsa_randomize(LLScriptLibData* src, S32 stride) | ||
1124 | { | ||
1125 | S32 number = src->getListLength(); | ||
1126 | if (number <= 0) | ||
1127 | { | ||
1128 | return NULL; | ||
1129 | } | ||
1130 | if (stride <= 0) | ||
1131 | { | ||
1132 | stride = 1; | ||
1133 | } | ||
1134 | if(number % stride) | ||
1135 | { | ||
1136 | LLScriptLibData* retval = src->mListp; | ||
1137 | src->mListp = NULL; | ||
1138 | return retval; | ||
1139 | } | ||
1140 | S32 buckets = number / stride; | ||
1141 | |||
1142 | // Copy everything into a special vector for sorting; | ||
1143 | std::vector<LLScriptLibData*> sort_array; | ||
1144 | sort_array.reserve(number); | ||
1145 | LLScriptLibData* temp = src->mListp; | ||
1146 | while(temp) | ||
1147 | { | ||
1148 | sort_array.push_back(temp); | ||
1149 | temp = temp->mListp; | ||
1150 | } | ||
1151 | |||
1152 | // We cannot simply call random_shuffle or similar algorithm since | ||
1153 | // we need to obey the stride. So, we iterate over what we have | ||
1154 | // and swap each with a random other segment. | ||
1155 | S32 index = 0; | ||
1156 | S32 ii = 0; | ||
1157 | for(; ii < number; ii += stride) | ||
1158 | { | ||
1159 | index = ll_rand(buckets) * stride; | ||
1160 | for(S32 jj = 0; jj < stride; ++jj) | ||
1161 | { | ||
1162 | std::swap(sort_array[ii + jj], sort_array[index + jj]); | ||
1163 | } | ||
1164 | } | ||
1165 | |||
1166 | // copy the pointers back out | ||
1167 | ii = 1; | ||
1168 | temp = sort_array[0]; | ||
1169 | while (ii < number) | ||
1170 | { | ||
1171 | temp->mListp = sort_array[ii++]; | ||
1172 | temp = temp->mListp; | ||
1173 | } | ||
1174 | temp->mListp = NULL; | ||
1175 | |||
1176 | src->mListp = NULL; | ||
1177 | |||
1178 | LLScriptLibData* ret_value = sort_array[0]; | ||
1179 | return ret_value; | ||
1180 | } | ||
diff --git a/linden/indra/lscript/lscript_library/lscript_library.cpp b/linden/indra/lscript/lscript_library/lscript_library.cpp index 098c836..1b92608 100644 --- a/linden/indra/lscript/lscript_library/lscript_library.cpp +++ b/linden/indra/lscript/lscript_library/lscript_library.cpp | |||
@@ -467,7 +467,7 @@ LLScriptLibraryFunction::~LLScriptLibraryFunction() | |||
467 | 467 | ||
468 | void LLScriptLibrary::addFunction(LLScriptLibraryFunction *func) | 468 | void LLScriptLibrary::addFunction(LLScriptLibraryFunction *func) |
469 | { | 469 | { |
470 | LLScriptLibraryFunction **temp = (LLScriptLibraryFunction **)new U32[mNextNumber + 1]; | 470 | LLScriptLibraryFunction **temp = new LLScriptLibraryFunction*[mNextNumber + 1]; |
471 | if (mNextNumber) | 471 | if (mNextNumber) |
472 | { | 472 | { |
473 | memcpy(temp, mFunctions, sizeof(LLScriptLibraryFunction *)*mNextNumber); | 473 | memcpy(temp, mFunctions, sizeof(LLScriptLibraryFunction *)*mNextNumber); |
diff --git a/linden/indra/lscript/lscript_library/lscript_library.vcproj b/linden/indra/lscript/lscript_library/lscript_library.vcproj index f4861c7..1a340da 100644 --- a/linden/indra/lscript/lscript_library/lscript_library.vcproj +++ b/linden/indra/lscript/lscript_library/lscript_library.vcproj | |||
@@ -19,7 +19,7 @@ | |||
19 | <Tool | 19 | <Tool |
20 | Name="VCCLCompilerTool" | 20 | Name="VCCLCompilerTool" |
21 | Optimization="0" | 21 | Optimization="0" |
22 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath" | 22 | AdditionalIncludeDirectories="..\;..\..\llmath;..\..\llcommon;"..\..\..\libraries\i686-win32";..\..\..\libraries\include" |
23 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;LL_DEBUG" | 23 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;LL_DEBUG" |
24 | MinimalRebuild="TRUE" | 24 | MinimalRebuild="TRUE" |
25 | BasicRuntimeChecks="3" | 25 | BasicRuntimeChecks="3" |
@@ -63,7 +63,7 @@ | |||
63 | CharacterSet="1"> | 63 | CharacterSet="1"> |
64 | <Tool | 64 | <Tool |
65 | Name="VCCLCompilerTool" | 65 | Name="VCCLCompilerTool" |
66 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath" | 66 | AdditionalIncludeDirectories="..\;..\..\llmath;..\..\llcommon;"..\..\..\libraries\i686-win32";..\..\..\libraries\include" |
67 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" | 67 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" |
68 | RuntimeLibrary="0" | 68 | RuntimeLibrary="0" |
69 | StructMemberAlignment="0" | 69 | StructMemberAlignment="0" |
@@ -106,7 +106,7 @@ | |||
106 | <Tool | 106 | <Tool |
107 | Name="VCCLCompilerTool" | 107 | Name="VCCLCompilerTool" |
108 | Optimization="0" | 108 | Optimization="0" |
109 | AdditionalIncludeDirectories="..;..\..\llcommon;..\..\llmath" | 109 | AdditionalIncludeDirectories="..\;..\..\llmath;..\..\llcommon;"..\..\..\libraries\i686-win32";..\..\..\libraries\include" |
110 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" | 110 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" |
111 | RuntimeLibrary="0" | 111 | RuntimeLibrary="0" |
112 | StructMemberAlignment="0" | 112 | StructMemberAlignment="0" |
diff --git a/linden/indra/mac_crash_logger/mac_crash_logger.cpp b/linden/indra/mac_crash_logger/mac_crash_logger.cpp index 177a4b5..372050d 100644 --- a/linden/indra/mac_crash_logger/mac_crash_logger.cpp +++ b/linden/indra/mac_crash_logger/mac_crash_logger.cpp | |||
@@ -330,9 +330,13 @@ int main(int argc, char **argv) | |||
330 | db_filep = new LLFileEncoder("DB", db_file_name.c_str()); | 330 | db_filep = new LLFileEncoder("DB", db_file_name.c_str()); |
331 | 331 | ||
332 | // Get the filename of the SecondLife.log file | 332 | // Get the filename of the SecondLife.log file |
333 | char tmp_sl_name[MAX_PATH]; | 333 | |
334 | // *NOTE: changing the size of either of these buffers will | ||
335 | // require changing the sscanf() format string to correctly | ||
336 | // account for it. | ||
337 | char tmp_sl_name[LL_MAX_PATH]; | ||
334 | tmp_sl_name[0] = '\0'; | 338 | tmp_sl_name[0] = '\0'; |
335 | char tmp_space[256]; | 339 | char tmp_space[MAX_STRING]; |
336 | tmp_space[0] = '\0'; | 340 | tmp_space[0] = '\0'; |
337 | 341 | ||
338 | // Look for it in the debug_info.log file | 342 | // Look for it in the debug_info.log file |
@@ -340,7 +344,11 @@ int main(int argc, char **argv) | |||
340 | { | 344 | { |
341 | // This was originally scanning for "SL Log: %[^\r\n]", which happily skipped to the next line | 345 | // This was originally scanning for "SL Log: %[^\r\n]", which happily skipped to the next line |
342 | // on debug logs (which don't have anything after "SL Log:" and tried to open a nonsensical filename. | 346 | // on debug logs (which don't have anything after "SL Log:" and tried to open a nonsensical filename. |
343 | sscanf(db_filep->mBuf.c_str(), "SL Log:%[ ]%[^\r\n]", tmp_space, tmp_sl_name); | 347 | sscanf( |
348 | db_filep->mBuf.c_str(), | ||
349 | "SL Log:%254[ ]%1023[^\r\n]", | ||
350 | tmp_space, | ||
351 | tmp_sl_name); | ||
344 | } | 352 | } |
345 | else | 353 | else |
346 | { | 354 | { |
diff --git a/linden/indra/mac_updater/mac_updater.cpp b/linden/indra/mac_updater/mac_updater.cpp index 25e203c..2061ab4 100644 --- a/linden/indra/mac_updater/mac_updater.cpp +++ b/linden/indra/mac_updater/mac_updater.cpp | |||
@@ -613,6 +613,7 @@ void *updatethreadproc(void*) | |||
613 | char tempDir[PATH_MAX] = ""; | 613 | char tempDir[PATH_MAX] = ""; |
614 | FSRef tempDirRef; | 614 | FSRef tempDirRef; |
615 | char temp[PATH_MAX]; | 615 | char temp[PATH_MAX]; |
616 | // *NOTE: This buffer length is used in a scanf() below. | ||
616 | char deviceNode[1024] = ""; | 617 | char deviceNode[1024] = ""; |
617 | FILE *downloadFile = NULL; | 618 | FILE *downloadFile = NULL; |
618 | OSStatus err; | 619 | OSStatus err; |
@@ -937,7 +938,7 @@ void *updatethreadproc(void*) | |||
937 | if(sub != NULL) | 938 | if(sub != NULL) |
938 | { | 939 | { |
939 | sub += strlen(prefix); | 940 | sub += strlen(prefix); |
940 | sscanf(sub, "%s", deviceNode); | 941 | sscanf(sub, "%1023s", deviceNode); |
941 | } | 942 | } |
942 | } | 943 | } |
943 | 944 | ||
diff --git a/linden/indra/newview/English.lproj/InfoPlist.strings b/linden/indra/newview/English.lproj/InfoPlist.strings index ca392f1..2f68a02 100644 --- a/linden/indra/newview/English.lproj/InfoPlist.strings +++ b/linden/indra/newview/English.lproj/InfoPlist.strings | |||
@@ -1,5 +1,5 @@ | |||
1 | /* Localized versions of Info.plist keys */ | 1 | /* Localized versions of Info.plist keys */ |
2 | 2 | ||
3 | CFBundleName = "Second Life"; | 3 | CFBundleName = "Second Life"; |
4 | CFBundleShortVersionString = "Second Life version 1.13.2.12"; | 4 | CFBundleShortVersionString = "Second Life version 1.13.2.15"; |
5 | CFBundleGetInfoString = "Second Life version 1.13.2.12, Copyright 2004-2006 Linden Research, Inc."; | 5 | CFBundleGetInfoString = "Second Life version 1.13.2.15, Copyright 2004-2006 Linden Research, Inc."; |
diff --git a/linden/indra/newview/Info-SecondLife.plist b/linden/indra/newview/Info-SecondLife.plist index 8e8771d..3e6c65e 100644 --- a/linden/indra/newview/Info-SecondLife.plist +++ b/linden/indra/newview/Info-SecondLife.plist | |||
@@ -32,7 +32,7 @@ | |||
32 | </dict> | 32 | </dict> |
33 | </array> | 33 | </array> |
34 | <key>CFBundleVersion</key> | 34 | <key>CFBundleVersion</key> |
35 | <string>1.13.2.12</string> | 35 | <string>1.13.2.15</string> |
36 | <key>CSResourcesFileMapped</key> | 36 | <key>CSResourcesFileMapped</key> |
37 | <true/> | 37 | <true/> |
38 | </dict> | 38 | </dict> |
diff --git a/linden/indra/newview/linux_tools/exposed-symbols.txt b/linden/indra/newview/linux_tools/exposed-symbols.txt new file mode 100644 index 0000000..98df90a --- /dev/null +++ b/linden/indra/newview/linux_tools/exposed-symbols.txt | |||
@@ -0,0 +1,3 @@ | |||
1 | initllpython | ||
2 | createLLImageJ2CKDU | ||
3 | destroyLLImageJ2CKDU | ||
diff --git a/linden/indra/newview/linux_tools/hidesymbols.ver b/linden/indra/newview/linux_tools/hidesymbols.ver deleted file mode 100644 index 6ce7719..0000000 --- a/linden/indra/newview/linux_tools/hidesymbols.ver +++ /dev/null | |||
@@ -1,9 +0,0 @@ | |||
1 | LL_PRIVATE { | ||
2 | global: | ||
3 | initllpython; | ||
4 | createLLImageJ2CKDU; | ||
5 | destroyLLImageJ2CKDU; | ||
6 | local: | ||
7 | *; | ||
8 | }; | ||
9 | |||
diff --git a/linden/indra/newview/linux_tools/package-client.sh b/linden/indra/newview/linux_tools/package-client.sh index 1446e78..b054386 100755 --- a/linden/indra/newview/linux_tools/package-client.sh +++ b/linden/indra/newview/linux_tools/package-client.sh | |||
@@ -106,8 +106,15 @@ then | |||
106 | echo 'Default grid - creating empty gridargs.dat' | 106 | echo 'Default grid - creating empty gridargs.dat' |
107 | echo " " > $PACKAGE_NAME/gridargs.dat | 107 | echo " " > $PACKAGE_NAME/gridargs.dat |
108 | else | 108 | else |
109 | echo "Creating gridargs.dat for package, grid $GRID" | 109 | if [ X$GRID == X'firstlook' ] |
110 | echo "--${GRID} -helperuri http://preview-${GRID}.secondlife.com/helpers/" > $PACKAGE_NAME/gridargs.dat | 110 | then |
111 | # firstlook is a special case... it's not really a grid. | ||
112 | echo "Creating gridargs.dat for firstlook" | ||
113 | echo "-settings settings_firstlook.xml" > $PACKAGE_NAME/gridargs.dat | ||
114 | else | ||
115 | echo "Creating gridargs.dat for package, grid $GRID" | ||
116 | echo "-settings settings_beta.xml --${GRID} -helperuri http://preview-${GRID}.secondlife.com/helpers/" > $PACKAGE_NAME/gridargs.dat | ||
117 | fi | ||
111 | fi | 118 | fi |
112 | 119 | ||
113 | TARBALL=$PACKAGE_NAME.tar.bz2 | 120 | TARBALL=$PACKAGE_NAME.tar.bz2 |
diff --git a/linden/indra/newview/llagent.cpp b/linden/indra/newview/llagent.cpp index 26ef1b0..6d9137d 100644 --- a/linden/indra/newview/llagent.cpp +++ b/linden/indra/newview/llagent.cpp | |||
@@ -2115,11 +2115,11 @@ void LLAgent::updateWanderTarget() | |||
2115 | F32 rand_x; | 2115 | F32 rand_x; |
2116 | F32 rand_y; | 2116 | F32 rand_y; |
2117 | 2117 | ||
2118 | if (mWanderTimer.checkExpirationAndReset(frand(MAX_WANDER_TIME))) | 2118 | if (mWanderTimer.checkExpirationAndReset(ll_frand(MAX_WANDER_TIME))) |
2119 | { | 2119 | { |
2120 | // Pick a random spot to wander towards | 2120 | // Pick a random spot to wander towards |
2121 | num_regions = gWorldPointer->mActiveRegionList.getLength(); | 2121 | num_regions = gWorldPointer->mActiveRegionList.getLength(); |
2122 | S32 region_num = llround(frand(1.f) * num_regions); | 2122 | S32 region_num = llround(ll_frand() * num_regions); |
2123 | rand_region = gWorldPointer->mActiveRegionList.getFirstData(); | 2123 | rand_region = gWorldPointer->mActiveRegionList.getFirstData(); |
2124 | S32 i = 0; | 2124 | S32 i = 0; |
2125 | while (i < region_num) | 2125 | while (i < region_num) |
@@ -2127,8 +2127,8 @@ void LLAgent::updateWanderTarget() | |||
2127 | rand_region = gWorldPointer->mActiveRegionList.getNextData(); | 2127 | rand_region = gWorldPointer->mActiveRegionList.getNextData(); |
2128 | i++; | 2128 | i++; |
2129 | } | 2129 | } |
2130 | rand_x = frand(rand_region->getWidth()); | 2130 | rand_x = ll_frand(rand_region->getWidth()); |
2131 | rand_y = frand(rand_region->getWidth()); | 2131 | rand_y = ll_frand(rand_region->getWidth()); |
2132 | 2132 | ||
2133 | stopAutoPilot(); | 2133 | stopAutoPilot(); |
2134 | startAutoPilotGlobal(rand_region->getPosGlobalFromRegion(LLVector3(rand_x, rand_y, 0.f))); | 2134 | startAutoPilotGlobal(rand_region->getPosGlobalFromRegion(LLVector3(rand_x, rand_y, 0.f))); |
@@ -5687,7 +5687,7 @@ void LLAgent::fidget() | |||
5687 | // pick a random fidget anim here | 5687 | // pick a random fidget anim here |
5688 | S32 oldFidget = mCurrentFidget; | 5688 | S32 oldFidget = mCurrentFidget; |
5689 | 5689 | ||
5690 | mCurrentFidget = gLindenLabRandomNumber.llrand(NUM_AGENT_STAND_ANIMS); | 5690 | mCurrentFidget = ll_rand(NUM_AGENT_STAND_ANIMS); |
5691 | 5691 | ||
5692 | if (mCurrentFidget != oldFidget) | 5692 | if (mCurrentFidget != oldFidget) |
5693 | { | 5693 | { |
@@ -5719,7 +5719,7 @@ void LLAgent::fidget() | |||
5719 | } | 5719 | } |
5720 | 5720 | ||
5721 | // calculate next fidget time | 5721 | // calculate next fidget time |
5722 | mNextFidgetTime = curTime + gLindenLabRandomNumber.llfrand(MAX_FIDGET_TIME - MIN_FIDGET_TIME) + MIN_FIDGET_TIME; | 5722 | mNextFidgetTime = curTime + ll_frand(MAX_FIDGET_TIME - MIN_FIDGET_TIME) + MIN_FIDGET_TIME; |
5723 | } | 5723 | } |
5724 | } | 5724 | } |
5725 | } | 5725 | } |
diff --git a/linden/indra/newview/llanimalcontrols.cpp b/linden/indra/newview/llanimalcontrols.cpp index 8bafe86..2e047ae 100644 --- a/linden/indra/newview/llanimalcontrols.cpp +++ b/linden/indra/newview/llanimalcontrols.cpp | |||
@@ -103,7 +103,7 @@ void LLAnimalControlsVirtualServer::update() | |||
103 | 103 | ||
104 | F32 leftRightSpan = 5.0f; | 104 | F32 leftRightSpan = 5.0f; |
105 | 105 | ||
106 | F32 randomSpan = gLindenLabRandomNumber.llfrand( leftRightSpan ); | 106 | F32 randomSpan = ll_frand( leftRightSpan ); |
107 | 107 | ||
108 | focusPosition += leftDirection * ( - leftRightSpan * ONE_HALF + randomSpan ); | 108 | focusPosition += leftDirection * ( - leftRightSpan * ONE_HALF + randomSpan ); |
109 | } | 109 | } |
diff --git a/linden/indra/newview/llcloud.cpp b/linden/indra/newview/llcloud.cpp index e1b2281..ca05562 100644 --- a/linden/indra/newview/llcloud.cpp +++ b/linden/indra/newview/llcloud.cpp | |||
@@ -193,9 +193,9 @@ void LLCloudGroup::updatePuffCount() | |||
193 | for (i = current_puff_count; i < target_puff_count; i++) | 193 | for (i = current_puff_count; i < target_puff_count; i++) |
194 | { | 194 | { |
195 | puff_pos_global = mVOCloudsp->getPositionGlobal(); | 195 | puff_pos_global = mVOCloudsp->getPositionGlobal(); |
196 | F32 x = frand(256.f/CLOUD_GROUPS_PER_EDGE) - 128.f/CLOUD_GROUPS_PER_EDGE; | 196 | F32 x = ll_frand(256.f/CLOUD_GROUPS_PER_EDGE) - 128.f/CLOUD_GROUPS_PER_EDGE; |
197 | F32 y = frand(256.f/CLOUD_GROUPS_PER_EDGE) - 128.f/CLOUD_GROUPS_PER_EDGE; | 197 | F32 y = ll_frand(256.f/CLOUD_GROUPS_PER_EDGE) - 128.f/CLOUD_GROUPS_PER_EDGE; |
198 | F32 z = frand(CLOUD_HEIGHT_RANGE) - 0.5f*CLOUD_HEIGHT_RANGE; | 198 | F32 z = ll_frand(CLOUD_HEIGHT_RANGE) - 0.5f*CLOUD_HEIGHT_RANGE; |
199 | puff_pos_global += LLVector3d(x, y, z); | 199 | puff_pos_global += LLVector3d(x, y, z); |
200 | mCloudPuffs[i].mPositionGlobal = puff_pos_global; | 200 | mCloudPuffs[i].mPositionGlobal = puff_pos_global; |
201 | mCloudPuffs[i].mAlpha = 0.01f; | 201 | mCloudPuffs[i].mAlpha = 0.01f; |
diff --git a/linden/indra/newview/llcontroldef.cpp b/linden/indra/newview/llcontroldef.cpp index c186f6a..850b5bf 100644 --- a/linden/indra/newview/llcontroldef.cpp +++ b/linden/indra/newview/llcontroldef.cpp | |||
@@ -106,6 +106,7 @@ void declare_settings() | |||
106 | gSavedSettings.declareS32("MenuBarWidth", 410, "", NO_PERSIST ); | 106 | gSavedSettings.declareS32("MenuBarWidth", 410, "", NO_PERSIST ); |
107 | 107 | ||
108 | gSavedSettings.declareF32("MenuAccessKeyTime", 0.25f, "Time (seconds) in which the menu key must be tapped to move focus to the menu bar"); | 108 | gSavedSettings.declareF32("MenuAccessKeyTime", 0.25f, "Time (seconds) in which the menu key must be tapped to move focus to the menu bar"); |
109 | gSavedSettings.declareBOOL("UseAltKeyForMenus", FALSE, "Access menus via keyboard by tapping Alt"); | ||
109 | // Which background overlay to use | 110 | // Which background overlay to use |
110 | gSavedSettings.declareS32("MapOverlayIndex", 0, "Currently selected world map type"); | 111 | gSavedSettings.declareS32("MapOverlayIndex", 0, "Currently selected world map type"); |
111 | 112 | ||
diff --git a/linden/indra/newview/lldrawpoolbump.cpp b/linden/indra/newview/lldrawpoolbump.cpp index 28e60f1..befcc70 100644 --- a/linden/indra/newview/lldrawpoolbump.cpp +++ b/linden/indra/newview/lldrawpoolbump.cpp | |||
@@ -113,9 +113,10 @@ void LLStandardBumpmap::restoreGL() | |||
113 | 113 | ||
114 | while( !feof(file) && (LLStandardBumpmap::sStandardBumpmapCount < (U32)TEM_BUMPMAP_COUNT) ) | 114 | while( !feof(file) && (LLStandardBumpmap::sStandardBumpmapCount < (U32)TEM_BUMPMAP_COUNT) ) |
115 | { | 115 | { |
116 | // *NOTE: This buffer size is hard coded into scanf() below. | ||
116 | char label[2048] = ""; | 117 | char label[2048] = ""; |
117 | char bump_file[2048] = ""; | 118 | char bump_file[2048] = ""; |
118 | fields_read = fscanf( file, "\n%s %s", label, bump_file); | 119 | fields_read = fscanf( file, "\n%2047s %2047s", label, bump_file); |
119 | if( EOF == fields_read ) | 120 | if( EOF == fields_read ) |
120 | { | 121 | { |
121 | break; | 122 | break; |
diff --git a/linden/indra/newview/llfasttimerview.cpp b/linden/indra/newview/llfasttimerview.cpp index 3fddc4b..e147e3f 100644 --- a/linden/indra/newview/llfasttimerview.cpp +++ b/linden/indra/newview/llfasttimerview.cpp | |||
@@ -71,19 +71,21 @@ static LLColor4 green9(0.6f, 1.0f, 0.6f, 1.0f); | |||
71 | // red (5) magenta (4) | 71 | // red (5) magenta (4) |
72 | static struct ft_display_info ft_display_table[] = | 72 | static struct ft_display_info ft_display_table[] = |
73 | { | 73 | { |
74 | { LLFastTimer::FTM_FRAME, "Frame", &LLColor4::white, 0 }, | 74 | { LLFastTimer::FTM_FRAME, "Frame", &LLColor4::white, 0 }, |
75 | { LLFastTimer::FTM_MESSAGES, " Messages", &LLColor4::grey1, 0 }, | 75 | { LLFastTimer::FTM_MESSAGES, " Messages", &LLColor4::grey1, 0 }, |
76 | { LLFastTimer::FTM_SLEEP, " Sleep", &LLColor4::grey2, 0 }, | 76 | { LLFastTimer::FTM_SLEEP, " Sleep", &LLColor4::grey2, 0 }, |
77 | { LLFastTimer::FTM_IDLE, " Idle", &blue0, 0 }, | 77 | { LLFastTimer::FTM_IDLE, " Idle", &blue0, 0 }, |
78 | { LLFastTimer::FTM_INVENTORY, " Inventory Update", &LLColor4::purple6, 1 }, | 78 | { LLFastTimer::FTM_PUMP, " Pump", &LLColor4::magenta2, 1 }, |
79 | { LLFastTimer::FTM_AUTO_SELECT, " Open and Select", &LLColor4::red, 0 }, | 79 | { LLFastTimer::FTM_CURL, " Curl", &LLColor4::magenta3, 0 }, |
80 | { LLFastTimer::FTM_INVENTORY, " Inventory Update", &LLColor4::purple6, 1 }, | ||
81 | { LLFastTimer::FTM_AUTO_SELECT, " Open and Select", &LLColor4::red, 0 }, | ||
80 | { LLFastTimer::FTM_FILTER, " Filter", &LLColor4::red2, 0 }, | 82 | { LLFastTimer::FTM_FILTER, " Filter", &LLColor4::red2, 0 }, |
81 | { LLFastTimer::FTM_ARRANGE, " Arrange", &LLColor4::red3, 0 }, | 83 | { LLFastTimer::FTM_ARRANGE, " Arrange", &LLColor4::red3, 0 }, |
82 | { LLFastTimer::FTM_REFRESH, " Refresh", &LLColor4::red4, 0 }, | 84 | { LLFastTimer::FTM_REFRESH, " Refresh", &LLColor4::red4, 0 }, |
83 | { LLFastTimer::FTM_SORT, " Sort", &LLColor4::red5, 0 }, | 85 | { LLFastTimer::FTM_SORT, " Sort", &LLColor4::red5, 0 }, |
84 | { LLFastTimer::FTM_RESET_DRAWORDER, " ResetDrawOrder", &LLColor4::pink1, 0 }, | 86 | { LLFastTimer::FTM_RESET_DRAWORDER, " ResetDrawOrder", &LLColor4::pink1, 0 }, |
85 | { LLFastTimer::FTM_WORLD_UPDATE, " World Update", &LLColor4::blue1, 1 }, | 87 | { LLFastTimer::FTM_WORLD_UPDATE, " World Update", &LLColor4::blue1, 1 }, |
86 | { LLFastTimer::FTM_UPDATE_MOVE, " Move Objects", &LLColor4::pink2, 0 }, | 88 | { LLFastTimer::FTM_UPDATE_MOVE, " Move Objects", &LLColor4::pink2, 0 }, |
87 | { LLFastTimer::FTM_OCTREE_BALANCE, " Octree Balance", &LLColor4::red3, 0 }, | 89 | { LLFastTimer::FTM_OCTREE_BALANCE, " Octree Balance", &LLColor4::red3, 0 }, |
88 | { LLFastTimer::FTM_CULL, " Object Cull", &LLColor4::blue2, 0 }, | 90 | { LLFastTimer::FTM_CULL, " Object Cull", &LLColor4::blue2, 0 }, |
89 | { LLFastTimer::FTM_CULL_REBOUND, " Rebound", &LLColor4::blue3, 0 }, | 91 | { LLFastTimer::FTM_CULL_REBOUND, " Rebound", &LLColor4::blue3, 0 }, |
@@ -281,6 +283,13 @@ BOOL LLFastTimerView::handleMouseDown(S32 x, S32 y, MASK mask) | |||
281 | } | 283 | } |
282 | } | 284 | } |
283 | } | 285 | } |
286 | else if (mask & MASK_ALT) | ||
287 | { | ||
288 | if (mask & MASK_SHIFT) | ||
289 | mSubtractHidden = !mSubtractHidden; | ||
290 | else | ||
291 | mDisplayCalls = !mDisplayCalls; | ||
292 | } | ||
284 | else if (mask & MASK_SHIFT) | 293 | else if (mask & MASK_SHIFT) |
285 | { | 294 | { |
286 | if (++mDisplayMode > 3) | 295 | if (++mDisplayMode > 3) |
@@ -301,8 +310,8 @@ BOOL LLFastTimerView::handleMouseDown(S32 x, S32 y, MASK mask) | |||
301 | mScrollIndex = 0; | 310 | mScrollIndex = 0; |
302 | } | 311 | } |
303 | } | 312 | } |
304 | // RN: for now, pass all mouse events through | 313 | // SJB: Don't pass mouse clicks through the display |
305 | return FALSE; | 314 | return TRUE; |
306 | } | 315 | } |
307 | 316 | ||
308 | BOOL LLFastTimerView::handleMouseUp(S32 x, S32 y, MASK mask) | 317 | BOOL LLFastTimerView::handleMouseUp(S32 x, S32 y, MASK mask) |
@@ -359,33 +368,6 @@ BOOL LLFastTimerView::handleScrollWheel(S32 x, S32 y, S32 clicks) | |||
359 | return FALSE; | 368 | return FALSE; |
360 | } | 369 | } |
361 | 370 | ||
362 | BOOL LLFastTimerView::handleKey(KEY key, MASK mask, BOOL called_from_parent) | ||
363 | { | ||
364 | // Otherwise space key gets eaten from the rest of the UI. JC | ||
365 | if (getVisible()) | ||
366 | { | ||
367 | switch (key) | ||
368 | { | ||
369 | case '=': | ||
370 | mDisplayCalls = !mDisplayCalls; | ||
371 | return TRUE; | ||
372 | case '-': | ||
373 | mSubtractHidden = !mSubtractHidden; | ||
374 | return TRUE; | ||
375 | case ' ': | ||
376 | // pause/unpause | ||
377 | LLFastTimer::sPauseHistory = !LLFastTimer::sPauseHistory; | ||
378 | // reset scroll to bottom when unpausing | ||
379 | if (!LLFastTimer::sPauseHistory) | ||
380 | { | ||
381 | mScrollIndex = 0; | ||
382 | } | ||
383 | return TRUE; | ||
384 | } | ||
385 | } | ||
386 | return FALSE; | ||
387 | } | ||
388 | |||
389 | void LLFastTimerView::draw() | 371 | void LLFastTimerView::draw() |
390 | { | 372 | { |
391 | LLFastTimer t(LLFastTimer::FTM_RENDER_TIMER); | 373 | LLFastTimer t(LLFastTimer::FTM_RENDER_TIMER); |
@@ -480,7 +462,7 @@ void LLFastTimerView::draw() | |||
480 | LLFontGL::sMonospace->renderUTF8(tdesc, 0, x, y, LLColor4::white, LLFontGL::LEFT, LLFontGL::TOP); | 462 | LLFontGL::sMonospace->renderUTF8(tdesc, 0, x, y, LLColor4::white, LLFontGL::LEFT, LLFontGL::TOP); |
481 | y -= (texth + 2); | 463 | y -= (texth + 2); |
482 | 464 | ||
483 | LLFontGL::sMonospace->renderUTF8("[Right-click to log selected] [= to toggle counts] [- to subtract hidden]", | 465 | LLFontGL::sMonospace->renderUTF8("[Right-Click log selected] [ALT-Click toggle counts] [ALT-SHIFT-Click sub hidden]", |
484 | 0, x, y, LLColor4::white, LLFontGL::LEFT, LLFontGL::TOP); | 466 | 0, x, y, LLColor4::white, LLFontGL::LEFT, LLFontGL::TOP); |
485 | y -= (texth + 2); | 467 | y -= (texth + 2); |
486 | } | 468 | } |
@@ -566,7 +548,7 @@ void LLFastTimerView::draw() | |||
566 | } | 548 | } |
567 | else | 549 | else |
568 | { | 550 | { |
569 | U64 ticks = disabled >= 1 ? ticks_sum[0][i] : LLFastTimer::sCountAverage[tidx]; | 551 | U64 ticks = ticks_sum[0][i]; |
570 | ms = (F32)((F64)ticks * iclock_freq); | 552 | ms = (F32)((F64)ticks * iclock_freq); |
571 | calls = (S32)LLFastTimer::sCallAverage[tidx]; | 553 | calls = (S32)LLFastTimer::sCallAverage[tidx]; |
572 | } | 554 | } |
diff --git a/linden/indra/newview/llfasttimerview.h b/linden/indra/newview/llfasttimerview.h index eb160e8..b20c8eb 100644 --- a/linden/indra/newview/llfasttimerview.h +++ b/linden/indra/newview/llfasttimerview.h | |||
@@ -45,7 +45,6 @@ public: | |||
45 | virtual BOOL handleMouseUp(S32 x, S32 y, MASK mask); | 45 | virtual BOOL handleMouseUp(S32 x, S32 y, MASK mask); |
46 | virtual BOOL handleHover(S32 x, S32 y, MASK mask); | 46 | virtual BOOL handleHover(S32 x, S32 y, MASK mask); |
47 | virtual BOOL handleScrollWheel(S32 x, S32 y, S32 clicks); | 47 | virtual BOOL handleScrollWheel(S32 x, S32 y, S32 clicks); |
48 | virtual BOOL handleKey(KEY key, MASK mask, BOOL called_from_parent); | ||
49 | virtual void draw(); | 48 | virtual void draw(); |
50 | 49 | ||
51 | S32 getLegendIndex(S32 y); | 50 | S32 getLegendIndex(S32 y); |
diff --git a/linden/indra/newview/llfeaturemanager.cpp b/linden/indra/newview/llfeaturemanager.cpp index d3b0dbb..061b343 100644 --- a/linden/indra/newview/llfeaturemanager.cpp +++ b/linden/indra/newview/llfeaturemanager.cpp | |||
@@ -300,12 +300,7 @@ BOOL LLFeatureManager::loadFeatureTables() | |||
300 | return TRUE; | 300 | return TRUE; |
301 | } | 301 | } |
302 | 302 | ||
303 | S32 LLFeatureManager::getGPUClass() | 303 | void LLFeatureManager::loadGPUClass() |
304 | { | ||
305 | return mGPUClass; | ||
306 | } | ||
307 | |||
308 | S32 LLFeatureManager::loadGPUClass() | ||
309 | { | 304 | { |
310 | std::string data_path = gDirUtilp->getAppRODataDir(); | 305 | std::string data_path = gDirUtilp->getAppRODataDir(); |
311 | 306 | ||
@@ -313,6 +308,10 @@ S32 LLFeatureManager::loadGPUClass() | |||
313 | 308 | ||
314 | data_path += GPU_TABLE_FILENAME; | 309 | data_path += GPU_TABLE_FILENAME; |
315 | 310 | ||
311 | // defaults | ||
312 | mGPUClass = 0; | ||
313 | mGPUString = gGLManager.getRawGLString(); | ||
314 | |||
316 | llifstream file; | 315 | llifstream file; |
317 | 316 | ||
318 | file.open(data_path.c_str()); | 317 | file.open(data_path.c_str()); |
@@ -320,7 +319,7 @@ S32 LLFeatureManager::loadGPUClass() | |||
320 | if (!file) | 319 | if (!file) |
321 | { | 320 | { |
322 | llwarns << "Unable to open GPU table: " << data_path << "!" << llendl; | 321 | llwarns << "Unable to open GPU table: " << data_path << "!" << llendl; |
323 | return 0; | 322 | return; |
324 | } | 323 | } |
325 | 324 | ||
326 | std::string renderer = gGLManager.getRawGLString(); | 325 | std::string renderer = gGLManager.getRawGLString(); |
@@ -379,14 +378,14 @@ S32 LLFeatureManager::loadGPUClass() | |||
379 | { | 378 | { |
380 | file.close(); | 379 | file.close(); |
381 | llinfos << "GPU is " << label << llendl; | 380 | llinfos << "GPU is " << label << llendl; |
382 | return (S32) strtol(cls, NULL, 10); | 381 | mGPUString = label; |
382 | mGPUClass = (S32) strtol(cls, NULL, 10); | ||
383 | } | 383 | } |
384 | } | 384 | } |
385 | file.close(); | 385 | file.close(); |
386 | //flp->dump(); | 386 | //flp->dump(); |
387 | 387 | ||
388 | llwarns << "Couldn't match GPU to a class: " << gGLManager.getRawGLString() << llendl; | 388 | llwarns << "Couldn't match GPU to a class: " << gGLManager.getRawGLString() << llendl; |
389 | return 0; | ||
390 | } | 389 | } |
391 | 390 | ||
392 | void LLFeatureManager::cleanupFeatureTables() | 391 | void LLFeatureManager::cleanupFeatureTables() |
@@ -419,7 +418,7 @@ void LLFeatureManager::initCPUFeatureMasks() | |||
419 | 418 | ||
420 | void LLFeatureManager::initGraphicsFeatureMasks() | 419 | void LLFeatureManager::initGraphicsFeatureMasks() |
421 | { | 420 | { |
422 | mGPUClass = loadGPUClass(); | 421 | loadGPUClass(); |
423 | 422 | ||
424 | if (mGPUClass >= 0 && mGPUClass < 4) | 423 | if (mGPUClass >= 0 && mGPUClass < 4) |
425 | { | 424 | { |
diff --git a/linden/indra/newview/llfeaturemanager.h b/linden/indra/newview/llfeaturemanager.h index d38e5b7..a24f06f 100644 --- a/linden/indra/newview/llfeaturemanager.h +++ b/linden/indra/newview/llfeaturemanager.h | |||
@@ -84,9 +84,10 @@ public: | |||
84 | void maskCurrentList(const char *name); // Mask the current feature list with the named list | 84 | void maskCurrentList(const char *name); // Mask the current feature list with the named list |
85 | 85 | ||
86 | BOOL loadFeatureTables(); | 86 | BOOL loadFeatureTables(); |
87 | S32 getGPUClass(); | ||
88 | S32 loadGPUClass(); | ||
89 | 87 | ||
88 | S32 getGPUClass() { return mGPUClass; } | ||
89 | std::string& getGPUString() { return mGPUString; } | ||
90 | |||
90 | void cleanupFeatureTables(); | 91 | void cleanupFeatureTables(); |
91 | 92 | ||
92 | S32 getVersion() const { return mTableVersion; } | 93 | S32 getVersion() const { return mTableVersion; } |
@@ -102,7 +103,9 @@ public: | |||
102 | BOOL initPCIFeatureMasks(); | 103 | BOOL initPCIFeatureMasks(); |
103 | 104 | ||
104 | void applyRecommendedFeatures(); | 105 | void applyRecommendedFeatures(); |
106 | |||
105 | protected: | 107 | protected: |
108 | void loadGPUClass(); | ||
106 | void initBaseMask(); | 109 | void initBaseMask(); |
107 | 110 | ||
108 | std::map<LLString, LLFeatureList *> mMaskList; | 111 | std::map<LLString, LLFeatureList *> mMaskList; |
@@ -110,6 +113,7 @@ protected: | |||
110 | S32 mTableVersion; | 113 | S32 mTableVersion; |
111 | BOOL mSafe; // Reinitialize everything to the "safe" mask | 114 | BOOL mSafe; // Reinitialize everything to the "safe" mask |
112 | S32 mGPUClass; | 115 | S32 mGPUClass; |
116 | std::string mGPUString; | ||
113 | }; | 117 | }; |
114 | 118 | ||
115 | extern LLFeatureManager *gFeatureManagerp; | 119 | extern LLFeatureManager *gFeatureManagerp; |
diff --git a/linden/indra/newview/llflexibleobject.cpp b/linden/indra/newview/llflexibleobject.cpp index 7e748f6..7e37c4c 100644 --- a/linden/indra/newview/llflexibleobject.cpp +++ b/linden/indra/newview/llflexibleobject.cpp | |||
@@ -204,9 +204,13 @@ void LLVolumeImplFlexible::setAttributesOfAllSections() | |||
204 | end_rot = F_PI * params.getTwist(); | 204 | end_rot = F_PI * params.getTwist(); |
205 | } | 205 | } |
206 | 206 | ||
207 | if (!mVO->mDrawable) | ||
208 | { | ||
209 | return; | ||
210 | } | ||
211 | |||
207 | S32 num_sections = 1 << mSimulateRes; | 212 | S32 num_sections = 1 << mSimulateRes; |
208 | 213 | ||
209 | |||
210 | LLVector3 scale = mVO->mDrawable->getScale(); | 214 | LLVector3 scale = mVO->mDrawable->getScale(); |
211 | 215 | ||
212 | mSection[0].mPosition = getAnchorPosition(); | 216 | mSection[0].mPosition = getAnchorPosition(); |
diff --git a/linden/indra/newview/llfloatereditui.cpp b/linden/indra/newview/llfloatereditui.cpp index d6a61d7..21580d3 100644 --- a/linden/indra/newview/llfloatereditui.cpp +++ b/linden/indra/newview/llfloatereditui.cpp | |||
@@ -53,7 +53,7 @@ void LLFloaterEditUI::navigateHierarchyButtonPressed(void* data) | |||
53 | for(idx = 0,itor = parentChildren->begin();itor!=parentChildren->end();itor++,idx++){ | 53 | for(idx = 0,itor = parentChildren->begin();itor!=parentChildren->end();itor++,idx++){ |
54 | if((*itor)==view)break; | 54 | if((*itor)==view)break; |
55 | } | 55 | } |
56 | switch((int)data) | 56 | switch((intptr_t)data) |
57 | { | 57 | { |
58 | case 0 ://up | 58 | case 0 ://up |
59 | view = view->getParent(); | 59 | view = view->getParent(); |
diff --git a/linden/indra/newview/llfloatertools.cpp b/linden/indra/newview/llfloatertools.cpp index c9edf98..05dd70b 100644 --- a/linden/indra/newview/llfloatertools.cpp +++ b/linden/indra/newview/llfloatertools.cpp | |||
@@ -383,8 +383,7 @@ LLFloaterTools::LLFloaterTools() | |||
383 | mPanelLandInfo(NULL), | 383 | mPanelLandInfo(NULL), |
384 | 384 | ||
385 | mTabLand(NULL), | 385 | mTabLand(NULL), |
386 | mDirty(TRUE), | 386 | mDirty(TRUE) |
387 | mLastTool(gToolNull) | ||
388 | { | 387 | { |
389 | mAutoFocus = FALSE; | 388 | mAutoFocus = FALSE; |
390 | LLCallbackMap::map_t factory_map; | 389 | LLCallbackMap::map_t factory_map; |
@@ -949,21 +948,13 @@ void LLFloaterTools::onClickGridOptions(void* data) | |||
949 | //floaterp->addDependentFloater(LLFloaterBuildOptions::getInstance(), FALSE); | 948 | //floaterp->addDependentFloater(LLFloaterBuildOptions::getInstance(), FALSE); |
950 | } | 949 | } |
951 | 950 | ||
952 | void LLFloaterTools::saveLastTool() | ||
953 | { | ||
954 | mLastTool = gToolMgr->getCurrentTool( MASK_NONE ); | ||
955 | } | ||
956 | |||
957 | void LLFloaterTools::setEditTool(void* tool_pointer) | 951 | void LLFloaterTools::setEditTool(void* tool_pointer) |
958 | { | 952 | { |
959 | select_tool(tool_pointer); | 953 | select_tool(tool_pointer); |
960 | if(gFloaterTools && tool_pointer != gToolNull) | ||
961 | { | ||
962 | gFloaterTools->saveLastTool(); | ||
963 | } | ||
964 | } | 954 | } |
965 | 955 | ||
966 | void LLFloaterTools::onFocusReceived() | 956 | void LLFloaterTools::onFocusReceived() |
967 | { | 957 | { |
968 | select_tool(mLastTool); | 958 | gCurrentToolset = gBasicToolset; |
959 | gCurrentToolset->selectTool(gCurrentToolset->getSelectedTool()); | ||
969 | } \ No newline at end of file | 960 | } \ No newline at end of file |
diff --git a/linden/indra/newview/llfloatertools.h b/linden/indra/newview/llfloatertools.h index 343a898..a6c4ceb 100644 --- a/linden/indra/newview/llfloatertools.h +++ b/linden/indra/newview/llfloatertools.h | |||
@@ -175,7 +175,6 @@ public: | |||
175 | LLPanelLandInfo *mPanelLandInfo; | 175 | LLPanelLandInfo *mPanelLandInfo; |
176 | 176 | ||
177 | LLTabContainer* mTabLand; | 177 | LLTabContainer* mTabLand; |
178 | LLTool* mLastTool; | ||
179 | 178 | ||
180 | private: | 179 | private: |
181 | BOOL mDirty; | 180 | BOOL mDirty; |
diff --git a/linden/indra/newview/llhippo.cpp b/linden/indra/newview/llhippo.cpp index bcaf498..b2dd20f 100644 --- a/linden/indra/newview/llhippo.cpp +++ b/linden/indra/newview/llhippo.cpp | |||
@@ -51,7 +51,7 @@ void trigger_hippo_bug(void*) | |||
51 | { | 51 | { |
52 | chat = TRUE; | 52 | chat = TRUE; |
53 | } | 53 | } |
54 | else if (frand(1.f) > 0.5f) | 54 | else if (ll_frand() > 0.5f) |
55 | { | 55 | { |
56 | chat = TRUE; | 56 | chat = TRUE; |
57 | } | 57 | } |
diff --git a/linden/indra/newview/llhudeffectbeam.cpp b/linden/indra/newview/llhudeffectbeam.cpp index a7e7a5e..db24875 100644 --- a/linden/indra/newview/llhudeffectbeam.cpp +++ b/linden/indra/newview/llhudeffectbeam.cpp | |||
@@ -369,9 +369,9 @@ void LLHUDEffectBeam::setupParticle(const S32 i) | |||
369 | // Generate a random offset for the target point. | 369 | // Generate a random offset for the target point. |
370 | const F32 SCALE = 0.5f; | 370 | const F32 SCALE = 0.5f; |
371 | F32 x, y, z; | 371 | F32 x, y, z; |
372 | x = frand(SCALE) - 0.5f*SCALE; | 372 | x = ll_frand(SCALE) - 0.5f*SCALE; |
373 | y = frand(SCALE) - 0.5f*SCALE; | 373 | y = ll_frand(SCALE) - 0.5f*SCALE; |
374 | z = frand(SCALE) - 0.5f*SCALE; | 374 | z = ll_frand(SCALE) - 0.5f*SCALE; |
375 | 375 | ||
376 | LLVector3d target_pos_global(mTargetPos); | 376 | LLVector3d target_pos_global(mTargetPos); |
377 | target_pos_global += LLVector3d(x, y, z); | 377 | target_pos_global += LLVector3d(x, y, z); |
diff --git a/linden/indra/newview/llinventorymodel.cpp b/linden/indra/newview/llinventorymodel.cpp index 04506c8..7864aa8 100644 --- a/linden/indra/newview/llinventorymodel.cpp +++ b/linden/indra/newview/llinventorymodel.cpp | |||
@@ -1966,11 +1966,12 @@ bool LLInventoryModel::loadFromFile( | |||
1966 | llinfos << "unable to load inventory from: " << filename << llendl; | 1966 | llinfos << "unable to load inventory from: " << filename << llendl; |
1967 | return false; | 1967 | return false; |
1968 | } | 1968 | } |
1969 | // *NOTE: This buffer size is hard coded into scanf() below. | ||
1969 | char buffer[MAX_STRING]; | 1970 | char buffer[MAX_STRING]; |
1970 | char keyword[MAX_STRING]; | 1971 | char keyword[MAX_STRING]; |
1971 | while(!feof(file) && fgets(buffer, MAX_STRING, file)) | 1972 | while(!feof(file) && fgets(buffer, MAX_STRING, file)) |
1972 | { | 1973 | { |
1973 | sscanf(buffer, " %s", keyword); | 1974 | sscanf(buffer, " %254s", keyword); |
1974 | if(0 == strcmp("inv_category", keyword)) | 1975 | if(0 == strcmp("inv_category", keyword)) |
1975 | { | 1976 | { |
1976 | LLPointer<LLViewerInventoryCategory> inv_cat = new LLViewerInventoryCategory(LLUUID::null); | 1977 | LLPointer<LLViewerInventoryCategory> inv_cat = new LLViewerInventoryCategory(LLUUID::null); |
diff --git a/linden/indra/newview/llmanip.cpp b/linden/indra/newview/llmanip.cpp index 538e6df..20d77e0 100644 --- a/linden/indra/newview/llmanip.cpp +++ b/linden/indra/newview/llmanip.cpp | |||
@@ -107,9 +107,7 @@ void LLManip::getManipNormal(LLViewerObject* object, EManipPart manip, LLVector3 | |||
107 | LLVector3 arrow_axis; | 107 | LLVector3 arrow_axis; |
108 | getManipAxis(object, manip, arrow_axis); | 108 | getManipAxis(object, manip, arrow_axis); |
109 | 109 | ||
110 | LLVector3 origin_dir = grid_origin - gCamera->getOrigin(); | 110 | LLVector3 cross = arrow_axis % gCamera->getAtAxis(); |
111 | origin_dir.normVec(); | ||
112 | LLVector3 cross = arrow_axis % origin_dir; | ||
113 | normal = cross % arrow_axis; | 111 | normal = cross % arrow_axis; |
114 | normal.normVec(); | 112 | normal.normVec(); |
115 | } | 113 | } |
diff --git a/linden/indra/newview/llmutelist.cpp b/linden/indra/newview/llmutelist.cpp index 2101e87..fc0046a 100644 --- a/linden/indra/newview/llmutelist.cpp +++ b/linden/indra/newview/llmutelist.cpp | |||
@@ -363,6 +363,8 @@ BOOL LLMuteList::loadFromFile(const LLString& filename) | |||
363 | return FALSE; | 363 | return FALSE; |
364 | } | 364 | } |
365 | 365 | ||
366 | // *NOTE: Changing the size of these buffers will require changes | ||
367 | // in the scanf below. | ||
366 | char id_buffer[MAX_STRING]; | 368 | char id_buffer[MAX_STRING]; |
367 | char name_buffer[MAX_STRING]; | 369 | char name_buffer[MAX_STRING]; |
368 | char buffer[MAX_STRING]; | 370 | char buffer[MAX_STRING]; |
@@ -372,7 +374,7 @@ BOOL LLMuteList::loadFromFile(const LLString& filename) | |||
372 | id_buffer[0] = '\0'; | 374 | id_buffer[0] = '\0'; |
373 | name_buffer[0] = '\0'; | 375 | name_buffer[0] = '\0'; |
374 | S32 type = 0; | 376 | S32 type = 0; |
375 | sscanf(buffer, " %d %s %[^|]", &type, id_buffer, name_buffer); | 377 | sscanf(buffer, " %d %254s %254[^|]", &type, id_buffer, name_buffer); |
376 | LLUUID id = LLUUID(id_buffer); | 378 | LLUUID id = LLUUID(id_buffer); |
377 | LLMute mute(id, name_buffer, (LLMute::EType)type); | 379 | LLMute mute(id, name_buffer, (LLMute::EType)type); |
378 | if (mute.mID.isNull() | 380 | if (mute.mID.isNull() |
diff --git a/linden/indra/newview/llpanelavatar.cpp b/linden/indra/newview/llpanelavatar.cpp index d54f16b..8ba33a9 100644 --- a/linden/indra/newview/llpanelavatar.cpp +++ b/linden/indra/newview/llpanelavatar.cpp | |||
@@ -848,14 +848,17 @@ void LLPanelAvatarClassified::enableControls(BOOL self) | |||
848 | BOOL LLPanelAvatarClassified::titleIsValid() | 848 | BOOL LLPanelAvatarClassified::titleIsValid() |
849 | { | 849 | { |
850 | LLTabContainerCommon* tabs = LLViewerUICtrlFactory::getTabContainerByName(this, "classified tab"); | 850 | LLTabContainerCommon* tabs = LLViewerUICtrlFactory::getTabContainerByName(this, "classified tab"); |
851 | for (S32 i = 0; i < tabs->getTabCount(); i++) | 851 | if ( tabs ) |
852 | { | 852 | { |
853 | LLPanelClassified* panel = (LLPanelClassified*)tabs->getPanelByIndex(i); | 853 | LLPanelClassified* panel = (LLPanelClassified*)tabs->getCurrentPanel(); |
854 | if ( ! panel->titleIsValid() ) | 854 | if ( panel ) |
855 | { | 855 | { |
856 | return FALSE; | 856 | if ( ! panel->titleIsValid() ) |
857 | } | 857 | { |
858 | } | 858 | return FALSE; |
859 | }; | ||
860 | }; | ||
861 | }; | ||
859 | 862 | ||
860 | return TRUE; | 863 | return TRUE; |
861 | } | 864 | } |
@@ -1659,7 +1662,8 @@ void LLPanelAvatar::onClickOK(void *userdata) | |||
1659 | { | 1662 | { |
1660 | self->sendAvatarPropertiesUpdate(); | 1663 | self->sendAvatarPropertiesUpdate(); |
1661 | 1664 | ||
1662 | if ( self->mPanelClassified->titleIsValid() ) | 1665 | LLTabContainerCommon* tabs = LLUICtrlFactory::getTabContainerByName(self,"tab"); |
1666 | if ( tabs->getCurrentPanel() != self->mPanelClassified ) | ||
1663 | { | 1667 | { |
1664 | self->mPanelClassified->apply(); | 1668 | self->mPanelClassified->apply(); |
1665 | 1669 | ||
@@ -1669,6 +1673,19 @@ void LLPanelAvatar::onClickOK(void *userdata) | |||
1669 | infop->close(); | 1673 | infop->close(); |
1670 | } | 1674 | } |
1671 | } | 1675 | } |
1676 | else | ||
1677 | { | ||
1678 | if ( self->mPanelClassified->titleIsValid() ) | ||
1679 | { | ||
1680 | self->mPanelClassified->apply(); | ||
1681 | |||
1682 | LLFloaterAvatarInfo *infop = LLFloaterAvatarInfo::getInstance(self->mAvatarID); | ||
1683 | if (infop) | ||
1684 | { | ||
1685 | infop->close(); | ||
1686 | } | ||
1687 | } | ||
1688 | } | ||
1672 | } | 1689 | } |
1673 | } | 1690 | } |
1674 | 1691 | ||
diff --git a/linden/indra/newview/llstartup.cpp b/linden/indra/newview/llstartup.cpp index 5eabad3..916db16 100644 --- a/linden/indra/newview/llstartup.cpp +++ b/linden/indra/newview/llstartup.cpp | |||
@@ -685,7 +685,7 @@ BOOL idle_startup() | |||
685 | gSavedSettings.loadFromFile(gDirUtilp->getExpandedFilename(LL_PATH_PER_SL_ACCOUNT,"overrides.xml")); | 685 | gSavedSettings.loadFromFile(gDirUtilp->getExpandedFilename(LL_PATH_PER_SL_ACCOUNT,"overrides.xml")); |
686 | 686 | ||
687 | // handle the per account settings setup | 687 | // handle the per account settings setup |
688 | strcpy(gPerAccountSettingsFileName, gDirUtilp->getExpandedFilename(LL_PATH_PER_SL_ACCOUNT, DEFAULT_SETTINGS_FILE).c_str()); | 688 | gPerAccountSettingsFileName = gDirUtilp->getExpandedFilename(LL_PATH_PER_SL_ACCOUNT, DEFAULT_SETTINGS_FILE); |
689 | 689 | ||
690 | // per account settings. Set defaults here if not found. If we get a bunch of these, eventually move to a function. | 690 | // per account settings. Set defaults here if not found. If we get a bunch of these, eventually move to a function. |
691 | gSavedPerAccountSettings.loadFromFile(gPerAccountSettingsFileName); | 691 | gSavedPerAccountSettings.loadFromFile(gPerAccountSettingsFileName); |
diff --git a/linden/indra/newview/lltexlayer.cpp b/linden/indra/newview/lltexlayer.cpp index 0292417..63d167d 100644 --- a/linden/indra/newview/lltexlayer.cpp +++ b/linden/indra/newview/lltexlayer.cpp | |||
@@ -487,7 +487,7 @@ void LLTexLayerSetBuffer::readBackAndUpload(U8* baked_bump_data) | |||
487 | // static | 487 | // static |
488 | void LLTexLayerSetBuffer::onTextureUploadComplete(const LLUUID& uuid, void* userdata, S32 result) // StoreAssetData callback (not fixed) | 488 | void LLTexLayerSetBuffer::onTextureUploadComplete(const LLUUID& uuid, void* userdata, S32 result) // StoreAssetData callback (not fixed) |
489 | { | 489 | { |
490 | LLBakedUploadData* baked_upload_data = (LLBakedUploadData*)(U32)userdata; | 490 | LLBakedUploadData* baked_upload_data = (LLBakedUploadData*)userdata; |
491 | 491 | ||
492 | LLVOAvatar* avatar = gAgent.getAvatarObject(); | 492 | LLVOAvatar* avatar = gAgent.getAvatarObject(); |
493 | 493 | ||
diff --git a/linden/indra/newview/llviewercontrol.cpp b/linden/indra/newview/llviewercontrol.cpp index de89965..86e58d1 100644 --- a/linden/indra/newview/llviewercontrol.cpp +++ b/linden/indra/newview/llviewercontrol.cpp | |||
@@ -57,8 +57,8 @@ LLControlGroup gCrashSettings; // saved at end of session | |||
57 | LLString gLastRunVersion; | 57 | LLString gLastRunVersion; |
58 | LLString gCurrentVersion; | 58 | LLString gCurrentVersion; |
59 | 59 | ||
60 | char gSettingsFileName[LL_MAX_PATH]; | 60 | LLString gSettingsFileName; |
61 | char gPerAccountSettingsFileName[LL_MAX_PATH] = ""; | 61 | LLString gPerAccountSettingsFileName; |
62 | 62 | ||
63 | LLFloaterSettingsDebug::LLFloaterSettingsDebug() : LLFloater("Configuration Editor") | 63 | LLFloaterSettingsDebug::LLFloaterSettingsDebug() : LLFloater("Configuration Editor") |
64 | { | 64 | { |
diff --git a/linden/indra/newview/llviewercontrol.h b/linden/indra/newview/llviewercontrol.h index 06d666e..4be4313 100644 --- a/linden/indra/newview/llviewercontrol.h +++ b/linden/indra/newview/llviewercontrol.h | |||
@@ -72,8 +72,7 @@ extern LLControlGroup gCrashSettings; | |||
72 | extern LLString gLastRunVersion; | 72 | extern LLString gLastRunVersion; |
73 | extern LLString gCurrentVersion; | 73 | extern LLString gCurrentVersion; |
74 | 74 | ||
75 | extern char gSettingsFileName[LL_MAX_PATH]; | 75 | extern LLString gSettingsFileName; |
76 | extern char gPerAccountSettingsFileName[LL_MAX_PATH]; | 76 | extern LLString gPerAccountSettingsFileName; |
77 | extern const char *DEFAULT_SETTINGS_FILE; | ||
78 | 77 | ||
79 | #endif // LL_LLVIEWERCONTROL_H | 78 | #endif // LL_LLVIEWERCONTROL_H |
diff --git a/linden/indra/newview/llviewerimage.cpp b/linden/indra/newview/llviewerimage.cpp index ad1604e..7500ada 100644 --- a/linden/indra/newview/llviewerimage.cpp +++ b/linden/indra/newview/llviewerimage.cpp | |||
@@ -45,7 +45,6 @@ | |||
45 | #include "llvfs.h" | 45 | #include "llvfs.h" |
46 | #include "message.h" | 46 | #include "message.h" |
47 | #include "lltimer.h" | 47 | #include "lltimer.h" |
48 | //#include "vmath.h" // For frand | ||
49 | 48 | ||
50 | // viewer includes | 49 | // viewer includes |
51 | #include "llviewerimagelist.h" | 50 | #include "llviewerimagelist.h" |
diff --git a/linden/indra/newview/llviewerinventory.cpp b/linden/indra/newview/llviewerinventory.cpp index 1ed6525..487a9f8 100644 --- a/linden/indra/newview/llviewerinventory.cpp +++ b/linden/indra/newview/llviewerinventory.cpp | |||
@@ -449,6 +449,7 @@ bool LLViewerInventoryCategory::fetchDescendents() | |||
449 | 449 | ||
450 | bool LLViewerInventoryCategory::importFileLocal(FILE* fp) | 450 | bool LLViewerInventoryCategory::importFileLocal(FILE* fp) |
451 | { | 451 | { |
452 | // *NOTE: This buffer size is hard coded into scanf() below. | ||
452 | char buffer[MAX_STRING]; | 453 | char buffer[MAX_STRING]; |
453 | char keyword[MAX_STRING]; | 454 | char keyword[MAX_STRING]; |
454 | char valuestr[MAX_STRING]; | 455 | char valuestr[MAX_STRING]; |
@@ -458,7 +459,7 @@ bool LLViewerInventoryCategory::importFileLocal(FILE* fp) | |||
458 | while(!feof(fp)) | 459 | while(!feof(fp)) |
459 | { | 460 | { |
460 | fgets(buffer, MAX_STRING, fp); | 461 | fgets(buffer, MAX_STRING, fp); |
461 | sscanf(buffer, " %s %s", keyword, valuestr); | 462 | sscanf(buffer, " %254s %254s", keyword, valuestr); |
462 | if(!keyword) | 463 | if(!keyword) |
463 | { | 464 | { |
464 | continue; | 465 | continue; |
@@ -491,7 +492,7 @@ bool LLViewerInventoryCategory::importFileLocal(FILE* fp) | |||
491 | { | 492 | { |
492 | //strcpy(valuestr, buffer + strlen(keyword) + 3); | 493 | //strcpy(valuestr, buffer + strlen(keyword) + 3); |
493 | // *NOTE: Not ANSI C, but widely supported. | 494 | // *NOTE: Not ANSI C, but widely supported. |
494 | sscanf(buffer, " %s %[^|]", keyword, valuestr); | 495 | sscanf(buffer, " %254s %254[^|]", keyword, valuestr); |
495 | mName.assign(valuestr); | 496 | mName.assign(valuestr); |
496 | LLString::replaceNonstandardASCII(mName, ' '); | 497 | LLString::replaceNonstandardASCII(mName, ' '); |
497 | LLString::replaceChar(mName, '|', ' '); | 498 | LLString::replaceChar(mName, '|', ' '); |
diff --git a/linden/indra/newview/llviewerkeyboard.cpp b/linden/indra/newview/llviewerkeyboard.cpp index 531cb89..c5ada54 100644 --- a/linden/indra/newview/llviewerkeyboard.cpp +++ b/linden/indra/newview/llviewerkeyboard.cpp | |||
@@ -704,6 +704,7 @@ S32 LLViewerKeyboard::loadBindings(const char *filename) | |||
704 | FILE *fp; | 704 | FILE *fp; |
705 | const S32 BUFFER_SIZE = 2048; | 705 | const S32 BUFFER_SIZE = 2048; |
706 | char buffer[BUFFER_SIZE]; | 706 | char buffer[BUFFER_SIZE]; |
707 | // *NOTE: This buffer size is hard coded into scanf() below. | ||
707 | char mode_string[MAX_STRING]; | 708 | char mode_string[MAX_STRING]; |
708 | char key_string[MAX_STRING]; | 709 | char key_string[MAX_STRING]; |
709 | char mask_string[MAX_STRING]; | 710 | char mask_string[MAX_STRING]; |
@@ -733,7 +734,7 @@ S32 LLViewerKeyboard::loadBindings(const char *filename) | |||
733 | if (buffer[0] == '#' || buffer[0] == '\n') continue; | 734 | if (buffer[0] == '#' || buffer[0] == '\n') continue; |
734 | 735 | ||
735 | // grab the binding strings | 736 | // grab the binding strings |
736 | tokens_read = sscanf(buffer, "%s %s %s %s", mode_string, key_string, mask_string, function_string); | 737 | tokens_read = sscanf(buffer, "%254s %254s %254s %254s", mode_string, key_string, mask_string, function_string); |
737 | 738 | ||
738 | if (tokens_read == EOF) | 739 | if (tokens_read == EOF) |
739 | { | 740 | { |
diff --git a/linden/indra/newview/llviewermenu.cpp b/linden/indra/newview/llviewermenu.cpp index 921e650..3e5063e 100644 --- a/linden/indra/newview/llviewermenu.cpp +++ b/linden/indra/newview/llviewermenu.cpp | |||
@@ -3965,6 +3965,7 @@ void force_import_geometry(void*) | |||
3965 | child = root->getNextNamedChild()) | 3965 | child = root->getNextNamedChild()) |
3966 | { | 3966 | { |
3967 | // get object data | 3967 | // get object data |
3968 | // *NOTE: This buffer size is hard coded into scanf() below. | ||
3968 | char name[255]; // Shape | 3969 | char name[255]; // Shape |
3969 | char description[255]; // Description | 3970 | char description[255]; // Description |
3970 | U32 material; // Material | 3971 | U32 material; // Material |
@@ -3997,9 +3998,9 @@ void force_import_geometry(void*) | |||
3997 | child->getAttributeString("PCode", &attribute); | 3998 | child->getAttributeString("PCode", &attribute); |
3998 | pcode = atoi(attribute.c_str()); | 3999 | pcode = atoi(attribute.c_str()); |
3999 | child->getAttributeString("Shape", &attribute); | 4000 | child->getAttributeString("Shape", &attribute); |
4000 | sscanf(attribute.c_str(), "%s", name); | 4001 | sscanf(attribute.c_str(), "%254s", name); |
4001 | child->getAttributeString("Description", &attribute); | 4002 | child->getAttributeString("Description", &attribute); |
4002 | sscanf(attribute.c_str(), "%s", description); | 4003 | sscanf(attribute.c_str(), "%254s", description); |
4003 | child->getAttributeString("Material", &attribute); | 4004 | child->getAttributeString("Material", &attribute); |
4004 | material = atoi(attribute.c_str()); | 4005 | material = atoi(attribute.c_str()); |
4005 | child->getAttributeString("Scale", &attribute); | 4006 | child->getAttributeString("Scale", &attribute); |
@@ -4079,6 +4080,7 @@ void force_import_geometry(void*) | |||
4079 | // read the faces | 4080 | // read the faces |
4080 | U32 facenumber; | 4081 | U32 facenumber; |
4081 | LLColor4 color; | 4082 | LLColor4 color; |
4083 | // *NOTE: This buffer size is hard coded into scanf() below. | ||
4082 | char texture[UUID_STR_LENGTH]; | 4084 | char texture[UUID_STR_LENGTH]; |
4083 | LLUUID texid; | 4085 | LLUUID texid; |
4084 | texid.toString(texture); | 4086 | texid.toString(texture); |
@@ -4089,7 +4091,7 @@ void force_import_geometry(void*) | |||
4089 | face->getAttributeString("FaceColor", &attribute); | 4091 | face->getAttributeString("FaceColor", &attribute); |
4090 | sscanf(attribute, "%d %f %f %f %f", &facenumber, &color.mV[VX], &color.mV[VY], &color.mV[VZ], &color.mV[VW]); | 4092 | sscanf(attribute, "%d %f %f %f %f", &facenumber, &color.mV[VX], &color.mV[VY], &color.mV[VZ], &color.mV[VW]); |
4091 | face->getAttributeString("Face", &attribute); | 4093 | face->getAttributeString("Face", &attribute); |
4092 | sscanf(attribute, "%d %f %f %f %f %f %d %s", &facenumber, &sx, &sy, &ox, &oy, &rot, &bump, texture); | 4094 | sscanf(attribute, "%d %f %f %f %f %f %d %36s", &facenumber, &sx, &sy, &ox, &oy, &rot, &bump, texture); |
4093 | texid.set(texture); | 4095 | texid.set(texture); |
4094 | te.setColor(color); | 4096 | te.setColor(color); |
4095 | te.setBumpShinyFullbright(bump); | 4097 | te.setBumpShinyFullbright(bump); |
@@ -5025,7 +5027,7 @@ const char* upload_pick(void* data) | |||
5025 | LLFilePicker::ELoadFilter type; | 5027 | LLFilePicker::ELoadFilter type; |
5026 | if(data) | 5028 | if(data) |
5027 | { | 5029 | { |
5028 | type = (LLFilePicker::ELoadFilter)((S32)data); | 5030 | type = (LLFilePicker::ELoadFilter)((intptr_t)data); |
5029 | } | 5031 | } |
5030 | else | 5032 | else |
5031 | { | 5033 | { |
@@ -5506,7 +5508,8 @@ void upload_new_resource(const LLString& src_filename, std::string name, | |||
5506 | if (fscanf(in, "LindenResource\nversion %d\n", &version)) | 5508 | if (fscanf(in, "LindenResource\nversion %d\n", &version)) |
5507 | { | 5509 | { |
5508 | if (2 == version) | 5510 | if (2 == version) |
5509 | { | 5511 | { |
5512 | // *NOTE: This buffer size is hard coded into scanf() below. | ||
5510 | char label[MAX_STRING]; | 5513 | char label[MAX_STRING]; |
5511 | char value[MAX_STRING]; | 5514 | char value[MAX_STRING]; |
5512 | S32 tokens_read; | 5515 | S32 tokens_read; |
@@ -5514,7 +5517,7 @@ void upload_new_resource(const LLString& src_filename, std::string name, | |||
5514 | { | 5517 | { |
5515 | label[0] = '\0'; | 5518 | label[0] = '\0'; |
5516 | value[0] = '\0'; | 5519 | value[0] = '\0'; |
5517 | tokens_read = sscanf(buf, "%s %s\n", label, value); | 5520 | tokens_read = sscanf(buf, "%254s %254s\n", label, value); |
5518 | 5521 | ||
5519 | llinfos << "got: " << label << " = " << value | 5522 | llinfos << "got: " << label << " = " << value |
5520 | << llendl; | 5523 | << llendl; |
@@ -5930,7 +5933,7 @@ void handle_export_selected( void * ) | |||
5930 | 5933 | ||
5931 | BOOL menu_check_build_tool( void* user_data ) | 5934 | BOOL menu_check_build_tool( void* user_data ) |
5932 | { | 5935 | { |
5933 | S32 index = (S32) user_data; | 5936 | S32 index = (intptr_t) user_data; |
5934 | return gCurrentToolset->isToolSelected( index ); | 5937 | return gCurrentToolset->isToolSelected( index ); |
5935 | } | 5938 | } |
5936 | 5939 | ||
@@ -6223,7 +6226,7 @@ class LLObjectEnableSitOrStand : public view_listener_t | |||
6223 | { | 6226 | { |
6224 | bool new_value = false; | 6227 | bool new_value = false; |
6225 | LLViewerObject* dest_object = NULL; | 6228 | LLViewerObject* dest_object = NULL; |
6226 | if(dest_object = gObjectList.findObject(gLastHitObjectID)) | 6229 | if((dest_object = gObjectList.findObject(gLastHitObjectID))) |
6227 | { | 6230 | { |
6228 | if(dest_object->getPCode() == LL_PCODE_VOLUME) | 6231 | if(dest_object->getPCode() == LL_PCODE_VOLUME) |
6229 | { | 6232 | { |
@@ -8075,7 +8078,7 @@ void handle_debug_avatar_textures(void*) | |||
8075 | 8078 | ||
8076 | void handle_grab_texture(void* data) | 8079 | void handle_grab_texture(void* data) |
8077 | { | 8080 | { |
8078 | LLVOAvatar::ETextureIndex index = (LLVOAvatar::ETextureIndex) ((U32) data); | 8081 | LLVOAvatar::ETextureIndex index = (LLVOAvatar::ETextureIndex)((intptr_t)data); |
8079 | LLVOAvatar* avatar = gAgent.getAvatarObject(); | 8082 | LLVOAvatar* avatar = gAgent.getAvatarObject(); |
8080 | if ( avatar ) | 8083 | if ( avatar ) |
8081 | { | 8084 | { |
@@ -8166,7 +8169,7 @@ void handle_grab_texture(void* data) | |||
8166 | 8169 | ||
8167 | BOOL enable_grab_texture(void* data) | 8170 | BOOL enable_grab_texture(void* data) |
8168 | { | 8171 | { |
8169 | LLVOAvatar::ETextureIndex index = (LLVOAvatar::ETextureIndex) ((U32) data); | 8172 | LLVOAvatar::ETextureIndex index = (LLVOAvatar::ETextureIndex)((intptr_t)data); |
8170 | LLVOAvatar* avatar = gAgent.getAvatarObject(); | 8173 | LLVOAvatar* avatar = gAgent.getAvatarObject(); |
8171 | if ( avatar ) | 8174 | if ( avatar ) |
8172 | { | 8175 | { |
diff --git a/linden/indra/newview/llviewermessage.cpp b/linden/indra/newview/llviewermessage.cpp index ba5be0a..124ae13 100644 --- a/linden/indra/newview/llviewermessage.cpp +++ b/linden/indra/newview/llviewermessage.cpp | |||
@@ -1999,7 +1999,7 @@ void process_chat_from_simulator(LLMessageSystem *msg, void **user_data) | |||
1999 | && chatter != gAgent.getAvatarObject()) | 1999 | && chatter != gAgent.getAvatarObject()) |
2000 | { | 2000 | { |
2001 | gAgent.heardChat(chat); | 2001 | gAgent.heardChat(chat); |
2002 | if (gLindenLabRandomNumber.llrand(2) == 0) | 2002 | if (ll_rand(2) == 0) |
2003 | { | 2003 | { |
2004 | gAgent.setLookAt(LOOKAT_TARGET_AUTO_LISTEN, chatter, LLVector3::zero); | 2004 | gAgent.setLookAt(LOOKAT_TARGET_AUTO_LISTEN, chatter, LLVector3::zero); |
2005 | } | 2005 | } |
diff --git a/linden/indra/newview/llviewerobject.cpp b/linden/indra/newview/llviewerobject.cpp index d034aa7..40930e6 100644 --- a/linden/indra/newview/llviewerobject.cpp +++ b/linden/indra/newview/llviewerobject.cpp | |||
@@ -2396,6 +2396,7 @@ void LLViewerObject::loadTaskInvFile(const char* filename) | |||
2396 | if(ifs.good()) | 2396 | if(ifs.good()) |
2397 | { | 2397 | { |
2398 | char buffer[MAX_STRING]; | 2398 | char buffer[MAX_STRING]; |
2399 | // *NOTE: This buffer size is hard coded into scanf() below. | ||
2399 | char keyword[MAX_STRING]; | 2400 | char keyword[MAX_STRING]; |
2400 | if(mInventory) | 2401 | if(mInventory) |
2401 | { | 2402 | { |
@@ -2408,7 +2409,7 @@ void LLViewerObject::loadTaskInvFile(const char* filename) | |||
2408 | while(ifs.good()) | 2409 | while(ifs.good()) |
2409 | { | 2410 | { |
2410 | ifs.getline(buffer, MAX_STRING); | 2411 | ifs.getline(buffer, MAX_STRING); |
2411 | sscanf(buffer, " %s", keyword); | 2412 | sscanf(buffer, " %254s", keyword); |
2412 | if(0 == strcmp("inv_item", keyword)) | 2413 | if(0 == strcmp("inv_item", keyword)) |
2413 | { | 2414 | { |
2414 | LLPointer<LLInventoryObject> inv = new LLViewerInventoryItem; | 2415 | LLPointer<LLInventoryObject> inv = new LLViewerInventoryItem; |
diff --git a/linden/indra/newview/llviewerpartsim.cpp b/linden/indra/newview/llviewerpartsim.cpp index 1175553..be2c90f 100644 --- a/linden/indra/newview/llviewerpartsim.cpp +++ b/linden/indra/newview/llviewerpartsim.cpp | |||
@@ -418,7 +418,7 @@ BOOL LLViewerPartSim::shouldAddPart() | |||
418 | F32 frac = (F32)sParticleCount/(F32)sMaxParticleCount; | 418 | F32 frac = (F32)sParticleCount/(F32)sMaxParticleCount; |
419 | frac -= 0.75; | 419 | frac -= 0.75; |
420 | frac *= 3.f; | 420 | frac *= 3.f; |
421 | if (frand(1.f) < frac) | 421 | if (ll_frand() < frac) |
422 | { | 422 | { |
423 | // Skip... | 423 | // Skip... |
424 | return FALSE; | 424 | return FALSE; |
@@ -549,9 +549,9 @@ void LLViewerPartSim::updateSimulation() | |||
549 | // pain. | 549 | // pain. |
550 | S32 i; | 550 | S32 i; |
551 | S32 count = mViewerPartSources.count(); | 551 | S32 count = mViewerPartSources.count(); |
552 | S32 start = (S32)frand((F32)count); | 552 | S32 start = (S32)ll_frand((F32)count); |
553 | S32 dir = 1; | 553 | S32 dir = 1; |
554 | if (frand(1.0) > 0.5f) | 554 | if (ll_frand() > 0.5f) |
555 | { | 555 | { |
556 | dir = -1; | 556 | dir = -1; |
557 | } | 557 | } |
diff --git a/linden/indra/newview/llviewerpartsource.cpp b/linden/indra/newview/llviewerpartsource.cpp index ceb6761..39869e2 100644 --- a/linden/indra/newview/llviewerpartsource.cpp +++ b/linden/indra/newview/llviewerpartsource.cpp | |||
@@ -213,9 +213,9 @@ void LLViewerPartSourceScript::update(const F32 dt) | |||
213 | F32 mvs; | 213 | F32 mvs; |
214 | do | 214 | do |
215 | { | 215 | { |
216 | part_dir_vector.mV[VX] = frand(2.f) - 1.f; | 216 | part_dir_vector.mV[VX] = ll_frand(2.f) - 1.f; |
217 | part_dir_vector.mV[VY] = frand(2.f) - 1.f; | 217 | part_dir_vector.mV[VY] = ll_frand(2.f) - 1.f; |
218 | part_dir_vector.mV[VZ] = frand(2.f) - 1.f; | 218 | part_dir_vector.mV[VZ] = ll_frand(2.f) - 1.f; |
219 | mvs = part_dir_vector.magVecSquared(); | 219 | mvs = part_dir_vector.magVecSquared(); |
220 | } | 220 | } |
221 | while ((mvs > 1.f) || (mvs < 0.01f)); | 221 | while ((mvs > 1.f) || (mvs < 0.01f)); |
@@ -223,7 +223,7 @@ void LLViewerPartSourceScript::update(const F32 dt) | |||
223 | part_dir_vector.normVec(); | 223 | part_dir_vector.normVec(); |
224 | part.mPosAgent += mPartSysData.mBurstRadius*part_dir_vector; | 224 | part.mPosAgent += mPartSysData.mBurstRadius*part_dir_vector; |
225 | part.mVelocity = part_dir_vector; | 225 | part.mVelocity = part_dir_vector; |
226 | F32 speed = mPartSysData.mBurstSpeedMin + frand(mPartSysData.mBurstSpeedMax - mPartSysData.mBurstSpeedMin); | 226 | F32 speed = mPartSysData.mBurstSpeedMin + ll_frand(mPartSysData.mBurstSpeedMax - mPartSysData.mBurstSpeedMin); |
227 | part.mVelocity *= speed; | 227 | part.mVelocity *= speed; |
228 | } | 228 | } |
229 | else if (mPartSysData.mPattern & LLPartSysData::LL_PART_SRC_PATTERN_ANGLE | 229 | else if (mPartSysData.mPattern & LLPartSysData::LL_PART_SRC_PATTERN_ANGLE |
@@ -242,10 +242,10 @@ void LLViewerPartSourceScript::update(const F32 dt) | |||
242 | F32 outerAngle = mPartSysData.mOuterAngle; | 242 | F32 outerAngle = mPartSysData.mOuterAngle; |
243 | 243 | ||
244 | // generate a random angle within the given space... | 244 | // generate a random angle within the given space... |
245 | F32 angle = innerAngle + frand(outerAngle - innerAngle); | 245 | F32 angle = innerAngle + ll_frand(outerAngle - innerAngle); |
246 | 246 | ||
247 | // split which side it will go on randomly... | 247 | // split which side it will go on randomly... |
248 | if (frand(1.0) < 0.5) | 248 | if (ll_frand() < 0.5) |
249 | { | 249 | { |
250 | angle = -angle; | 250 | angle = -angle; |
251 | } | 251 | } |
@@ -256,7 +256,7 @@ void LLViewerPartSourceScript::update(const F32 dt) | |||
256 | // If this is a cone pattern, rotate again to create the cone. | 256 | // If this is a cone pattern, rotate again to create the cone. |
257 | if (mPartSysData.mPattern & LLPartSysData::LL_PART_SRC_PATTERN_ANGLE_CONE) | 257 | if (mPartSysData.mPattern & LLPartSysData::LL_PART_SRC_PATTERN_ANGLE_CONE) |
258 | { | 258 | { |
259 | part_dir_vector.rotVec(frand(4*F_PI), 0.0, 0.0, 1.0); | 259 | part_dir_vector.rotVec(ll_frand(4*F_PI), 0.0, 0.0, 1.0); |
260 | } | 260 | } |
261 | 261 | ||
262 | // Only apply this rotation if using the deprecated angles. | 262 | // Only apply this rotation if using the deprecated angles. |
@@ -276,7 +276,7 @@ void LLViewerPartSourceScript::update(const F32 dt) | |||
276 | 276 | ||
277 | part.mVelocity = part_dir_vector; | 277 | part.mVelocity = part_dir_vector; |
278 | 278 | ||
279 | F32 speed = mPartSysData.mBurstSpeedMin + frand(mPartSysData.mBurstSpeedMax - mPartSysData.mBurstSpeedMin); | 279 | F32 speed = mPartSysData.mBurstSpeedMin + ll_frand(mPartSysData.mBurstSpeedMax - mPartSysData.mBurstSpeedMin); |
280 | part.mVelocity *= speed; | 280 | part.mVelocity *= speed; |
281 | } | 281 | } |
282 | else | 282 | else |
@@ -459,7 +459,7 @@ void LLViewerPartSourceSpiral::update(const F32 dt) | |||
459 | part.mLastUpdateTime = 0.f; | 459 | part.mLastUpdateTime = 0.f; |
460 | part.mScale.mV[0] = 0.25f; | 460 | part.mScale.mV[0] = 0.25f; |
461 | part.mScale.mV[1] = 0.25f; | 461 | part.mScale.mV[1] = 0.25f; |
462 | part.mParameter = frand(F_TWO_PI); | 462 | part.mParameter = ll_frand(F_TWO_PI); |
463 | 463 | ||
464 | gWorldPointer->mPartSim.addPart(part); | 464 | gWorldPointer->mPartSim.addPart(part); |
465 | } | 465 | } |
@@ -720,7 +720,7 @@ void LLViewerPartSourceChat::update(const F32 dt) | |||
720 | part.mLastUpdateTime = 0.f; | 720 | part.mLastUpdateTime = 0.f; |
721 | part.mScale.mV[0] = 0.25f; | 721 | part.mScale.mV[0] = 0.25f; |
722 | part.mScale.mV[1] = 0.25f; | 722 | part.mScale.mV[1] = 0.25f; |
723 | part.mParameter = frand(F_TWO_PI); | 723 | part.mParameter = ll_frand(F_TWO_PI); |
724 | 724 | ||
725 | gWorldPointer->mPartSim.addPart(part); | 725 | gWorldPointer->mPartSim.addPart(part); |
726 | } | 726 | } |
diff --git a/linden/indra/newview/llviewerstats.cpp b/linden/indra/newview/llviewerstats.cpp index e1e783c..e04918e 100644 --- a/linden/indra/newview/llviewerstats.cpp +++ b/linden/indra/newview/llviewerstats.cpp | |||
@@ -57,8 +57,8 @@ public: | |||
57 | 57 | ||
58 | const StatAttributes STAT_INFO[LLViewerStats::ST_COUNT] = | 58 | const StatAttributes STAT_INFO[LLViewerStats::ST_COUNT] = |
59 | { | 59 | { |
60 | // ST_MOUSELOOK_SECONDS | 60 | // ST_VERSION |
61 | StatAttributes("Seconds in Mouselook", FALSE, TRUE), | 61 | StatAttributes("Version", TRUE, FALSE), |
62 | // ST_AVATAR_EDIT_SECONDS | 62 | // ST_AVATAR_EDIT_SECONDS |
63 | StatAttributes("Seconds in Edit Appearence", FALSE, TRUE), | 63 | StatAttributes("Seconds in Edit Appearence", FALSE, TRUE), |
64 | // ST_TOOLBOX_SECONDS | 64 | // ST_TOOLBOX_SECONDS |
@@ -77,10 +77,10 @@ const StatAttributes STAT_INFO[LLViewerStats::ST_COUNT] = | |||
77 | StatAttributes("Object rez count", FALSE, FALSE), | 77 | StatAttributes("Object rez count", FALSE, FALSE), |
78 | // ST_FPS_10_SECONDS | 78 | // ST_FPS_10_SECONDS |
79 | StatAttributes("Seconds below 10 FPS", FALSE, TRUE), | 79 | StatAttributes("Seconds below 10 FPS", FALSE, TRUE), |
80 | // ST_FPS_5_SECONDS | ||
81 | StatAttributes("Seconds below 5 FPS", FALSE, TRUE), | ||
82 | // ST_FPS_2_SECONDS | 80 | // ST_FPS_2_SECONDS |
83 | StatAttributes("Seconds below 2 FPS", FALSE, TRUE), | 81 | StatAttributes("Seconds below 2 FPS", FALSE, TRUE), |
82 | // ST_MOUSELOOK_SECONDS | ||
83 | StatAttributes("Seconds in Mouselook", FALSE, TRUE), | ||
84 | // ST_FLY_COUNT | 84 | // ST_FLY_COUNT |
85 | StatAttributes("Fly count", FALSE, FALSE), | 85 | StatAttributes("Fly count", FALSE, FALSE), |
86 | // ST_TELEPORT_COUNT | 86 | // ST_TELEPORT_COUNT |
@@ -248,10 +248,6 @@ void LLViewerStats::updateFrameStats(const F64 time_diff) | |||
248 | { | 248 | { |
249 | incStat(LLViewerStats::ST_FPS_2_SECONDS, time_diff); | 249 | incStat(LLViewerStats::ST_FPS_2_SECONDS, time_diff); |
250 | } | 250 | } |
251 | if (time_diff >= 0.2) | ||
252 | { | ||
253 | incStat(LLViewerStats::ST_FPS_5_SECONDS, time_diff); | ||
254 | } | ||
255 | if (time_diff >= 0.125) | 251 | if (time_diff >= 0.125) |
256 | { | 252 | { |
257 | incStat(LLViewerStats::ST_FPS_8_SECONDS, time_diff); | 253 | incStat(LLViewerStats::ST_FPS_8_SECONDS, time_diff); |
diff --git a/linden/indra/newview/llviewerstats.h b/linden/indra/newview/llviewerstats.h index 9b446ec..a3eb4c1 100644 --- a/linden/indra/newview/llviewerstats.h +++ b/linden/indra/newview/llviewerstats.h | |||
@@ -98,7 +98,7 @@ public: | |||
98 | // in statTypeToText in llviewerstats.cpp | 98 | // in statTypeToText in llviewerstats.cpp |
99 | enum EStatType | 99 | enum EStatType |
100 | { | 100 | { |
101 | ST_MOUSELOOK_SECONDS = 0, | 101 | ST_VERSION = 0, |
102 | ST_AVATAR_EDIT_SECONDS = 1, | 102 | ST_AVATAR_EDIT_SECONDS = 1, |
103 | ST_TOOLBOX_SECONDS = 2, | 103 | ST_TOOLBOX_SECONDS = 2, |
104 | ST_CHAT_COUNT = 3, | 104 | ST_CHAT_COUNT = 3, |
@@ -108,8 +108,8 @@ public: | |||
108 | ST_CREATE_COUNT = 7, | 108 | ST_CREATE_COUNT = 7, |
109 | ST_REZ_COUNT = 8, | 109 | ST_REZ_COUNT = 8, |
110 | ST_FPS_10_SECONDS = 9, | 110 | ST_FPS_10_SECONDS = 9, |
111 | ST_FPS_5_SECONDS = 10, | 111 | ST_FPS_2_SECONDS = 10, |
112 | ST_FPS_2_SECONDS = 11, | 112 | ST_MOUSELOOK_SECONDS = 11, |
113 | ST_FLY_COUNT = 12, | 113 | ST_FLY_COUNT = 12, |
114 | ST_TELEPORT_COUNT = 13, | 114 | ST_TELEPORT_COUNT = 13, |
115 | ST_OBJECT_DELETE_COUNT = 14, | 115 | ST_OBJECT_DELETE_COUNT = 14, |
diff --git a/linden/indra/newview/llvoavatar.cpp b/linden/indra/newview/llvoavatar.cpp index 3d4f1c0..ece24e0 100644 --- a/linden/indra/newview/llvoavatar.cpp +++ b/linden/indra/newview/llvoavatar.cpp | |||
@@ -2382,7 +2382,7 @@ BOOL LLVOAvatar::idleUpdate(LLAgent &agent, LLWorld &world, const F64 &time) | |||
2382 | static const F32 UPDATE_TIME = .5f; | 2382 | static const F32 UPDATE_TIME = .5f; |
2383 | if (mUpdateLODTimer.hasExpired()) | 2383 | if (mUpdateLODTimer.hasExpired()) |
2384 | { | 2384 | { |
2385 | mUpdateLODTimer.setTimerExpirySec(UPDATE_TIME * (.75f + frand(0.5f))); | 2385 | mUpdateLODTimer.setTimerExpirySec(UPDATE_TIME * (.75f + ll_frand(0.5f))); |
2386 | updateJointLODs(); | 2386 | updateJointLODs(); |
2387 | } | 2387 | } |
2388 | 2388 | ||
diff --git a/linden/indra/newview/llvograss.cpp b/linden/indra/newview/llvograss.cpp index 048ae61..58e5378 100644 --- a/linden/indra/newview/llvograss.cpp +++ b/linden/indra/newview/llvograss.cpp | |||
@@ -229,26 +229,26 @@ void LLVOGrass::initClass() | |||
229 | { | 229 | { |
230 | if (1) //(i%2 == 0) Uncomment for X blading | 230 | if (1) //(i%2 == 0) Uncomment for X blading |
231 | { | 231 | { |
232 | F32 u = sqrt(-2.0f * log(frand(1.0))); | 232 | F32 u = sqrt(-2.0f * log(ll_frand())); |
233 | F32 v = 2.0f * F_PI * frand(1.0); | 233 | F32 v = 2.0f * F_PI * ll_frand(); |
234 | 234 | ||
235 | x = u * sin(v) * GRASS_DISTRIBUTION_SD; | 235 | x = u * sin(v) * GRASS_DISTRIBUTION_SD; |
236 | y = u * cos(v) * GRASS_DISTRIBUTION_SD; | 236 | y = u * cos(v) * GRASS_DISTRIBUTION_SD; |
237 | 237 | ||
238 | rot = frand(F_PI); | 238 | rot = ll_frand(F_PI); |
239 | } | 239 | } |
240 | else | 240 | else |
241 | { | 241 | { |
242 | rot += (F_PI*0.4f + frand(0.2f*F_PI)); | 242 | rot += (F_PI*0.4f + ll_frand(0.2f*F_PI)); |
243 | } | 243 | } |
244 | 244 | ||
245 | exp_x[i] = x; | 245 | exp_x[i] = x; |
246 | exp_y[i] = y; | 246 | exp_y[i] = y; |
247 | rot_x[i] = sin(rot); | 247 | rot_x[i] = sin(rot); |
248 | rot_y[i] = cos(rot); | 248 | rot_y[i] = cos(rot); |
249 | dz_x[i] = frand(GRASS_BLADE_BASE * 0.25f); | 249 | dz_x[i] = ll_frand(GRASS_BLADE_BASE * 0.25f); |
250 | dz_y[i] = frand(GRASS_BLADE_BASE * 0.25f); | 250 | dz_y[i] = ll_frand(GRASS_BLADE_BASE * 0.25f); |
251 | w_mod[i] = 0.5f + frand(1.f); // Degree to which blade is moved by wind | 251 | w_mod[i] = 0.5f + ll_frand(); // Degree to which blade is moved by wind |
252 | 252 | ||
253 | } | 253 | } |
254 | } | 254 | } |
diff --git a/linden/indra/newview/llvopart.cpp b/linden/indra/newview/llvopart.cpp index 5e471be..6b38cf9 100644 --- a/linden/indra/newview/llvopart.cpp +++ b/linden/indra/newview/llvopart.cpp | |||
@@ -654,7 +654,7 @@ void LLVOPart::setParticleCountdownStateWaitingDead(const U32 particleNumber) | |||
654 | 654 | ||
655 | frequency = mSpawnFrequency; | 655 | frequency = mSpawnFrequency; |
656 | // **** Hack! remainingLifetime counts up from negative, to avoid subtracts! - djs | 656 | // **** Hack! remainingLifetime counts up from negative, to avoid subtracts! - djs |
657 | mParticleState[particleNumber].remainingLifetime = -(((mSpawnFrequencyRange * 2.0f)*frand(1.f)) + frequency - mSpawnFrequencyRange); | 657 | mParticleState[particleNumber].remainingLifetime = -(((mSpawnFrequencyRange * 2.0f)*ll_frand()) + frequency - mSpawnFrequencyRange); |
658 | } | 658 | } |
659 | 659 | ||
660 | //Can override later | 660 | //Can override later |
@@ -672,9 +672,9 @@ void LLVOPart::spawnParticle(const U32 particleNumber) | |||
672 | mDeadArr[particleNumber] = 0; // not dead yet! | 672 | mDeadArr[particleNumber] = 0; // not dead yet! |
673 | 673 | ||
674 | //j = pos_offset_i(particleNumber); | 674 | //j = pos_offset_i(particleNumber); |
675 | mParticleState[particleNumber].position[0] = 2.f*mSpawnRange*(frand(1.f)) - mSpawnRange; | 675 | mParticleState[particleNumber].position[0] = 2.f*mSpawnRange*(ll_frand()) - mSpawnRange; |
676 | mParticleState[particleNumber].position[1] = 2.f*mSpawnRange*(frand(1.f)) - mSpawnRange; | 676 | mParticleState[particleNumber].position[1] = 2.f*mSpawnRange*(ll_frand()) - mSpawnRange; |
677 | mParticleState[particleNumber].position[2] = 2.f*mSpawnRange*(frand(1.f)) - mSpawnRange; | 677 | mParticleState[particleNumber].position[2] = 2.f*mSpawnRange*(ll_frand()) - mSpawnRange; |
678 | 678 | ||
679 | //mParticleStateArray[j] = (pos_ranges[1] - pos_ranges[0])*(F32)rand()/((F32)RAND_MAX) + pos_ranges[0]; | 679 | //mParticleStateArray[j] = (pos_ranges[1] - pos_ranges[0])*(F32)rand()/((F32)RAND_MAX) + pos_ranges[0]; |
680 | //j++; | 680 | //j++; |
@@ -687,12 +687,12 @@ void LLVOPart::spawnParticle(const U32 particleNumber) | |||
687 | //Create the ranged direction vector first - then rotate by the actual direction and then scale | 687 | //Create the ranged direction vector first - then rotate by the actual direction and then scale |
688 | //Creating a random value about 1,0,0 | 688 | //Creating a random value about 1,0,0 |
689 | //1. pick a random angle YZ orientation through full circle. | 689 | //1. pick a random angle YZ orientation through full circle. |
690 | randomUnitValue = (frand(1.f)); | 690 | randomUnitValue = (ll_frand()); |
691 | direction.mV[VY] = sinf(randomUnitValue * 2.0 * F_PI); | 691 | direction.mV[VY] = sinf(randomUnitValue * 2.0 * F_PI); |
692 | direction.mV[VZ] = cosf(randomUnitValue * 2.0 * F_PI); | 692 | direction.mV[VZ] = cosf(randomUnitValue * 2.0 * F_PI); |
693 | 693 | ||
694 | //2. pick a rotation to this angle to project into z which is scaled by mSpawnDirectionRange | 694 | //2. pick a rotation to this angle to project into z which is scaled by mSpawnDirectionRange |
695 | randomUnitValue = (frand(1.f)); | 695 | randomUnitValue = (ll_frand()); |
696 | randomUnitValue *= mSpawnDirectionRange; | 696 | randomUnitValue *= mSpawnDirectionRange; |
697 | direction.mV[VY] = direction.mV[VY] * sinf(randomUnitValue * F_PI); | 697 | direction.mV[VY] = direction.mV[VY] * sinf(randomUnitValue * F_PI); |
698 | direction.mV[VZ] = direction.mV[VZ] * sinf(randomUnitValue * F_PI); | 698 | direction.mV[VZ] = direction.mV[VZ] * sinf(randomUnitValue * F_PI); |
@@ -804,7 +804,7 @@ void LLVOPart::spawnParticle(const U32 particleNumber) | |||
804 | 804 | ||
805 | 805 | ||
806 | //4. scale the vector by a random scale by mSpawnVelocityRange and offset by mSpawnVelocity | 806 | //4. scale the vector by a random scale by mSpawnVelocityRange and offset by mSpawnVelocity |
807 | randomUnitValue = (frand(1.f)); | 807 | randomUnitValue = (ll_frand()); |
808 | randomUnitValue = (randomUnitValue * mSpawnVelocityRange) + mSpawnVelocity; | 808 | randomUnitValue = (randomUnitValue * mSpawnVelocityRange) + mSpawnVelocity; |
809 | 809 | ||
810 | mParticleState[particleNumber].velocity[0] = direction.mV[VX] * randomUnitValue; | 810 | mParticleState[particleNumber].velocity[0] = direction.mV[VX] * randomUnitValue; |
@@ -822,16 +822,16 @@ void LLVOPart::spawnParticle(const U32 particleNumber) | |||
822 | 822 | ||
823 | mParticleState[particleNumber].acceleration[2] = 0.0f; | 823 | mParticleState[particleNumber].acceleration[2] = 0.0f; |
824 | 824 | ||
825 | mParticleState[particleNumber].scale[0] = (mScale_range[1] - mScale_range[0])*frand(1.f) + mScale_range[0]; | 825 | mParticleState[particleNumber].scale[0] = (mScale_range[1] - mScale_range[0])*ll_frand() + mScale_range[0]; |
826 | mParticleState[particleNumber].scale[1] = (mScale_range[3] - mScale_range[2])*frand(1.f) + mScale_range[2]; | 826 | mParticleState[particleNumber].scale[1] = (mScale_range[3] - mScale_range[2])*ll_frand() + mScale_range[2]; |
827 | mParticleState[particleNumber].scale[2] = 0.0f; | 827 | mParticleState[particleNumber].scale[2] = 0.0f; |
828 | 828 | ||
829 | mParticleState[particleNumber].alpha[0] = (mAlpha_range[1] - mAlpha_range[0])*frand(1.f) + mAlpha_range[0]; | 829 | mParticleState[particleNumber].alpha[0] = (mAlpha_range[1] - mAlpha_range[0])*ll_frand() + mAlpha_range[0]; |
830 | mParticleState[particleNumber].alpha[1] = (mAlpha_range[3] - mAlpha_range[2])*frand(1.f) + mAlpha_range[2]; | 830 | mParticleState[particleNumber].alpha[1] = (mAlpha_range[3] - mAlpha_range[2])*ll_frand() + mAlpha_range[2]; |
831 | mParticleState[particleNumber].alpha[2] = 0.0f; | 831 | mParticleState[particleNumber].alpha[2] = 0.0f; |
832 | 832 | ||
833 | // **** Hack! remainingLifetime counts up from negative, to avoid subtracts! - djs | 833 | // **** Hack! remainingLifetime counts up from negative, to avoid subtracts! - djs |
834 | mParticleState[particleNumber].remainingLifetime = -((mIndividualLifetimeRange*2.0f)*frand(1.f) + mIndividualLifetime - mIndividualLifetimeRange); | 834 | mParticleState[particleNumber].remainingLifetime = -((mIndividualLifetimeRange*2.0f)*ll_frand() + mIndividualLifetime - mIndividualLifetimeRange); |
835 | 835 | ||
836 | //rest of the state - 0 for now | 836 | //rest of the state - 0 for now |
837 | mParticleState[particleNumber].deathOffset = 0.0f; | 837 | mParticleState[particleNumber].deathOffset = 0.0f; |
diff --git a/linden/indra/newview/llvopartgroup.cpp b/linden/indra/newview/llvopartgroup.cpp index 10a765d..150f5cd 100644 --- a/linden/indra/newview/llvopartgroup.cpp +++ b/linden/indra/newview/llvopartgroup.cpp | |||
@@ -53,7 +53,7 @@ LLVOPartGroup::LLVOPartGroup(const LLUUID &id, const LLPCode pcode, LLViewerRegi | |||
53 | setNumTEs(1); | 53 | setNumTEs(1); |
54 | setTETexture(0, LLUUID::null); | 54 | setTETexture(0, LLUUID::null); |
55 | mbCanSelect = FALSE; // users can't select particle systems | 55 | mbCanSelect = FALSE; // users can't select particle systems |
56 | mDebugColor = LLColor4(frand(1.f), frand(1.f), frand(1.f), 1.f); | 56 | mDebugColor = LLColor4(ll_frand(), ll_frand(), ll_frand(), 1.f); |
57 | } | 57 | } |
58 | 58 | ||
59 | 59 | ||
diff --git a/linden/indra/newview/llvosky.cpp b/linden/indra/newview/llvosky.cpp index 927b784..559e846 100644 --- a/linden/indra/newview/llvosky.cpp +++ b/linden/indra/newview/llvosky.cpp | |||
@@ -664,20 +664,18 @@ void LLVOSky::restoreGL() | |||
664 | 664 | ||
665 | void LLVOSky::updateHaze() | 665 | void LLVOSky::updateHaze() |
666 | { | 666 | { |
667 | time_t timer; | 667 | static LLRandLagFib607 weather_generator(LLUUID::getRandomSeed()); |
668 | time(&timer); | ||
669 | static LLRand WeatherRandomNumber(gmtime(&timer)->tm_mday); | ||
670 | if (gSavedSettings.getBOOL("FixedWeather")) | 668 | if (gSavedSettings.getBOOL("FixedWeather")) |
671 | { | 669 | { |
672 | WeatherRandomNumber.seed(8008135); | 670 | weather_generator.seed(8008135); |
673 | } | 671 | } |
674 | 672 | ||
675 | const F32 fo_upper_bound = 5; | 673 | const F32 fo_upper_bound = 5; |
676 | const F32 sca_upper_bound = 6; | 674 | const F32 sca_upper_bound = 6; |
677 | const F32 fo = 1 + WeatherRandomNumber.llfrand(fo_upper_bound - 1); | 675 | const F32 fo = 1 + (F32)weather_generator() *(fo_upper_bound - 1); |
678 | const static F32 upper = 0.5f / gFastLn.ln(fo_upper_bound); | 676 | const static F32 upper = 0.5f / gFastLn.ln(fo_upper_bound); |
679 | mHaze.setFalloff(fo); | 677 | mHaze.setFalloff(fo); |
680 | mHaze.setG(WeatherRandomNumber.llfrand(0.0f + upper * gFastLn.ln(fo))); | 678 | mHaze.setG((F32)weather_generator() * (0.0f + upper * gFastLn.ln(fo))); |
681 | LLColor3 sca; | 679 | LLColor3 sca; |
682 | const F32 cd = mCloudDensity * 3; | 680 | const F32 cd = mCloudDensity * 3; |
683 | F32 min_r = cd - 1; | 681 | F32 min_r = cd - 1; |
@@ -691,7 +689,7 @@ void LLVOSky::updateHaze() | |||
691 | max_r = sca_upper_bound; | 689 | max_r = sca_upper_bound; |
692 | } | 690 | } |
693 | 691 | ||
694 | sca.mV[0] = min_r + WeatherRandomNumber.llfrand(max_r - min_r);//frand(6); | 692 | sca.mV[0] = min_r + (F32)weather_generator() * (max_r - min_r); |
695 | 693 | ||
696 | min_r = sca.mV[0] - 0.1f; | 694 | min_r = sca.mV[0] - 0.1f; |
697 | if (min_r < 0) | 695 | if (min_r < 0) |
@@ -704,7 +702,7 @@ void LLVOSky::updateHaze() | |||
704 | max_r = sca_upper_bound; | 702 | max_r = sca_upper_bound; |
705 | } | 703 | } |
706 | 704 | ||
707 | sca.mV[1] = min_r + WeatherRandomNumber.llfrand(max_r - min_r); | 705 | sca.mV[1] = min_r + (F32)weather_generator() * (max_r - min_r); |
708 | 706 | ||
709 | min_r = sca.mV[1]; | 707 | min_r = sca.mV[1]; |
710 | if (min_r < 0) | 708 | if (min_r < 0) |
@@ -717,7 +715,7 @@ void LLVOSky::updateHaze() | |||
717 | max_r = sca_upper_bound; | 715 | max_r = sca_upper_bound; |
718 | } | 716 | } |
719 | 717 | ||
720 | sca.mV[2] = min_r + WeatherRandomNumber.llfrand(max_r - min_r); | 718 | sca.mV[2] = min_r + (F32)weather_generator() * (max_r - min_r); |
721 | 719 | ||
722 | sca = AIR_SCA_AVG * sca; | 720 | sca = AIR_SCA_AVG * sca; |
723 | 721 | ||
diff --git a/linden/indra/newview/llvostars.cpp b/linden/indra/newview/llvostars.cpp index d20c5da..3fd3b91 100644 --- a/linden/indra/newview/llvostars.cpp +++ b/linden/indra/newview/llvostars.cpp | |||
@@ -125,19 +125,19 @@ void LLVOStars::initStars() | |||
125 | U32 i; | 125 | U32 i; |
126 | for (i = 0; i < NUMBER_OF_STARS; i++ ) | 126 | for (i = 0; i < NUMBER_OF_STARS; i++ ) |
127 | { | 127 | { |
128 | v_p->mV[VX] = frand(1.f) - 0.5f; | 128 | v_p->mV[VX] = ll_frand() - 0.5f; |
129 | v_p->mV[VY] = frand(1.f) - 0.5f; | 129 | v_p->mV[VY] = ll_frand() - 0.5f; |
130 | 130 | ||
131 | // we only want stars on the top half of the dome! | 131 | // we only want stars on the top half of the dome! |
132 | 132 | ||
133 | v_p->mV[VZ] = frand(1.f)/2.f; | 133 | v_p->mV[VZ] = ll_frand()/2.f; |
134 | 134 | ||
135 | v_p->normVec(); | 135 | v_p->normVec(); |
136 | *v_p *= DISTANCE_TO_STARS; | 136 | *v_p *= DISTANCE_TO_STARS; |
137 | *v_i = llmin((F32)pow(frand(1.f),2.f) + 0.1f, 1.f); | 137 | *v_i = llmin((F32)pow(ll_frand(),2.f) + 0.1f, 1.f); |
138 | v_c->mV[VRED] = 0.75f + frand(1.f) * 0.25f ; | 138 | v_c->mV[VRED] = 0.75f + ll_frand() * 0.25f ; |
139 | v_c->mV[VGREEN] = 1.f ; | 139 | v_c->mV[VGREEN] = 1.f ; |
140 | v_c->mV[VBLUE] = 0.75f + frand(1.f) * 0.25f ; | 140 | v_c->mV[VBLUE] = 0.75f + ll_frand() * 0.25f ; |
141 | v_c->mV[VALPHA] = 1.f; | 141 | v_c->mV[VALPHA] = 1.f; |
142 | v_c->clamp(); | 142 | v_c->clamp(); |
143 | v_p++; | 143 | v_p++; |
@@ -179,7 +179,7 @@ void LLVOStars::updateStarColors() | |||
179 | sundir_factor = (1 - how_close_to_sun) / sunclose_range; | 179 | sundir_factor = (1 - how_close_to_sun) / sunclose_range; |
180 | } | 180 | } |
181 | intensity = *(v_i); | 181 | intensity = *(v_i); |
182 | F32 alpha = v_c->mV[VALPHA] + (frand(1.f) - 0.5f) * var * intensity; | 182 | F32 alpha = v_c->mV[VALPHA] + (ll_frand() - 0.5f) * var * intensity; |
183 | if (alpha < min * intensity) | 183 | if (alpha < min * intensity) |
184 | { | 184 | { |
185 | alpha = min * intensity; | 185 | alpha = min * intensity; |
diff --git a/linden/indra/newview/llvotreenew.cpp b/linden/indra/newview/llvotreenew.cpp index 40b0c58..d7fc635 100644 --- a/linden/indra/newview/llvotreenew.cpp +++ b/linden/indra/newview/llvotreenew.cpp | |||
@@ -138,9 +138,9 @@ void LLVOTreeNew::initClass() | |||
138 | //LLVOTreeNew::sParameters = LLTreeParams(); | 138 | //LLVOTreeNew::sParameters = LLTreeParams(); |
139 | 139 | ||
140 | // initialize an array of random numbers that we'll be using | 140 | // initialize an array of random numbers that we'll be using |
141 | gLindenLabRandomNumber.seed(0); | 141 | LLRandLagFib607 tree_rand; |
142 | for (i = 0; i < MAX_RAND_NUMS; i++) | 142 | for (i = 0; i < MAX_RAND_NUMS; i++) |
143 | sRandNums[i] = gLindenLabRandomNumber.llfrand(1.0); | 143 | sRandNums[i] = (F32)tree_rand(); |
144 | } | 144 | } |
145 | 145 | ||
146 | /* | 146 | /* |
@@ -959,7 +959,8 @@ void LLVOTreeNew::drawTree(LLDrawPool &draw_pool) | |||
959 | U8 i, j; | 959 | U8 i, j; |
960 | 960 | ||
961 | // seed the drawtree thing with the object's uuid to make it original but predictable... | 961 | // seed the drawtree thing with the object's uuid to make it original but predictable... |
962 | gLindenLabRandomNumber.seed(0); | 962 | // don't re-seed the process random number generator. bad. |
963 | //gLindenLabRandomNumber.seed(0); | ||
963 | 964 | ||
964 | // reset the rand offsets | 965 | // reset the rand offsets |
965 | for (i = 0; i < MAX_LEVELS; i++) mRandOffset[i] = 0; | 966 | for (i = 0; i < MAX_LEVELS; i++) mRandOffset[i] = 0; |
diff --git a/linden/indra/newview/llvotreenew.h b/linden/indra/newview/llvotreenew.h index 058bd19..936028a 100644 --- a/linden/indra/newview/llvotreenew.h +++ b/linden/indra/newview/llvotreenew.h | |||
@@ -78,7 +78,7 @@ public: | |||
78 | // return +- negPos | 78 | // return +- negPos |
79 | static S32 llrand_signed(S32 negPos) | 79 | static S32 llrand_signed(S32 negPos) |
80 | { | 80 | { |
81 | return (gLindenLabRandomNumber.llrand((U32)negPos * 2) - negPos); | 81 | return (ll_rand((U32)negPos * 2) - negPos); |
82 | }; | 82 | }; |
83 | 83 | ||
84 | static S32 llrand_signed(S32 negPos, U32 index) | 84 | static S32 llrand_signed(S32 negPos, U32 index) |
@@ -94,7 +94,7 @@ public: | |||
94 | // return +- negPos | 94 | // return +- negPos |
95 | static F32 llfrand_signed(F32 negPos) | 95 | static F32 llfrand_signed(F32 negPos) |
96 | { | 96 | { |
97 | return (gLindenLabRandomNumber.llfrand(negPos * 2.0f) - negPos); | 97 | return (ll_frand(negPos * 2.0f) - negPos); |
98 | }; | 98 | }; |
99 | 99 | ||
100 | static F32 llfrand_signed(F32 negPos, U32 index) | 100 | static F32 llfrand_signed(F32 negPos, U32 index) |
@@ -110,7 +110,7 @@ public: | |||
110 | // return between 0-pos | 110 | // return between 0-pos |
111 | static F32 llfrand_unsigned(F32 pos) | 111 | static F32 llfrand_unsigned(F32 pos) |
112 | { | 112 | { |
113 | return gLindenLabRandomNumber.llfrand(pos); | 113 | return ll_frand(pos); |
114 | }; | 114 | }; |
115 | 115 | ||
116 | static void cleanupTextures() {}; // not needed anymore | 116 | static void cleanupTextures() {}; // not needed anymore |
diff --git a/linden/indra/newview/llwearable.cpp b/linden/indra/newview/llwearable.cpp index 62a1d20..310eae5 100644 --- a/linden/indra/newview/llwearable.cpp +++ b/linden/indra/newview/llwearable.cpp | |||
@@ -265,6 +265,9 @@ BOOL LLWearable::exportFile( FILE* file ) | |||
265 | 265 | ||
266 | BOOL LLWearable::importFile( FILE* file ) | 266 | BOOL LLWearable::importFile( FILE* file ) |
267 | { | 267 | { |
268 | // *NOTE: changing the type or size of this buffer will require | ||
269 | // changes in the fscanf() code below. You would be better off | ||
270 | // rewriting this to use streams and not require an open FILE. | ||
268 | char text_buffer[2048]; | 271 | char text_buffer[2048]; |
269 | S32 fields_read = 0; | 272 | S32 fields_read = 0; |
270 | 273 | ||
@@ -295,7 +298,7 @@ BOOL LLWearable::importFile( FILE* file ) | |||
295 | else | 298 | else |
296 | { | 299 | { |
297 | ungetc( next_char, file ); | 300 | ungetc( next_char, file ); |
298 | fields_read = fscanf( file, "%[^\n]", text_buffer ); | 301 | fields_read = fscanf( file, "%2047[^\n]", text_buffer ); |
299 | if( (1 != fields_read) || (fgetc( file ) != '\n') ) | 302 | if( (1 != fields_read) || (fgetc( file ) != '\n') ) |
300 | { | 303 | { |
301 | llwarns << "Bad Wearable asset: early end of file" << llendl; | 304 | llwarns << "Bad Wearable asset: early end of file" << llendl; |
@@ -315,7 +318,7 @@ BOOL LLWearable::importFile( FILE* file ) | |||
315 | else | 318 | else |
316 | { | 319 | { |
317 | ungetc( next_char, file ); | 320 | ungetc( next_char, file ); |
318 | fields_read = fscanf( file, "%[^\n]", text_buffer ); | 321 | fields_read = fscanf( file, "%2047[^\n]", text_buffer ); |
319 | if( (1 != fields_read) || (fgetc( file ) != '\n') ) | 322 | if( (1 != fields_read) || (fgetc( file ) != '\n') ) |
320 | { | 323 | { |
321 | llwarns << "Bad Wearable asset: early end of file" << llendl; | 324 | llwarns << "Bad Wearable asset: early end of file" << llendl; |
@@ -422,7 +425,7 @@ BOOL LLWearable::importFile( FILE* file ) | |||
422 | for( i = 0; i < num_textures; i++ ) | 425 | for( i = 0; i < num_textures; i++ ) |
423 | { | 426 | { |
424 | S32 te = 0; | 427 | S32 te = 0; |
425 | fields_read = fscanf( file, "%d %s\n", &te, text_buffer); | 428 | fields_read = fscanf( file, "%d %2047s\n", &te, text_buffer); |
426 | if( fields_read != 2 ) | 429 | if( fields_read != 2 ) |
427 | { | 430 | { |
428 | llwarns << "Bad Wearable asset: bad texture, #" << i << llendl; | 431 | llwarns << "Bad Wearable asset: bad texture, #" << i << llendl; |
diff --git a/linden/indra/newview/llwebbrowserctrl.cpp b/linden/indra/newview/llwebbrowserctrl.cpp index afbff65..6d1ee28 100644 --- a/linden/indra/newview/llwebbrowserctrl.cpp +++ b/linden/indra/newview/llwebbrowserctrl.cpp | |||
@@ -251,8 +251,16 @@ void LLWebBrowserCtrl::navigateTo( std::string urlIn ) | |||
251 | 251 | ||
252 | // don't browse to anything that starts with secondlife:// | 252 | // don't browse to anything that starts with secondlife:// |
253 | if ( urlIn.length() >= protocol.length() ) | 253 | if ( urlIn.length() >= protocol.length() ) |
254 | { | ||
254 | if ( LLString::compareInsensitive( urlIn.substr( 0, protocol.length() ).c_str(), protocol.c_str() ) != 0 ) | 255 | if ( LLString::compareInsensitive( urlIn.substr( 0, protocol.length() ).c_str(), protocol.c_str() ) != 0 ) |
256 | { | ||
255 | LLMozLib::getInstance()->navigateTo( mEmbeddedBrowserWindowId, urlIn ); | 257 | LLMozLib::getInstance()->navigateTo( mEmbeddedBrowserWindowId, urlIn ); |
258 | } | ||
259 | } | ||
260 | else | ||
261 | { | ||
262 | LLMozLib::getInstance()->navigateTo( mEmbeddedBrowserWindowId, urlIn ); | ||
263 | } | ||
256 | } | 264 | } |
257 | 265 | ||
258 | //////////////////////////////////////////////////////////////////////////////// | 266 | //////////////////////////////////////////////////////////////////////////////// |
diff --git a/linden/indra/newview/llwebbrowserctrl.h b/linden/indra/newview/llwebbrowserctrl.h index 57c72c5..bad6e88 100644 --- a/linden/indra/newview/llwebbrowserctrl.h +++ b/linden/indra/newview/llwebbrowserctrl.h | |||
@@ -254,4 +254,4 @@ class LLWebBrowserTexture : public LLDynamicTexture | |||
254 | 254 | ||
255 | #endif // // LL_LIBXUL_ENABLED | 255 | #endif // // LL_LIBXUL_ENABLED |
256 | 256 | ||
257 | #endif // LL_LLWEBBROWSERCTRL_H \ No newline at end of file | 257 | #endif // LL_LLWEBBROWSERCTRL_H |
diff --git a/linden/indra/newview/releasenotes.txt b/linden/indra/newview/releasenotes.txt index a96a62a..4cce794 100644 --- a/linden/indra/newview/releasenotes.txt +++ b/linden/indra/newview/releasenotes.txt | |||
@@ -1,3 +1,21 @@ | |||
1 | Release Notes for Second Life 1.13.2(15) January 25, 2007 | ||
2 | ===================================== | ||
3 | Changes: | ||
4 | * Tapping Alt to focus on menus has been disabled | ||
5 | * Separate settings.ini file used by Beta and First Look clients | ||
6 | ** Uninstalling these clients will no longer remove Second Life user settings | ||
7 | |||
8 | Bug fixes: | ||
9 | * Alt-mouseclick no longer puts focus on the menus | ||
10 | * Popup warnings for sandbox regions reflect changes made in 1.13.2(11) | ||
11 | * Fixed error while editing profile if you have a classified | ||
12 | * Fixed Buy Pass option in pie menu not appearing unless access list for avatars is enabled | ||
13 | * Fixed build tool not changing type until you use another menu | ||
14 | * Fixed dragging position arrows sideways moves object vertically | ||
15 | * Fixed clicking More/Less in editor selects Create | ||
16 | * Fixed loud noise in wind on dual core systems | ||
17 | * Fixed a client crash | ||
18 | |||
1 | Release Notes for Second Life 1.13.2(12) January 19, 2007 | 19 | Release Notes for Second Life 1.13.2(12) January 19, 2007 |
2 | ===================================== | 20 | ===================================== |
3 | Bug fixes: | 21 | Bug fixes: |
diff --git a/linden/indra/newview/res/newViewRes.rc b/linden/indra/newview/res/newViewRes.rc index 44aab17..cf7b935 100644 --- a/linden/indra/newview/res/newViewRes.rc +++ b/linden/indra/newview/res/newViewRes.rc | |||
@@ -227,7 +227,7 @@ TOOLPIPETTE CURSOR "toolpipette.cur" | |||
227 | // | 227 | // |
228 | 228 | ||
229 | VS_VERSION_INFO VERSIONINFO | 229 | VS_VERSION_INFO VERSIONINFO |
230 | FILEVERSION 1,13,2,12 | 230 | FILEVERSION 1,13,2,15 |
231 | PRODUCTVERSION 1,13,2,0 | 231 | PRODUCTVERSION 1,13,2,0 |
232 | FILEFLAGSMASK 0x3fL | 232 | FILEFLAGSMASK 0x3fL |
233 | #ifdef _DEBUG | 233 | #ifdef _DEBUG |
@@ -245,7 +245,7 @@ BEGIN | |||
245 | BEGIN | 245 | BEGIN |
246 | VALUE "CompanyName", "Linden Lab" | 246 | VALUE "CompanyName", "Linden Lab" |
247 | VALUE "FileDescription", "Second Life" | 247 | VALUE "FileDescription", "Second Life" |
248 | VALUE "FileVersion", "1.13.2.12" | 248 | VALUE "FileVersion", "1.13.2.15" |
249 | VALUE "InternalName", "Second Life" | 249 | VALUE "InternalName", "Second Life" |
250 | VALUE "LegalCopyright", "Copyright © 2001-2006, Linden Research, Inc." | 250 | VALUE "LegalCopyright", "Copyright © 2001-2006, Linden Research, Inc." |
251 | VALUE "OriginalFilename", "SecondLife.exe" | 251 | VALUE "OriginalFilename", "SecondLife.exe" |
diff --git a/linden/indra/newview/rsyncfiles.txt b/linden/indra/newview/rsyncfiles.txt new file mode 100644 index 0000000..0763c5c --- /dev/null +++ b/linden/indra/newview/rsyncfiles.txt | |||
@@ -0,0 +1,22 @@ | |||
1 | - *.cpp | ||
2 | - *.c | ||
3 | - *.h | ||
4 | - .svn/ | ||
5 | - CVS/ | ||
6 | - .cvsignore | ||
7 | - .DS_Store | ||
8 | - /app_settings/mozilla/ | ||
9 | - /app_settings/mozilla_debug/ | ||
10 | + /app_settings/ | ||
11 | + /character/ | ||
12 | + /help/ | ||
13 | + /trial/ | ||
14 | + /fonts/ | ||
15 | + /skins/ | ||
16 | + /cursors_mac/ | ||
17 | + /featuretable.txt | ||
18 | + /featuretable_mac.txt | ||
19 | + /releasenotes.txt | ||
20 | + /lsl_guide.html | ||
21 | + /secondlife.icns | ||
22 | + /gpu_table.txt | ||
diff --git a/linden/indra/newview/secondlife setup build firstlook.bat b/linden/indra/newview/secondlife setup build firstlook.bat new file mode 100644 index 0000000..099f4fc --- /dev/null +++ b/linden/indra/newview/secondlife setup build firstlook.bat | |||
@@ -0,0 +1,11 @@ | |||
1 | @rem Invoke the script which preps then runs the installer. | ||
2 | @rem This batch file is customized per grid. | ||
3 | |||
4 | set LOGINPAGEURL=http://secondlife.com/app/login/firstlook/ | ||
5 | set ARGS=/DFIRSTLOOK | ||
6 | |||
7 | @rem To build optional "update" installer (doesn't have static VFS): | ||
8 | @rem | ||
9 | @rem set ARGS=/DUPDATE | ||
10 | |||
11 | @"secondlife setup build.bat" %LOGINPAGEURL% %ARGS% | ||
diff --git a/linden/indra/newview/skins/xui/en-us/notify.xml b/linden/indra/newview/skins/xui/en-us/notify.xml index 70defa7..747d1ca 100644 --- a/linden/indra/newview/skins/xui/en-us/notify.xml +++ b/linden/indra/newview/skins/xui/en-us/notify.xml | |||
@@ -802,9 +802,8 @@ You can edit your appearance as often as you like. | |||
802 | <notify name="FirstSandbox" tip="false"> | 802 | <notify name="FirstSandbox" tip="false"> |
803 | <message name="message"> | 803 | <message name="message"> |
804 | This is a sandbox region. | 804 | This is a sandbox region. |
805 | Objects you build here may be deleted after you | 805 | Objects you build here may be deleted after |
806 | leave the area, and the region will be wiped | 806 | you leave the area, Sandboxes clean on a regular basis, please refer to the information at the top of the screen next to the region name. |
807 | every [HOURS] hours starting at [TIME] AM Pacific Time. | ||
808 | 807 | ||
809 | Sandbox regions are uncommon, and are marked with signs. | 808 | Sandbox regions are uncommon, and are marked with signs. |
810 | </message> | 809 | </message> |
diff --git a/linden/indra/newview/viewer.cpp b/linden/indra/newview/viewer.cpp index c009039..19b5260 100644 --- a/linden/indra/newview/viewer.cpp +++ b/linden/indra/newview/viewer.cpp | |||
@@ -352,7 +352,7 @@ BOOL gDoneLogout = FALSE; | |||
352 | 352 | ||
353 | BOOL gInitializationComplete = FALSE; // used in windows handlers to determine if OK to call idle() | 353 | BOOL gInitializationComplete = FALSE; // used in windows handlers to determine if OK to call idle() |
354 | BOOL gAutoLogin = FALSE; | 354 | BOOL gAutoLogin = FALSE; |
355 | char gOldSettingsFileName[LL_MAX_PATH]; | 355 | LLString gOldSettingsFileName; |
356 | BOOL gPrintMessagesThisFrame = FALSE; | 356 | BOOL gPrintMessagesThisFrame = FALSE; |
357 | const char* DEFAULT_SETTINGS_FILE = "settings.xml"; | 357 | const char* DEFAULT_SETTINGS_FILE = "settings.xml"; |
358 | const char* LEGACY_DEFAULT_SETTINGS_FILE = "settings.ini"; | 358 | const char* LEGACY_DEFAULT_SETTINGS_FILE = "settings.ini"; |
@@ -925,8 +925,8 @@ int main( int argc, char **argv ) | |||
925 | // | 925 | // |
926 | 926 | ||
927 | // Set up some defaults... | 927 | // Set up some defaults... |
928 | strcpy(gSettingsFileName, gDirUtilp->getExpandedFilename(LL_PATH_USER_SETTINGS, DEFAULT_SETTINGS_FILE).c_str()); | 928 | gSettingsFileName = gDirUtilp->getExpandedFilename(LL_PATH_USER_SETTINGS, DEFAULT_SETTINGS_FILE); |
929 | strcpy(gOldSettingsFileName, gDirUtilp->getExpandedFilename(LL_PATH_USER_SETTINGS, LEGACY_DEFAULT_SETTINGS_FILE).c_str()); | 929 | gOldSettingsFileName = gDirUtilp->getExpandedFilename(LL_PATH_USER_SETTINGS, LEGACY_DEFAULT_SETTINGS_FILE); |
930 | gUserServer.setPort(DEFAULT_USER_SERVER_PORT); | 930 | gUserServer.setPort(DEFAULT_USER_SERVER_PORT); |
931 | 931 | ||
932 | ///////////////////////////////////////// | 932 | ///////////////////////////////////////// |
@@ -4215,7 +4215,7 @@ BOOL add_object( LLPCode pcode, S32 x, S32 y, U8 use_physics ) | |||
4215 | { | 4215 | { |
4216 | case LL_PCODE_LEGACY_GRASS: | 4216 | case LL_PCODE_LEGACY_GRASS: |
4217 | // Randomize size of grass patch | 4217 | // Randomize size of grass patch |
4218 | scale.setVec(10.f + frand(20.f), 10.f + frand(20.f), 1.f + frand(2.f)); | 4218 | scale.setVec(10.f + ll_frand(20.f), 10.f + ll_frand(20.f), 1.f + ll_frand(2.f)); |
4219 | state = rand() % LLVOGrass::sMaxGrassSpecies; | 4219 | state = rand() % LLVOGrass::sMaxGrassSpecies; |
4220 | break; | 4220 | break; |
4221 | 4221 | ||
@@ -5337,8 +5337,14 @@ void send_stats() | |||
5337 | gMessageSystem->addU32Fast(_PREHASH_SysRAM, gSysMemory.getPhysicalMemory()); | 5337 | gMessageSystem->addU32Fast(_PREHASH_SysRAM, gSysMemory.getPhysicalMemory()); |
5338 | gMessageSystem->addStringFast(_PREHASH_SysOS, gSysOS.getOSString()); | 5338 | gMessageSystem->addStringFast(_PREHASH_SysOS, gSysOS.getOSString()); |
5339 | gMessageSystem->addStringFast(_PREHASH_SysCPU, gSysCPU.getCPUStringTerse()); | 5339 | gMessageSystem->addStringFast(_PREHASH_SysCPU, gSysCPU.getCPUStringTerse()); |
5340 | |||
5340 | 5341 | ||
5341 | gMessageSystem->addStringFast(_PREHASH_SysGPU, gGLManager.getRawGLString()); | 5342 | std::string gpu_desc = llformat("%-6s Class %d ", |
5343 | gGLManager.mGLVendorShort.substr(0,6).c_str(), | ||
5344 | gFeatureManagerp->getGPUClass()) | ||
5345 | + gFeatureManagerp->getGPUString(); | ||
5346 | |||
5347 | gMessageSystem->addStringFast(_PREHASH_SysGPU, gpu_desc); | ||
5342 | 5348 | ||
5343 | gMessageSystem->nextBlockFast(_PREHASH_DownloadTotals); | 5349 | gMessageSystem->nextBlockFast(_PREHASH_DownloadTotals); |
5344 | gMessageSystem->addU32Fast(_PREHASH_World, gTotalWorldBytes); | 5350 | gMessageSystem->addU32Fast(_PREHASH_World, gTotalWorldBytes); |
@@ -5365,6 +5371,14 @@ void send_stats() | |||
5365 | gMessageSystem->addU32Fast(_PREHASH_OffCircuit, (U32)gMessageSystem->mOffCircuitPackets); | 5371 | gMessageSystem->addU32Fast(_PREHASH_OffCircuit, (U32)gMessageSystem->mOffCircuitPackets); |
5366 | gMessageSystem->addU32Fast(_PREHASH_Invalid, (U32)gMessageSystem->mInvalidOnCircuitPackets); | 5372 | gMessageSystem->addU32Fast(_PREHASH_Invalid, (U32)gMessageSystem->mInvalidOnCircuitPackets); |
5367 | 5373 | ||
5374 | // 1.00.00.000000 | ||
5375 | F64 version = | ||
5376 | LL_VERSION_MAJOR * 10000000000.0 + | ||
5377 | LL_VERSION_MINOR * 100000000.0 + | ||
5378 | LL_VERSION_PATCH * 1000000.0 + | ||
5379 | LL_VERSION_BUILD; | ||
5380 | gViewerStats->setStat(LLViewerStats::ST_VERSION, version); | ||
5381 | |||
5368 | gViewerStats->addToMessage(); | 5382 | gViewerStats->addToMessage(); |
5369 | 5383 | ||
5370 | gAgent.sendReliableMessage(); | 5384 | gAgent.sendReliableMessage(); |
@@ -5596,7 +5610,7 @@ int parse_args(int argc, char **argv) | |||
5596 | std::string folder(argv[j]); | 5610 | std::string folder(argv[j]); |
5597 | gDirUtilp->setSkinFolder(folder); | 5611 | gDirUtilp->setSkinFolder(folder); |
5598 | } | 5612 | } |
5599 | else if (!strcmp(argv[j], "--autologin")) | 5613 | else if (!strcmp(argv[j], "-autologin") || !strcmp(argv[j], "--autologin")) // keep --autologin for compatibility |
5600 | { | 5614 | { |
5601 | gAutoLogin = TRUE; | 5615 | gAutoLogin = TRUE; |
5602 | } | 5616 | } |
@@ -5731,8 +5745,9 @@ int parse_args(int argc, char **argv) | |||
5731 | } | 5745 | } |
5732 | else if (!strcmp(argv[j], "-logfile") && (++j < argc)) | 5746 | else if (!strcmp(argv[j], "-logfile") && (++j < argc)) |
5733 | { | 5747 | { |
5748 | // *NOTE: This buffer size is hard coded into scanf() below. | ||
5734 | char logfile[256]; | 5749 | char logfile[256]; |
5735 | sscanf(argv[j], "%s", logfile); | 5750 | sscanf(argv[j], "%255s", logfile); |
5736 | llinfos << "Setting log file to " << logfile << llendl; | 5751 | llinfos << "Setting log file to " << logfile << llendl; |
5737 | LLFile::remove(logfile); | 5752 | LLFile::remove(logfile); |
5738 | if (!gErrorStream.setFile(logfile)) | 5753 | if (!gErrorStream.setFile(logfile)) |
@@ -5742,7 +5757,7 @@ int parse_args(int argc, char **argv) | |||
5742 | } | 5757 | } |
5743 | else if (!strcmp(argv[j], "-settings") && (++j < argc)) | 5758 | else if (!strcmp(argv[j], "-settings") && (++j < argc)) |
5744 | { | 5759 | { |
5745 | strcpy(gSettingsFileName, argv[j]); | 5760 | gSettingsFileName = gDirUtilp->getExpandedFilename(LL_PATH_USER_SETTINGS, argv[j]); |
5746 | } | 5761 | } |
5747 | else if (!strcmp(argv[j], "-setdefault") && (j + 2 < argc)) | 5762 | else if (!strcmp(argv[j], "-setdefault") && (j + 2 < argc)) |
5748 | { | 5763 | { |
@@ -6475,7 +6490,7 @@ void cleanup_app() | |||
6475 | // Must do this after all panels have been deleted because panels that have persistent rects | 6490 | // Must do this after all panels have been deleted because panels that have persistent rects |
6476 | // save their rects on delete. | 6491 | // save their rects on delete. |
6477 | gSavedSettings.saveToFile(gSettingsFileName, TRUE); | 6492 | gSavedSettings.saveToFile(gSettingsFileName, TRUE); |
6478 | if (gPerAccountSettingsFileName[0]) | 6493 | if (!gPerAccountSettingsFileName.empty()) |
6479 | { | 6494 | { |
6480 | gSavedPerAccountSettings.saveToFile(gPerAccountSettingsFileName, TRUE); | 6495 | gSavedPerAccountSettings.saveToFile(gPerAccountSettingsFileName, TRUE); |
6481 | } | 6496 | } |
diff --git a/linden/indra/newview/viewer.h b/linden/indra/newview/viewer.h index ed302ce..34ca249 100644 --- a/linden/indra/newview/viewer.h +++ b/linden/indra/newview/viewer.h | |||
@@ -95,7 +95,7 @@ extern LLTimer gLogoutTimer; | |||
95 | extern BOOL gInProductionGrid; | 95 | extern BOOL gInProductionGrid; |
96 | extern S32 gCrashBehavior; | 96 | extern S32 gCrashBehavior; |
97 | extern bool gVerifySSLCert; | 97 | extern bool gVerifySSLCert; |
98 | 98 | extern const char* DEFAULT_SETTINGS_FILE; | |
99 | 99 | ||
100 | // TODO: Eliminate most of these, move into a globals structure. | 100 | // TODO: Eliminate most of these, move into a globals structure. |
101 | extern const U32 PATCH_SIZE; | 101 | extern const U32 PATCH_SIZE; |
diff --git a/linden/indra/test/files.lst b/linden/indra/test/files.lst index 3824bd8..0f99ce9 100644 --- a/linden/indra/test/files.lst +++ b/linden/indra/test/files.lst | |||
@@ -7,6 +7,7 @@ test/llhttpnode_tut.cpp | |||
7 | test/lliohttpserver_tut.cpp | 7 | test/lliohttpserver_tut.cpp |
8 | test/llmime_tut.cpp | 8 | test/llmime_tut.cpp |
9 | test/llpipeutil.cpp | 9 | test/llpipeutil.cpp |
10 | test/llrandom_tut.cpp | ||
10 | test/llsd_new_tut.cpp | 11 | test/llsd_new_tut.cpp |
11 | test/llsdserialize_tut.cpp | 12 | test/llsdserialize_tut.cpp |
12 | test/llsd_message_system_tut.cpp | 13 | test/llsd_message_system_tut.cpp |
diff --git a/linden/indra/test/llrandom_tut.cpp b/linden/indra/test/llrandom_tut.cpp new file mode 100755 index 0000000..1bb795e --- /dev/null +++ b/linden/indra/test/llrandom_tut.cpp | |||
@@ -0,0 +1,69 @@ | |||
1 | /** | ||
2 | * @file llrandom_tut.cpp | ||
3 | * @author Phoenix | ||
4 | * @date 2007-01-25 | ||
5 | * | ||
6 | * Copyright (c) 2007-2007, Linden Research, Inc. | ||
7 | * | ||
8 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
9 | * to you under the terms of the GNU General Public License, version 2.0 | ||
10 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
11 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
12 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
13 | * online at http://secondlife.com/developers/opensource/gplv2 | ||
14 | * | ||
15 | * There are special exceptions to the terms and conditions of the GPL as | ||
16 | * it is applied to this Source Code. View the full text of the exception | ||
17 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
18 | * online at http://secondlife.com/developers/opensource/flossexception | ||
19 | * | ||
20 | * By copying, modifying or distributing this software, you acknowledge | ||
21 | * that you have read and understood your obligations described above, | ||
22 | * and agree to abide by those obligations. | ||
23 | * | ||
24 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
25 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
26 | * COMPLETENESS OR PERFORMANCE. | ||
27 | */ | ||
28 | |||
29 | #include <tut/tut.h> | ||
30 | |||
31 | #include "linden_common.h" | ||
32 | #include "llrand.h" | ||
33 | #include "lltut.h" | ||
34 | |||
35 | |||
36 | namespace tut | ||
37 | { | ||
38 | struct random | ||
39 | { | ||
40 | }; | ||
41 | |||
42 | typedef test_group<random> random_t; | ||
43 | typedef random_t::object random_object_t; | ||
44 | tut::random_t tut_random("random"); | ||
45 | |||
46 | template<> template<> | ||
47 | void random_object_t::test<1>() | ||
48 | { | ||
49 | F32 number = 0.0f; | ||
50 | for(S32 ii = 0; ii < 100000; ++ii) | ||
51 | { | ||
52 | number = ll_frand(); | ||
53 | ensure("frand >= 0", (number >= 0.0f)); | ||
54 | ensure("frand < 1", (number < 1.0f)); | ||
55 | } | ||
56 | } | ||
57 | |||
58 | template<> template<> | ||
59 | void random_object_t::test<2>() | ||
60 | { | ||
61 | F32 number = 0.0f; | ||
62 | for(S32 ii = 0; ii < 100000; ++ii) | ||
63 | { | ||
64 | number = ll_frand(2.0f) - 1.0f; | ||
65 | ensure("frand >= 0", (number >= -1.0f)); | ||
66 | ensure("frand < 1", (number <= 1.0f)); | ||
67 | } | ||
68 | } | ||
69 | } | ||
diff --git a/linden/indra/test/test.vcproj b/linden/indra/test/test.vcproj index 64c247c..f07d412 100644 --- a/linden/indra/test/test.vcproj +++ b/linden/indra/test/test.vcproj | |||
@@ -204,6 +204,9 @@ | |||
204 | RelativePath=".\llpipeutil.cpp"> | 204 | RelativePath=".\llpipeutil.cpp"> |
205 | </File> | 205 | </File> |
206 | <File | 206 | <File |
207 | RelativePath=".\llrandom_tut.cpp"> | ||
208 | </File> | ||
209 | <File | ||
207 | RelativePath=".\llsd_message_system_tut.cpp"> | 210 | RelativePath=".\llsd_message_system_tut.cpp"> |
208 | </File> | 211 | </File> |
209 | <File | 212 | <File |
diff --git a/linden/indra/win_crash_logger/win_crash_logger.cpp b/linden/indra/win_crash_logger/win_crash_logger.cpp index 3aa41d0..effe56c 100644 --- a/linden/indra/win_crash_logger/win_crash_logger.cpp +++ b/linden/indra/win_crash_logger/win_crash_logger.cpp | |||
@@ -496,6 +496,7 @@ void send_crash_report() | |||
496 | db_filep = new LLFileEncoder("DB", db_file_name.c_str()); | 496 | db_filep = new LLFileEncoder("DB", db_file_name.c_str()); |
497 | 497 | ||
498 | // Get the filename of the SecondLife.log file | 498 | // Get the filename of the SecondLife.log file |
499 | // *NOTE: This buffer size is hard coded into scanf() below. | ||
499 | char tmp_sl_name[256]; | 500 | char tmp_sl_name[256]; |
500 | tmp_sl_name[0] = '\0'; | 501 | tmp_sl_name[0] = '\0'; |
501 | 502 | ||
@@ -506,7 +507,10 @@ void send_crash_report() | |||
506 | // Look for it in the debug_info.log file | 507 | // Look for it in the debug_info.log file |
507 | if (db_filep->isValid()) | 508 | if (db_filep->isValid()) |
508 | { | 509 | { |
509 | sscanf((const char *)db_filep->mBuf, "SL Log: %[^\r\n]", tmp_sl_name); | 510 | sscanf( |
511 | (const char*)db_filep->mBuf, | ||
512 | "SL Log: %255[^\r\n]", | ||
513 | tmp_sl_name); | ||
510 | } | 514 | } |
511 | else | 515 | else |
512 | { | 516 | { |