2009-04-24 23:35:41 +00:00
|
|
|
// Scintilla source code edit control
|
|
|
|
/** @file RESearch.h
|
|
|
|
** Interface to the regular expression search library.
|
|
|
|
**/
|
|
|
|
// Written by Neil Hodgson <neilh@scintilla.org>
|
|
|
|
// Based on the work of Ozan S. Yigit.
|
|
|
|
// This file is in the public domain.
|
|
|
|
|
|
|
|
#ifndef RESEARCH_H
|
|
|
|
#define RESEARCH_H
|
|
|
|
|
|
|
|
namespace Scintilla {
|
|
|
|
|
|
|
|
class CharacterIndexer {
|
|
|
|
public:
|
2019-05-04 18:14:48 +00:00
|
|
|
virtual char CharAt(Sci::Position index) const=0;
|
2009-04-24 23:35:41 +00:00
|
|
|
virtual ~CharacterIndexer() {
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
class RESearch {
|
|
|
|
|
|
|
|
public:
|
2015-06-07 21:19:26 +00:00
|
|
|
explicit RESearch(CharClassify *charClassTable);
|
2019-05-04 18:14:48 +00:00
|
|
|
// No dynamic allocation so default copy constructor and assignment operator are OK.
|
2009-04-24 23:35:41 +00:00
|
|
|
~RESearch();
|
2021-02-21 04:53:09 +00:00
|
|
|
void Clear() noexcept;
|
2019-05-04 18:14:48 +00:00
|
|
|
void GrabMatches(const CharacterIndexer &ci);
|
2021-02-21 04:53:09 +00:00
|
|
|
const char *Compile(const char *pattern, Sci::Position length, bool caseSensitive, bool posix) noexcept;
|
2019-05-04 18:14:48 +00:00
|
|
|
int Execute(const CharacterIndexer &ci, Sci::Position lp, Sci::Position endp);
|
2009-04-24 23:35:41 +00:00
|
|
|
|
2021-02-21 04:53:09 +00:00
|
|
|
static constexpr int MAXTAG = 10;
|
|
|
|
static constexpr int NOTFOUND = -1;
|
2009-04-24 23:35:41 +00:00
|
|
|
|
2019-05-04 18:14:48 +00:00
|
|
|
Sci::Position bopat[MAXTAG];
|
|
|
|
Sci::Position eopat[MAXTAG];
|
2013-08-28 00:44:27 +00:00
|
|
|
std::string pat[MAXTAG];
|
2009-04-24 23:35:41 +00:00
|
|
|
|
|
|
|
private:
|
2019-07-21 13:26:02 +00:00
|
|
|
|
2021-02-21 04:53:09 +00:00
|
|
|
static constexpr int MAXNFA = 4096;
|
|
|
|
// The following constants are not meant to be changeable.
|
2019-07-21 13:26:02 +00:00
|
|
|
// They are for readability only.
|
2021-02-21 04:53:09 +00:00
|
|
|
static constexpr int MAXCHR = 256;
|
|
|
|
static constexpr int CHRBIT = 8;
|
|
|
|
static constexpr int BITBLK = MAXCHR / CHRBIT;
|
2019-07-21 13:26:02 +00:00
|
|
|
|
2021-02-21 04:53:09 +00:00
|
|
|
void ChSet(unsigned char c) noexcept;
|
|
|
|
void ChSetWithCase(unsigned char c, bool caseSensitive) noexcept;
|
|
|
|
int GetBackslashExpression(const char *pattern, int &incr) noexcept;
|
2009-04-24 23:35:41 +00:00
|
|
|
|
2019-05-04 18:14:48 +00:00
|
|
|
Sci::Position PMatch(const CharacterIndexer &ci, Sci::Position lp, Sci::Position endp, char *ap);
|
2009-04-24 23:35:41 +00:00
|
|
|
|
2019-05-04 18:14:48 +00:00
|
|
|
Sci::Position bol;
|
|
|
|
Sci::Position tagstk[MAXTAG]; /* subpat tag stack */
|
2009-04-24 23:35:41 +00:00
|
|
|
char nfa[MAXNFA]; /* automaton */
|
|
|
|
int sta;
|
|
|
|
unsigned char bittab[BITBLK]; /* bit table for CCL pre-set bits */
|
|
|
|
int failure;
|
|
|
|
CharClassify *charClass;
|
2021-02-21 04:53:09 +00:00
|
|
|
bool iswordc(unsigned char x) const noexcept {
|
2009-04-24 23:35:41 +00:00
|
|
|
return charClass->IsWord(x);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|