diff options
Diffstat (limited to 'indra/llxuixml')
| -rw-r--r-- | indra/llxuixml/llinitparam.cpp | 38 | ||||
| -rw-r--r-- | indra/llxuixml/llinitparam.h | 46 | ||||
| -rw-r--r-- | indra/llxuixml/lluicolor.cpp | 14 | ||||
| -rw-r--r-- | indra/llxuixml/lluicolor.h | 8 | ||||
| -rw-r--r-- | indra/llxuixml/llxuiparser.cpp | 36 | 
5 files changed, 58 insertions, 84 deletions
| diff --git a/indra/llxuixml/llinitparam.cpp b/indra/llxuixml/llinitparam.cpp index d908c85da6..2ead5a4a57 100644 --- a/indra/llxuixml/llinitparam.cpp +++ b/indra/llxuixml/llinitparam.cpp @@ -84,8 +84,7 @@ namespace LLInitParam  	// BaseBlock  	//  	BaseBlock::BaseBlock() -	:	mLastChangedParam(0), -		mChangeVersion(0), +	:	mChangeVersion(0),  		mBlockDescriptor(NULL)  	{} @@ -138,7 +137,7 @@ namespace LLInitParam  	} -	bool BaseBlock::validateBlock(bool silent) const +	bool BaseBlock::validateBlock(bool emit_errors) const  	{  		const BlockDescriptor& block_data = getBlockDescriptor();  		for (BlockDescriptor::param_validation_list_t::const_iterator it = block_data.mValidationList.begin(); it != block_data.mValidationList.end(); ++it) @@ -146,7 +145,7 @@ namespace LLInitParam  			const Param* param = getParamFromHandle(it->first);  			if (!it->second(param))  			{ -				if (!silent) +				if (emit_errors)  				{  					llwarns << "Invalid param \"" << getParamName(block_data, param) << "\"" << llendl;  				} @@ -348,7 +347,6 @@ namespace LLInitParam  			if (deserialize_func && deserialize_func(*paramp, p, name_stack, name_stack.first == name_stack.second ? -1 : name_stack.first->second))  			{ -				mLastChangedParam = (*it)->mParamHandle;  				return true;  			}  		} @@ -417,9 +415,11 @@ namespace LLInitParam  	void BaseBlock::setLastChangedParam(const Param& last_param, bool user_provided)  	{  -		mLastChangedParam = getHandleFromParam(&last_param);  +		if (user_provided) +		{  		mChangeVersion++;  	} +	}  	const std::string& BaseBlock::getParamName(const BlockDescriptor& block_data, const Param* paramp) const  	{ @@ -458,28 +458,7 @@ namespace LLInitParam  	// take all provided params from other and apply to self  	// NOTE: this requires that "other" is of the same derived type as this -	bool BaseBlock::overwriteFromImpl(BlockDescriptor& block_data, const BaseBlock& other) -	{ -		bool param_changed = false; -		BlockDescriptor::all_params_list_t::const_iterator end_it = block_data.mAllParams.end(); -		for (BlockDescriptor::all_params_list_t::const_iterator it = block_data.mAllParams.begin(); -			it != end_it; -			++it) -		{ -			const Param* other_paramp = other.getParamFromHandle(it->mParamHandle); -			ParamDescriptor::merge_func_t merge_func = it->mMergeFunc; -			if (merge_func) -			{ -				Param* paramp = getParamFromHandle(it->mParamHandle); -				param_changed |= merge_func(*paramp, *other_paramp, true); -				mLastChangedParam = it->mParamHandle; -			} -		} -		return param_changed; -	} - -	// take all provided params that are not already provided, and apply to self -	bool BaseBlock::fillFromImpl(BlockDescriptor& block_data, const BaseBlock& other) +	bool BaseBlock::merge(BlockDescriptor& block_data, const BaseBlock& other, bool overwrite)  	{  		bool param_changed = false;  		BlockDescriptor::all_params_list_t::const_iterator end_it = block_data.mAllParams.end(); @@ -492,8 +471,7 @@ namespace LLInitParam  			if (merge_func)  			{  				Param* paramp = getParamFromHandle(it->mParamHandle); -				param_changed |= merge_func(*paramp, *other_paramp, false); -				mLastChangedParam = it->mParamHandle; +				param_changed |= merge_func(*paramp, *other_paramp, overwrite);  			}  		}  		return param_changed; diff --git a/indra/llxuixml/llinitparam.h b/indra/llxuixml/llinitparam.h index a84e47f998..c9c1d4af90 100644 --- a/indra/llxuixml/llinitparam.h +++ b/indra/llxuixml/llinitparam.h @@ -407,7 +407,7 @@ namespace LLInitParam  	class BaseBlock  	{  	public: -		// "Multiple" constraint types +		// "Multiple" constraint types, put here in root class to avoid ambiguity during use  		struct AnyAmount  		{  			static U32 minCount() { return 0; } @@ -452,7 +452,7 @@ namespace LLInitParam  		bool submitValue(const Parser::name_stack_t& name_stack, Parser& p, bool silent=false);  		param_handle_t getHandleFromParam(const Param* param) const; -		bool validateBlock(bool silent = false) const; +		bool validateBlock(bool emit_errors = true) const;  		Param* getParamFromHandle(const param_handle_t param_handle)  		{ @@ -472,7 +472,6 @@ namespace LLInitParam  		// Blocks can override this to do custom tracking of changes  		virtual void setLastChangedParam(const Param& last_param, bool user_provided); -		const Param* getLastChangedParam() const { return mLastChangedParam ? getParamFromHandle(mLastChangedParam) : NULL; }  		S32 getLastChangeVersion() const { return mChangeVersion; }  		bool isDefault() const { return mChangeVersion == 0; } @@ -501,13 +500,9 @@ namespace LLInitParam  		// take all provided params from other and apply to self -		bool overwriteFromImpl(BlockDescriptor& block_data, const BaseBlock& other); - -		// take all provided params that are not already provided, and apply to self -		bool fillFromImpl(BlockDescriptor& block_data, const BaseBlock& other); +		bool merge(BlockDescriptor& block_data, const BaseBlock& other, bool overwrite);  		// can be updated in getters -		mutable param_handle_t	mLastChangedParam;  		mutable S32				mChangeVersion;  		BlockDescriptor*		mBlockDescriptor;	// most derived block descriptor @@ -807,7 +802,7 @@ namespace LLInitParam  			if (Param::getProvided() && mData.mValidatedVersion < T::getLastChangeVersion())  			{  				// a sub-block is "provided" when it has been filled in enough to be valid -				mData.mValidated = T::validateBlock(true); +				mData.mValidated = T::validateBlock(false);  				mData.mValidatedVersion = T::getLastChangeVersion();  			}  			return Param::getProvided() && mData.mValidated; @@ -1238,7 +1233,7 @@ namespace LLInitParam  				it != mValues.end();  				++it)  			{ -				if(it->validateBlock(true)) count++; +				if(it->validateBlock(false)) count++;  			}  			return count;  		} @@ -1288,7 +1283,7 @@ namespace LLInitParam  		bool overwriteFrom(const self_t& other)  		{  			mCurChoice = other.mCurChoice; -			return BaseBlock::overwriteFromImpl(blockDescriptor(), other); +			return BaseBlock::merge(blockDescriptor(), other, true);  		}  		// take all provided params that are not already provided, and apply to self @@ -1415,13 +1410,13 @@ namespace LLInitParam  		// take all provided params from other and apply to self  		bool overwriteFrom(const self_t& other)  		{ -			return BaseBlock::overwriteFromImpl(blockDescriptor(), other); +			return BaseBlock::merge(blockDescriptor(), other, true);  		}  		// take all provided params that are not already provided, and apply to self  		bool fillFrom(const self_t& other)  		{ -			return BaseBlock::fillFromImpl(blockDescriptor(), other); +			return BaseBlock::merge(blockDescriptor(), other, false);  		}  	protected:  		Block() @@ -1712,7 +1707,7 @@ namespace LLInitParam  			// if cached value is stale, regenerate from params  			if (Param::getProvided() && mData.mLastParamVersion < BaseBlock::getLastChangeVersion())  			{ -				if (block_t::validateBlock(true)) +				if (block_t::validateBlock(false))  				{  					static_cast<const DERIVED*>(this)->setValueFromBlock();  					// clear stale keyword associated with old value @@ -1734,6 +1729,7 @@ namespace LLInitParam  		void set(value_assignment_t val, bool flag_as_provided = true)  		{  			Param::enclosingBlock().setLastChangedParam(*this, flag_as_provided); +			  			// set param version number to be up to date, so we ignore block contents  			mData.mLastParamVersion = BaseBlock::getLastChangeVersion(); @@ -1770,7 +1766,7 @@ namespace LLInitParam  			if (Param::getProvided() && (mData.mLastParamVersion < BaseBlock::getLastChangeVersion()))  			{  				// go ahead and issue warnings at this point if any param is invalid -				if(block_t::validateBlock(false)) +				if(block_t::validateBlock(true))  				{  					static_cast<const DERIVED*>(this)->setValueFromBlock();  					mData.clearKey(); @@ -1798,25 +1794,23 @@ namespace LLInitParam  	private:  		static bool mergeWith(Param& dst, const Param& src, bool overwrite)  		{ -			const self_t& src_param = static_cast<const self_t&>(src); +			const self_t& src_typed_param = static_cast<const self_t&>(src);  			self_t& dst_typed_param = static_cast<self_t&>(dst); -			if (src_param.isProvided() +			if (src_typed_param.isProvided()  				&& (overwrite || !dst_typed_param.isProvided()))  			{  				// assign individual parameters -				if (overwrite) -				{ -					dst_typed_param.BaseBlock::overwriteFromImpl(block_t::blockDescriptor(), src_param); -				} -				else -				{ -					dst_typed_param.BaseBlock::fillFromImpl(block_t::blockDescriptor(), src_param); -				} +				dst_typed_param.BaseBlock::merge(block_t::blockDescriptor(), src_typed_param, overwrite); +  				// then copy actual value -				dst_typed_param.mData.mValue = src_param.get(); +				dst_typed_param.mData.mValue = src_typed_param.get();  				dst_typed_param.mData.clearKey();  				dst_typed_param.setProvided(true); + +				// Propagate value back to block params since the value was updated during this merge. +				// This will result in mData.mValue and the block params being in sync. +				static_cast<DERIVED&>(dst_typed_param).setBlockFromValue();  				return true;  			}  			return false; diff --git a/indra/llxuixml/lluicolor.cpp b/indra/llxuixml/lluicolor.cpp index 424d878a6b..0049ec055c 100644 --- a/indra/llxuixml/lluicolor.cpp +++ b/indra/llxuixml/lluicolor.cpp @@ -16,13 +16,15 @@ LLUIColor::LLUIColor()  {  } -LLUIColor::LLUIColor(const LLColor4* color) -	:mColorPtr(color) + +LLUIColor::LLUIColor(const LLColor4& color) +:	mColor(color),  +	mColorPtr(NULL)  {  } -LLUIColor::LLUIColor(const LLColor4& color) -	:mColor(color), mColorPtr(NULL) +LLUIColor::LLUIColor(const LLUIColor* color) +:	mColorPtr(color)  {  } @@ -32,14 +34,14 @@ void LLUIColor::set(const LLColor4& color)  	mColorPtr = NULL;  } -void LLUIColor::set(const LLColor4* color) +void LLUIColor::set(const LLUIColor* color)  {  	mColorPtr = color;  }  const LLColor4& LLUIColor::get() const  { -	return (mColorPtr == NULL ? mColor : *mColorPtr); +	return (mColorPtr == NULL ? mColor : mColorPtr->get());  }  LLUIColor::operator const LLColor4& () const diff --git a/indra/llxuixml/lluicolor.h b/indra/llxuixml/lluicolor.h index bb0f786326..0ef2f78b24 100644 --- a/indra/llxuixml/lluicolor.h +++ b/indra/llxuixml/lluicolor.h @@ -22,11 +22,11 @@ class LLUIColor  {  public:  	LLUIColor(); -	LLUIColor(const LLColor4* color);  	LLUIColor(const LLColor4& color); +	LLUIColor(const LLUIColor* color);  	void set(const LLColor4& color); -	void set(const LLColor4* color); +	void set(const LLUIColor* color);  	const LLColor4& get() const; @@ -38,7 +38,7 @@ public:  private:  	friend struct LLInitParam::ParamCompare<LLUIColor, false>; -	const LLColor4* mColorPtr; +	const LLUIColor* mColorPtr;  	LLColor4 mColor;  }; @@ -47,7 +47,7 @@ namespace LLInitParam  	template<>  	struct ParamCompare<LLUIColor, false>  	{ -		static bool equals(const class LLUIColor& a, const class LLUIColor& b); +		static bool equals(const LLUIColor& a, const LLUIColor& b);  	};  } diff --git a/indra/llxuixml/llxuiparser.cpp b/indra/llxuixml/llxuiparser.cpp index 17399865e5..dbc20a5a1e 100644 --- a/indra/llxuixml/llxuiparser.cpp +++ b/indra/llxuixml/llxuiparser.cpp @@ -324,33 +324,33 @@ void LLXUIXSDWriter::writeXSD(const std::string& type_name, const std::string& p  	// add includes for all possible children  	const std::type_info* type = *LLWidgetTypeRegistry::instance().getValue(type_name);  	const widget_registry_t* widget_registryp = LLChildRegistryRegistry::instance().getValue(type); -	 -	// add include declarations for all valid children -	for (widget_registry_t::Registrar::registry_map_t::const_iterator it = widget_registryp->currentRegistrar().beginItems(); -		it != widget_registryp->currentRegistrar().endItems(); -		++it) -	{ -		std::string widget_name = it->first; -		if (widget_name == type_name) -		{ -			continue; -		} -		LLXMLNodePtr nodep = new LLXMLNode("xs:include", false); -		nodep->createChild("schemaLocation", true)->setStringValue(widget_name + ".xsd"); - -		// add to front of schema -		mSchemaNode->addChild(nodep, mSchemaNode); -	}  	// add choices for valid children  	if (widget_registryp)  	{ +		// add include declarations for all valid children +		for (widget_registry_t::Registrar::registry_map_t::const_iterator it = widget_registryp->currentRegistrar().beginItems(); +		     it != widget_registryp->currentRegistrar().endItems(); +		     ++it) +		{ +			std::string widget_name = it->first; +			if (widget_name == type_name) +			{ +				continue; +			} +			LLXMLNodePtr nodep = new LLXMLNode("xs:include", false); +			nodep->createChild("schemaLocation", true)->setStringValue(widget_name + ".xsd"); +			 +			// add to front of schema +			mSchemaNode->addChild(nodep, mSchemaNode); +		} +  		for (widget_registry_t::Registrar::registry_map_t::const_iterator it = widget_registryp->currentRegistrar().beginItems();  			it != widget_registryp->currentRegistrar().endItems();  			++it)  		{  			std::string widget_name = it->first; -            //<xs:element name="widget_name" type="widget_name"> +			//<xs:element name="widget_name" type="widget_name">  			LLXMLNodePtr widget_node = mElementNode->createChild("xs:element", false);  			widget_node->createChild("name", true)->setStringValue(widget_name);  			widget_node->createChild("type", true)->setStringValue(widget_name); | 
