1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70
|
// Scintilla source code edit control
/** @file CatalogueModules.h
** Lexer infrastructure.
** Contains a list of LexerModules which can be searched to find a module appropriate for a
** particular language.
**/
// Copyright 1998-2010 by Neil Hodgson <neilh@scintilla.org>
// The License.txt file describes the conditions under which this software may be distributed.
#ifndef CATALOGUEMODULES_H
#define CATALOGUEMODULES_H
namespace Scintilla {
class CatalogueModules {
std::vector<LexerModule *> lexerCatalogue;
public:
const LexerModule *Find(int language) const {
for (const LexerModule *lm : lexerCatalogue) {
if (lm->GetLanguage() == language) {
return lm;
}
}
return nullptr;
}
const LexerModule *Find(const char *languageName) const noexcept {
if (languageName) {
for (const LexerModule *lm : lexerCatalogue) {
if (lm->languageName && (0 == strcmp(lm->languageName, languageName))) {
return lm;
}
}
}
return nullptr;
}
void AddLexerModule(LexerModule *plm) {
lexerCatalogue.push_back(plm);
}
unsigned int Count() const noexcept {
return static_cast<unsigned int>(lexerCatalogue.size());
}
const char *Name(unsigned int index) const noexcept {
if (index < static_cast<unsigned int>(lexerCatalogue.size())) {
return lexerCatalogue[index]->languageName;
} else {
return "";
}
}
LexerFactoryFunction Factory(unsigned int index) const noexcept {
// Works for object lexers but not for function lexers
return lexerCatalogue[index]->fnFactory;
}
ILexer *Create(unsigned int index) const {
const LexerModule *plm = lexerCatalogue[index];
if (!plm) {
return nullptr;
}
return plm->Create();
}
};
}
#endif
|