diff options
Diffstat (limited to 'src/LexHaskell.cxx')
-rw-r--r-- | src/LexHaskell.cxx | 275 |
1 files changed, 0 insertions, 275 deletions
diff --git a/src/LexHaskell.cxx b/src/LexHaskell.cxx deleted file mode 100644 index b528f3f0e..000000000 --- a/src/LexHaskell.cxx +++ /dev/null @@ -1,275 +0,0 @@ -/****************************************************************** - * LexHaskell.cxx - * - * A haskell lexer for the scintilla code control. - * Some stuff "lended" from LexPython.cxx and LexCPP.cxx. - * External lexer stuff inspired from the caml external lexer. - * - * Written by Tobias Engvall - tumm at dtek dot chalmers dot se - * - * - * TODO: - * * Implement a folder :) - * * Nice Character-lexing (stuff inside '\''), LexPython has - * this. - * - * - *****************************************************************/ - -#include <stdlib.h> -#include <string.h> -#include <ctype.h> -#include <stdio.h> -#include <stdarg.h> - -#include "Platform.h" - -#include "PropSet.h" -#include "PropSetSimple.h" -#include "Accessor.h" -#include "StyleContext.h" -#include "KeyWords.h" -#include "Scintilla.h" -#include "SciLexer.h" - -#ifdef SCI_NAMESPACE -using namespace Scintilla; -#endif - -#ifdef BUILD_AS_EXTERNAL_LEXER - -#include "ExternalLexer.h" -#include "WindowAccessor.h" - -#define BUILD_EXTERNAL_LEXER 0 - -#endif - -// Max level of nested comments -#define SCE_HA_COMMENTMAX SCE_HA_COMMENTBLOCK3 - - -enum kwType { kwOther, kwClass, kwData, kwInstance, kwImport, kwModule, kwType}; - -static inline bool IsNewline(const int ch) { - return (ch == '\n' || ch == '\r'); -} - -static inline bool IsWhitespace(const int ch) { - return ( ch == ' ' - || ch == '\t' - || IsNewline(ch) ); -} - -static inline bool IsAWordStart(const int ch) { - return (ch < 0x80) && (isalnum(ch) || ch == '_'); -} - -static inline bool IsAWordChar(const int ch) { - return (ch < 0x80) && (isalnum(ch) || ch == '.' || ch == '_' || ch == '\''); -} - -static void ColorizeHaskellDoc(unsigned int startPos, int length, int initStyle, - WordList *keywordlists[], Accessor &styler) { - - WordList &keywords = *keywordlists[0]; - - int kwLast = kwOther; - - StyleContext sc(startPos, length, initStyle, styler); - - for (; sc.More(); sc.Forward()) { - - // Check for state end - // Operator - if (sc.state == SCE_HA_OPERATOR) { - kwLast = kwOther; - sc.SetState(SCE_HA_DEFAULT); - } - // String - else if (sc.state == SCE_HA_STRING) { - if (sc.ch == '\"') { - sc.ForwardSetState(SCE_HA_DEFAULT); - } else if (sc.ch == '\\') { - sc.Forward(); - } - } - // Char - else if (sc.state == SCE_HA_CHARACTER) { - if (sc.ch == '\'') { - sc.ForwardSetState(SCE_HA_DEFAULT); - } else if (sc.ch == '\\') { - sc.Forward(); - } - } - // Number - else if (sc.state == SCE_HA_NUMBER) { - if (!IsADigit(sc.ch)) { - sc.SetState(SCE_HA_DEFAULT); - } - } - // Types, constructors, etc. - else if (sc.state == SCE_HA_CAPITAL) { - if (!IsAWordChar(sc.ch) || sc.ch == '.') { - sc.SetState(SCE_HA_DEFAULT); - } - } - // Identifier - else if (sc.state == SCE_HA_IDENTIFIER) { - if (!IsAWordChar(sc.ch)) { - char s[100]; - sc.GetCurrent(s, sizeof(s)); - int style = SCE_HA_IDENTIFIER; - if ((kwLast == kwImport) || (strcmp(s,"qualified") == 0) || (strcmp(s,"as") == 0)) { - style = SCE_HA_IMPORT; - } else if (keywords.InList(s)) { - style = SCE_HA_KEYWORD; - } else if (kwLast == kwData) { - style = SCE_HA_DATA; - } else if (kwLast == kwClass) { - style = SCE_HA_CLASS; - } else if (kwLast == kwModule) { - style = SCE_HA_MODULE; - } else if (isupper(s[0])) { - style = SCE_HA_CAPITAL; - } - sc.ChangeState(style); - sc.SetState(SCE_HA_DEFAULT); - if (style == SCE_HA_KEYWORD) { - if (0 == strcmp(s, "class")) - kwLast = kwClass; - else if (0 == strcmp(s, "data")) - kwLast = kwData; - else if (0 == strcmp(s, "instance")) - kwLast = kwInstance; - else if (0 == strcmp(s, "import")) - kwLast = kwImport; - else if (0 == strcmp(s, "module")) - kwLast = kwModule; - else - kwLast = kwOther; - } else if (style == SCE_HA_CLASS || style == SCE_HA_IMPORT || - style == SCE_HA_MODULE || style == SCE_HA_CAPITAL || - style == SCE_HA_DATA || style == SCE_HA_INSTANCE) { - kwLast = kwOther; - } - } - } - // Comments - // Oneliner - else if (sc.state == SCE_HA_COMMENTLINE) { - if (IsNewline(sc.ch)) - sc.SetState(SCE_HA_DEFAULT); - } - // Nested - else if (sc.state >= SCE_HA_COMMENTBLOCK) { - if (sc.Match("{-")) { - if (sc.state < SCE_HA_COMMENTMAX) - sc.SetState(sc.state + 1); - } - else if (sc.Match("-}")) { - sc.Forward(); - if (sc.state == SCE_HA_COMMENTBLOCK) - sc.ForwardSetState(SCE_HA_DEFAULT); - else - sc.ForwardSetState(sc.state - 1); - } - } - // New state? - if (sc.state == SCE_HA_DEFAULT) { - // Digit - if (IsADigit(sc.ch) || (sc.ch == '.' && IsADigit(sc.chNext))) { - sc.SetState(SCE_HA_NUMBER); - if (sc.ch == '0' && (sc.chNext == 'X' || sc.chNext == 'x')) { // Match anything starting with "0x" or "0X", too - sc.Forward(1); - } - } - // Comment line - else if (sc.Match("--")) { - sc.SetState(SCE_HA_COMMENTLINE); - // Comment block - } - else if (sc.Match("{-")) { - sc.SetState(SCE_HA_COMMENTBLOCK); - } - // String - else if (sc.Match('\"')) { - sc.SetState(SCE_HA_STRING); - } - // Character - else if (sc.Match('\'')) { - sc.SetState(SCE_HA_CHARACTER); - } - // Stringstart - else if (sc.Match('\"')) { - sc.SetState(SCE_HA_STRING); - } - // Operator - else if (isascii(sc.ch) && isoperator(static_cast<char>(sc.ch))) { - sc.SetState(SCE_HA_OPERATOR); - } - // Keyword - else if (IsAWordStart(sc.ch)) { - sc.SetState(SCE_HA_IDENTIFIER); - } - - } - } - sc.Complete(); -} - -// External stuff - used for dynamic-loading, not implemented in wxStyledTextCtrl yet. -// Inspired by the caml external lexer - Credits to Robert Roessler - http://www.rftp.com -#ifdef BUILD_EXTERNAL_LEXER -static const char* LexerName = "haskell"; - -void EXT_LEXER_DECL Lex(unsigned int lexer, unsigned int startPos, int length, int initStyle, - char *words[], WindowID window, char *props) -{ - PropSetSimple ps; - ps.SetMultiple(props); - WindowAccessor wa(window, ps); - - int nWL = 0; - for (; words[nWL]; nWL++) ; - WordList** wl = new WordList* [nWL + 1]; - int i = 0; - for (; i<nWL; i++) - { - wl[i] = new WordList(); - wl[i]->Set(words[i]); - } - wl[i] = 0; - - ColorizeHaskellDoc(startPos, length, initStyle, wl, wa); - wa.Flush(); - for (i=nWL-1;i>=0;i--) - delete wl[i]; - delete [] wl; -} - -void EXT_LEXER_DECL Fold (unsigned int lexer, unsigned int startPos, int length, int initStyle, - char *words[], WindowID window, char *props) -{ - -} - -int EXT_LEXER_DECL GetLexerCount() -{ - return 1; -} - -void EXT_LEXER_DECL GetLexerName(unsigned int Index, char *name, int buflength) -{ - if (buflength > 0) { - buflength--; - int n = strlen(LexerName); - if (n > buflength) - n = buflength; - memcpy(name, LexerName, n), name[n] = '\0'; - } -} -#endif - -LexerModule lmHaskell(SCLEX_HASKELL, ColorizeHaskellDoc, "haskell"); - |