diff options
| -rw-r--r-- | doc/ScintillaHistory.html | 1 | ||||
| -rw-r--r-- | gtk/makefile | 2 | ||||
| -rw-r--r-- | gtk/scintilla.mak | 3 | ||||
| -rw-r--r-- | include/SciLexer.h | 19 | ||||
| -rw-r--r-- | include/Scintilla.iface | 21 | ||||
| -rw-r--r-- | src/KeyWords.cxx | 1 | ||||
| -rw-r--r-- | src/LexD.cxx | 354 | ||||
| -rw-r--r-- | vcbuild/SciLexer.dsp | 4 | ||||
| -rw-r--r-- | win32/makefile | 2 | ||||
| -rw-r--r-- | win32/scintilla.mak | 3 | ||||
| -rw-r--r-- | win32/scintilla_vc6.mak | 3 | 
11 files changed, 411 insertions, 2 deletions
| diff --git a/doc/ScintillaHistory.html b/doc/ScintillaHistory.html index 5884d7460..365472d4f 100644 --- a/doc/ScintillaHistory.html +++ b/doc/ScintillaHistory.html @@ -224,6 +224,7 @@  	<li>Snow</li>  	<li>Mitchell Foral</li>  	<li>Pieter Holtzhausen</li> +	<li>Waldemar Augustyn</li>      </ul>      <p>         Images used in GTK+ version diff --git a/gtk/makefile b/gtk/makefile index d88a4e33b..64a7934c7 100644 --- a/gtk/makefile +++ b/gtk/makefile @@ -65,7 +65,7 @@ endif  LEXOBJS=\  LexAda.o LexAPDL.o LexAsm.o LexAsn1.o LexAU3.o LexAVE.o LexBaan.o LexBash.o \  LexBasic.o LexBullant.o LexCaml.o LexCLW.o LexConf.o LexCPP.o LexCrontab.o \ -LexCsound.o LexCSS.o LexEiffel.o LexErlang.o LexEScript.o LexFlagship.o \ +LexCsound.o LexCSS.o LexD.o LexEiffel.o LexErlang.o LexEScript.o LexFlagship.o \  LexForth.o LexFortran.o LexGui4Cli.o LexHaskell.o LexHTML.o LexInno.o LexKix.o \  LexLisp.o LexLout.o LexLua.o LexMatlab.o LexMetapost.o LexMMIXAL.o LexMPT.o \  LexMSSQL.o LexNsis.o LexOpal.o LexOthers.o LexPascal.o LexPB.o LexPerl.o \ diff --git a/gtk/scintilla.mak b/gtk/scintilla.mak index ad2d3fc4e..59704918b 100644 --- a/gtk/scintilla.mak +++ b/gtk/scintilla.mak @@ -157,6 +157,7 @@ LEXOBJS=\  	$(DIR_O)\LexCrontab.obj \  	$(DIR_O)\LexCsound.obj \  	$(DIR_O)\LexCSS.obj \ +	$(DIR_O)\LexD.obj \  	$(DIR_O)\LexEiffel.obj \  	$(DIR_O)\LexErlang.obj \  	$(DIR_O)\LexEScript.obj \ @@ -353,6 +354,8 @@ $(DIR_O)\LexCsound.obj: ..\src\LexCsound.cxx $(LEX_HEADERS)  $(DIR_O)\LexCSS.obj: ..\src\LexCSS.cxx $(LEX_HEADERS) +$(DIR_O)\LexD.obj: ..\src\LexD.cxx $(LEX_HEADERS) +  $(DIR_O)\LexEiffel.obj: ..\src\LexEiffel.cxx $(LEX_HEADERS)  $(DIR_O)\LexErlang.obj: ..\src\LexErlang.cxx $(LEX_HEADERS) diff --git a/include/SciLexer.h b/include/SciLexer.h index 22d016d21..9e14a058d 100644 --- a/include/SciLexer.h +++ b/include/SciLexer.h @@ -91,6 +91,7 @@  #define SCLEX_INNOSETUP 76  #define SCLEX_OPAL 77  #define SCLEX_SPICE 78 +#define SCLEX_D 79  #define SCLEX_AUTOMATIC 1000  #define SCE_P_DEFAULT 0  #define SCE_P_COMMENTLINE 1 @@ -128,6 +129,24 @@  #define SCE_C_COMMENTDOCKEYWORD 17  #define SCE_C_COMMENTDOCKEYWORDERROR 18  #define SCE_C_GLOBALCLASS 19 +#define SCE_D_DEFAULT 0 +#define SCE_D_COMMENT 1 +#define SCE_D_COMMENTLINE 2 +#define SCE_D_COMMENTDOC 3 +#define SCE_D_COMMENTNESTED 4 +#define SCE_D_NUMBER 5 +#define SCE_D_WORD 6 +#define SCE_D_WORD2 7 +#define SCE_D_WORD3 8 +#define SCE_D_TYPEDEF 9 +#define SCE_D_STRING 10 +#define SCE_D_STRINGEOL 11 +#define SCE_D_CHARACTER 12 +#define SCE_D_OPERATOR 13 +#define SCE_D_IDENTIFIER 14 +#define SCE_D_COMMENTLINEDOC 15 +#define SCE_D_COMMENTDOCKEYWORD 16 +#define SCE_D_COMMENTDOCKEYWORDERROR 17  #define SCE_TCL_DEFAULT 0  #define SCE_TCL_COMMENT 1  #define SCE_TCL_COMMENTLINE 2 diff --git a/include/Scintilla.iface b/include/Scintilla.iface index 277ea9237..085470e04 100644 --- a/include/Scintilla.iface +++ b/include/Scintilla.iface @@ -1851,6 +1851,7 @@ val SCLEX_FREEBASIC=75  val SCLEX_INNOSETUP=76  val SCLEX_OPAL=77  val SCLEX_SPICE=78 +val SCLEX_D=79  # When a lexer specifies its language as SCLEX_AUTOMATIC it receives a  # value assigned in sequence from SCLEX_AUTOMATIC+1. @@ -1897,6 +1898,26 @@ val SCE_C_WORD2=16  val SCE_C_COMMENTDOCKEYWORD=17  val SCE_C_COMMENTDOCKEYWORDERROR=18  val SCE_C_GLOBALCLASS=19 +# Lexical states for SCLEX_D +lex D=SCLEX_D SCE_D_ +val SCE_D_DEFAULT=0 +val SCE_D_COMMENT=1 +val SCE_D_COMMENTLINE=2 +val SCE_D_COMMENTDOC=3 +val SCE_D_COMMENTNESTED=4 +val SCE_D_NUMBER=5 +val SCE_D_WORD=6 +val SCE_D_WORD2=7 +val SCE_D_WORD3=8 +val SCE_D_TYPEDEF=9 +val SCE_D_STRING=10 +val SCE_D_STRINGEOL=11 +val SCE_D_CHARACTER=12 +val SCE_D_OPERATOR=13 +val SCE_D_IDENTIFIER=14 +val SCE_D_COMMENTLINEDOC=15 +val SCE_D_COMMENTDOCKEYWORD=16 +val SCE_D_COMMENTDOCKEYWORDERROR=17  # Lexical states for SCLEX_TCL  lex TCL=SCLEX_TCL SCE_TCL_  val SCE_TCL_DEFAULT=0 diff --git a/src/KeyWords.cxx b/src/KeyWords.cxx index f82eb7df6..745169575 100644 --- a/src/KeyWords.cxx +++ b/src/KeyWords.cxx @@ -157,6 +157,7 @@ int Scintilla_LinkLexers() {  	LINK_LEXER(lmCPPNoCase);  	LINK_LEXER(lmCsound);  	LINK_LEXER(lmCss); +	LINK_LEXER(lmD);  	LINK_LEXER(lmDiff);  	LINK_LEXER(lmEiffel);  	LINK_LEXER(lmEiffelkw); diff --git a/src/LexD.cxx b/src/LexD.cxx new file mode 100644 index 000000000..9103d25e7 --- /dev/null +++ b/src/LexD.cxx @@ -0,0 +1,354 @@ +/** @file LexD.cxx + ** Lexer for D. + ** + ** Copyright (c) 2006 by Waldemar Augustyn <waldemar@wdmsys.com> + **/ +// Copyright 1998-2005 by Neil Hodgson <neilh@scintilla.org> +// The License.txt file describes the conditions under which this software may be distributed. + +#include <stdlib.h> +#include <string.h> +#include <ctype.h> +#include <stdio.h> +#include <stdarg.h> + +#include "Platform.h" + +#include "PropSet.h" +#include "Accessor.h" +#include "StyleContext.h" +#include "KeyWords.h" +#include "Scintilla.h" +#include "SciLexer.h" + +/*/ Nested comments require keeping the value of the nesting level for every +    position in the document.  But since scintilla always styles line by line, +    we only need to store one value per line. The non-negative number indicates +    nesting level at the end of the line. +/*/ + +// We use custom qualifiers since it is not clear what D allows. + +static bool IsWordStart(int ch) { +	return isascii(ch) && (isalpha(ch) || ch == '_'); +} + +static bool IsWord(int ch) { +	return isascii(ch) && (isalnum(ch) || ch == '_'); +} + +static bool IsDoxygen(int ch) { +	if (isascii(ch) && islower(ch)) +		return true; +	if (ch == '$' || ch == '@' || ch == '\\' || +		ch == '&' || ch == '#' || ch == '<' || ch == '>' || +		ch == '{' || ch == '}' || ch == '[' || ch == ']') +		return true; +	return false; +} + + +static void ColouriseDoc(unsigned int startPos, int length, int initStyle,  +    WordList *keywordlists[], Accessor &styler, bool caseSensitive) { + +    WordList &keywords = *keywordlists[0]; +    WordList &keywords2 = *keywordlists[1]; +    WordList &keywords3 = *keywordlists[2]; +    WordList &keywords4 = *keywordlists[3]; + +    int styleBeforeDCKeyword = SCE_D_DEFAULT; + +    StyleContext sc(startPos, length, initStyle, styler); + +    int curLine = styler.GetLine(startPos); +    int curNcLevel = curLine > 0? styler.GetLineState(curLine-1): 0; + +    for (; sc.More(); sc.Forward()) { + +        if (sc.atLineStart) { +            if (sc.state == SCE_D_STRING) { +                // Prevent SCE_D_STRINGEOL from leaking back to previous line which +                // ends with a line continuation by locking in the state upto this position. +                sc.SetState(SCE_D_STRING); +            } +            curLine = styler.GetLine(sc.currentPos); +            styler.SetLineState(curLine, curNcLevel); +        } + +        // Handle line continuation generically. +        if (sc.ch == '\\') { +            if (sc.chNext == '\n' || sc.chNext == '\r') { +                sc.Forward(); +                if (sc.ch == '\r' && sc.chNext == '\n') { +                    sc.Forward(); +                } +                continue; +            } +        } + +        // Determine if the current state should terminate. +        switch (sc.state) { +            case SCE_D_OPERATOR: +                sc.SetState(SCE_D_DEFAULT); +                break; +            case SCE_D_NUMBER: +                // We accept almost anything because of hex. and number suffixes +                if (!IsWord(sc.ch) && sc.ch != '.') { +                    sc.SetState(SCE_D_DEFAULT); +                } +                break; +            case SCE_D_IDENTIFIER: +                if (!IsWord(sc.ch)) { +                    char s[1000]; +                    if (caseSensitive) { +                        sc.GetCurrent(s, sizeof(s)); +                    } else { +                        sc.GetCurrentLowered(s, sizeof(s)); +                    } +                    if (keywords.InList(s)) { +                        sc.ChangeState(SCE_D_WORD); +                    } else if (keywords2.InList(s)) { +                        sc.ChangeState(SCE_D_WORD2); +                    } else if (keywords4.InList(s)) { +                        sc.ChangeState(SCE_D_TYPEDEF); +                    } +                    sc.SetState(SCE_D_DEFAULT); +                } +                break; +            case SCE_D_COMMENT: +                if (sc.Match('*', '/')) { +                    sc.Forward(); +                    sc.ForwardSetState(SCE_D_DEFAULT); +                } +                break; +            case SCE_D_COMMENTDOC: +                if (sc.Match('*', '/')) { +                    sc.Forward(); +                    sc.ForwardSetState(SCE_D_DEFAULT); +                } else if (sc.ch == '@' || sc.ch == '\\') { // JavaDoc and Doxygen support +                    // Verify that we have the conditions to mark a comment-doc-keyword +                    if ((IsASpace(sc.chPrev) || sc.chPrev == '*') && (!IsASpace(sc.chNext))) { +                        styleBeforeDCKeyword = SCE_D_COMMENTDOC; +                        sc.SetState(SCE_D_COMMENTDOCKEYWORD); +                    } +                } +                break; +            case SCE_D_COMMENTLINE: +                if (sc.atLineStart) { +                    sc.SetState(SCE_D_DEFAULT); +                } +                break; +            case SCE_D_COMMENTLINEDOC: +                if (sc.atLineStart) { +                    sc.SetState(SCE_D_DEFAULT); +                } else if (sc.ch == '@' || sc.ch == '\\') { // JavaDoc and Doxygen support +                    // Verify that we have the conditions to mark a comment-doc-keyword +                    if ((IsASpace(sc.chPrev) || sc.chPrev == '/' || sc.chPrev == '!') && (!IsASpace(sc.chNext))) { +                        styleBeforeDCKeyword = SCE_D_COMMENTLINEDOC; +                        sc.SetState(SCE_D_COMMENTDOCKEYWORD); +                    } +                } +                break; +            case SCE_D_COMMENTDOCKEYWORD: +                if ((styleBeforeDCKeyword == SCE_D_COMMENTDOC) && sc.Match('*', '/')) { +                    sc.ChangeState(SCE_D_COMMENTDOCKEYWORDERROR); +                    sc.Forward(); +                    sc.ForwardSetState(SCE_D_DEFAULT); +                } else if (!IsDoxygen(sc.ch)) { +                    char s[100]; +                    if (caseSensitive) { +                        sc.GetCurrent(s, sizeof(s)); +                    } else { +                        sc.GetCurrentLowered(s, sizeof(s)); +                    } +                    if (!IsASpace(sc.ch) || !keywords3.InList(s + 1)) { +                        sc.ChangeState(SCE_D_COMMENTDOCKEYWORDERROR); +                    } +                    sc.SetState(styleBeforeDCKeyword); +                } +                break; +            case SCE_D_COMMENTNESTED: +                if (sc.Match('+', '/')) { +                    if (curNcLevel > 0) +                        curNcLevel -= 1; +                    curLine = styler.GetLine(sc.currentPos); +                    styler.SetLineState(curLine, curNcLevel); +                    sc.Forward(); +                    if (curNcLevel == 0) { +                        sc.ForwardSetState(SCE_D_DEFAULT); +		    } +                } +                else if (sc.Match('/','+')) { +                    curNcLevel += 1; +                    curLine = styler.GetLine(sc.currentPos); +                    styler.SetLineState(curLine, curNcLevel); +                    sc.Forward(); +                } +                break; +            case SCE_D_STRING: +                if (sc.atLineEnd) { +                    sc.ChangeState(SCE_D_STRINGEOL); +                } else if (sc.ch == '\\') { +                    if (sc.chNext == '\"' || sc.chNext == '\'' || sc.chNext == '\\') { +                        sc.Forward(); +                    } +                } else if (sc.ch == '\"') { +                    sc.ForwardSetState(SCE_D_DEFAULT); +                } +                break; +            case SCE_D_CHARACTER: +                if (sc.atLineEnd) { +                    sc.ChangeState(SCE_D_STRINGEOL); +                } else if (sc.ch == '\\') { +                    if (sc.chNext == '\"' || sc.chNext == '\'' || sc.chNext == '\\') { +                        sc.Forward(); +                    } +                } else if (sc.ch == '\'') { +                    sc.ForwardSetState(SCE_D_DEFAULT); +                } +                break; +            case SCE_D_STRINGEOL: +                if (sc.atLineStart) { +                    sc.SetState(SCE_D_DEFAULT); +                } +                break; +        } + +        // Determine if a new state should be entered. +        if (sc.state == SCE_D_DEFAULT) { +            if (IsADigit(sc.ch) || (sc.ch == '.' && IsADigit(sc.chNext))) { +                    sc.SetState(SCE_D_NUMBER); +            } else if (IsWordStart(sc.ch)) { +                    sc.SetState(SCE_D_IDENTIFIER); +            } else if (sc.Match('/','+')) { +                curNcLevel += 1; +		curLine = styler.GetLine(sc.currentPos); +                styler.SetLineState(curLine, curNcLevel); +                sc.SetState(SCE_D_COMMENTNESTED); +                sc.Forward(); +            } else if (sc.Match('/', '*')) { +                if (sc.Match("/**") || sc.Match("/*!")) {   // Support of Qt/Doxygen doc. style +                    sc.SetState(SCE_D_COMMENTDOC); +                } else { +                    sc.SetState(SCE_D_COMMENT); +                } +                sc.Forward();   // Eat the * so it isn't used for the end of the comment +            } else if (sc.Match('/', '/')) { +                if ((sc.Match("///") && !sc.Match("////")) || sc.Match("//!")) +                    // Support of Qt/Doxygen doc. style +                    sc.SetState(SCE_D_COMMENTLINEDOC); +                else +                    sc.SetState(SCE_D_COMMENTLINE); +            } else if (sc.ch == '\"') { +                sc.SetState(SCE_D_STRING); +            } else if (sc.ch == '\'') { +                sc.SetState(SCE_D_CHARACTER); +            } else if (isoperator(static_cast<char>(sc.ch))) { +                sc.SetState(SCE_D_OPERATOR); +            } +        } +    } +    sc.Complete(); +} + +static bool IsStreamCommentStyle(int style) { +    return style == SCE_D_COMMENT || +        style == SCE_D_COMMENTDOC || +        style == SCE_D_COMMENTDOCKEYWORD || +        style == SCE_D_COMMENTDOCKEYWORDERROR; +} + +// Store both the current line's fold level and the next lines in the +// level store to make it easy to pick up with each increment +// and to make it possible to fiddle the current level for "} else {". +static void FoldDoc(unsigned int startPos, int length, int initStyle, Accessor &styler) { +    bool foldComment = styler.GetPropertyInt("fold.comment") != 0; +    bool foldCompact = styler.GetPropertyInt("fold.compact", 1) != 0; +    bool foldAtElse = styler.GetPropertyInt("lexer.d.fold.at.else", +		styler.GetPropertyInt("fold.at.else", 0)) != 0; +    unsigned int endPos = startPos + length; +    int visibleChars = 0; +    int lineCurrent = styler.GetLine(startPos); +    int levelCurrent = SC_FOLDLEVELBASE; +    if (lineCurrent > 0) +        levelCurrent = styler.LevelAt(lineCurrent-1) >> 16; +    int levelMinCurrent = levelCurrent; +    int levelNext = levelCurrent; +    char chNext = styler[startPos]; +    int styleNext = styler.StyleAt(startPos); +    int style = initStyle; +    for (unsigned int i = startPos; i < endPos; i++) { +        char ch = chNext; +        chNext = styler.SafeGetCharAt(i + 1); +        int stylePrev = style; +        style = styleNext; +        styleNext = styler.StyleAt(i + 1); +        bool atEOL = (ch == '\r' && chNext != '\n') || (ch == '\n'); +        if (foldComment && IsStreamCommentStyle(style)) { +            if (!IsStreamCommentStyle(stylePrev)) { +                levelNext++; +            } else if (!IsStreamCommentStyle(styleNext) && !atEOL) { +                // Comments don't end at end of line and the next character may be unstyled. +                levelNext--; +            } +        } +        if (style == SCE_D_OPERATOR) { +            if (ch == '{') { +                // Measure the minimum before a '{' to allow +                // folding on "} else {" +                if (levelMinCurrent > levelNext) { +                    levelMinCurrent = levelNext; +                } +                levelNext++; +            } else if (ch == '}') { +                levelNext--; +            } +        } +        if (atEOL) { +            if (foldComment) {	// Handle nested comments +		int nc; +                nc =  styler.GetLineState(lineCurrent); +                nc -= lineCurrent>0? styler.GetLineState(lineCurrent-1): 0; +                levelNext += nc; +	    } +            int levelUse = levelCurrent; +            if (foldAtElse) { +                levelUse = levelMinCurrent; +            } +            int lev = levelUse | levelNext << 16; +            if (visibleChars == 0 && foldCompact) +                lev |= SC_FOLDLEVELWHITEFLAG; +            if (levelUse < levelNext) +                lev |= SC_FOLDLEVELHEADERFLAG; +            if (lev != styler.LevelAt(lineCurrent)) { +                styler.SetLevel(lineCurrent, lev); +            } +            lineCurrent++; +            levelCurrent = levelNext; +            levelMinCurrent = levelCurrent; +            visibleChars = 0; +        } +        if (!IsASpace(ch)) +            visibleChars++; +    } +} + +static void FoldDDoc(unsigned int startPos, int length, int initStyle, +    WordList *[], Accessor &styler) { +        FoldDoc(startPos, length, initStyle, styler); +} + +static const char * const dWordLists[] = { +            "Primary keywords and identifiers", +            "Secondary keywords and identifiers", +            "Documentation comment keywords", +            "Type definitions and aliases", +            0, +        }; + +static void ColouriseDDoc(unsigned int startPos, int length,  +    int initStyle, WordList *keywordlists[], Accessor &styler) { +        ColouriseDoc(startPos, length, initStyle, keywordlists, styler, true); +} + +LexerModule lmD(SCLEX_D, ColouriseDDoc, "d", FoldDDoc, dWordLists); diff --git a/vcbuild/SciLexer.dsp b/vcbuild/SciLexer.dsp index 8f18059e9..f54b4bde3 100644 --- a/vcbuild/SciLexer.dsp +++ b/vcbuild/SciLexer.dsp @@ -198,6 +198,10 @@ SOURCE=..\src\LexCPP.cxx  # End Source File  # Begin Source File +SOURCE=..\src\LexD.cxx +# End Source File +# Begin Source File +  SOURCE=..\src\LexCrontab.cxx  # End Source File  # Begin Source File diff --git a/win32/makefile b/win32/makefile index 203102312..41d50ac92 100644 --- a/win32/makefile +++ b/win32/makefile @@ -53,7 +53,7 @@ deps:  LEXOBJS=\  LexAda.o LexAPDL.o LexAsm.o LexAsn1.o LexAU3.o LexAVE.o LexBaan.o LexBash.o \  LexBasic.o LexBullant.o LexCaml.o LexCLW.o LexConf.o LexCPP.o LexCrontab.o \ -LexCsound.o LexCSS.o LexEiffel.o LexErlang.o LexEScript.o LexFlagship.o \ +LexCsound.o LexCSS.o LexD.o LexEiffel.o LexErlang.o LexEScript.o LexFlagship.o \  LexForth.o LexFortran.o LexGui4Cli.o LexHaskell.o LexHTML.o LexInno.o LexKix.o \  LexLisp.o LexLout.o LexLua.o LexMatlab.o LexMetapost.o LexMMIXAL.o LexMPT.o \  LexMSSQL.o LexNsis.o LexOpal.o LexOthers.o LexPascal.o LexPB.o LexPerl.o \ diff --git a/win32/scintilla.mak b/win32/scintilla.mak index 2ff1524db..d812696f4 100644 --- a/win32/scintilla.mak +++ b/win32/scintilla.mak @@ -127,6 +127,7 @@ LEXOBJS=\  	$(DIR_O)\LexCrontab.obj \  	$(DIR_O)\LexCsound.obj \  	$(DIR_O)\LexCSS.obj \ +	$(DIR_O)\LexD.obj \  	$(DIR_O)\LexEiffel.obj \  	$(DIR_O)\LexErlang.obj \  	$(DIR_O)\LexEScript.obj \ @@ -314,6 +315,8 @@ $(DIR_O)\LexCsound.obj: ..\src\LexCsound.cxx $(LEX_HEADERS)  $(DIR_O)\LexCSS.obj: ..\src\LexCSS.cxx $(LEX_HEADERS) +$(DIR_O)\LexD.obj: ..\src\LexD.cxx $(LEX_HEADERS) +  $(DIR_O)\LexEiffel.obj: ..\src\LexEiffel.cxx $(LEX_HEADERS)  $(DIR_O)\LexErlang.obj: ..\src\LexErlang.cxx $(LEX_HEADERS) diff --git a/win32/scintilla_vc6.mak b/win32/scintilla_vc6.mak index 60683abdc..e8f7fac77 100644 --- a/win32/scintilla_vc6.mak +++ b/win32/scintilla_vc6.mak @@ -129,6 +129,7 @@ LEXOBJS=\  	$(DIR_O)\LexCrontab.obj \  	$(DIR_O)\LexCsound.obj \  	$(DIR_O)\LexCSS.obj \ +	$(DIR_O)\LexD.obj \  	$(DIR_O)\LexEiffel.obj \  	$(DIR_O)\LexErlang.obj \  	$(DIR_O)\LexEScript.obj \ @@ -316,6 +317,8 @@ $(DIR_O)\LexCsound.obj: ..\src\LexCsound.cxx $(LEX_HEADERS)  $(DIR_O)\LexCSS.obj: ..\src\LexCSS.cxx $(LEX_HEADERS) +$(DIR_O)\LexD.obj: ..\src\LexD.cxx $(LEX_HEADERS) +  $(DIR_O)\LexEiffel.obj: ..\src\LexEiffel.cxx $(LEX_HEADERS)  $(DIR_O)\LexErlang.obj: ..\src\LexErlang.cxx $(LEX_HEADERS) | 
