diff options
| author | Nat Goodspeed <nat@lindenlab.com> | 2021-05-13 22:10:43 -0400 | 
|---|---|---|
| committer | Nat Goodspeed <nat@lindenlab.com> | 2021-05-13 22:10:43 -0400 | 
| commit | d3d8203be4aec8ad90c0044e3a0ade1d91df64ea (patch) | |
| tree | f244144045e09df2a21a9271ab3a55ac3f356e3c | |
| parent | f7f6553cac78f1cf00cc1776de95f578e5853109 (diff) | |
SL-15258: Remove additional std library features dropped with C++17.
| -rw-r--r-- | indra/llcommon/llsd.h | 43 | ||||
| -rw-r--r-- | indra/llcommon/llstl.h | 237 | ||||
| -rw-r--r-- | indra/llcommon/tests/llleap_test.cpp | 2 | ||||
| -rw-r--r-- | indra/llmessage/llcircuit.cpp | 11 | ||||
| -rw-r--r-- | indra/llmessage/lldispatcher.cpp | 2 | ||||
| -rw-r--r-- | indra/llmessage/llmessagethrottle.cpp | 22 | ||||
| -rw-r--r-- | indra/newview/llexperiencelog.cpp | 4 | ||||
| -rw-r--r-- | indra/newview/llgesturemgr.cpp | 2 | 
8 files changed, 10 insertions, 313 deletions
| diff --git a/indra/llcommon/llsd.h b/indra/llcommon/llsd.h index 5b6d5545af..6638b25feb 100644 --- a/indra/llcommon/llsd.h +++ b/indra/llcommon/llsd.h @@ -413,49 +413,6 @@ public:  	static std::string		typeString(Type type);		// Return human-readable type as a string  }; -struct llsd_select_bool : public std::unary_function<LLSD, LLSD::Boolean> -{ -	LLSD::Boolean operator()(const LLSD& sd) const -	{ -		return sd.asBoolean(); -	} -}; -struct llsd_select_integer : public std::unary_function<LLSD, LLSD::Integer> -{ -	LLSD::Integer operator()(const LLSD& sd) const -	{ -		return sd.asInteger(); -	} -}; -struct llsd_select_real : public std::unary_function<LLSD, LLSD::Real> -{ -	LLSD::Real operator()(const LLSD& sd) const -	{ -		return sd.asReal(); -	} -}; -struct llsd_select_float : public std::unary_function<LLSD, F32> -{ -	F32 operator()(const LLSD& sd) const -	{ -		return (F32)sd.asReal(); -	} -}; -struct llsd_select_uuid : public std::unary_function<LLSD, LLSD::UUID> -{ -	LLSD::UUID operator()(const LLSD& sd) const -	{ -		return sd.asUUID(); -	} -}; -struct llsd_select_string : public std::unary_function<LLSD, LLSD::String> -{ -	LLSD::String operator()(const LLSD& sd) const -	{ -		return sd.asString(); -	} -}; -  LL_COMMON_API std::ostream& operator<<(std::ostream& s, const LLSD& llsd);  namespace llsd diff --git a/indra/llcommon/llstl.h b/indra/llcommon/llstl.h index a90c2c7e08..d28260b9f8 100644 --- a/indra/llcommon/llstl.h +++ b/indra/llcommon/llstl.h @@ -40,30 +40,6 @@  // <ND> For strcmp  #include <string.h>  #endif -// Use to compare the first element only of a pair -// e.g. typedef std::set<std::pair<int, Data*>, compare_pair<int, Data*> > some_pair_set_t;  -template <typename T1, typename T2> -struct compare_pair_first -{ -	bool operator()(const std::pair<T1, T2>& a, const std::pair<T1, T2>& b) const -	{ -		return a.first < b.first; -	} -}; - -template <typename T1, typename T2> -struct compare_pair_greater -{ -	bool operator()(const std::pair<T1, T2>& a, const std::pair<T1, T2>& b) const -	{ -		if (!(a.first < b.first)) -			return true; -		else if (!(b.first < a.first)) -			return false; -		else -			return !(a.second < b.second); -	} -};  // Use to compare the contents of two pointers (e.g. std::string*)  template <typename T> @@ -123,58 +99,6 @@ struct DeletePairedPointerArray  }; -// Alternate version of the above so that has a more cumbersome -// syntax, but it can be used with compositional functors. -// NOTE: The functor retuns a bool because msdev bombs during the -// composition if you return void. Once we upgrade to a newer -// compiler, the second unary_function template parameter can be set -// to void. -// -// Here's a snippet showing how you use this object: -// -// typedef std::map<int, widget*> map_type; -// map_type widget_map; -// ... // add elements -// // delete them all -// for_each(widget_map.begin(), -//          widget_map.end(), -//          llcompose1(DeletePointerFunctor<widget>(), -//                     llselect2nd<map_type::value_type>())); - -template<typename T> -struct DeletePointerFunctor : public std::unary_function<T*, bool> -{ -	bool operator()(T* ptr) const -	{ -		delete ptr; -		return true; -	} -}; - -// See notes about DeleteArray for why you should consider avoiding this. -template<typename T> -struct DeleteArrayFunctor : public std::unary_function<T*, bool> -{ -	bool operator()(T* ptr) const -	{ -		delete[] ptr; -		return true; -	} -}; - -// CopyNewPointer is a simple helper which accepts a pointer, and -// returns a new pointer built with the copy constructor. Example: -// -//  transform(in.begin(), in.end(), out.end(), CopyNewPointer()); - -struct CopyNewPointer -{ -	template<typename T> T* operator()(const T* ptr) const -	{ -		return new T(*ptr); -	} -}; -  template<typename T, typename ALLOC>  void delete_and_clear(std::list<T*, ALLOC>& list)  { @@ -363,161 +287,6 @@ OutputIter ll_transform_n(  } - -/* - * - * Copyright (c) 1994 - * Hewlett-Packard Company - * - * Permission to use, copy, modify, distribute and sell this software - * and its documentation for any purpose is hereby granted without fee, - * provided that the above copyright notice appear in all copies and - * that both that copyright notice and this permission notice appear - * in supporting documentation.  Hewlett-Packard Company makes no - * representations about the suitability of this software for any - * purpose.  It is provided "as is" without express or implied warranty. - * - * - * Copyright (c) 1996-1998 - * Silicon Graphics Computer Systems, Inc. - * - * Permission to use, copy, modify, distribute and sell this software - * and its documentation for any purpose is hereby granted without fee, - * provided that the above copyright notice appear in all copies and - * that both that copyright notice and this permission notice appear - * in supporting documentation.  Silicon Graphics makes no - * representations about the suitability of this software for any - * purpose.  It is provided "as is" without express or implied warranty. - */ - - -// helper to deal with the fact that MSDev does not package -// select... with the stl. Look up usage on the sgi website. - -template <class _Pair> -struct _LLSelect1st : public std::unary_function<_Pair, typename _Pair::first_type> { -  const typename _Pair::first_type& operator()(const _Pair& __x) const { -    return __x.first; -  } -}; - -template <class _Pair> -struct _LLSelect2nd : public std::unary_function<_Pair, typename _Pair::second_type> -{ -  const typename _Pair::second_type& operator()(const _Pair& __x) const { -    return __x.second; -  } -}; - -template <class _Pair> struct llselect1st : public _LLSelect1st<_Pair> {}; -template <class _Pair> struct llselect2nd : public _LLSelect2nd<_Pair> {}; - -// helper to deal with the fact that MSDev does not package -// compose... with the stl. Look up usage on the sgi website. - -template <class _Operation1, class _Operation2> -class ll_unary_compose : -	public std::unary_function<typename _Operation2::argument_type, -							   typename _Operation1::result_type> -{ -protected: -  _Operation1 __op1; -  _Operation2 __op2; -public: -  ll_unary_compose(const _Operation1& __x, const _Operation2& __y) -    : __op1(__x), __op2(__y) {} -  typename _Operation1::result_type -  operator()(const typename _Operation2::argument_type& __x) const { -    return __op1(__op2(__x)); -  } -}; - -template <class _Operation1, class _Operation2> -inline ll_unary_compose<_Operation1,_Operation2> -llcompose1(const _Operation1& __op1, const _Operation2& __op2) -{ -  return ll_unary_compose<_Operation1,_Operation2>(__op1, __op2); -} - -template <class _Operation1, class _Operation2, class _Operation3> -class ll_binary_compose -  : public std::unary_function<typename _Operation2::argument_type, -							   typename _Operation1::result_type> { -protected: -  _Operation1 _M_op1; -  _Operation2 _M_op2; -  _Operation3 _M_op3; -public: -  ll_binary_compose(const _Operation1& __x, const _Operation2& __y, -					const _Operation3& __z) -    : _M_op1(__x), _M_op2(__y), _M_op3(__z) { } -  typename _Operation1::result_type -  operator()(const typename _Operation2::argument_type& __x) const { -    return _M_op1(_M_op2(__x), _M_op3(__x)); -  } -}; - -template <class _Operation1, class _Operation2, class _Operation3> -inline ll_binary_compose<_Operation1, _Operation2, _Operation3> -llcompose2(const _Operation1& __op1, const _Operation2& __op2, -         const _Operation3& __op3) -{ -  return ll_binary_compose<_Operation1,_Operation2,_Operation3> -    (__op1, __op2, __op3); -} - -// helpers to deal with the fact that MSDev does not package -// bind... with the stl. Again, this is from sgi. -template <class _Operation> -class llbinder1st : -	public std::unary_function<typename _Operation::second_argument_type, -							   typename _Operation::result_type> { -protected: -  _Operation op; -  typename _Operation::first_argument_type value; -public: -  llbinder1st(const _Operation& __x, -			  const typename _Operation::first_argument_type& __y) -      : op(__x), value(__y) {} -	typename _Operation::result_type -	operator()(const typename _Operation::second_argument_type& __x) const { -		return op(value, __x); -	} -}; - -template <class _Operation, class _Tp> -inline llbinder1st<_Operation> -llbind1st(const _Operation& __oper, const _Tp& __x) -{ -  typedef typename _Operation::first_argument_type _Arg1_type; -  return llbinder1st<_Operation>(__oper, _Arg1_type(__x)); -} - -template <class _Operation> -class llbinder2nd -	: public std::unary_function<typename _Operation::first_argument_type, -								 typename _Operation::result_type> { -protected: -	_Operation op; -	typename _Operation::second_argument_type value; -public: -	llbinder2nd(const _Operation& __x, -				const typename _Operation::second_argument_type& __y) -		: op(__x), value(__y) {} -	typename _Operation::result_type -	operator()(const typename _Operation::first_argument_type& __x) const { -		return op(__x, value); -	} -}; - -template <class _Operation, class _Tp> -inline llbinder2nd<_Operation> -llbind2nd(const _Operation& __oper, const _Tp& __x) -{ -  typedef typename _Operation::second_argument_type _Arg2_type; -  return llbinder2nd<_Operation>(__oper, _Arg2_type(__x)); -} -  /**   * Compare std::type_info* pointers a la std::less. We break this out as a   * separate function for use in two different std::less specializations. @@ -548,8 +317,7 @@ bool before(const std::type_info* lhs, const std::type_info* rhs)  namespace std  {  	template <> -	struct less<const std::type_info*>: -		public std::binary_function<const std::type_info*, const std::type_info*, bool> +	struct less<const std::type_info*>  	{  		bool operator()(const std::type_info* lhs, const std::type_info* rhs) const  		{ @@ -558,8 +326,7 @@ namespace std  	};  	template <> -	struct less<std::type_info*>: -		public std::binary_function<std::type_info*, std::type_info*, bool> +	struct less<std::type_info*>  	{  		bool operator()(std::type_info* lhs, std::type_info* rhs) const  		{ diff --git a/indra/llcommon/tests/llleap_test.cpp b/indra/llcommon/tests/llleap_test.cpp index 9d71e327d8..fd96aa01d5 100644 --- a/indra/llcommon/tests/llleap_test.cpp +++ b/indra/llcommon/tests/llleap_test.cpp @@ -530,7 +530,7 @@ namespace tut          result.ensure();      } -    struct TestLargeMessage: public std::binary_function<size_t, size_t, bool> +    struct TestLargeMessage      {          TestLargeMessage(const std::string& PYTHON_, const std::string& reader_module_,                           const std::string& test_name_): diff --git a/indra/llmessage/llcircuit.cpp b/indra/llmessage/llcircuit.cpp index 8baa2e328b..a39989515e 100644 --- a/indra/llmessage/llcircuit.cpp +++ b/indra/llmessage/llcircuit.cpp @@ -436,12 +436,11 @@ LLCircuit::LLCircuit(const F32Seconds circuit_heartbeat_interval, const F32Secon  LLCircuit::~LLCircuit()  { -	// delete pointers in the map. -	std::for_each(mCircuitData.begin(), -				  mCircuitData.end(), -				  llcompose1( -					  DeletePointerFunctor<LLCircuitData>(), -					  llselect2nd<circuit_data_map::value_type>())); +    // delete pointers in the map. +    for (auto circ_pair : mCircuitData) +    { +        delete circ_pair.second; +    }  }  LLCircuitData *LLCircuit::addCircuitData(const LLHost &host, TPACKETID in_id) diff --git a/indra/llmessage/lldispatcher.cpp b/indra/llmessage/lldispatcher.cpp index 717ef10f70..8dfd924f31 100644 --- a/indra/llmessage/lldispatcher.cpp +++ b/indra/llmessage/lldispatcher.cpp @@ -62,7 +62,7 @@ void LLDispatcher::copyAllHandlerNames(keys_t& names) const  		mHandlers.begin(),  		mHandlers.end(),  		std::back_insert_iterator<keys_t>(names), -		llselect1st<dispatch_map_t::value_type>()); +		[](const dispatch_map_t::value_type& pair){ return pair.first; });  }  bool LLDispatcher::dispatch( diff --git a/indra/llmessage/llmessagethrottle.cpp b/indra/llmessage/llmessagethrottle.cpp index 579d6d7187..c5ae8b4547 100644 --- a/indra/llmessage/llmessagethrottle.cpp +++ b/indra/llmessage/llmessagethrottle.cpp @@ -32,18 +32,8 @@  #include "llframetimer.h"  // This is used for the stl search_n function. -#if _MSC_VER >= 1500 // VC9 has a bug in search_n -struct eq_message_throttle_entry : public std::binary_function< LLMessageThrottleEntry, LLMessageThrottleEntry, bool > -{ -	bool operator()(const LLMessageThrottleEntry& a, const LLMessageThrottleEntry& b) const -	{ -		return a.getHash() == b.getHash(); -	} -}; -#else  bool eq_message_throttle_entry(LLMessageThrottleEntry a, LLMessageThrottleEntry b)   		{ return a.getHash() == b.getHash(); } -#endif  const U64 SEC_TO_USEC = 1000000; @@ -118,14 +108,8 @@ BOOL LLMessageThrottle::addViewerAlert(const LLUUID& to, const std::string& mesg  	LLMessageThrottleEntry entry(hash, LLFrameTimer::getTotalTime());  	// Check if this message is already in the list. -#if _MSC_VER >= 1500 // VC9 has a bug in search_n -	// SJB: This *should* work but has not been tested yet *TODO: Test! -	message_list_iterator_t found = std::find_if(message_list->begin(), message_list->end(), -												 std::bind2nd(eq_message_throttle_entry(), entry)); -#else   	message_list_iterator_t found = std::search_n(message_list->begin(), message_list->end(),   												  1, entry, eq_message_throttle_entry); -#endif  	if (found == message_list->end())  	{  		// This message was not found.  Add it to the list. @@ -152,14 +136,8 @@ BOOL LLMessageThrottle::addAgentAlert(const LLUUID& agent, const LLUUID& task, c  	LLMessageThrottleEntry entry(hash, LLFrameTimer::getTotalTime());  	// Check if this message is already in the list. -#if _MSC_VER >= 1500 // VC9 has a bug in search_n -	// SJB: This *should* work but has not been tested yet *TODO: Test! -	message_list_iterator_t found = std::find_if(message_list->begin(), message_list->end(), -												 std::bind2nd(eq_message_throttle_entry(), entry)); -#else  	message_list_iterator_t found = std::search_n(message_list->begin(), message_list->end(),  												  1, entry, eq_message_throttle_entry); -#endif  	if (found == message_list->end())  	{ diff --git a/indra/newview/llexperiencelog.cpp b/indra/newview/llexperiencelog.cpp index ee5d561927..c441fbc09f 100644 --- a/indra/newview/llexperiencelog.cpp +++ b/indra/newview/llexperiencelog.cpp @@ -149,10 +149,6 @@ std::string LLExperienceLog::getPermissionString( const LLSD& message, const std  		{  			buf.str(entry);  		} -		else -		{ -			buf.str(); -		}  	}  	if(buf.str().empty()) diff --git a/indra/newview/llgesturemgr.cpp b/indra/newview/llgesturemgr.cpp index 950a6cfaef..eb0e77311b 100644 --- a/indra/newview/llgesturemgr.cpp +++ b/indra/newview/llgesturemgr.cpp @@ -752,7 +752,7 @@ S32 LLGestureMgr::getPlayingCount() const  } -struct IsGesturePlaying : public std::unary_function<LLMultiGesture*, bool> +struct IsGesturePlaying  {  	bool operator()(const LLMultiGesture* gesture) const  	{ | 
