diff options
| author | seth_productengine <none@none> | 2011-07-07 21:09:09 +0300 | 
|---|---|---|
| committer | seth_productengine <none@none> | 2011-07-07 21:09:09 +0300 | 
| commit | 52b9842ced222ac05f54058833f9404409eb0c79 (patch) | |
| tree | adc593c3a6f26a88c42531faf066618e92a4e0c5 /indra/llvfs | |
| parent | 66dcc72870b19c6ada65a643ca33c779c9c9989b (diff) | |
STORM-1476 FIXED Replaced non-fatal errors in LLDirIterator constructor with warnings to avoid viewer crashes.
Added exception handling case.
Diffstat (limited to 'indra/llvfs')
| -rw-r--r-- | indra/llvfs/lldiriterator.cpp | 20 | 
1 files changed, 16 insertions, 4 deletions
| diff --git a/indra/llvfs/lldiriterator.cpp b/indra/llvfs/lldiriterator.cpp index 25550321f0..ff92cbb7fd 100644 --- a/indra/llvfs/lldiriterator.cpp +++ b/indra/llvfs/lldiriterator.cpp @@ -52,8 +52,20 @@ LLDirIterator::Impl::Impl(const std::string &dirname, const std::string &mask)  {  	fs::path dir_path(dirname); -	// Check if path exists. -	if (!fs::exists(dir_path)) +	bool is_dir = false; + +	// Check if path is a directory. +	try +	{ +		is_dir = fs::is_directory(dir_path); +	} +	catch (fs::basic_filesystem_error<fs::path>& e) +	{ +		llwarns << e.what() << llendl; +		return; +	} + +	if (!is_dir)  	{  		llwarns << "Invalid path: \"" << dir_path.string() << "\"" << llendl;  		return; @@ -66,7 +78,7 @@ LLDirIterator::Impl::Impl(const std::string &dirname, const std::string &mask)  	}  	catch (fs::basic_filesystem_error<fs::path>& e)  	{ -		llerrs << e.what() << llendl; +		llwarns << e.what() << llendl;  		return;  	} @@ -82,7 +94,7 @@ LLDirIterator::Impl::Impl(const std::string &dirname, const std::string &mask)  	}  	catch (boost::regex_error& e)  	{ -		llerrs << "\"" << exp << "\" is not a valid regular expression: " +		llwarns << "\"" << exp << "\" is not a valid regular expression: "  				<< e.what() << llendl;  		return;  	} | 
