|
|
|
/* ****************************************************************************
|
|
|
|
This file is part of KBabel
|
|
|
|
|
|
|
|
Copyright (C) 2001 by Matthias Kiefer <matthias.kiefer@gmx.de>
|
|
|
|
|
|
|
|
based on code of Andrea Rizzi <rizzi@kde.org>
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program 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 General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
|
|
|
|
In addition, as a special exception, the copyright holders give
|
|
|
|
permission to link the code of this program with any edition of
|
|
|
|
the TQt library by Trolltech AS, Norway (or with modified versions
|
|
|
|
of TQt that use the same license as TQt), and distribute linked
|
|
|
|
combinations including the two. You must obey the GNU General
|
|
|
|
Public License in all respects for all of the code used other than
|
|
|
|
TQt. If you modify this file, you may extend this exception to
|
|
|
|
your version of the file, but you are not obligated to do so. If
|
|
|
|
you do not wish to do so, delete this exception statement from
|
|
|
|
your version.
|
|
|
|
|
|
|
|
**************************************************************************** */
|
|
|
|
#ifndef _REGEXP_EXTRACTOR_H_
|
|
|
|
#define _REGEXP_EXTRACTOR_H_
|
|
|
|
|
|
|
|
#include <tqptrlist.h>
|
|
|
|
#include <tqstring.h>
|
|
|
|
#include <tqstringlist.h>
|
|
|
|
#include <tqvaluelist.h>
|
|
|
|
#include <tqregexp.h>
|
|
|
|
#include <kdemacros.h>
|
|
|
|
|
|
|
|
namespace KBabel
|
|
|
|
{
|
|
|
|
|
|
|
|
struct KDE_EXPORT MatchedEntryInfo{
|
|
|
|
uint index;
|
|
|
|
TQString extracted;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* class to extract entries based on regexps from a string
|
|
|
|
* @author Andrea Rizzi <rizzi@kde.org>
|
|
|
|
*/
|
|
|
|
class KDE_EXPORT RegExpExtractor
|
|
|
|
{
|
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Create a regexp extractor for "string"
|
|
|
|
*/
|
|
|
|
RegExpExtractor(const TQStringList& regexps);
|
|
|
|
|
|
|
|
virtual ~RegExpExtractor() {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the string of this extractor
|
|
|
|
*/
|
|
|
|
void setString(TQString string);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the number of matches found
|
|
|
|
*/
|
|
|
|
uint countMatches();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the first match, and set the internal cursor to
|
|
|
|
* the beginning
|
|
|
|
*/
|
|
|
|
TQString firstMatch();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the next match and move cursor forward
|
|
|
|
*/
|
|
|
|
TQString nextMatch();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the n-th match. It also moves the cursor.
|
|
|
|
*/
|
|
|
|
TQString match(uint matchnumber);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the n-th match. It also moves the cursor. -1 is there
|
|
|
|
* is no such match.
|
|
|
|
*/
|
|
|
|
int matchIndex(uint matchnumber);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the next match and move cursor forward
|
|
|
|
*/
|
|
|
|
TQString prevMatch();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the last match and move the cursor to the end
|
|
|
|
*/
|
|
|
|
TQString lastMatch();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return a list of all matches
|
|
|
|
*/
|
|
|
|
TQStringList matches();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the string without matched text
|
|
|
|
*
|
|
|
|
* @param keepPos if false, the matches are just removed and so the
|
|
|
|
* position of the other words in the string will change. If true,
|
|
|
|
* the matches are replaced with ' ' and therefore the position of the
|
|
|
|
* words will not change
|
|
|
|
*/
|
|
|
|
TQString plainString(bool keepPos=false);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the string, where matches are replaced with the given string
|
|
|
|
*/
|
|
|
|
TQString matchesReplaced(const TQString& replace);
|
|
|
|
|
|
|
|
//Functions that allow user to define his own regexps.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a regexp to the list of regexp identifier.
|
|
|
|
*/
|
|
|
|
void addRegExpIdentifier(TQString regexp);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Delete from the regexp list the regexp.
|
|
|
|
*/
|
|
|
|
void deleteRegExpIdentifier(TQString regexp);
|
|
|
|
|
|
|
|
void setRegExpList( const TQStringList& regexps );
|
|
|
|
|
|
|
|
TQStringList regExpList();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
void processString();
|
|
|
|
TQPtrList<MatchedEntryInfo> _matches;
|
|
|
|
TQString _string;
|
|
|
|
TQStringList _regExpList;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|