diff options
Diffstat (limited to 'indra/llui/lltextparser.cpp')
| -rw-r--r-- | indra/llui/lltextparser.cpp | 76 | 
1 files changed, 29 insertions, 47 deletions
| diff --git a/indra/llui/lltextparser.cpp b/indra/llui/lltextparser.cpp index 76a39e3094..a4fe4f6ca8 100644 --- a/indra/llui/lltextparser.cpp +++ b/indra/llui/lltextparser.cpp @@ -1,31 +1,25 @@  /**    * @file lltextparser.cpp   * - * $LicenseInfo:firstyear=2001&license=viewergpl$ - *  - * Copyright (c) 2001-2009, Linden Research, Inc. - *  + * $LicenseInfo:firstyear=2001&license=viewerlgpl$   * Second Life Viewer Source Code - * The source code in this file ("Source Code") is provided by Linden Lab - * to you under the terms of the GNU General Public License, version 2.0 - * ("GPL"), unless you have obtained a separate licensing agreement - * ("Other License"), formally executed by you and Linden Lab.  Terms of - * the GPL can be found in doc/GPL-license.txt in this distribution, or - * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 + * Copyright (C) 2010, 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.   *  - * There are special exceptions to the terms and conditions of the GPL as - * it is applied to this Source Code. View the full text of the exception - * in the file doc/FLOSS-exception.txt in this software distribution, or - * online at - * http://secondlifegrid.net/programs/open_source/licensing/flossexception + * 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.   *  - * By copying, modifying or distributing this software, you acknowledge - * that you have read and understood your obligations described above, - * and agree to abide by those obligations. + * 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   *  - * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO - * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. + * Linden Research, Inc., 945 Battery Street, San Francisco, CA  94111  USA   * $/LicenseInfo$   */ @@ -43,29 +37,14 @@  #include "v4color.h"  #include "lldir.h" -// Routines used for parsing text for TextParsers and html - -LLTextParser* LLTextParser::sInstance = NULL; -  //  // Member Functions  // -LLTextParser::~LLTextParser() -{ -	sInstance=NULL; -} +LLTextParser::LLTextParser() +:	mLoaded(false) +{} -// static -LLTextParser* LLTextParser::getInstance() -{ -	if (!sInstance) -	{ -		sInstance = new LLTextParser(); -		sInstance->loadFromDisk(); -	} -	return sInstance; -}  // Moved triggerAlerts() to llfloaterchat.cpp to break llui/llaudio library dependency. @@ -105,6 +84,8 @@ S32 LLTextParser::findPattern(const std::string &text, LLSD highlight)  LLSD LLTextParser::parsePartialLineHighlights(const std::string &text, const LLColor4 &color, EHighlightPosition part, S32 index)  { +	loadKeywords(); +  	//evil recursive string atomizer.  	LLSD ret_llsd, start_llsd, middle_llsd, end_llsd; @@ -195,6 +176,8 @@ LLSD LLTextParser::parsePartialLineHighlights(const std::string &text, const LLC  bool LLTextParser::parseFullLineHighlights(const std::string &text, LLColor4 *color)  { +	loadKeywords(); +  	for (S32 i=0;i<mHighlights.size();i++)  	{  		if ((S32)mHighlights[i]["highlight"]==ALL || (S32)mHighlights[i]["condition"]==MATCHES) @@ -221,14 +204,14 @@ std::string LLTextParser::getFileName()  	return path;    } -LLSD LLTextParser::loadFromDisk() +void LLTextParser::loadKeywords()  { -	std::string filename=getFileName(); -	if (filename.empty()) -	{ -		llwarns << "LLTextParser::loadFromDisk() no valid user directory." << llendl;  +	if (mLoaded) +	{// keywords already loaded +		return;  	} -	else +	std::string filename=getFileName(); +	if (!filename.empty())  	{  		llifstream file;  		file.open(filename.c_str()); @@ -237,9 +220,8 @@ LLSD LLTextParser::loadFromDisk()  			LLSDSerialize::fromXML(mHighlights, file);  		}  		file.close(); +		mLoaded = true;  	} - -	return mHighlights;  }  bool LLTextParser::saveToDisk(LLSD highlights) | 
