diff options
Diffstat (limited to 'indra/newview')
67 files changed, 515 insertions, 175 deletions
| diff --git a/indra/newview/CMakeLists.txt b/indra/newview/CMakeLists.txt index 0a267cbad0..0a267cbad0 100755..100644 --- a/indra/newview/CMakeLists.txt +++ b/indra/newview/CMakeLists.txt diff --git a/indra/newview/app_settings/logcontrol.xml b/indra/newview/app_settings/logcontrol.xml index 64122bbb6c..64122bbb6c 100755..100644 --- a/indra/newview/app_settings/logcontrol.xml +++ b/indra/newview/app_settings/logcontrol.xml diff --git a/indra/newview/app_settings/settings.xml b/indra/newview/app_settings/settings.xml index 22bf40a911..c9b4de0140 100755..100644 --- a/indra/newview/app_settings/settings.xml +++ b/indra/newview/app_settings/settings.xml @@ -7642,6 +7642,17 @@        <key>Value</key>        <integer>1</integer>      </map> +  <key>RenderCompressTextures</key> +  <map> +    <key>Comment</key> +    <string>Enable texture compression on OpenGL 3.0 and later implementations (EXPERIMENTAL, requires restart)</string> +    <key>Persist</key> +    <integer>1</integer> +    <key>Type</key> +    <string>Boolean</string> +    <key>Value</key> +    <integer>0</integer> +  </map>      <key>RenderPerformanceTest</key>      <map>        <key>Comment</key> @@ -9134,28 +9145,19 @@      <key>Value</key>      <integer>0</integer>    </map> -    <key>RenderUseShaderLOD</key> -    <map> -      <key>Comment</key> -      <string>Whether we want to have different shaders for LOD</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>RenderUseShaderNearParticles</key> -    <map> -      <key>Comment</key> -      <string>Whether we want to use shaders on near particles</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>0</integer> -    </map> +     +  <key>RenderAutoHideSurfaceAreaLimit</key> +  <map> +    <key>Comment</key> +    <string>Maximum surface area of a set of proximal objects inworld before automatically hiding geometry to prevent system overload.</string> +    <key>Persist</key> +    <integer>1</integer> +    <key>Type</key> +    <string>F32</string> +    <key>Value</key> +    <integer>0</integer> +  </map> +      <key>RenderVBOEnable</key>      <map>        <key>Comment</key> diff --git a/indra/newview/featuretable.txt b/indra/newview/featuretable.txt index 76bb2b0976..e8a109e661 100644 --- a/indra/newview/featuretable.txt +++ b/indra/newview/featuretable.txt @@ -61,6 +61,7 @@ WLSkyDetail					1	128  Disregard128DefaultDrawDistance	1	1  Disregard96DefaultDrawDistance	1	1  RenderTextureMemoryMultiple		1	1.0 +RenderCompressTextures		1	1  RenderShaderLightingMaxLevel	1	3  RenderDeferred				1	1  RenderDeferredSSAO			1	1 @@ -72,6 +73,38 @@ RenderMaxTextureIndex		1	16  // +// Low Graphics Settings (fixed function) +// +list LowFixedFunction +RenderAnisotropic			1	0 +RenderAvatarCloth			1	0 +RenderAvatarLODFactor		1	0 +RenderAvatarPhysicsLODFactor 1	0 +RenderAvatarMaxVisible      1   3 +RenderAvatarVP				1	0 +RenderFarClip				1	64 +RenderFlexTimeFactor		1	0 +RenderGlowResolutionPow		1	8 +RenderMaxPartCount			1	0 +RenderObjectBump			1	0 +RenderLocalLights			1	0 +RenderReflectionDetail		1	0 +RenderTerrainDetail			1	0 +RenderTerrainLODFactor		1	1 +RenderTransparentWater		1	0 +RenderTreeLODFactor			1	0 +RenderUseImpostors			1	1 +RenderVolumeLODFactor		1	1.125 +VertexShaderEnable			1	0 +WindLightUseAtmosShaders	1	0 +WLSkyDetail					1	48 +RenderDeferred				1	0 +RenderDeferredSSAO			1	0 +RenderShadowDetail			1	0 +RenderFSAASamples			1	0 + + +//  // Low Graphics Settings  //  list Low @@ -94,7 +127,7 @@ RenderTransparentWater		1	0  RenderTreeLODFactor			1	0  RenderUseImpostors			1	1  RenderVolumeLODFactor		1	1.125 -VertexShaderEnable			1	0 +VertexShaderEnable			1	1  WindLightUseAtmosShaders	1	0  WLSkyDetail					1	48  RenderDeferred				1	0 @@ -223,6 +256,12 @@ list Class3  RenderVBOEnable				1	1  // +// VRAM > 512MB +// +list VRAMGT512 +RenderCompressTextures		1	0 + +//  // No Pixel Shaders available  //  list NoPixelShaders @@ -302,6 +341,7 @@ RenderMaxTextureIndex		1	1  list Intel  RenderAnisotropic			1	0  RenderVBOEnable				1	0 +RenderFSAASamples			1	0  list GeForce2  RenderAnisotropic			1	0 diff --git a/indra/newview/featuretable_linux.txt b/indra/newview/featuretable_linux.txt index 5e217e000a..3a0e7e3697 100644 --- a/indra/newview/featuretable_linux.txt +++ b/indra/newview/featuretable_linux.txt @@ -61,6 +61,7 @@ WLSkyDetail					1	128  Disregard128DefaultDrawDistance	1	1  Disregard96DefaultDrawDistance	1	1  RenderTextureMemoryMultiple		1	1.0 +RenderCompressTextures		1	1  RenderShaderLightingMaxLevel		1	3  RenderDeferred				1	1  RenderDeferredSSAO			1	1 @@ -69,6 +70,37 @@ RenderFSAASamples			1	16  RenderMaxTextureIndex		1	16  // +// Low Graphics Settings (fixed function) +// +list LowFixedFunction +RenderAnisotropic			1	0 +RenderAvatarCloth			1	0 +RenderAvatarLODFactor		1	0 +RenderAvatarPhysicsLODFactor 1	0 +RenderAvatarMaxVisible      1   3 +RenderAvatarVP				1	0 +RenderFarClip				1	64 +RenderFlexTimeFactor		1	0 +RenderGlowResolutionPow		1	8 +RenderLocalLights			1	0 +RenderMaxPartCount			1	0 +RenderObjectBump			1	0 +RenderReflectionDetail		1	0 +RenderTerrainDetail			1	0 +RenderTerrainLODFactor		1	1 +RenderTransparentWater		1	0 +RenderTreeLODFactor			1	0 +RenderUseImpostors			1	1 +RenderVolumeLODFactor		1	0.5 +VertexShaderEnable			1	1 +WindLightUseAtmosShaders	1	0 +WLSkyDetail					1	48 +RenderDeferred				1	0 +RenderDeferredSSAO			1	0 +RenderShadowDetail			1	0 +RenderFSAASamples			1	0 + +//  // Low Graphics Settings  //  list Low @@ -220,6 +252,12 @@ list Class3  RenderVBOEnable				1	1  // +// VRAM > 512MB +// +list VRAMGT512 +RenderCompressTextures		1	0 + +//  // No Pixel Shaders available  //  list NoPixelShaders @@ -291,10 +329,15 @@ RenderObjectBump			0	0  list OpenGLPre15  RenderVBOEnable				1	0 +list OpenGLPre30 +RenderDeferred				0	0 +RenderMaxTextureIndex		1	1 +  list Intel  RenderAnisotropic			1	0  // Avoid some Intel crashes on Linux  RenderCubeMap				0	0 +RenderFSAASamples			1	0  list GeForce2  RenderAnisotropic			1	0 diff --git a/indra/newview/featuretable_mac.txt b/indra/newview/featuretable_mac.txt index 915a012a39..96362ff4bb 100644 --- a/indra/newview/featuretable_mac.txt +++ b/indra/newview/featuretable_mac.txt @@ -61,6 +61,7 @@ WLSkyDetail						1	128  Disregard128DefaultDrawDistance	1	1  Disregard96DefaultDrawDistance	1	1  RenderTextureMemoryMultiple		1	0.5 +RenderCompressTextures			1	1  RenderShaderLightingMaxLevel	1	3  RenderDeferred				1	1  RenderDeferredSSAO			1	1 @@ -71,6 +72,37 @@ RenderFSAASamples			1	16  RenderMaxTextureIndex		1	16  // +// Low Graphics Settings (fixed function) +// +list LowFixedFunction +RenderAnisotropic			1	0 +RenderAvatarCloth			1	0 +RenderAvatarLODFactor		1	0 +RenderAvatarPhysicsLODFactor 1	0 +RenderAvatarMaxVisible      1   3 +RenderAvatarVP				1	0 +RenderFarClip				1	64 +RenderFlexTimeFactor		1	0 +RenderGlowResolutionPow		1	8 +RenderLocalLights			1	0 +RenderMaxPartCount			1	0 +RenderObjectBump			1	0 +RenderReflectionDetail		1	0 +RenderTerrainDetail			1	0 +RenderTerrainLODFactor		1	1 +RenderTransparentWater		1	0 +RenderTreeLODFactor			1	0 +RenderUseImpostors			1	1 +RenderVolumeLODFactor		1	0.5 +VertexShaderEnable			1	0 +WindLightUseAtmosShaders	1	0 +WLSkyDetail					1	48 +RenderDeferred				1	0 +RenderDeferredSSAO			1	0 +RenderShadowDetail			1	0 +RenderFSAASamples			1	0 + +//  // Low Graphics Settings  //  list Low @@ -93,7 +125,7 @@ RenderTransparentWater		1	0  RenderTreeLODFactor			1	0  RenderUseImpostors			1	1  RenderVolumeLODFactor		1	0.5 -VertexShaderEnable			1	0 +VertexShaderEnable			1	1  WindLightUseAtmosShaders	1	0  WLSkyDetail					1	48  RenderDeferred				1	0 @@ -248,6 +280,12 @@ RenderDeferredSSAO			0	0  RenderShadowDetail			0	0  // +// VRAM > 512MB +// +list VRAMGT512 +RenderCompressTextures		1	0 + +//  // "Default" setups for safe, low, medium, high  //  list safe @@ -286,6 +324,7 @@ RenderObjectBump			0	0  list OpenGLPre15  RenderVBOEnable				1	0 +  list TexUnit8orLess  RenderDeferredSSAO			0	0 @@ -295,6 +334,7 @@ RenderDeferredSSAO			1	0  list Intel  RenderAnisotropic			1	0  RenderLocalLights			1	0 +RenderFSAASamples			1	0  list GeForce2  RenderAnisotropic			1	0 diff --git a/indra/newview/featuretable_xp.txt b/indra/newview/featuretable_xp.txt index ae2cf910f2..398a64378e 100644 --- a/indra/newview/featuretable_xp.txt +++ b/indra/newview/featuretable_xp.txt @@ -61,6 +61,7 @@ WLSkyDetail					1	128  Disregard128DefaultDrawDistance	1	1  Disregard96DefaultDrawDistance	1	1  RenderTextureMemoryMultiple		1	1.0 +RenderCompressTextures		1	1  RenderShaderLightingMaxLevel	1	3  RenderDeferred				1	0  RenderDeferredSSAO			1	0 @@ -71,6 +72,37 @@ RenderFSAASamples			1	16  RenderMaxTextureIndex		1	16  // +// Low Graphics Settings (fixed function) +// +list LowFixedFunction +RenderAnisotropic			1	0 +RenderAvatarCloth			1	0 +RenderAvatarLODFactor		1	0 +RenderAvatarPhysicsLODFactor 1	0 +RenderAvatarMaxVisible      1   3 +RenderAvatarVP				1	0 +RenderFarClip				1	64 +RenderFlexTimeFactor		1	0 +RenderGlowResolutionPow		1	8 +RenderLocalLights			1	0 +RenderMaxPartCount			1	0 +RenderObjectBump			1	0 +RenderReflectionDetail		1	0 +RenderTerrainDetail			1	0 +RenderTerrainLODFactor		1	1 +RenderTransparentWater		1	0 +RenderTreeLODFactor			1	0 +RenderUseImpostors			1	1 +RenderVolumeLODFactor		1	0.5 +VertexShaderEnable			1	0 +WindLightUseAtmosShaders	1	0 +WLSkyDetail					1	48 +RenderDeferred				1	0 +RenderDeferredSSAO			1	0 +RenderShadowDetail			1	0 +RenderFSAASamples			1	0 + +//  // Low Graphics Settings  //  list Low @@ -93,7 +125,7 @@ RenderTransparentWater		1	0  RenderTreeLODFactor			1	0  RenderUseImpostors			1	1  RenderVolumeLODFactor		1	0.5 -VertexShaderEnable			1	0 +VertexShaderEnable			1	1  WindLightUseAtmosShaders	1	0  WLSkyDetail					1	48  RenderDeferred				1	0 @@ -222,6 +254,12 @@ list Class3  RenderVBOEnable				1	1  // +// VRAM > 512MB +// +list VRAMGT512 +RenderCompressTextures		1	0 + +//  // No Pixel Shaders available  //  list NoPixelShaders @@ -299,6 +337,7 @@ RenderMaxTextureIndex		1	1  list Intel  RenderAnisotropic			1	0  RenderVBOEnable				1	0 +RenderFSAASamples			1	0  list GeForce2  RenderAnisotropic			1	0 diff --git a/indra/newview/gpu_table.txt b/indra/newview/gpu_table.txt index 198e702459..777d54a5c3 100644 --- a/indra/newview/gpu_table.txt +++ b/indra/newview/gpu_table.txt @@ -205,6 +205,7 @@ ATI Radeon X800					.*ATI.*Radeon ?X8.*							2		1  ATI Radeon X900					.*ATI.*Radeon ?X9.*							2		1  ATI Radeon Xpress				.*ATI.*Radeon Xpress.*						0		1  ATI Rage 128					.*ATI.*Rage 128.*							0		1 +ATI R300 (9700)					.*R300.*									1		1  ATI R350 (9800)					.*R350.*									1		1  ATI R580 (X1900)				.*R580.*									3		1  ATI RC410 (Xpress 200)			.*RC410.*									0		0 diff --git a/indra/newview/llagentwearables.cpp b/indra/newview/llagentwearables.cpp index e441f21f90..e441f21f90 100755..100644 --- a/indra/newview/llagentwearables.cpp +++ b/indra/newview/llagentwearables.cpp diff --git a/indra/newview/llagentwearables.h b/indra/newview/llagentwearables.h index 5932be21c6..5932be21c6 100755..100644 --- a/indra/newview/llagentwearables.h +++ b/indra/newview/llagentwearables.h diff --git a/indra/newview/llappearancemgr.cpp b/indra/newview/llappearancemgr.cpp index faadfb4b87..faadfb4b87 100755..100644 --- a/indra/newview/llappearancemgr.cpp +++ b/indra/newview/llappearancemgr.cpp diff --git a/indra/newview/llappviewer.cpp b/indra/newview/llappviewer.cpp index e05a75d1ba..ed04b5bf38 100644 --- a/indra/newview/llappviewer.cpp +++ b/indra/newview/llappviewer.cpp @@ -531,6 +531,7 @@ static void settings_to_globals()  	LLRender::sGLCoreProfile = gSavedSettings.getBOOL("RenderGLCoreProfile");  	LLImageGL::sGlobalUseAnisotropic	= gSavedSettings.getBOOL("RenderAnisotropic"); +	LLImageGL::sCompressTextures		= gSavedSettings.getBOOL("RenderCompressTextures");  	LLVOVolume::sLODFactor				= gSavedSettings.getF32("RenderVolumeLODFactor");  	LLVOVolume::sDistanceFactor			= 1.f-LLVOVolume::sLODFactor * 0.1f;  	LLVolumeImplFlexible::sUpdateFactor = gSavedSettings.getF32("RenderFlexTimeFactor"); @@ -548,7 +549,7 @@ static void settings_to_globals()  	gAgentPilot.setNumRuns(gSavedSettings.getS32("StatsNumRuns"));  	gAgentPilot.setQuitAfterRuns(gSavedSettings.getBOOL("StatsQuitAfterRuns"));  	gAgent.setHideGroupTitle(gSavedSettings.getBOOL("RenderHideGroupTitle")); - +		  	gDebugWindowProc = gSavedSettings.getBOOL("DebugWindowProc");  	gShowObjectUpdates = gSavedSettings.getBOOL("ShowObjectUpdates");  	LLWorldMapView::sMapScale = gSavedSettings.getF32("MapScale"); @@ -1016,6 +1017,15 @@ bool LLAppViewer::init()  		}  	} +#if LL_WINDOWS +	if (gGLManager.mIsIntel &&  +		LLFeatureManager::getInstance()->getGPUClass() > 0 && +		gGLManager.mGLVersion <= 3.f) +	{ +		LLNotificationsUtil::add("IntelOldDriver"); +	} +#endif +  	// save the graphics card  	gDebugInfo["GraphicsCard"] = LLFeatureManager::getInstance()->getGPUString(); @@ -1549,7 +1559,6 @@ bool LLAppViewer::cleanup()  	if (! isError())  	{  		std::string logdir = gDirUtilp->getExpandedFilename(LL_PATH_LOGS, ""); -		logdir += gDirUtilp->getDirDelimiter();  		gDirUtilp->deleteFilesInDir(logdir, "*-*-*-*-*.dmp");  	} @@ -1805,8 +1814,7 @@ bool LLAppViewer::cleanup()  	if (mPurgeOnExit)  	{  		llinfos << "Purging all cache files on exit" << llendflush; -		std::string mask = gDirUtilp->getDirDelimiter() + "*.*"; -		gDirUtilp->deleteFilesInDir(gDirUtilp->getExpandedFilename(LL_PATH_CACHE,""),mask); +		gDirUtilp->deleteFilesInDir(gDirUtilp->getExpandedFilename(LL_PATH_CACHE,""), "*.*");  	}  	removeMarkerFile(); // Any crashes from here on we'll just have to ignore @@ -3040,8 +3048,7 @@ void LLAppViewer::cleanupSavedSettings()  void LLAppViewer::removeCacheFiles(const std::string& file_mask)  { -	std::string mask = gDirUtilp->getDirDelimiter() + file_mask; -	gDirUtilp->deleteFilesInDir(gDirUtilp->getExpandedFilename(LL_PATH_CACHE, ""), mask); +	gDirUtilp->deleteFilesInDir(gDirUtilp->getExpandedFilename(LL_PATH_CACHE, ""), file_mask);  }  void LLAppViewer::writeSystemInfo() @@ -3900,8 +3907,7 @@ void LLAppViewer::purgeCache()  	LL_INFOS("AppCache") << "Purging Cache and Texture Cache..." << LL_ENDL;  	LLAppViewer::getTextureCache()->purgeCache(LL_PATH_CACHE);  	LLVOCache::getInstance()->removeCache(LL_PATH_CACHE); -	std::string mask = "*.*"; -	gDirUtilp->deleteFilesInDir(gDirUtilp->getExpandedFilename(LL_PATH_CACHE, ""), mask); +	gDirUtilp->deleteFilesInDir(gDirUtilp->getExpandedFilename(LL_PATH_CACHE, ""), "*.*");  }  std::string LLAppViewer::getSecondLifeTitle() const diff --git a/indra/newview/llavataractions.cpp b/indra/newview/llavataractions.cpp index f618af9536..fdd4565e50 100755 --- a/indra/newview/llavataractions.cpp +++ b/indra/newview/llavataractions.cpp @@ -594,7 +594,7 @@ namespace action_give_inventory  		}  		S32 count = LLShareInfo::instance().mAvatarNames.size(); -		bool shared = false; +		bool shared = count && !inventory_selected_uuids.empty();  		// iterate through avatars  		for(S32 i = 0; i < count; ++i) @@ -616,8 +616,10 @@ namespace action_give_inventory  				LLViewerInventoryCategory* inv_cat = gInventory.getCategory(*it);  				if (inv_cat)  				{ -					LLGiveInventory::doGiveInventoryCategory(avatar_uuid, inv_cat, session_id); -					shared = true; +					if (!LLGiveInventory::doGiveInventoryCategory(avatar_uuid, inv_cat, session_id, "ItemsShared")) +					{ +						shared = false; +					}  					break;  				}  				LLViewerInventoryItem* inv_item = gInventory.getItem(*it); @@ -632,8 +634,10 @@ namespace action_give_inventory  				}  				else  				{ -				LLGiveInventory::doGiveInventoryItem(avatar_uuid, inv_item, session_id); -					shared = true; +					if (!LLGiveInventory::doGiveInventoryItem(avatar_uuid, inv_item, session_id)) +					{ +						shared = false; +					}  				}  			}  			if (noncopy_items.beginArray() != noncopy_items.endArray()) @@ -643,8 +647,10 @@ namespace action_give_inventory  				LLSD payload;  				payload["agent_id"] = avatar_uuid;  				payload["items"] = noncopy_items; +				payload["success_notification"] = "ItemsShared";  				LLNotificationsUtil::add("CannotCopyWarning", substitutions, payload,  					&LLGiveInventory::handleCopyProtectedItem); +				shared = false;  				break;  			}  		} diff --git a/indra/newview/lldrawpoolbump.cpp b/indra/newview/lldrawpoolbump.cpp index b58efe62ab..6f71e6ebc8 100644 --- a/indra/newview/lldrawpoolbump.cpp +++ b/indra/newview/lldrawpoolbump.cpp @@ -1341,8 +1341,7 @@ void LLBumpImageList::onSourceLoaded( BOOL success, LLViewerTexture *src_vi, LLI  			// immediately assign bump to a global smart pointer in case some local smart pointer  			// accidentally releases it.  			LLPointer<LLViewerTexture> bump = LLViewerTextureManager::getLocalTexture( TRUE ); -			 -			 +  			if (!LLPipeline::sRenderDeferred)  			{  				LLFastTimer t(FTM_BUMP_SOURCE_CREATE); @@ -1351,6 +1350,10 @@ void LLBumpImageList::onSourceLoaded( BOOL success, LLViewerTexture *src_vi, LLI  			}  			else   			{ //convert to normal map +				 +				//disable compression on normal maps to prevent errors below +				bump->getGLTexture()->setAllowCompression(false); +  				{  					LLFastTimer t(FTM_BUMP_SOURCE_CREATE);  					bump->setExplicitFormat(GL_RGBA8, GL_ALPHA); diff --git a/indra/newview/llfeaturemanager.cpp b/indra/newview/llfeaturemanager.cpp index 08f9d26705..ec2493dd2e 100644 --- a/indra/newview/llfeaturemanager.cpp +++ b/indra/newview/llfeaturemanager.cpp @@ -670,7 +670,14 @@ void LLFeatureManager::setGraphicsLevel(S32 level, bool skipFeatures)  	switch (level)  	{  		case 0: -			maskFeatures("Low");			 +			if (gGLManager.mGLVersion < 3.f || gGLManager.mIsIntel) +			{ //only use fixed function by default if GL version < 3.0 or this is an intel graphics chip +				maskFeatures("LowFixedFunction");			 +			} +			else +			{ //same as low, but with "Basic Shaders" enabled +				maskFeatures("Low"); +			}  			break;  		case 1:  			maskFeatures("Mid"); @@ -779,6 +786,10 @@ void LLFeatureManager::applyBaseMasks()  	{  		maskFeatures("MapBufferRange");  	} +	if (gGLManager.mVRAM > 512) +	{ +		maskFeatures("VRAMGT512"); +	}  	// now mask by gpu string  	// Replaces ' ' with '_' in mGPUString to deal with inability for parser to handle spaces diff --git a/indra/newview/llfloaterbvhpreview.cpp b/indra/newview/llfloaterbvhpreview.cpp index b050a638dc..ac33a05f42 100644 --- a/indra/newview/llfloaterbvhpreview.cpp +++ b/indra/newview/llfloaterbvhpreview.cpp @@ -416,6 +416,9 @@ void LLFloaterBvhPreview::draw()  //-----------------------------------------------------------------------------  void LLFloaterBvhPreview::resetMotion()  { +	if (!mAnimPreview) +		return; +  	LLVOAvatar* avatarp = mAnimPreview->getDummyAvatar();  	BOOL paused = avatarp->areAnimationsPaused(); @@ -535,6 +538,9 @@ BOOL LLFloaterBvhPreview::handleHover(S32 x, S32 y, MASK mask)  //-----------------------------------------------------------------------------  BOOL LLFloaterBvhPreview::handleScrollWheel(S32 x, S32 y, S32 clicks)  { +	if (!mAnimPreview) +		return false; +  	mAnimPreview->zoom((F32)clicks * -0.2f);  	mAnimPreview->requestUpdate(); @@ -670,7 +676,7 @@ void LLFloaterBvhPreview::onCommitBaseAnim()  //-----------------------------------------------------------------------------  void LLFloaterBvhPreview::onCommitLoop()  { -	if (!getEnabled()) +	if (!getEnabled() || !mAnimPreview)  		return;  	LLVOAvatar* avatarp = mAnimPreview->getDummyAvatar(); @@ -689,7 +695,7 @@ void LLFloaterBvhPreview::onCommitLoop()  //-----------------------------------------------------------------------------  void LLFloaterBvhPreview::onCommitLoopIn()  { -	if (!getEnabled()) +	if (!getEnabled() || !mAnimPreview)  		return;  	LLVOAvatar* avatarp = mAnimPreview->getDummyAvatar(); @@ -709,7 +715,7 @@ void LLFloaterBvhPreview::onCommitLoopIn()  //-----------------------------------------------------------------------------  void LLFloaterBvhPreview::onCommitLoopOut()  { -	if (!getEnabled()) +	if (!getEnabled() || !mAnimPreview)  		return;  	LLVOAvatar* avatarp = mAnimPreview->getDummyAvatar(); @@ -729,7 +735,7 @@ void LLFloaterBvhPreview::onCommitLoopOut()  //-----------------------------------------------------------------------------  void LLFloaterBvhPreview::onCommitName()  { -	if (!getEnabled()) +	if (!getEnabled() || !mAnimPreview)  		return;  	LLVOAvatar* avatarp = mAnimPreview->getDummyAvatar(); @@ -770,7 +776,7 @@ void LLFloaterBvhPreview::onCommitEmote()  //-----------------------------------------------------------------------------  void LLFloaterBvhPreview::onCommitPriority()  { -	if (!getEnabled()) +	if (!getEnabled() || !mAnimPreview)  		return;  	LLVOAvatar* avatarp = mAnimPreview->getDummyAvatar(); @@ -784,7 +790,7 @@ void LLFloaterBvhPreview::onCommitPriority()  //-----------------------------------------------------------------------------  void LLFloaterBvhPreview::onCommitEaseIn()  { -	if (!getEnabled()) +	if (!getEnabled() || !mAnimPreview)  		return;  	LLVOAvatar* avatarp = mAnimPreview->getDummyAvatar(); @@ -799,7 +805,7 @@ void LLFloaterBvhPreview::onCommitEaseIn()  //-----------------------------------------------------------------------------  void LLFloaterBvhPreview::onCommitEaseOut()  { -	if (!getEnabled()) +	if (!getEnabled() || !mAnimPreview)  		return;  	LLVOAvatar* avatarp = mAnimPreview->getDummyAvatar(); @@ -814,7 +820,7 @@ void LLFloaterBvhPreview::onCommitEaseOut()  //-----------------------------------------------------------------------------  bool LLFloaterBvhPreview::validateEaseIn(const LLSD& data)  { -	if (!getEnabled()) +	if (!getEnabled() || !mAnimPreview)  		return false;  	LLVOAvatar* avatarp = mAnimPreview->getDummyAvatar(); @@ -834,7 +840,7 @@ bool LLFloaterBvhPreview::validateEaseIn(const LLSD& data)  //-----------------------------------------------------------------------------  bool LLFloaterBvhPreview::validateEaseOut(const LLSD& data)  { -	if (!getEnabled()) +	if (!getEnabled() || !mAnimPreview)  		return false;  	LLVOAvatar* avatarp = mAnimPreview->getDummyAvatar(); diff --git a/indra/newview/llfloaterhardwaresettings.cpp b/indra/newview/llfloaterhardwaresettings.cpp index f9a403cf9f..116bd241c4 100644 --- a/indra/newview/llfloaterhardwaresettings.cpp +++ b/indra/newview/llfloaterhardwaresettings.cpp @@ -37,6 +37,7 @@  #include "llspinctrl.h"  #include "llstartup.h"  #include "lltextbox.h" +#include "llcombobox.h"  #include "pipeline.h"  // Linden library includes @@ -99,6 +100,12 @@ void LLFloaterHardwareSettings::refreshEnabledState()  		getChildView("vbo")->setEnabled(FALSE);  	} +	if (!LLFeatureManager::getInstance()->isFeatureAvailable("RenderCompressTextures") || +		!gGLManager.mHasVertexBufferObject) +	{ +		getChildView("texture compression")->setEnabled(FALSE); +	} +  	// if no windlight shaders, turn off nighttime brightness, gamma, and fog distance  	LLSpinCtrl* gamma_ctrl = getChild<LLSpinCtrl>("gamma");  	gamma_ctrl->setEnabled(!gPipeline.canUseWindLightShaders()); @@ -142,6 +149,13 @@ BOOL LLFloaterHardwareSettings::postBuild()  {  	childSetAction("OK", onBtnOK, this); +	if (gGLManager.mIsIntel || gGLManager.mGLVersion < 3.f) +	{ //remove FSAA settings above "4x" +		LLComboBox* combo = getChild<LLComboBox>("fsaa"); +		combo->remove("8x"); +		combo->remove("16x"); +	} +  	refresh();  	center(); diff --git a/indra/newview/llfolderviewitem.cpp b/indra/newview/llfolderviewitem.cpp index d2b4866987..515e544452 100644 --- a/indra/newview/llfolderviewitem.cpp +++ b/indra/newview/llfolderviewitem.cpp @@ -2183,14 +2183,8 @@ BOOL LLFolderViewFolder::addItem(LLFolderViewItem* item)  	item->dirtyFilter(); -	// Update the folder creation date if the folder has no creation date -	bool setting_date = false; -	const time_t item_creation_date = item->getCreationDate(); -	if ((item_creation_date > 0) && (mCreationDate == 0)) -	{ -		setCreationDate(item_creation_date); -		setting_date = true; -	} +	// Update the folder creation date if the child is newer than our current date +	setCreationDate(llmax<time_t>(mCreationDate, item->getCreationDate()));  	// Handle sorting  	requestArrange(); @@ -2200,11 +2194,8 @@ BOOL LLFolderViewFolder::addItem(LLFolderViewItem* item)  	LLFolderViewFolder* parentp = getParentFolder();  	while (parentp)  	{ -		// Update the parent folder creation date -		if (setting_date && (parentp->mCreationDate == 0)) -		{ -			parentp->setCreationDate(item_creation_date); -		} +		// Update the folder creation date if the child is newer than our current date +		parentp->setCreationDate(llmax<time_t>(parentp->mCreationDate, item->getCreationDate()));  		if (parentp->mSortFunction.isByDate())  		{ diff --git a/indra/newview/llgiveinventory.cpp b/indra/newview/llgiveinventory.cpp index 30858871ec..72bea8db10 100644 --- a/indra/newview/llgiveinventory.cpp +++ b/indra/newview/llgiveinventory.cpp @@ -220,17 +220,25 @@ bool LLGiveInventory::doGiveInventoryItem(const LLUUID& to_agent,  	return res;  } -void LLGiveInventory::doGiveInventoryCategory(const LLUUID& to_agent, +bool LLGiveInventory::doGiveInventoryCategory(const LLUUID& to_agent,  											  const LLInventoryCategory* cat, -											  const LLUUID& im_session_id) +											  const LLUUID& im_session_id, +											  const std::string& notification_name)  { -	if (!cat) return; +	if (!cat) +	{ +		return false; +	}  	llinfos << "LLGiveInventory::giveInventoryCategory() - "  		<< cat->getUUID() << llendl; -	if (!isAgentAvatarValid()) return; +	if (!isAgentAvatarValid()) +	{ +		return false; +	} +	bool give_successful = true;  	// Test out how many items are being given.  	LLViewerInventoryCategory::cat_array_t cats;  	LLViewerInventoryItem::item_array_t items; @@ -253,24 +261,24 @@ void LLGiveInventory::doGiveInventoryCategory(const LLUUID& to_agent,  	if (!complete)  	{  		LLNotificationsUtil::add("IncompleteInventory"); -		return; +		give_successful = false;  	}  	count = items.count() + cats.count();  	if (count > MAX_ITEMS)  	{  		LLNotificationsUtil::add("TooManyItems"); -		return; +		give_successful = false;  	}  	else if (count == 0)  	{  		LLNotificationsUtil::add("NoItems"); -		return; +		give_successful = false;  	} -	else +	else if (give_successful)  	{  		if (0 == giveable.countNoCopy())  		{ -			LLGiveInventory::commitGiveInventoryCategory(to_agent, cat, im_session_id); +			give_successful = LLGiveInventory::commitGiveInventoryCategory(to_agent, cat, im_session_id);  		}  		else  		{ @@ -279,9 +287,16 @@ void LLGiveInventory::doGiveInventoryCategory(const LLUUID& to_agent,  			LLSD payload;  			payload["agent_id"] = to_agent;  			payload["folder_id"] = cat->getUUID(); +			if (!notification_name.empty()) +			{ +				payload["success_notification"] = notification_name; +			}  			LLNotificationsUtil::add("CannotCopyCountItems", args, payload, &LLGiveInventory::handleCopyProtectedCategory); +			give_successful = false;  		}  	} + +	return give_successful;  }  ////////////////////////////////////////////////////////////////////////// @@ -325,6 +340,7 @@ bool LLGiveInventory::handleCopyProtectedItem(const LLSD& notification, const LL  	S32 option = LLNotificationsUtil::getSelectedOption(notification, response);  	LLSD itmes = notification["payload"]["items"];  	LLInventoryItem* item = NULL; +	bool give_successful = true;  	switch(option)  	{  	case 0:  // "Yes" @@ -343,15 +359,21 @@ bool LLGiveInventory::handleCopyProtectedItem(const LLSD& notification, const LL  			else  			{  				LLNotificationsUtil::add("CannotGiveItem"); +				give_successful = false;  			}  		} +		if (give_successful && notification["payload"]["success_notification"].isDefined()) +		{ +			LLNotificationsUtil::add(notification["payload"]["success_notification"].asString()); +		}  		break;  	default: // no, cancel, whatever, who cares, not yes.  		LLNotificationsUtil::add("TransactionCancelled"); +		give_successful = false;  		break;  	} -	return false; +	return give_successful;  }  // static @@ -408,13 +430,14 @@ bool LLGiveInventory::handleCopyProtectedCategory(const LLSD& notification, cons  {  	S32 option = LLNotificationsUtil::getSelectedOption(notification, response);  	LLInventoryCategory* cat = NULL; +	bool give_successful = true;  	switch(option)  	{  	case 0:  // "Yes"  		cat = gInventory.getCategory(notification["payload"]["folder_id"].asUUID());  		if (cat)  		{ -			LLGiveInventory::commitGiveInventoryCategory(notification["payload"]["agent_id"].asUUID(), +			give_successful = LLGiveInventory::commitGiveInventoryCategory(notification["payload"]["agent_id"].asUUID(),  				cat);  			LLViewerInventoryCategory::cat_array_t cats;  			LLViewerInventoryItem::item_array_t items; @@ -430,27 +453,37 @@ bool LLGiveInventory::handleCopyProtectedCategory(const LLSD& notification, cons  				gInventory.deleteObject(items.get(i)->getUUID());  			}  			gInventory.notifyObservers(); + +			if (give_successful && notification["payload"]["success_notification"].isDefined()) +			{ +				LLNotificationsUtil::add(notification["payload"]["success_notification"].asString()); +			}  		}  		else  		{  			LLNotificationsUtil::add("CannotGiveCategory"); +			give_successful = false;  		}  		break;  	default: // no, cancel, whatever, who cares, not yes.  		LLNotificationsUtil::add("TransactionCancelled"); +		give_successful = false;  		break;  	} -	return false; +	return give_successful;  }  // static -void LLGiveInventory::commitGiveInventoryCategory(const LLUUID& to_agent, +bool LLGiveInventory::commitGiveInventoryCategory(const LLUUID& to_agent,  													const LLInventoryCategory* cat,  													const LLUUID& im_session_id)  { -	if (!cat) return; +	if (!cat) +	{ +		return false; +	}  	llinfos << "LLGiveInventory::commitGiveInventoryCategory() - "  		<< cat->getUUID() << llendl; @@ -467,6 +500,7 @@ void LLGiveInventory::commitGiveInventoryCategory(const LLUUID& to_agent,  		LLInventoryModel::EXCLUDE_TRASH,  		giveable); +	bool give_successful = true;  	// MAX ITEMS is based on (sizeof(uuid)+2) * count must be <  	// MTUBYTES or 18 * count < 1200 => count < 1200/18 =>  	// 66. I've cut it down a bit from there to give some pad. @@ -474,12 +508,12 @@ void LLGiveInventory::commitGiveInventoryCategory(const LLUUID& to_agent,  	if (count > MAX_ITEMS)  	{  		LLNotificationsUtil::add("TooManyItems"); -		return; +		give_successful = false;  	}  	else if (count == 0)  	{  		LLNotificationsUtil::add("NoItems"); -		return; +		give_successful = false;  	}  	else  	{ @@ -545,6 +579,8 @@ void LLGiveInventory::commitGiveInventoryCategory(const LLUUID& to_agent,  		logInventoryOffer(to_agent, im_session_id);  	} + +	return give_successful;  }  // EOF diff --git a/indra/newview/llgiveinventory.h b/indra/newview/llgiveinventory.h index e1e221c75b..85bc1ed49c 100644 --- a/indra/newview/llgiveinventory.h +++ b/indra/newview/llgiveinventory.h @@ -62,9 +62,10 @@ public:  	/**  	 * Gives passed inventory category to specified avatar in specified session.  	 */ -	static void doGiveInventoryCategory(const LLUUID& to_agent, +	static bool doGiveInventoryCategory(const LLUUID& to_agent,  									const LLInventoryCategory* item, -									const LLUUID &session_id = LLUUID::null); +									const LLUUID &session_id = LLUUID::null, +									const std::string& notification = std::string());  	// give inventory item functionality  	static bool handleCopyProtectedItem(const LLSD& notification, const LLSD& response); @@ -85,7 +86,7 @@ private:  	// give inventory category functionality  	static bool handleCopyProtectedCategory(const LLSD& notification, const LLSD& response); -	static void commitGiveInventoryCategory(const LLUUID& to_agent, +	static bool commitGiveInventoryCategory(const LLUUID& to_agent,  									const LLInventoryCategory* cat,  									const LLUUID &im_session_id = LLUUID::null); diff --git a/indra/newview/llimfloatercontainer.cpp b/indra/newview/llimfloatercontainer.cpp index c8e48b0d42..0f0ae896a2 100644 --- a/indra/newview/llimfloatercontainer.cpp +++ b/indra/newview/llimfloatercontainer.cpp @@ -119,6 +119,7 @@ void LLIMFloaterContainer::addFloater(LLFloater* floaterp,  void LLIMFloaterContainer::onCloseFloater(LLUUID& id)  {  	mSessions.erase(id); +	setFocus(TRUE);  }  void LLIMFloaterContainer::onNewMessageReceived(const LLSD& data) diff --git a/indra/newview/llimview.cpp b/indra/newview/llimview.cpp index a7c4618fa4..4000570872 100644 --- a/indra/newview/llimview.cpp +++ b/indra/newview/llimview.cpp @@ -3237,7 +3237,6 @@ public:  			//just like a normal IM  			//this is just replicated code from process_improved_im  			//and should really go in it's own function -jwolk -			LLChat chat;  			std::string message = message_params["message"].asString();  			std::string name = message_params["from_name"].asString(); @@ -3255,14 +3254,7 @@ public:  				name,  				LLMute::flagTextChat); -			BOOL is_linden = LLMuteList::getInstance()->isLinden(name); -			std::string separator_string(": "); -			 -			chat.mMuted = is_muted && !is_linden; -			chat.mFromID = from_id; -			chat.mFromName = name; - -			if (!is_linden && is_busy) +			if (is_busy || is_muted)  			{  				return;  			} diff --git a/indra/newview/llinspectobject.cpp b/indra/newview/llinspectobject.cpp index acc139c569..a7b93b8030 100644 --- a/indra/newview/llinspectobject.cpp +++ b/indra/newview/llinspectobject.cpp @@ -111,6 +111,7 @@ private:  private:  	LLUUID				mObjectID; +	LLUUID				mPreviousObjectID;  	S32					mObjectFace;  	viewer_media_t		mMediaImpl;  	LLMediaEntry*       mMediaEntry; @@ -249,6 +250,7 @@ void LLInspectObject::onClose(bool app_quitting)  {  	// Release selection to deselect  	mObjectSelection = NULL; +	mPreviousObjectID = mObjectID;  	getChild<LLMenuButton>("gear_btn")->hideMenu();  } @@ -266,6 +268,13 @@ void LLInspectObject::update()  	LLSelectNode* nodep = selection->getFirstRootNode();  	if (!nodep) return; +	// If we don't have fresh object info yet and it's the object we inspected last time, +	// keep showing the previously retrieved data until we get the update. +	if (!nodep->mValid && nodep->getObject()->getID() == mPreviousObjectID) +	{ +		return; +	} +  	updateButtons(nodep);  	updateName(nodep);  	updateDescription(nodep); diff --git a/indra/newview/llinventoryfilter.cpp b/indra/newview/llinventoryfilter.cpp index 4d0af94f9f..4573074c73 100644 --- a/indra/newview/llinventoryfilter.cpp +++ b/indra/newview/llinventoryfilter.cpp @@ -654,7 +654,7 @@ void LLInventoryFilter::setHoursAgo(U32 hours)  		bool are_date_limits_valid = mFilterOps.mMinDate == time_min() && mFilterOps.mMaxDate == time_max();  		bool is_increasing = hours > mFilterOps.mHoursAgo; -		bool is_increasing_from_zero = is_increasing && !mFilterOps.mHoursAgo; +		bool is_increasing_from_zero = is_increasing && !mFilterOps.mHoursAgo && !isSinceLogoff();  		// *NOTE: need to cache last filter time, in case filter goes stale  		BOOL less_restrictive = (are_date_limits_valid && ((is_increasing && mFilterOps.mHoursAgo)) || !hours); diff --git a/indra/newview/llinventorymodel.cpp b/indra/newview/llinventorymodel.cpp index 8092f3bf36..8092f3bf36 100755..100644 --- a/indra/newview/llinventorymodel.cpp +++ b/indra/newview/llinventorymodel.cpp diff --git a/indra/newview/llmeshrepository.cpp b/indra/newview/llmeshrepository.cpp index f461c7e46f..c899e8991e 100755 --- a/indra/newview/llmeshrepository.cpp +++ b/indra/newview/llmeshrepository.cpp @@ -1620,7 +1620,7 @@ void LLMeshUploadThread::doWholeModelUpload()  			mCurlRequest->process();  			//sleep for 10ms to prevent eating a whole core  			apr_sleep(10000); -		} while (mCurlRequest->getQueued() > 0); +		} while (!LLAppViewer::isQuitting() && mCurlRequest->getQueued() > 0);  	}  	delete mCurlRequest; diff --git a/indra/newview/llnavigationbar.cpp b/indra/newview/llnavigationbar.cpp index 2a08cb1845..95caa2731a 100644 --- a/indra/newview/llnavigationbar.cpp +++ b/indra/newview/llnavigationbar.cpp @@ -267,7 +267,6 @@ LLNavigationBar::LLNavigationBar()  	mBtnForward(NULL),  	mBtnHome(NULL),  	mCmbLocation(NULL), -	mPurgeTPHistoryItems(false),  	mSaveToLocationHistory(false)  {  	buildFromFile( "panel_navigation_bar.xml"); @@ -338,12 +337,6 @@ void LLNavigationBar::setVisible(BOOL visible)  void LLNavigationBar::draw()  { -	if(mPurgeTPHistoryItems) -	{ -		LLTeleportHistory::getInstance()->purgeItems(); -		mPurgeTPHistoryItems = false; -	} -  	if (isBackgroundVisible())  	{  		static LLUICachedControl<S32> drop_shadow_floater ("DropShadowFloater", 0); @@ -687,7 +680,7 @@ void LLNavigationBar::clearHistoryCache()  	LLLocationHistory* lh = LLLocationHistory::getInstance();  	lh->removeItems();  	lh->save();	 -	mPurgeTPHistoryItems= true; +	LLTeleportHistory::getInstance()->purgeItems();  }  int LLNavigationBar::getDefNavBarHeight() diff --git a/indra/newview/llnavigationbar.h b/indra/newview/llnavigationbar.h index e4ce9e3998..7878bab24e 100644 --- a/indra/newview/llnavigationbar.h +++ b/indra/newview/llnavigationbar.h @@ -145,7 +145,6 @@ private:  	boost::signals2::connection	mTeleportFailedConnection;  	boost::signals2::connection	mTeleportFinishConnection;  	boost::signals2::connection	mHistoryMenuConnection; -	bool						mPurgeTPHistoryItems;  	// if true, save location to location history when teleport finishes  	bool						mSaveToLocationHistory;  }; diff --git a/indra/newview/llnearbychatbar.cpp b/indra/newview/llnearbychatbar.cpp index c71ea48193..00ff81724c 100644 --- a/indra/newview/llnearbychatbar.cpp +++ b/indra/newview/llnearbychatbar.cpp @@ -105,15 +105,17 @@ BOOL LLNearbyChatBar::postBuild()  	mNearbyChat = getChildView("nearby_chat"); -	LLUICtrl* show_btn = getChild<LLUICtrl>("show_nearby_chat"); +	gSavedSettings.declareBOOL("nearbychat_history_visibility", mNearbyChat->getVisible(), "Visibility state of nearby chat history", TRUE); +	BOOL show_nearby_chat = gSavedSettings.getBOOL("nearbychat_history_visibility"); + +	LLButton* show_btn = getChild<LLButton>("show_nearby_chat");  	show_btn->setCommitCallback(boost::bind(&LLNearbyChatBar::onToggleNearbyChatPanel, this)); +	show_btn->setToggleState(show_nearby_chat);  	mOutputMonitor = getChild<LLOutputMonitorCtrl>("chat_zone_indicator");  	mOutputMonitor->setVisible(FALSE); -	gSavedSettings.declareBOOL("nearbychat_history_visibility", mNearbyChat->getVisible(), "Visibility state of nearby chat history", TRUE); - -	mNearbyChat->setVisible(gSavedSettings.getBOOL("nearbychat_history_visibility")); +	showNearbyChatPanel(show_nearby_chat);  	// Register for font change notifications  	LLViewerChat::setFontChangedCallback(boost::bind(&LLNearbyChatBar::onChatFontChange, this, _1)); @@ -394,26 +396,23 @@ void LLNearbyChatBar::sendChat( EChatType type )  	}  } - -void LLNearbyChatBar::onToggleNearbyChatPanel() +void LLNearbyChatBar::showNearbyChatPanel(bool show)  { -	LLView* nearby_chat = getChildView("nearby_chat"); - -	if (nearby_chat->getVisible()) +	if (!show)  	{ -		if (!isMinimized()) +		if (mNearbyChat->getVisible() && !isMinimized())  		{  			mExpandedHeight = getRect().getHeight();  		}  		setResizeLimits(getMinWidth(), COLLAPSED_HEIGHT); -		nearby_chat->setVisible(FALSE); +		mNearbyChat->setVisible(FALSE);  		reshape(getRect().getWidth(), COLLAPSED_HEIGHT);  		enableResizeCtrls(true, true, false);  		storeRectControl();  	}  	else  	{ -		nearby_chat->setVisible(TRUE); +		mNearbyChat->setVisible(TRUE);  		setResizeLimits(getMinWidth(), EXPANDED_MIN_HEIGHT);  		reshape(getRect().getWidth(), mExpandedHeight);  		enableResizeCtrls(true); @@ -423,6 +422,11 @@ void LLNearbyChatBar::onToggleNearbyChatPanel()  	gSavedSettings.setBOOL("nearbychat_history_visibility", mNearbyChat->getVisible());  } +void LLNearbyChatBar::onToggleNearbyChatPanel() +{ +	showNearbyChatPanel(!mNearbyChat->getVisible()); +} +  void LLNearbyChatBar::setMinimized(BOOL b)  {  	LLNearbyChat* nearby_chat = getChild<LLNearbyChat>("nearby_chat"); diff --git a/indra/newview/llnearbychatbar.h b/indra/newview/llnearbychatbar.h index aa9c3a6a98..662496d338 100644 --- a/indra/newview/llnearbychatbar.h +++ b/indra/newview/llnearbychatbar.h @@ -39,6 +39,8 @@ class LLNearbyChatBarListener;  class LLNearbyChatBar :	public LLFloater  { +	LOG_CLASS(LLNearbyChatBar); +  public:  	// constructor for inline chat-bars (e.g. hosted in chat history window)  	LLNearbyChatBar(const LLSD& key); @@ -78,6 +80,7 @@ protected:  	/* virtual */ bool applyRectControl(); +	void showNearbyChatPanel(bool show);  	void onToggleNearbyChatPanel();  	static LLWString stripChannelNumber(const LLWString &mesg, S32* channel); diff --git a/indra/newview/llprogressview.cpp b/indra/newview/llprogressview.cpp index 5d7a5b1c59..f86e583b9e 100644 --- a/indra/newview/llprogressview.cpp +++ b/indra/newview/llprogressview.cpp @@ -40,6 +40,7 @@  #include "llagent.h"  #include "llbutton.h" +#include "llcallbacklist.h"  #include "llfocusmgr.h"  #include "llnotifications.h"  #include "llprogressbar.h" @@ -72,6 +73,8 @@ LLProgressView::LLProgressView()  	mStartupComplete(false)  {  	mUpdateEvents.listen("self", boost::bind(&LLProgressView::handleUpdate, this, _1)); +	mFadeToWorldTimer.stop(); +	mFadeFromLoginTimer.stop();  }  BOOL LLProgressView::postBuild() @@ -87,8 +90,6 @@ BOOL LLProgressView::postBuild()  	mCancelBtn = getChild<LLButton>("cancel_btn");  	mCancelBtn->setClickedCallback(  LLProgressView::onCancelButtonClicked, NULL ); -	mFadeToWorldTimer.stop(); -	mFadeFromLoginTimer.stop();  	getChild<LLTextBox>("title_text")->setText(LLStringExplicit(LLAppViewer::instance()->getSecondLifeTitle())); @@ -106,6 +107,9 @@ BOOL LLProgressView::postBuild()  LLProgressView::~LLProgressView()  { +	// Just in case something went wrong, make sure we deregister our idle callback. +	gIdleCallbacks.deleteFunction(onIdle, this); +  	gFocusMgr.releaseFocusIfNeeded( this );  	sInstance = NULL; @@ -154,6 +158,7 @@ void LLProgressView::revealIntroPanel()  	}  	mFadeFromLoginTimer.start(); +	gIdleCallbacks.addFunction(onIdle, this);  }  void LLProgressView::setStartupComplete() @@ -236,13 +241,6 @@ void LLProgressView::draw()  		}  		LLPanel::draw(); - -		if (mFadeFromLoginTimer.getElapsedTimeF32() > FADE_TO_WORLD_TIME ) -		{ -			mFadeFromLoginTimer.stop(); -			LLPanelLogin::closePanel(); -		} -  		return;  	} @@ -424,3 +422,21 @@ void LLProgressView::handleMediaEvent(LLPluginClassMedia* self, EMediaEvent even  		}  	}  } + + +// static +void LLProgressView::onIdle(void* user_data) +{ +	LLProgressView* self = (LLProgressView*) user_data; + +	// Close login panel on mFadeToWorldTimer expiration. +	if (self->mFadeFromLoginTimer.getStarted() && +		self->mFadeFromLoginTimer.getElapsedTimeF32() > FADE_TO_WORLD_TIME) +	{ +		self->mFadeFromLoginTimer.stop(); +		LLPanelLogin::closePanel(); + +		// Nothing to do anymore. +		gIdleCallbacks.deleteFunction(onIdle, user_data); +	} +} diff --git a/indra/newview/llprogressview.h b/indra/newview/llprogressview.h index fac00ad04d..813576b21d 100644 --- a/indra/newview/llprogressview.h +++ b/indra/newview/llprogressview.h @@ -41,6 +41,8 @@ class LLProgressView :  	public LLViewerMediaObserver  { +	LOG_CLASS(LLProgressView); +  public:  	LLProgressView();  	virtual ~LLProgressView(); @@ -74,10 +76,6 @@ public:  	static void onClickMessage(void*);  	bool onAlertModal(const LLSD& sd); -	// note - this is not just hiding the intro panel - it also hides the parent panel -	// and is used when the intro is finished and we want to show the world -	void removeIntroPanel(); -  protected:  	LLProgressBar* mProgressBar;  	LLMediaCtrl* mMediaCtrl; @@ -96,6 +94,7 @@ protected:  	LLEventStream mUpdateEvents;   	bool handleUpdate(const LLSD& event_data); +	static void onIdle(void* user_data);  };  #endif // LL_LLPROGRESSVIEW_H diff --git a/indra/newview/llselectmgr.cpp b/indra/newview/llselectmgr.cpp index 6111255a66..eec2c0a521 100644 --- a/indra/newview/llselectmgr.cpp +++ b/indra/newview/llselectmgr.cpp @@ -3051,11 +3051,11 @@ bool LLSelectMgr::confirmDelete(const LLSD& notification, const LLSD& response,  			// TODO: Make sure you have delete permissions on all of them.  			const LLUUID trash_id = gInventory.findCategoryUUIDForType(LLFolderType::FT_TRASH);  			// attempt to derez into the trash. -			LLDeRezInfo* info = new LLDeRezInfo(DRD_TRASH, trash_id); +			LLDeRezInfo info(DRD_TRASH, trash_id);  			LLSelectMgr::getInstance()->sendListToRegions("DeRezObject",  										  packDeRezHeader,  										  packObjectLocalID, -										  (void*)info, +										  (void*) &info,  										  SEND_ONLY_ROOTS);  			// VEFFECT: Delete Object - one effect for all deletes  			if (LLSelectMgr::getInstance()->mSelectedObjects->mSelectType != SELECT_TYPE_HUD) @@ -3745,13 +3745,15 @@ void LLSelectMgr::deselectAllIfTooFar()  void LLSelectMgr::selectionSetObjectName(const std::string& name)  { +	std::string name_copy(name); +  	// we only work correctly if 1 object is selected.  	if(mSelectedObjects->getRootObjectCount() == 1)  	{  		sendListToRegions("ObjectName",  						  packAgentAndSessionID,  						  packObjectName, -						  (void*)(new std::string(name)), +						  (void*)(&name_copy),  						  SEND_ONLY_ROOTS);  	}  	else if(mSelectedObjects->getObjectCount() == 1) @@ -3759,20 +3761,22 @@ void LLSelectMgr::selectionSetObjectName(const std::string& name)  		sendListToRegions("ObjectName",  						  packAgentAndSessionID,  						  packObjectName, -						  (void*)(new std::string(name)), +						  (void*)(&name_copy),  						  SEND_INDIVIDUALS);  	}  }  void LLSelectMgr::selectionSetObjectDescription(const std::string& desc)  { +	std::string desc_copy(desc); +  	// we only work correctly if 1 object is selected.  	if(mSelectedObjects->getRootObjectCount() == 1)  	{  		sendListToRegions("ObjectDescription",  						  packAgentAndSessionID,  						  packObjectDescription, -						  (void*)(new std::string(desc)), +						  (void*)(&desc_copy),  						  SEND_ONLY_ROOTS);  	}  	else if(mSelectedObjects->getObjectCount() == 1) @@ -3780,7 +3784,7 @@ void LLSelectMgr::selectionSetObjectDescription(const std::string& desc)  		sendListToRegions("ObjectDescription",  						  packAgentAndSessionID,  						  packObjectDescription, -						  (void*)(new std::string(desc)), +						  (void*)(&desc_copy),  						  SEND_INDIVIDUALS);  	}  } @@ -4298,15 +4302,14 @@ void LLSelectMgr::packObjectName(LLSelectNode* node, void* user_data)  		gMessageSystem->addU32Fast(_PREHASH_LocalID, node->getObject()->getLocalID());  		gMessageSystem->addStringFast(_PREHASH_Name, *name);  	} -	delete name;  }  // static  void LLSelectMgr::packObjectDescription(LLSelectNode* node, void* user_data)  {  	const std::string* desc = (const std::string*)user_data; -	if(!desc->empty()) -	{ +	if(desc) +	{	// Empty (non-null, but zero length) descriptions are OK  		gMessageSystem->nextBlockFast(_PREHASH_ObjectData);  		gMessageSystem->addU32Fast(_PREHASH_LocalID, node->getObject()->getLocalID());  		gMessageSystem->addStringFast(_PREHASH_Description, *desc); diff --git a/indra/newview/llsidepaneltaskinfo.cpp b/indra/newview/llsidepaneltaskinfo.cpp index 24cb559fd0..64b82aa0bb 100644 --- a/indra/newview/llsidepaneltaskinfo.cpp +++ b/indra/newview/llsidepaneltaskinfo.cpp @@ -94,7 +94,7 @@ BOOL LLSidepanelTaskInfo::postBuild()  	mPayBtn = getChild<LLButton>("pay_btn");  	mPayBtn->setClickedCallback(boost::bind(&LLSidepanelTaskInfo::onPayButtonClicked, this));  	mBuyBtn = getChild<LLButton>("buy_btn"); -	mBuyBtn->setClickedCallback(boost::bind(&LLSidepanelTaskInfo::onBuyButtonClicked, this)); +	mBuyBtn->setClickedCallback(boost::bind(&handle_buy));  	mDetailsBtn = getChild<LLButton>("details_btn");  	mDetailsBtn->setClickedCallback(boost::bind(&LLSidepanelTaskInfo::onDetailsButtonClicked, this)); @@ -1114,8 +1114,6 @@ void LLSidepanelTaskInfo::doClickAction(U8 click_action)  			// Set click action back to its old value  			U8 click_action = 0;  			LLSelectMgr::getInstance()->selectionGetClickAction(&click_action); -//			box->setCurrentByIndex((S32)click_action); -  			return;  		}  	} diff --git a/indra/newview/llspatialpartition.cpp b/indra/newview/llspatialpartition.cpp index b7a5eea27c..8e62b79d7f 100644 --- a/indra/newview/llspatialpartition.cpp +++ b/indra/newview/llspatialpartition.cpp @@ -1186,6 +1186,7 @@ void LLSpatialGroup::clearOcclusionState(U32 state, S32 mode)  //======================================  LLSpatialGroup::LLSpatialGroup(OctreeNode* node, LLSpatialPartition* part) : +	mObjectBoxSize(1.f),  	mState(0),  	mGeometryBytes(0),  	mSurfaceArea(0.f), diff --git a/indra/newview/llspatialpartition.h b/indra/newview/llspatialpartition.h index 6c14ecf452..1a93145cc5 100644 --- a/indra/newview/llspatialpartition.h +++ b/indra/newview/llspatialpartition.h @@ -378,6 +378,8 @@ public:  	LLVector4a mObjectBounds[2]; // bounding box (center, size) of objects in this node  	LLVector4a mViewAngle;  	LLVector4a mLastUpdateViewAngle; + +	F32 mObjectBoxSize; //cached mObjectBounds[1].getLength3()  private:  	U32                     mCurUpdatingTime ; diff --git a/indra/newview/llstartup.cpp b/indra/newview/llstartup.cpp index 6b0fc26db7..6b0fc26db7 100755..100644 --- a/indra/newview/llstartup.cpp +++ b/indra/newview/llstartup.cpp diff --git a/indra/newview/llstartup.h b/indra/newview/llstartup.h index 3754aaf966..3754aaf966 100755..100644 --- a/indra/newview/llstartup.h +++ b/indra/newview/llstartup.h diff --git a/indra/newview/lltexturefetch.cpp b/indra/newview/lltexturefetch.cpp index e2af497a7d..e2af497a7d 100755..100644 --- a/indra/newview/lltexturefetch.cpp +++ b/indra/newview/lltexturefetch.cpp diff --git a/indra/newview/lltextureview.cpp b/indra/newview/lltextureview.cpp index 425bf7ee87..425bf7ee87 100755..100644 --- a/indra/newview/lltextureview.cpp +++ b/indra/newview/lltextureview.cpp diff --git a/indra/newview/llviewerassetstats.cpp b/indra/newview/llviewerassetstats.cpp index 4c59fd0371..4c59fd0371 100755..100644 --- a/indra/newview/llviewerassetstats.cpp +++ b/indra/newview/llviewerassetstats.cpp diff --git a/indra/newview/llviewerassetstats.h b/indra/newview/llviewerassetstats.h index 8319752230..8319752230 100755..100644 --- a/indra/newview/llviewerassetstats.h +++ b/indra/newview/llviewerassetstats.h diff --git a/indra/newview/llviewerinventory.cpp b/indra/newview/llviewerinventory.cpp index b47a41c44c..b47a41c44c 100755..100644 --- a/indra/newview/llviewerinventory.cpp +++ b/indra/newview/llviewerinventory.cpp diff --git a/indra/newview/llviewerjointmesh.cpp b/indra/newview/llviewerjointmesh.cpp index f029ae5302..f029ae5302 100755..100644 --- a/indra/newview/llviewerjointmesh.cpp +++ b/indra/newview/llviewerjointmesh.cpp diff --git a/indra/newview/llviewerjointmesh.h b/indra/newview/llviewerjointmesh.h index dd5dae1dc1..dd5dae1dc1 100755..100644 --- a/indra/newview/llviewerjointmesh.h +++ b/indra/newview/llviewerjointmesh.h diff --git a/indra/newview/llviewermenu.cpp b/indra/newview/llviewermenu.cpp index 48e4813205..34e916fec0 100644 --- a/indra/newview/llviewermenu.cpp +++ b/indra/newview/llviewermenu.cpp @@ -93,6 +93,7 @@  #include "lltoolpie.h"  #include "lltoolselectland.h"  #include "lltrans.h" +#include "llviewerdisplay.h" //for gWindowResized  #include "llviewergenericmessage.h"  #include "llviewerhelp.h"  #include "llviewermenufile.h"	// init_menu_file() @@ -205,7 +206,7 @@ BOOL enable_take();  void handle_take();  void handle_object_show_inspector();  void handle_avatar_show_inspector(); -bool confirm_take(const LLSD& notification, const LLSD& response); +bool confirm_take(const LLSD& notification, const LLSD& response, LLObjectSelectionHandle selection_handle);  void handle_buy_object(LLSaleInfo sale_info);  void handle_buy_contents(LLSaleInfo sale_info); @@ -1173,6 +1174,7 @@ class LLAdvancedToggleWireframe : public view_listener_t  	bool handleEvent(const LLSD& userdata)  	{  		gUseWireframe = !(gUseWireframe); +		gWindowResized = TRUE;  		LLPipeline::updateRenderDeferred();  		gPipeline.resetVertexBuffers();  		return true; @@ -4511,7 +4513,10 @@ void handle_take()  	LLNotification::Params params("ConfirmObjectTakeLock");  	params.payload(payload); -	params.functor.function(confirm_take); +	// MAINT-290 +	// Reason: Showing the confirmation dialog resets object selection,	thus there is nothing to derez. +	// Fix: pass selection to the confirm_take, so that selection doesn't "die" after confirmation dialog is opened +	params.functor.function(boost::bind(confirm_take, _1, _2, LLSelectMgr::instance().getSelection()));  	if(locked_but_takeable_object ||  	   !you_own_everything) @@ -4564,7 +4569,7 @@ void handle_avatar_show_inspector() -bool confirm_take(const LLSD& notification, const LLSD& response) +bool confirm_take(const LLSD& notification, const LLSD& response, LLObjectSelectionHandle selection_handle)  {  	S32 option = LLNotificationsUtil::getSelectedOption(notification, response);  	if(enable_take() && (option == 0)) diff --git a/indra/newview/llviewermessage.cpp b/indra/newview/llviewermessage.cpp index ec42cb39f2..a9bff67f40 100755 --- a/indra/newview/llviewermessage.cpp +++ b/indra/newview/llviewermessage.cpp @@ -2706,7 +2706,7 @@ void process_improved_im(LLMessageSystem *msg, void **user_data)  	case IM_SESSION_SEND:  	{ -		if (!is_linden && is_busy) +		if (is_busy)  		{  			return;  		} diff --git a/indra/newview/llviewerstats.cpp b/indra/newview/llviewerstats.cpp index 497e95c5e3..497e95c5e3 100755..100644 --- a/indra/newview/llviewerstats.cpp +++ b/indra/newview/llviewerstats.cpp diff --git a/indra/newview/llviewerstats.h b/indra/newview/llviewerstats.h index 750d963f69..750d963f69 100755..100644 --- a/indra/newview/llviewerstats.h +++ b/indra/newview/llviewerstats.h diff --git a/indra/newview/llviewertexture.cpp b/indra/newview/llviewertexture.cpp index ea329f6aac..d844aeb12a 100644 --- a/indra/newview/llviewertexture.cpp +++ b/indra/newview/llviewertexture.cpp @@ -3343,10 +3343,14 @@ LLViewerMediaTexture::LLViewerMediaTexture(const LLUUID& id, BOOL usemipmaps, LL  	sMediaMap.insert(std::make_pair(id, this));  	mGLTexturep = gl_image ; +  	if(mGLTexturep.isNull())  	{  		generateGLTexture() ;  	} + +	mGLTexturep->setAllowCompression(false); +  	mGLTexturep->setNeedsAlphaAndPickMask(FALSE) ;  	mIsPlaying = FALSE ; diff --git a/indra/newview/llviewertexture.h b/indra/newview/llviewertexture.h index 41bf625225..f1105c3705 100644 --- a/indra/newview/llviewertexture.h +++ b/indra/newview/llviewertexture.h @@ -264,6 +264,9 @@ protected:  	void reorganizeVolumeList() ;  	void setTexelsPerImage();  private: +	friend class LLBumpImageList; +	friend class LLUIImageList; +  	//note: do not make this function public.  	/*virtual*/ LLImageGL* getGLTexture() const ;  	virtual void switchToCachedImage(); diff --git a/indra/newview/llviewertexturelist.cpp b/indra/newview/llviewertexturelist.cpp index 2008a884db..528e0080b7 100644 --- a/indra/newview/llviewertexturelist.cpp +++ b/indra/newview/llviewertexturelist.cpp @@ -1456,6 +1456,9 @@ LLUIImagePtr LLUIImageList::loadUIImage(LLViewerFetchedTexture* imagep, const st  	imagep->setAddressMode(LLTexUnit::TAM_CLAMP); +	//don't compress UI images +	imagep->getGLTexture()->setAllowCompression(false); +  	//all UI images are non-deletable  	imagep->setNoDelete(); diff --git a/indra/newview/llviewerwindow.cpp b/indra/newview/llviewerwindow.cpp index ecd76f5495..39e330ad66 100755 --- a/indra/newview/llviewerwindow.cpp +++ b/indra/newview/llviewerwindow.cpp @@ -534,7 +534,10 @@ public:  			} -			addText(xpos, ypos, llformat("%d MB Vertex Data (%d MB Pooled)", LLVertexBuffer::sAllocatedBytes/(1024*1024), LLVBOPool::sBytesPooled/(1024*1024))); +			addText(xpos, ypos, llformat("%d MB Index Data (%d MB Pooled, %d KIndices)", LLVertexBuffer::sAllocatedIndexBytes/(1024*1024), LLVBOPool::sIndexBytesPooled/(1024*1024), LLVertexBuffer::sIndexCount/1024)); +			ypos += y_inc; + +			addText(xpos, ypos, llformat("%d MB Vertex Data (%d MB Pooled, %d KVerts)", LLVertexBuffer::sAllocatedBytes/(1024*1024), LLVBOPool::sBytesPooled/(1024*1024), LLVertexBuffer::sVertexCount/1024));  			ypos += y_inc;  			addText(xpos, ypos, llformat("%d Vertex Buffers", LLVertexBuffer::sGLCount)); @@ -742,40 +745,41 @@ public:  		if (gSavedSettings.getBOOL("DebugShowTextureInfo"))  		{  			LLViewerObject* objectp = NULL ; -			//objectp = = gAgentCamera.getFocusObject();  			LLSelectNode* nodep = LLSelectMgr::instance().getHoverNode();  			if (nodep)  			{ -				objectp = nodep->getObject();			 +				objectp = nodep->getObject();  			} +  			if (objectp && !objectp->isDead())  			{  				S32 num_faces = objectp->mDrawable->getNumFaces() ; -				 +				std::set<LLViewerFetchedTexture*> tex_list; +  				for(S32 i = 0 ; i < num_faces; i++)  				{  					LLFace* facep = objectp->mDrawable->getFace(i) ;  					if(facep) -					{ -						//addText(xpos, ypos, llformat("ts_min: %.3f ts_max: %.3f tt_min: %.3f tt_max: %.3f", facep->mTexExtents[0].mV[0], facep->mTexExtents[1].mV[0], -						//		facep->mTexExtents[0].mV[1], facep->mTexExtents[1].mV[1])); -						//ypos += y_inc; -						 -						addText(xpos, ypos, llformat("v_size: %.3f:  p_size: %.3f", facep->getVirtualSize(), facep->getPixelArea())); -						ypos += y_inc; -						 -						//const LLTextureEntry *tep = facep->getTextureEntry(); -						//if(tep) -						//{ -						//	addText(xpos, ypos, llformat("scale_s: %.3f:  scale_t: %.3f", tep->mScaleS, tep->mScaleT)) ; -						//	ypos += y_inc; -						//} -						 -						LLViewerTexture* tex = facep->getTexture() ; +					{						 +						LLViewerFetchedTexture* tex = dynamic_cast<LLViewerFetchedTexture*>(facep->getTexture()) ;  						if(tex)  						{ -							addText(xpos, ypos, llformat("ID: %s v_size: %.3f", tex->getID().asString().c_str(), tex->getMaxVirtualSize())); +							if(tex_list.find(tex) != tex_list.end()) +							{ +								continue ; //already displayed. +							} +							tex_list.insert(tex); + +							std::string uuid_str; +							tex->getID().toString(uuid_str); +							uuid_str = uuid_str.substr(0,7); + +							addText(xpos, ypos, llformat("ID: %s v_size: %.3f", uuid_str.c_str(), tex->getMaxVirtualSize())); +							ypos += y_inc; + +							addText(xpos, ypos, llformat("discard level: %d desired level: %d Missing: %s", tex->getDiscardLevel(),  +								tex->getDesiredDiscardLevel(), tex->isMissingAsset() ? "Y" : "N"));  							ypos += y_inc;  						}  					} diff --git a/indra/newview/llvoavatar.cpp b/indra/newview/llvoavatar.cpp index eada77156e..eada77156e 100755..100644 --- a/indra/newview/llvoavatar.cpp +++ b/indra/newview/llvoavatar.cpp diff --git a/indra/newview/llvoavatar.h b/indra/newview/llvoavatar.h index 6fb56a4c0b..6fb56a4c0b 100755..100644 --- a/indra/newview/llvoavatar.h +++ b/indra/newview/llvoavatar.h diff --git a/indra/newview/llvoavatarself.cpp b/indra/newview/llvoavatarself.cpp index d2609e5587..d2609e5587 100755..100644 --- a/indra/newview/llvoavatarself.cpp +++ b/indra/newview/llvoavatarself.cpp diff --git a/indra/newview/llvoavatarself.h b/indra/newview/llvoavatarself.h index 543891ca63..543891ca63 100755..100644 --- a/indra/newview/llvoavatarself.h +++ b/indra/newview/llvoavatarself.h diff --git a/indra/newview/llvovolume.cpp b/indra/newview/llvovolume.cpp index e7c35d8220..080d1f774a 100644 --- a/indra/newview/llvovolume.cpp +++ b/indra/newview/llvovolume.cpp @@ -4123,6 +4123,9 @@ void LLVolumeGeometryManager::rebuildGeom(LLSpatialGroup* group)  	group->mGeometryBytes = 0;  	group->mSurfaceArea = 0; +	//cache object box size since it might be used for determining visibility +	group->mObjectBoxSize = group->mObjectBounds[1].getLength3().getF32(); +  	group->clearDrawMap();  	mFaceList.clear(); diff --git a/indra/newview/llworld.cpp b/indra/newview/llworld.cpp index 3d971e738e..b061c90d98 100644 --- a/indra/newview/llworld.cpp +++ b/indra/newview/llworld.cpp @@ -839,7 +839,6 @@ void LLWorld::updateWaterObjects()  	// Now, get a list of the holes  	S32 x, y; -	F32 water_height = gAgent.getRegion()->getWaterHeight() + 256.f;  	for (x = min_x; x <= max_x; x += rwidth)  	{  		for (y = min_y; y <= max_y; y += rwidth) @@ -851,7 +850,7 @@ void LLWorld::updateWaterObjects()  				waterp->setUseTexture(FALSE);  				waterp->setPositionGlobal(LLVector3d(x + rwidth/2,  													 y + rwidth/2, -													 water_height)); +													 256.f+DEFAULT_WATER_HEIGHT));  				waterp->setScale(LLVector3((F32)rwidth, (F32)rwidth, 512.f));  				gPipeline.createObject(waterp);  				mHoleWaterObjects.push_back(waterp); @@ -908,7 +907,7 @@ void LLWorld::updateWaterObjects()  		}  		waterp->setRegion(gAgent.getRegion()); -		LLVector3d water_pos(water_center_x, water_center_y, water_height) ; +		LLVector3d water_pos(water_center_x, water_center_y, 256.f+DEFAULT_WATER_HEIGHT) ;  		LLVector3 water_scale((F32) dim[0], (F32) dim[1], 512.f);  		//stretch out to horizon diff --git a/indra/newview/pipeline.cpp b/indra/newview/pipeline.cpp index dbcc7fba9f..ed636a40b2 100644 --- a/indra/newview/pipeline.cpp +++ b/indra/newview/pipeline.cpp @@ -187,6 +187,7 @@ F32 LLPipeline::RenderShadowFOVCutoff;  BOOL LLPipeline::CameraOffset;  F32 LLPipeline::CameraMaxCoF;  F32 LLPipeline::CameraDoFResScale; +F32 LLPipeline::RenderAutoHideSurfaceAreaLimit;  const F32 BACKLIGHT_DAY_MAGNITUDE_AVATAR = 0.2f;  const F32 BACKLIGHT_NIGHT_MAGNITUDE_AVATAR = 0.1f; @@ -592,6 +593,7 @@ void LLPipeline::init()  	gSavedSettings.getControl("CameraOffset")->getCommitSignal()->connect(boost::bind(&LLPipeline::refreshCachedSettings));  	gSavedSettings.getControl("CameraMaxCoF")->getCommitSignal()->connect(boost::bind(&LLPipeline::refreshCachedSettings));  	gSavedSettings.getControl("CameraDoFResScale")->getCommitSignal()->connect(boost::bind(&LLPipeline::refreshCachedSettings)); +	gSavedSettings.getControl("RenderAutoHideSurfaceAreaLimit")->getCommitSignal()->connect(boost::bind(&LLPipeline::refreshCachedSettings));  }  LLPipeline::~LLPipeline() @@ -1017,6 +1019,7 @@ void LLPipeline::refreshCachedSettings()  	CameraOffset = gSavedSettings.getBOOL("CameraOffset");  	CameraMaxCoF = gSavedSettings.getF32("CameraMaxCoF");  	CameraDoFResScale = gSavedSettings.getF32("CameraDoFResScale"); +	RenderAutoHideSurfaceAreaLimit = gSavedSettings.getF32("RenderAutoHideSurfaceAreaLimit");  	updateRenderDeferred();  } @@ -1138,7 +1141,7 @@ void LLPipeline::createGLBuffers()  			LLImageGL::generateTextures(1, &mNoiseMap);  			gGL.getTexUnit(0)->bindManual(LLTexUnit::TT_TEXTURE, mNoiseMap); -			LLImageGL::setManualImage(LLTexUnit::getInternalType(LLTexUnit::TT_TEXTURE), 0, GL_RGB16F_ARB, noiseRes, noiseRes, GL_RGB, GL_FLOAT, noise); +			LLImageGL::setManualImage(LLTexUnit::getInternalType(LLTexUnit::TT_TEXTURE), 0, GL_RGB16F_ARB, noiseRes, noiseRes, GL_RGB, GL_FLOAT, noise, false);  			gGL.getTexUnit(0)->setTextureFilteringOption(LLTexUnit::TFO_POINT);  		} @@ -1153,7 +1156,7 @@ void LLPipeline::createGLBuffers()  			LLImageGL::generateTextures(1, &mTrueNoiseMap);  			gGL.getTexUnit(0)->bindManual(LLTexUnit::TT_TEXTURE, mTrueNoiseMap); -			LLImageGL::setManualImage(LLTexUnit::getInternalType(LLTexUnit::TT_TEXTURE), 0, GL_RGB16F_ARB, noiseRes, noiseRes, GL_RGB,GL_FLOAT, noise); +			LLImageGL::setManualImage(LLTexUnit::getInternalType(LLTexUnit::TT_TEXTURE), 0, GL_RGB16F_ARB, noiseRes, noiseRes, GL_RGB,GL_FLOAT, noise, false);  			gGL.getTexUnit(0)->setTextureFilteringOption(LLTexUnit::TFO_POINT);  		} @@ -1209,7 +1212,7 @@ void LLPipeline::createLUTBuffers()  			LLImageGL::generateTextures(1, &mLightFunc);  			gGL.getTexUnit(0)->bindManual(LLTexUnit::TT_TEXTURE, mLightFunc); -			LLImageGL::setManualImage(LLTexUnit::getInternalType(LLTexUnit::TT_TEXTURE), 0, GL_R8, lightResX, lightResY, GL_RED, GL_UNSIGNED_BYTE, ls); +			LLImageGL::setManualImage(LLTexUnit::getInternalType(LLTexUnit::TT_TEXTURE), 0, GL_R8, lightResX, lightResY, GL_RED, GL_UNSIGNED_BYTE, ls, false);  			gGL.getTexUnit(0)->setTextureAddressMode(LLTexUnit::TAM_CLAMP);  			gGL.getTexUnit(0)->setTextureFilteringOption(LLTexUnit::TFO_TRILINEAR); @@ -3367,7 +3370,9 @@ void LLPipeline::postSort(LLCamera& camera)  	{  		LLSpatialGroup* group = *i;  		if (sUseOcclusion &&  -			group->isOcclusionState(LLSpatialGroup::OCCLUDED)) +			group->isOcclusionState(LLSpatialGroup::OCCLUDED) || +			(RenderAutoHideSurfaceAreaLimit > 0.f &&  +			group->mSurfaceArea > RenderAutoHideSurfaceAreaLimit*llmax(group->mObjectBoxSize, 10.f)))  		{  			continue;  		} diff --git a/indra/newview/pipeline.h b/indra/newview/pipeline.h index f922e3b4f3..5c623fc9f2 100644 --- a/indra/newview/pipeline.h +++ b/indra/newview/pipeline.h @@ -852,6 +852,7 @@ public:  	static BOOL CameraOffset;  	static F32 CameraMaxCoF;  	static F32 CameraDoFResScale; +	static F32 RenderAutoHideSurfaceAreaLimit;  };  void render_bbox(const LLVector3 &min, const LLVector3 &max); diff --git a/indra/newview/skins/default/xui/en/floater_hardware_settings.xml b/indra/newview/skins/default/xui/en/floater_hardware_settings.xml index 66bb9d3cea..9deb0d2030 100644 --- a/indra/newview/skins/default/xui/en/floater_hardware_settings.xml +++ b/indra/newview/skins/default/xui/en/floater_hardware_settings.xml @@ -132,6 +132,28 @@       name="vbo"       tool_tip="Enabling this on modern hardware gives a performance gain.  However, older hardware often has poor implementations of VBOs and you may get crashes when this is enabled."       width="315" /> +  <text +    type="string" +    length="1" +    follows="left|top" +    height="16" +    layout="topleft" +    left="10" +    name="tc label" +    top_pad="10" +    width="188"> +    Enable S3TC: +  </text> +    <check_box +     control_name="RenderCompressTextures" +     height="16" +     initial_value="true" +     label="Enable Texture Compression (requires restart)" +     layout="topleft" +     left_pad="10" +     name="texture compression" +     tool_tip="Compresses textures in video memory, allowing for higher resolution textures to be loaded at the cost of some color quality." +     width="315" />      <slider       control_name="TextureMemory"       decimal_digits="0" diff --git a/indra/newview/skins/default/xui/en/floater_report_abuse.xml b/indra/newview/skins/default/xui/en/floater_report_abuse.xml index e6d749a3f0..9561f67941 100644 --- a/indra/newview/skins/default/xui/en/floater_report_abuse.xml +++ b/indra/newview/skins/default/xui/en/floater_report_abuse.xml @@ -155,6 +155,7 @@       name="object_name"       top_delta="0"       translate="false" +     parse_urls="false"       use_ellipses="true"       width="185">          Consetetur Sadipscing diff --git a/indra/newview/skins/default/xui/en/notifications.xml b/indra/newview/skins/default/xui/en/notifications.xml index 46e467e230..a26c5bb344 100644 --- a/indra/newview/skins/default/xui/en/notifications.xml +++ b/indra/newview/skins/default/xui/en/notifications.xml @@ -1245,6 +1245,25 @@ Visit [_URL] for more information?    <notification     icon="alertmodal.tga" +   name="IntelOldDriver" +   type="alertmodal"> +     There is likely a newer driver for your graphics chip.  Updating graphics drivers can substantially improve performance. + +    Visit [_URL] to check for driver updates? +    <tag>confirm</tag> +    <url option="0" name="url"> +      http://www.intel.com/p/en_US/support/detect/graphics +    </url> +    <usetemplate +     ignoretext="My graphics driver is out of date" +     name="okcancelignore" +     notext="No" +     yestext="Yes"/> +    <tag>fail</tag> +  </notification> + +  <notification +   icon="alertmodal.tga"     name="UnknownGPU"     type="alertmodal">  Your system contains a graphics card that [APP_NAME] doesn't recognize. diff --git a/indra/newview/skins/default/xui/en/sidepanel_task_info.xml b/indra/newview/skins/default/xui/en/sidepanel_task_info.xml index 6600339ad7..bf2e6bc2d9 100644 --- a/indra/newview/skins/default/xui/en/sidepanel_task_info.xml +++ b/indra/newview/skins/default/xui/en/sidepanel_task_info.xml @@ -267,19 +267,19 @@                  <combo_box.item                   label="Touch  (default)"                   name="Touch/grab(default)" -                 value="Touch/grab (default)" /> +                 value="Touch" />                  <combo_box.item                   label="Sit on object"                   name="Sitonobject" -                 value="Sit on object" /> +                 value="Sit" />                  <combo_box.item                   label="Buy object"                   name="Buyobject" -                 value="Buy object" /> +                 value="Buy" />                  <combo_box.item                   label="Pay object"                   name="Payobject" -                 value="Pay object" /> +                 value="Pay" />                  <combo_box.item                   label="Open"                   name="Open" diff --git a/indra/newview/skins/default/xui/ja/notifications.xml b/indra/newview/skins/default/xui/ja/notifications.xml index 54031ccf12..7bf8a7b8be 100644 --- a/indra/newview/skins/default/xui/ja/notifications.xml +++ b/indra/newview/skins/default/xui/ja/notifications.xml @@ -2895,6 +2895,18 @@ M キーを押して変更します。  [RESIDENTS]  		<usetemplate name="okcancelbuttons" notext="取り消し" yestext="Ok"/>  	</notification> +	<notification name="ShareFolderConfirmation"> +		フォルダは一度に 1 つしか共有できません。 + +次のアイテムを共有しますか? + +<nolink>[ITEMS]</nolink> + +次の住人と共有: + +[RESIDENTS] +		<usetemplate name="okcancelbuttons" notext="取り消し" yestext="Ok"/> +	</notification>  	<notification name="ItemsShared">  		アイテムが共有されました。  	</notification> diff --git a/indra/newview/tests/llviewerassetstats_test.cpp b/indra/newview/tests/llviewerassetstats_test.cpp index f8923b9868..f8923b9868 100755..100644 --- a/indra/newview/tests/llviewerassetstats_test.cpp +++ b/indra/newview/tests/llviewerassetstats_test.cpp | 
