aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden
diff options
context:
space:
mode:
Diffstat (limited to 'linden')
-rw-r--r--linden/indra/newview/llwaterparammanager.cpp100
-rw-r--r--linden/indra/newview/llwlparammanager.h1
2 files changed, 51 insertions, 50 deletions
diff --git a/linden/indra/newview/llwaterparammanager.cpp b/linden/indra/newview/llwaterparammanager.cpp
index 0156622..9d0fd86 100644
--- a/linden/indra/newview/llwaterparammanager.cpp
+++ b/linden/indra/newview/llwaterparammanager.cpp
@@ -3,9 +3,9 @@
3 * @brief Implementation for the LLWaterParamManager class. 3 * @brief Implementation for the LLWaterParamManager class.
4 * 4 *
5 * $LicenseInfo:firstyear=2007&license=viewergpl$ 5 * $LicenseInfo:firstyear=2007&license=viewergpl$
6 * 6 *
7 * Copyright (c) 2007-2009, Linden Research, Inc. 7 * Copyright (c) 2007-2009, Linden Research, Inc.
8 * 8 *
9 * Second Life Viewer Source Code 9 * Second Life Viewer Source Code
10 * The source code in this file ("Source Code") is provided by Linden Lab 10 * The source code in this file ("Source Code") is provided by Linden Lab
11 * to you under the terms of the GNU General Public License, version 2.0 11 * to you under the terms of the GNU General Public License, version 2.0
@@ -13,17 +13,17 @@
13 * ("Other License"), formally executed by you and Linden Lab. Terms of 13 * ("Other License"), formally executed by you and Linden Lab. Terms of
14 * the GPL can be found in doc/GPL-license.txt in this distribution, or 14 * the GPL can be found in doc/GPL-license.txt in this distribution, or
15 * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 15 * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
16 * 16 *
17 * There are special exceptions to the terms and conditions of the GPL as 17 * There are special exceptions to the terms and conditions of the GPL as
18 * it is applied to this Source Code. View the full text of the exception 18 * it is applied to this Source Code. View the full text of the exception
19 * in the file doc/FLOSS-exception.txt in this software distribution, or 19 * in the file doc/FLOSS-exception.txt in this software distribution, or
20 * online at 20 * online at
21 * http://secondlifegrid.net/programs/open_source/licensing/flossexception 21 * http://secondlifegrid.net/programs/open_source/licensing/flossexception
22 * 22 *
23 * By copying, modifying or distributing this software, you acknowledge 23 * By copying, modifying or distributing this software, you acknowledge
24 * that you have read and understood your obligations described above, 24 * that you have read and understood your obligations described above,
25 * and agree to abide by those obligations. 25 * and agree to abide by those obligations.
26 * 26 *
27 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO 27 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
28 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, 28 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
29 * COMPLETENESS OR PERFORMANCE. 29 * COMPLETENESS OR PERFORMANCE.
@@ -102,9 +102,9 @@ void LLWaterParamManager::loadAllPresets(const std::string& file_name)
102{ 102{
103 std::string path_name(gDirUtilp->getExpandedFilename(LL_PATH_APP_SETTINGS, "windlight/water", "")); 103 std::string path_name(gDirUtilp->getExpandedFilename(LL_PATH_APP_SETTINGS, "windlight/water", ""));
104 LL_DEBUGS2("AppInit", "ShaderLoading") << "Loading Default water settings from " << path_name << LL_ENDL; 104 LL_DEBUGS2("AppInit", "ShaderLoading") << "Loading Default water settings from " << path_name << LL_ENDL;
105 105
106 bool found = true; 106 bool found = true;
107 while(found) 107 while(found)
108 { 108 {
109 std::string name; 109 std::string name;
110 found = gDirUtilp->getNextFileInDir(path_name, "*.xml", name, false); 110 found = gDirUtilp->getNextFileInDir(path_name, "*.xml", name, false);
@@ -128,9 +128,9 @@ void LLWaterParamManager::loadAllPresets(const std::string& file_name)
128 128
129 std::string path_name2(gDirUtilp->getExpandedFilename( LL_PATH_USER_SETTINGS , "windlight/water", "")); 129 std::string path_name2(gDirUtilp->getExpandedFilename( LL_PATH_USER_SETTINGS , "windlight/water", ""));
130 LL_DEBUGS2("AppInit", "Shaders") << "Loading User water settings from " << path_name2 << LL_ENDL; 130 LL_DEBUGS2("AppInit", "Shaders") << "Loading User water settings from " << path_name2 << LL_ENDL;
131 131
132 found = true; 132 found = true;
133 while(found) 133 while(found)
134 { 134 {
135 std::string name; 135 std::string name;
136 found = gDirUtilp->getNextFileInDir(path_name2, "*.xml", name, false); 136 found = gDirUtilp->getNextFileInDir(path_name2, "*.xml", name, false);
@@ -174,10 +174,10 @@ void LLWaterParamManager::loadPreset(const std::string & name,bool propagate)
174 174
175 std::string pathName(gDirUtilp->getExpandedFilename(LL_PATH_APP_SETTINGS, "windlight/water", escaped_filename)); 175 std::string pathName(gDirUtilp->getExpandedFilename(LL_PATH_APP_SETTINGS, "windlight/water", escaped_filename));
176 LL_DEBUGS2("AppInit", "Shaders") << "Loading water settings from " << pathName << LL_ENDL; 176 LL_DEBUGS2("AppInit", "Shaders") << "Loading water settings from " << pathName << LL_ENDL;
177 177
178 std::ifstream presetsXML; 178 std::ifstream presetsXML;
179 presetsXML.open(pathName.c_str()); 179 presetsXML.open(pathName.c_str());
180 180
181 // That failed, try loading from the users area instead. 181 // That failed, try loading from the users area instead.
182 if(!presetsXML) 182 if(!presetsXML)
183 { 183 {
@@ -190,8 +190,8 @@ void LLWaterParamManager::loadPreset(const std::string & name,bool propagate)
190 { 190 {
191 loadPresetXML(name, presetsXML); 191 loadPresetXML(name, presetsXML);
192 presetsXML.close(); 192 presetsXML.close();
193 } 193 }
194 else 194 else
195 { 195 {
196 llwarns << "Can't find " << name << llendl; 196 llwarns << "Can't find " << name << llendl;
197 return; 197 return;
@@ -240,17 +240,17 @@ bool LLWaterParamManager::loadPresetXML(const std::string& name, std::istream& p
240 } 240 }
241 } 241 }
242 } 242 }
243 243
244 std::map<std::string, LLWaterParamSet>::iterator mIt = mParamList.find(name); 244 std::map<std::string, LLWaterParamSet>::iterator mIt = mParamList.find(name);
245 if(mIt == mParamList.end()) 245 if(mIt == mParamList.end())
246 { 246 {
247 addParamSet(name, paramsData); 247 addParamSet(name, paramsData);
248 } 248 }
249 else 249 else
250 { 250 {
251 setParamSet(name, paramsData); 251 setParamSet(name, paramsData);
252 } 252 }
253 253
254 if(propagate) 254 if(propagate)
255 { 255 {
256 getParamSet(name, mCurParams); 256 getParamSet(name, mCurParams);
@@ -306,19 +306,19 @@ bool LLWaterParamManager::savePresetToNotecard(const std::string & name)
306{ 306{
307 // make an empty llsd 307 // make an empty llsd
308 LLSD paramsData(LLSD::emptyMap()); 308 LLSD paramsData(LLSD::emptyMap());
309 309
310 // fill it with LLSD windlight params 310 // fill it with LLSD windlight params
311 paramsData = mParamList[name].getAll(); 311 paramsData = mParamList[name].getAll();
312 312
313 // get some XML 313 // get some XML
314 std::ostringstream presetsXML; 314 std::ostringstream presetsXML;
315 LLPointer<LLSDFormatter> formatter = new LLSDXMLFormatter(); 315 LLPointer<LLSDFormatter> formatter = new LLSDXMLFormatter();
316 formatter->format(paramsData, presetsXML, LLSDFormatter::OPTIONS_PRETTY); 316 formatter->format(paramsData, presetsXML, LLSDFormatter::OPTIONS_PRETTY);
317 317
318 // Write it to a notecard 318 // Write it to a notecard
319 LLNotecard notecard; 319 LLNotecard notecard;
320 notecard.setText(presetsXML.str()); 320 notecard.setText(presetsXML.str());
321 321
322 LLInventoryItem *item = gInventory.getItem(mParamList[name].mInventoryID); 322 LLInventoryItem *item = gInventory.getItem(mParamList[name].mInventoryID);
323 if(!item) 323 if(!item)
324 { 324 {
@@ -332,13 +332,13 @@ bool LLWaterParamManager::savePresetToNotecard(const std::string & name)
332 LLAssetID asset_id; 332 LLAssetID asset_id;
333 tid.generate(); 333 tid.generate();
334 asset_id = tid.makeAssetID(gAgent.getSecureSessionID()); 334 asset_id = tid.makeAssetID(gAgent.getSecureSessionID());
335 335
336 LLVFile file(gVFS, asset_id, LLAssetType::AT_NOTECARD, LLVFile::APPEND); 336 LLVFile file(gVFS, asset_id, LLAssetType::AT_NOTECARD, LLVFile::APPEND);
337 337
338 std::ostringstream stream; 338 std::ostringstream stream;
339 notecard.exportStream(stream); 339 notecard.exportStream(stream);
340 std::string buffer = stream.str(); 340 std::string buffer = stream.str();
341 341
342 S32 size = buffer.length() + 1; 342 S32 size = buffer.length() + 1;
343 file.setMaxSize(size); 343 file.setMaxSize(size);
344 file.write((U8*)buffer.c_str(), size); 344 file.write((U8*)buffer.c_str(), size);
@@ -351,7 +351,7 @@ bool LLWaterParamManager::savePresetToNotecard(const std::string & name)
351 LL_WARNS("WindLight") << "Stuff the legacy system." << LL_ENDL; 351 LL_WARNS("WindLight") << "Stuff the legacy system." << LL_ENDL;
352 return false; 352 return false;
353 } 353 }
354 354
355 propagateParameters(); 355 propagateParameters();
356 return true; 356 return true;
357} 357}
@@ -374,8 +374,8 @@ void LLWaterParamManager::propagateParameters(void)
374 } 374 }
375 375
376 bool err; 376 bool err;
377 F32 fog_density_slider = 377 F32 fog_density_slider =
378 log(mCurParams.getFloat(mFogDensity.mName, err)) / 378 log(mCurParams.getFloat(mFogDensity.mName, err)) /
379 log(mFogDensity.mBase); 379 log(mFogDensity.mBase);
380 380
381 setDensitySliderValue(fog_density_slider); 381 setDensitySliderValue(fog_density_slider);
@@ -398,12 +398,12 @@ void LLWaterParamManager::updateShaderUniforms(LLGLSLShader * shader)
398void LLWaterParamManager::update(LLViewerCamera * cam) 398void LLWaterParamManager::update(LLViewerCamera * cam)
399{ 399{
400 LLFastTimer ftm(LLFastTimer::FTM_UPDATE_WLPARAM); 400 LLFastTimer ftm(LLFastTimer::FTM_UPDATE_WLPARAM);
401 401
402 // update the shaders and the menu 402 // update the shaders and the menu
403 propagateParameters(); 403 propagateParameters();
404 404
405 // sync menus if they exist 405 // sync menus if they exist
406 if(LLFloaterWater::isOpen()) 406 if(LLFloaterWater::isOpen())
407 { 407 {
408 LLFloaterWater::instance()->syncMenu(); 408 LLFloaterWater::instance()->syncMenu();
409 } 409 }
@@ -411,12 +411,12 @@ void LLWaterParamManager::update(LLViewerCamera * cam)
411 stop_glerror(); 411 stop_glerror();
412 412
413 // only do this if we're dealing with shaders 413 // only do this if we're dealing with shaders
414 if(gPipeline.canUseVertexShaders()) 414 if(gPipeline.canUseVertexShaders())
415 { 415 {
416 //transform water plane to eye space 416 //transform water plane to eye space
417 glh::vec3f norm(0.f, 0.f, 1.f); 417 glh::vec3f norm(0.f, 0.f, 1.f);
418 glh::vec3f p(0.f, 0.f, gAgent.getRegion()->getWaterHeight()+0.1f); 418 glh::vec3f p(0.f, 0.f, gAgent.getRegion()->getWaterHeight()+0.1f);
419 419
420 F32 modelView[16]; 420 F32 modelView[16];
421 for (U32 i = 0; i < 16; i++) 421 for (U32 i = 0; i < 16; i++)
422 { 422 {
@@ -434,13 +434,13 @@ void LLWaterParamManager::update(LLViewerCamera * cam)
434 mWaterPlane = LLVector4(enorm.v[0], enorm.v[1], enorm.v[2], -ep.dot(enorm)); 434 mWaterPlane = LLVector4(enorm.v[0], enorm.v[1], enorm.v[2], -ep.dot(enorm));
435 435
436 LLVector3 sunMoonDir; 436 LLVector3 sunMoonDir;
437 if (gSky.getSunDirection().mV[2] > NIGHTTIME_ELEVATION_COS) 437 if (gSky.getSunDirection().mV[2] > NIGHTTIME_ELEVATION_COS)
438 { 438 {
439 sunMoonDir = gSky.getSunDirection(); 439 sunMoonDir = gSky.getSunDirection();
440 } 440 }
441 else 441 else
442 { 442 {
443 sunMoonDir = gSky.getMoonDirection(); 443 sunMoonDir = gSky.getMoonDirection();
444 } 444 }
445 sunMoonDir.normVec(); 445 sunMoonDir.normVec();
446 mWaterFogKS = 1.f/llmax(sunMoonDir.mV[2], WATER_FOG_LIGHT_CLAMP); 446 mWaterFogKS = 1.f/llmax(sunMoonDir.mV[2], WATER_FOG_LIGHT_CLAMP);
@@ -510,8 +510,8 @@ bool LLWaterParamManager::addParamSet(const std::string& name, LLWaterParamSet&
510{ 510{
511 // add a new one if not one there already 511 // add a new one if not one there already
512 std::map<std::string, LLWaterParamSet>::iterator mIt = mParamList.find(name); 512 std::map<std::string, LLWaterParamSet>::iterator mIt = mParamList.find(name);
513 if(mIt == mParamList.end()) 513 if(mIt == mParamList.end())
514 { 514 {
515 mParamList[name] = param; 515 mParamList[name] = param;
516 return true; 516 return true;
517 } 517 }
@@ -538,7 +538,7 @@ bool LLWaterParamManager::getParamSet(const std::string& name, LLWaterParamSet&
538{ 538{
539 // find it and set it 539 // find it and set it
540 std::map<std::string, LLWaterParamSet>::iterator mIt = mParamList.find(name); 540 std::map<std::string, LLWaterParamSet>::iterator mIt = mParamList.find(name);
541 if(mIt != mParamList.end()) 541 if(mIt != mParamList.end())
542 { 542 {
543 param = mParamList[name]; 543 param = mParamList[name];
544 param.mName = name; 544 param.mName = name;
@@ -558,11 +558,11 @@ bool LLWaterParamManager::setParamSet(const std::string& name, LLWaterParamSet&
558bool LLWaterParamManager::setParamSet(const std::string& name, const LLSD & param) 558bool LLWaterParamManager::setParamSet(const std::string& name, const LLSD & param)
559{ 559{
560 // quick, non robust (we won't be working with files, but assets) check 560 // quick, non robust (we won't be working with files, but assets) check
561 if(!param.isMap()) 561 if(!param.isMap())
562 { 562 {
563 return false; 563 return false;
564 } 564 }
565 565
566 mParamList[name].setAll(param); 566 mParamList[name].setAll(param);
567 567
568 return true; 568 return true;
@@ -572,7 +572,7 @@ bool LLWaterParamManager::removeParamSet(const std::string& name, bool delete_fr
572{ 572{
573 // remove from param list 573 // remove from param list
574 std::map<std::string, LLWaterParamSet>::iterator mIt = mParamList.find(name); 574 std::map<std::string, LLWaterParamSet>::iterator mIt = mParamList.find(name);
575 if(mIt != mParamList.end()) 575 if(mIt != mParamList.end())
576 { 576 {
577 mParamList.erase(mIt); 577 mParamList.erase(mIt);
578 } 578 }
@@ -581,13 +581,13 @@ bool LLWaterParamManager::removeParamSet(const std::string& name, bool delete_fr
581 { 581 {
582 582
583 std::string path_name(gDirUtilp->getExpandedFilename( LL_PATH_USER_SETTINGS , "windlight/water", "")); 583 std::string path_name(gDirUtilp->getExpandedFilename( LL_PATH_USER_SETTINGS , "windlight/water", ""));
584 584
585 // use full curl escaped name 585 // use full curl escaped name
586 char * curl_str = curl_escape(name.c_str(), name.size()); 586 char * curl_str = curl_escape(name.c_str(), name.size());
587 std::string escaped_name(curl_str); 587 std::string escaped_name(curl_str);
588 curl_free(curl_str); 588 curl_free(curl_str);
589 curl_str = NULL; 589 curl_str = NULL;
590 590
591 gDirUtilp->deleteFilesInDir(path_name, escaped_name + ".xml"); 591 gDirUtilp->deleteFilesInDir(path_name, escaped_name + ".xml");
592 } 592 }
593 593
@@ -599,7 +599,7 @@ F32 LLWaterParamManager::getFogDensity(void)
599 bool err; 599 bool err;
600 600
601 F32 fogDensity = mCurParams.getFloat("waterFogDensity", err); 601 F32 fogDensity = mCurParams.getFloat("waterFogDensity", err);
602 602
603 // modify if we're underwater 603 // modify if we're underwater
604 const F32 water_height = gAgent.getRegion() ? gAgent.getRegion()->getWaterHeight() : 0.f; 604 const F32 water_height = gAgent.getRegion() ? gAgent.getRegion()->getWaterHeight() : 0.f;
605 F32 camera_height = gAgent.getCameraPositionAgent().mV[2]; 605 F32 camera_height = gAgent.getCameraPositionAgent().mV[2];
@@ -659,7 +659,7 @@ void LLWaterParamManager::loadWaterNotecard(LLVFS *vfs, const LLUUID& asset_id,
659 } 659 }
660 else 660 else
661 { 661 {
662 // We can do this because we know mCurParams 662 // We can do this because we know mCurParams
663 sInstance->mParamList[name].mInventoryID = inventory_id; 663 sInstance->mParamList[name].mInventoryID = inventory_id;
664 } 664 }
665 } 665 }
diff --git a/linden/indra/newview/llwlparammanager.h b/linden/indra/newview/llwlparammanager.h
index 4c7fdc1..27e7663 100644
--- a/linden/indra/newview/llwlparammanager.h
+++ b/linden/indra/newview/llwlparammanager.h
@@ -132,6 +132,7 @@ struct WLFloatControl {
132 } 132 }
133}; 133};
134 134
135
135/// WindLight parameter manager class - what controls all the wind light shaders 136/// WindLight parameter manager class - what controls all the wind light shaders
136class LLWLParamManager 137class LLWLParamManager
137{ 138{