diff options
Diffstat (limited to 'indra/llcommon')
| -rw-r--r-- | indra/llcommon/CMakeLists.txt | 2 | ||||
| -rw-r--r-- | indra/llcommon/llregex.h | 89 | ||||
| -rw-r--r-- | indra/llcommon/llsys.cpp | 39 | 
3 files changed, 93 insertions, 37 deletions
diff --git a/indra/llcommon/CMakeLists.txt b/indra/llcommon/CMakeLists.txt index eeb315ead6..0a22942dfd 100644 --- a/indra/llcommon/CMakeLists.txt +++ b/indra/llcommon/CMakeLists.txt @@ -207,9 +207,9 @@ set(llcommon_HEADER_FILES      llqueuedthread.h      llrand.h      llrefcount.h +    llregex.h      llregistry.h      llrun.h -    llrefcount.h      llsafehandle.h      llsd.h      llsdjson.h diff --git a/indra/llcommon/llregex.h b/indra/llcommon/llregex.h new file mode 100644 index 0000000000..2b7f5e47c2 --- /dev/null +++ b/indra/llcommon/llregex.h @@ -0,0 +1,89 @@ +/**  + * @file llregex.h + * + * $LicenseInfo:firstyear=2021&license=viewerlgpl$ + * Second Life Viewer Source Code + * Copyright (C) 2021, Linden Research, Inc. + *  + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; + * version 2.1 of the License only. + *  + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU + * Lesser General Public License for more details. + *  + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + *  + * Linden Research, Inc., 945 Battery Street, San Francisco, CA  94111  USA + * $/LicenseInfo$ + */ + +#ifndef LLREGEX_H +#define LLREGEX_H +#include <boost/regex.hpp> + +template <typename S, typename M, typename R> +LL_COMMON_API bool ll_regex_match(const S& string, M& match, const R& regex) +{ +	try +	{ +		return boost::regex_match(string, match, regex); +	} +	catch (const std::runtime_error& e) +	{ +		LL_WARNS() << "error matching with '" << regex.str() << "': " +			<< e.what() << ":\n'" << string << "'" << LL_ENDL; +		return false; +	} +} + +template <typename S, typename R> +LL_COMMON_API bool ll_regex_match(const S& string, const R& regex) +{ +	try +	{ +		return boost::regex_match(string, regex); +	} +	catch (const std::runtime_error& e) +	{ +		LL_WARNS() << "error matching with '" << regex.str() << "': " +			<< e.what() << ":\n'" << string << "'" << LL_ENDL; +		return false; +	} +} + +template <typename S, typename M, typename R> +bool ll_regex_search(const S& string, M& match, const R& regex) +{ +	try +	{ +		return boost::regex_search(string, match, regex); +	} +	catch (const std::runtime_error& e) +	{ +		LL_WARNS() << "error searching with '" << regex.str() << "': " +			<< e.what() << ":\n'" << string << "'" << LL_ENDL; +		return false; +	} +} + +template <typename S, typename R> +bool ll_regex_search(const S& string, const R& regex) +{ +	try +	{ +		return boost::regex_search(string, regex); +	} +	catch (const std::runtime_error& e) +	{ +		LL_WARNS() << "error searching with '" << regex.str() << "': " +			<< e.what() << ":\n'" << string << "'" << LL_ENDL; +		return false; +	} +} +#endif  // LLREGEX_H diff --git a/indra/llcommon/llsys.cpp b/indra/llcommon/llsys.cpp index 1f8d558fbe..f7461422f7 100644 --- a/indra/llcommon/llsys.cpp +++ b/indra/llcommon/llsys.cpp @@ -43,12 +43,12 @@  #include "llerrorcontrol.h"  #include "llevents.h"  #include "llformat.h" +#include "llregex.h"  #include "lltimer.h"  #include "llsdserialize.h"  #include "llsdutil.h"  #include <boost/bind.hpp>  #include <boost/circular_buffer.hpp> -#include <boost/regex.hpp>  #include <boost/foreach.hpp>  #include <boost/lexical_cast.hpp>  #include <boost/range.hpp> @@ -111,39 +111,6 @@ static const F32 MEM_INFO_THROTTLE = 20;  // dropped below the login framerate, we'd have very little additional data.  static const F32 MEM_INFO_WINDOW = 10*60; -// Wrap boost::regex_match() with a function that doesn't throw. -template <typename S, typename M, typename R> -static bool regex_match_no_exc(const S& string, M& match, const R& regex) -{ -    try -    { -        return boost::regex_match(string, match, regex); -    } -    catch (const std::runtime_error& e) -    { -        LL_WARNS("LLMemoryInfo") << "error matching with '" << regex.str() << "': " -                                 << e.what() << ":\n'" << string << "'" << LL_ENDL; -        return false; -    } -} - -// Wrap boost::regex_search() with a function that doesn't throw. -template <typename S, typename M, typename R> -static bool regex_search_no_exc(const S& string, M& match, const R& regex) -{ -    try -    { -        return boost::regex_search(string, match, regex); -    } -    catch (const std::runtime_error& e) -    { -        LL_WARNS("LLMemoryInfo") << "error searching with '" << regex.str() << "': " -                                 << e.what() << ":\n'" << string << "'" << LL_ENDL; -        return false; -    } -} - -  LLOSInfo::LLOSInfo() :  	mMajorVer(0), mMinorVer(0), mBuild(0), mOSVersionString("")	   { @@ -387,7 +354,7 @@ LLOSInfo::LLOSInfo() :  	boost::smatch matched;  	std::string glibc_version(gnu_get_libc_version()); -	if ( regex_match_no_exc(glibc_version, matched, os_version_parse) ) +	if ( ll_regex_match(glibc_version, matched, os_version_parse) )  	{  		LL_INFOS("AppInit") << "Using glibc version '" << glibc_version << "' as OS version" << LL_ENDL; @@ -1116,7 +1083,7 @@ LLSD LLMemoryInfo::loadStatsMap()  		while (std::getline(meminfo, line))  		{  			LL_DEBUGS("LLMemoryInfo") << line << LL_ENDL; -			if (regex_match_no_exc(line, matched, stat_rx)) +			if (ll_regex_match(line, matched, stat_rx))  			{  				// e.g. "MemTotal:		4108424 kB"  				LLSD::String key(matched[1].first, matched[1].second);  | 
