diff options
| -rw-r--r-- | gtk/makefile | 2 | ||||
| -rw-r--r-- | gtk/scintilla.mak | 3 | ||||
| -rw-r--r-- | include/SciLexer.h | 17 | ||||
| -rw-r--r-- | include/Scintilla.iface | 19 | ||||
| -rw-r--r-- | src/KeyWords.cxx | 2 | ||||
| -rw-r--r-- | src/LexCLW.cxx | 427 | ||||
| -rw-r--r-- | win32/makefile | 4 | ||||
| -rw-r--r-- | win32/scintilla.mak | 3 | ||||
| -rw-r--r-- | win32/scintilla_vc6.mak | 3 | 
9 files changed, 477 insertions, 3 deletions
| diff --git a/gtk/makefile b/gtk/makefile index 32bccbddb..bd234b934 100644 --- a/gtk/makefile +++ b/gtk/makefile @@ -60,7 +60,7 @@ endif  #++Autogenerated -- run src/LexGen.py to regenerate  #**LEXOBJS=\\\n\(\*.o \)  LEXOBJS=\ -LexAda.o LexAsm.o LexAVE.o LexBaan.o LexBullant.o LexConf.o LexCPP.o \ +LexAda.o LexAsm.o LexAVE.o LexBaan.o LexBullant.o LexCLW.o LexConf.o LexCPP.o \  LexCrontab.o LexCSS.o LexEiffel.o LexEScript.o LexFortran.o LexHTML.o \  LexLisp.o LexLout.o LexLua.o LexMatlab.o LexMMIXAL.o LexNsis.o LexOthers.o \  LexPascal.o LexPerl.o LexPOV.o LexPS.o LexPython.o LexRuby.o LexScriptol.o \ diff --git a/gtk/scintilla.mak b/gtk/scintilla.mak index b03f071ba..bbf6e3335 100644 --- a/gtk/scintilla.mak +++ b/gtk/scintilla.mak @@ -125,6 +125,7 @@ LEXOBJS=\  	$(DIR_O)\LexAVE.obj \  	$(DIR_O)\LexBaan.obj \  	$(DIR_O)\LexBullant.obj \ +	$(DIR_O)\LexCLW.obj \  	$(DIR_O)\LexConf.obj \  	$(DIR_O)\LexCPP.obj \  	$(DIR_O)\LexCrontab.obj \ @@ -271,6 +272,8 @@ $(DIR_O)\LexBaan.obj: ..\src\LexBaan.cxx $(LEX_HEADERS)  $(DIR_O)\LexBullant.obj: ..\src\LexBullant.cxx $(LEX_HEADERS) +$(DIR_O)\LexCLW.obj: ..\src\LexCLW.cxx $(LEX_HEADERS) +  $(DIR_O)\LexConf.obj: ..\src\LexConf.cxx $(LEX_HEADERS)  $(DIR_O)\LexCPP.obj: ..\src\LexCPP.cxx $(LEX_HEADERS) diff --git a/include/SciLexer.h b/include/SciLexer.h index 34867542f..0e93d13c0 100644 --- a/include/SciLexer.h +++ b/include/SciLexer.h @@ -59,6 +59,8 @@  #define SCLEX_PS 42  #define SCLEX_NSIS 43  #define SCLEX_MMIXAL 44 +#define SCLEX_CLW 45 +#define SCLEX_CLWNOCASE 46  #define SCLEX_AUTOMATIC 1000  #define SCE_P_DEFAULT 0  #define SCE_P_COMMENTLINE 1 @@ -545,6 +547,21 @@  #define SCE_MMIXAL_OPERATOR 15  #define SCE_MMIXAL_SYMBOL 16  #define SCE_MMIXAL_INCLUDE 17 +#define SCE_CLW_DEFAULT 0 +#define SCE_CLW_LABEL 1 +#define SCE_CLW_COMMENT 2 +#define SCE_CLW_STRING 3 +#define SCE_CLW_USER_IDENTIFIER 4 +#define SCE_CLW_INTEGER_CONSTANT 5 +#define SCE_CLW_REAL_CONSTANT 6 +#define SCE_CLW_PICTURE_STRING 7 +#define SCE_CLW_KEYWORD 8 +#define SCE_CLW_COMPILER_DIRECTIVE 9 +#define SCE_CLW_BUILTIN_PROCEDURES_FUNCTION 10 +#define SCE_CLW_STRUCTURE_DATA_TYPE 11 +#define SCE_CLW_ATTRIBUTE 12 +#define SCE_CLW_STANDARD_EQUATE 13 +#define SCE_CLW_ERROR 14  //--Autogenerated -- end of section automatically generated from Scintilla.iface  #endif diff --git a/include/Scintilla.iface b/include/Scintilla.iface index 423eb5ce6..8df06a495 100644 --- a/include/Scintilla.iface +++ b/include/Scintilla.iface @@ -1592,6 +1592,8 @@ val SCLEX_ESCRIPT=41  val SCLEX_PS=42  val SCLEX_NSIS=43  val SCLEX_MMIXAL=44 +val SCLEX_CLW=45 +val SCLEX_CLWNOCASE=46  # When a lexer specifies its language as SCLEX_AUTOMATIC it receives a  # value assigned in sequence from SCLEX_AUTOMATIC+1. @@ -2163,6 +2165,23 @@ val SCE_MMIXAL_HEX=14  val SCE_MMIXAL_OPERATOR=15  val SCE_MMIXAL_SYMBOL=16  val SCE_MMIXAL_INCLUDE=17 +# Lexical states for SCLEX_CLW +lex Clarion=SCLEX_CLW SCE_CLW_ +val SCE_CLW_DEFAULT=0 +val SCE_CLW_LABEL=1 +val SCE_CLW_COMMENT=2 +val SCE_CLW_STRING=3 +val SCE_CLW_USER_IDENTIFIER=4 +val SCE_CLW_INTEGER_CONSTANT=5 +val SCE_CLW_REAL_CONSTANT=6 +val SCE_CLW_PICTURE_STRING=7 +val SCE_CLW_KEYWORD=8 +val SCE_CLW_COMPILER_DIRECTIVE=9 +val SCE_CLW_BUILTIN_PROCEDURES_FUNCTION=10 +val SCE_CLW_STRUCTURE_DATA_TYPE=11 +val SCE_CLW_ATTRIBUTE=12 +val SCE_CLW_STANDARD_EQUATE=13 +val SCE_CLW_ERROR=14  # Events diff --git a/src/KeyWords.cxx b/src/KeyWords.cxx index ae22baf2f..64b4680b8 100644 --- a/src/KeyWords.cxx +++ b/src/KeyWords.cxx @@ -134,6 +134,8 @@ int Scintilla_LinkLexers() {  	LINK_LEXER(lmAVE);  	LINK_LEXER(lmBaan);  	LINK_LEXER(lmBullant); +	LINK_LEXER(lmClw); +	LINK_LEXER(lmClwNoCase);  	LINK_LEXER(lmConf);  	LINK_LEXER(lmCPP);  	LINK_LEXER(lmCPPNoCase); diff --git a/src/LexCLW.cxx b/src/LexCLW.cxx new file mode 100644 index 000000000..cfcf52e35 --- /dev/null +++ b/src/LexCLW.cxx @@ -0,0 +1,427 @@ +// Scintilla source code edit control +/** @file LexClw.cxx + ** Lexer for Clarion. + **/ +// Copyright 2003 by Ron Schofield <ron@schofieldcomputer.com> +// 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" + +// Is a label start character +inline bool IsALabelStart(const int iChar) { +	return(isalpha(iChar) || iChar == '_'); +} + +// Is a label character +inline bool IsALabelCharacter(const int iChar) { +	return(isalnum(iChar) || iChar == '_' || iChar == ':'); +} + +// Is the character is a ! and the the next character is not a ! +inline bool IsACommentStart(StyleContext &scDoc) { +	return(scDoc.ch == '!' && scDoc.chNext != '!'); +} + +// Is the character a Clarion hex character (ABCDEF) +inline bool IsAHexCharacter(const int iChar, bool bCaseSensitive) { +	// Case insensitive. +	if (!bCaseSensitive) { +		if (strchr("ABCDEFabcdef", iChar) != NULL) { +			return(true); +		} +	} +	// Case sensitive +	else { +		if (strchr("ABCDEF", iChar) != NULL) { +			return(true); +		} +	} +	return(false); +} + +// Is the character a Clarion base character (B=Binary, O=Octal, H=Hex) +inline bool IsANumericBaseCharacter(const int iChar, bool bCaseSensitive) { +	// Case insensitive. +	if (!bCaseSensitive) { +		// If character is a numeric base character +		if (strchr("BOHboh", iChar) != NULL) { +			return(true); +		} +	} +	// Case sensitive +	else { +		// If character is a numeric base character +		if (strchr("BOH", iChar) != NULL) { +			return(true); +		} +	} +	return(false); +} + +// Set the correct numeric constant state +inline bool SetNumericConstantState(StyleContext &scDoc) { +	int iPoints = 0;			// Point counter +	char cNumericString[100];	// Numeric string buffer + +	// Buffer the current numberic string +	scDoc.GetCurrent(cNumericString, sizeof(cNumericString)); +	// Loop through the string until end of string (NULL termination) +	for (int iIndex = 0; cNumericString[iIndex] != '\0'; iIndex++) { +		// Depending on the character +		switch (cNumericString[iIndex]) { +			// Is a . (point) +			case '.' : +				// Increment point counter +				iPoints++; +				break; +			default : +				break; +		} +	} +	// If points found (can be more than one for improper formatted number +	if (iPoints > 0) { +		return(true); +	} +	// Else no points found +	else { +		return(false); +	} +} + +// Clarion Language Colouring Procedure +static void ColouriseClwDoc(unsigned int uiStartPos, int iLength, int iInitStyle, WordList *wlKeywords[], Accessor &accStyler, bool bCaseSensitive) { + +	int iParenthesesLevel=0;		// Parenthese Level + +	WordList &wlClarionKeywords = *wlKeywords[0];		// Clarion Keywords +	WordList &wlCompilerDirectives = *wlKeywords[1];	// Compiler Directives +	WordList &wlBuiltInProcsFuncs = *wlKeywords[2];		// Builtin Procedures and Functions +	WordList &wlStructsDataTypes = *wlKeywords[3];		// Structures and Data Types +	WordList &wlAttributes = *wlKeywords[4];			// Procedure Attributes +	WordList &wlStandardEquates = *wlKeywords[5];		// Standard Equates +	WordList &wlReservedWords = *wlKeywords[6];			// Clarion Reserved Keywords + +	StyleContext scDoc(uiStartPos, iLength, iInitStyle, accStyler); + +	// lex source code +    for (; scDoc.More(); scDoc.Forward()) +	{ +		// +		// Determine if the current state should terminate. +		// + +		// Label State Handling +		if (scDoc.state == SCE_CLW_LABEL) { +			// If the character is not a valid label +			if (!IsALabelCharacter(scDoc.ch)) { +				// If the character is a . (dot syntax) +				if (scDoc.ch == '.') { +					// Uncolour the . (dot) to default state, move forward one character, +					// and change back to the label state. +					scDoc.SetState(SCE_CLW_DEFAULT); +					scDoc.Forward(); +					scDoc.SetState(SCE_CLW_LABEL); +				} +				// Else terminate the label state +				else { +					char cLabel[100];		// Label buffer +					// Buffer the current label string +					scDoc.GetCurrent(cLabel,sizeof(cLabel)); +					// If case insensitive, convert string to UPPERCASE to match passed keywords. +					if (!bCaseSensitive) { +						strupr(cLabel); +					} +					// If label string is in the Clarion reserved keyword list +					if (wlReservedWords.InList(cLabel)){ +						// change to error state +						scDoc.ChangeState(SCE_CLW_ERROR); +					} +					// Else if label string is in the compiler directive keyword list +					else if (wlCompilerDirectives.InList(cLabel)) { +						// change the state to compiler directive state +						scDoc.ChangeState(SCE_CLW_COMPILER_DIRECTIVE); +					} +					// Terminate the label state and set to default state +					scDoc.SetState(SCE_CLW_DEFAULT); +				} +			} +		} +		// Keyword State Handling +		else if (scDoc.state == SCE_CLW_KEYWORD) { +			// If character is : (colon) +			if (scDoc.ch == ':') { +				char cEquate[100];		// Equate buffer +				// Move forward to include : (colon) in buffer +				scDoc.Forward(); +				// Buffer the equate string +				scDoc.GetCurrent(cEquate,sizeof(cEquate)); +				// If case insensitive, convert string to UPPERCASE to match passed keywords. +				if (!bCaseSensitive) { +					strupr(cEquate); +				} +				// If statement string is in the equate list +				if (wlStandardEquates.InList(cEquate)) { +					// Change to equate state +					scDoc.ChangeState(SCE_CLW_STANDARD_EQUATE); +				} +			} +			// If the character is not a valid label character +			else if (!IsALabelCharacter(scDoc.ch)) { +				char cStatement[100];		// Statement buffer +				// Buffer the statement string +				scDoc.GetCurrent(cStatement,sizeof(cStatement)); +				// If case insensitive, convert string to UPPERCASE to match passed keywords. +				if (!bCaseSensitive) { +					strupr(cStatement); +				} +				// If statement string is in the Clarion keyword list +				if (wlClarionKeywords.InList(cStatement)) { +					// Set to the Clarion keyword state +					scDoc.ChangeState(SCE_CLW_KEYWORD); +				} +				// Else if statement string is in the compiler directive keyword list +				else if (wlCompilerDirectives.InList(cStatement)) { +					// Set to the compiler directive state +					scDoc.ChangeState(SCE_CLW_COMPILER_DIRECTIVE); +				} +				// Else if statement string is in the builtin procedures and functions keyword list +				else if (wlBuiltInProcsFuncs.InList(cStatement)) { +					// Set to the builtin procedures and functions state +					scDoc.ChangeState(SCE_CLW_BUILTIN_PROCEDURES_FUNCTION); +				} +				// Else if statement string is in the tructures and data types keyword list +				else if (wlStructsDataTypes.InList(cStatement)) { +					// Set to the structures and data types state +					scDoc.ChangeState(SCE_CLW_STRUCTURE_DATA_TYPE); +				} +				// Else if statement string is in the procedure attribute keyword list +				else if (wlAttributes.InList(cStatement)) { +					// Set to the procedure attribute state +					scDoc.ChangeState(SCE_CLW_ATTRIBUTE); +				} +				// Else if statement string is in the standard equate keyword list +				else if (wlStandardEquates.InList(cStatement)) { +					// Set to the standard equate state +					scDoc.ChangeState(SCE_CLW_STANDARD_EQUATE); +				} +				// Terminate the keyword state and set to default state +				scDoc.SetState(SCE_CLW_DEFAULT); +			} +		} +		// String State Handling +		else if (scDoc.state == SCE_CLW_STRING) { +			// If the character is an ' (single quote) +			if (scDoc.ch == '\'') { +				// Set the state to default and move forward colouring +				// the ' (single quote) as default state +				// terminating the string state +				scDoc.SetState(SCE_CLW_DEFAULT); +				scDoc.Forward(); +			} +			// If the next character is an ' (single quote) +			if (scDoc.chNext == '\'') { +				// Move forward one character and set to default state +				// colouring the next ' (single quote) as default state +				// terminating the string state +				scDoc.ForwardSetState(SCE_CLW_DEFAULT); +				scDoc.Forward(); +			} +		} +		// Picture String State Handling +		else if (scDoc.state == SCE_CLW_PICTURE_STRING) { +			// If the character is an ( (open parenthese) +			if (scDoc.ch == '(') { +				// Increment the parenthese level +				iParenthesesLevel++; +			} +			// Else if the character is a ) (close parenthese) +			else if (scDoc.ch == ')') { +				// If the parenthese level is set to zero +				// parentheses matched +				if (!iParenthesesLevel) { +					scDoc.SetState(SCE_CLW_DEFAULT); +				} +				// Else parenthese level is greater than zero +				// still looking for matching parentheses +				else { +					// Decrement the parenthese level +					iParenthesesLevel--; +				} +			} +		} +		// Standard Equate State Handling +		else if (scDoc.state == SCE_CLW_STANDARD_EQUATE) { +			if (!isalnum(scDoc.ch)) { +				scDoc.SetState(SCE_CLW_DEFAULT); +			} +		} +		// Integer Constant State Handling +		else if (scDoc.state == SCE_CLW_INTEGER_CONSTANT) { +			// If the character is not a digit (0-9) +			// or character is not a hexidecimal character (A-F) +			// or character is not a . (point) +			// or character is not a numberic base character (B,O,H) +			if (!(isdigit(scDoc.ch) +			|| IsAHexCharacter(scDoc.ch, bCaseSensitive) +			|| scDoc.ch == '.' +			|| IsANumericBaseCharacter(scDoc.ch, bCaseSensitive))) { +				// If the number was a real +				if (SetNumericConstantState(scDoc)) { +					// Colour the matched string to the real constant state +					scDoc.ChangeState(SCE_CLW_REAL_CONSTANT); +				} +				// Else the number was an integer +				else { +					// Colour the matched string to an integer constant state +					scDoc.ChangeState(SCE_CLW_INTEGER_CONSTANT); +				} +				// Terminate the integer constant state and set to default state +				scDoc.SetState(SCE_CLW_DEFAULT); +			} +		} + +		// +		// Determine if a new state should be entered. +		// + +		// Beginning of Line Handling +		if (scDoc.atLineStart) { +			// If column 1 character is a label start character +			if (IsALabelStart(scDoc.ch)) { +				// Set the state to label +				scDoc.SetState(SCE_CLW_LABEL); +			} +			// else if character is a space or tab +			else if (IsASpace(scDoc.ch)){ +				// Set to default state +				scDoc.SetState(SCE_CLW_DEFAULT); +			} +			// else if the start of a comment or is an * (asterisk) +			else if (IsACommentStart(scDoc) || scDoc.ch == '*' ) { +				// then set the state to comment. +				scDoc.SetState(SCE_CLW_COMMENT); +			} +			// else the character is a ? (question mark) +			else if (scDoc.ch == '?') { +				// Change to the compiler directive state, move forward, +				// colouring the ? (question mark), change back to default state. +				scDoc.ChangeState(SCE_CLW_COMPILER_DIRECTIVE); +				scDoc.Forward(); +				scDoc.SetState(SCE_CLW_DEFAULT); +			} +			// else an invalid character in column 1 +			else { +				// Set to error state +				scDoc.SetState(SCE_CLW_ERROR); +			} +		} +		// End of Line Handling +		else if (scDoc.atLineEnd) { +			// Reset to the default state at the end of each line. +			scDoc.SetState(SCE_CLW_DEFAULT); +		} +		// Default Handling +		else { +			// If in default state +			if (scDoc.state == SCE_CLW_DEFAULT) { +				// If is a letter could be a possible statement +				if (isalpha(scDoc.ch)) { +					// Set the state to Clarion Keyword and verify later +					scDoc.SetState(SCE_CLW_KEYWORD); +				} +				// else is a number +				else if (isdigit(scDoc.ch)) { +					// Set the state to Integer Constant and verify later +					scDoc.SetState(SCE_CLW_INTEGER_CONSTANT); +				} +				// else if the start of a comment or a | (line continuation) +				else if (IsACommentStart(scDoc) || scDoc.ch == '|') { +					// then set the state to comment. +					scDoc.SetState(SCE_CLW_COMMENT); +				} +				// else if the character is a ' (single quote) +				else if (scDoc.ch == '\'') { +					// If the character is also a ' (single quote) +					// Embedded Apostrophe +					if (scDoc.chNext == '\'') { +						// Move forward colouring it as default state +						scDoc.ForwardSetState(SCE_CLW_DEFAULT); +					} +					else { +						// move to the next character and then set the state to comment. +						scDoc.ForwardSetState(SCE_CLW_STRING); +					} +				} +				// else the character is an @ (apersand) +				else if (scDoc.ch == '@') { +					// Case insensitive. +					if (!bCaseSensitive) { +						// If character is a valid picture token character +						if (strchr("DEKNPSTdeknpst", scDoc.chNext) != NULL) { +							// Set to the picture string state +							scDoc.SetState(SCE_CLW_PICTURE_STRING); +						} +					} +					// Case sensitive +					else { +						// If character is a valid picture token character +						if (strchr("DEKNPST", scDoc.chNext) != NULL) { +							// Set the picture string state +							scDoc.SetState(SCE_CLW_PICTURE_STRING); +						} +					} +				} +			} +		} +	} +	// lexing complete +	scDoc.Complete(); +} + +// Clarion Language Case Sensitive Colouring Procedure +static void ColouriseClwDocSensitive(unsigned int uiStartPos, int iLength, int iInitStyle, WordList *wlKeywords[], Accessor &accStyler) { +	ColouriseClwDoc(uiStartPos, iLength, iInitStyle, wlKeywords, accStyler, true); +} + +// Clarion Language Case Insensitive Colouring Procedure +static void ColouriseClwDocInsensitive(unsigned int uiStartPos, int iLength, int iInitStyle, WordList *wlKeywords[], Accessor &accStyler) { +	ColouriseClwDoc(uiStartPos, iLength, iInitStyle, wlKeywords, accStyler, false); +} + +// Clarion Language Folding Procedure +#ifdef FOLDING_IMPLEMENTED +static void FoldClwDoc(unsigned int uiStartPos, int iLength, int iInitStyle, WordList *wlKeywords[], Accessor &accStyler) { + +} +#endif + +// Word List Descriptions +static const char * const rgWordListDescriptions[] = { +	"Clarion Keywords", +	"Compiler Directives", +	"Built-in Procedures and Functions", +	"Structure and Data Types", +	"Attributes", +	"Standard Equates", +	"Reserved Words", +	0, +}; + +// Case Sensitive Clarion Language Lexer +LexerModule lmClw(SCLEX_CLW, ColouriseClwDocSensitive, "clw", NULL, rgWordListDescriptions); + +// Case Insensitive Clarion Language Lexer +LexerModule lmClwNoCase(SCLEX_CLWNOCASE, ColouriseClwDocInsensitive, "clwnocase", NULL, rgWordListDescriptions); diff --git a/win32/makefile b/win32/makefile index 84c7ebe04..939d0f2f8 100644 --- a/win32/makefile +++ b/win32/makefile @@ -49,11 +49,11 @@ deps:  #++Autogenerated -- run src/LexGen.py to regenerate  #**LEXOBJS=\\\n\(\*.o \)  LEXOBJS=\ -LexAda.o LexAsm.o LexAVE.o LexBaan.o LexBullant.o LexConf.o LexCPP.o \ +LexAda.o LexAsm.o LexAVE.o LexBaan.o LexBullant.o LexCLW.o LexConf.o LexCPP.o \  LexCrontab.o LexCSS.o LexEiffel.o LexEScript.o LexFortran.o LexHTML.o \  LexLisp.o LexLout.o LexLua.o LexMatlab.o LexMMIXAL.o LexNsis.o LexOthers.o \  LexPascal.o LexPerl.o LexPOV.o LexPS.o LexPython.o LexRuby.o LexScriptol.o \ -LexSQL.o LexVB.o +LexSQL.o LexVB.o   #--Autogenerated -- end of automatically generated section  SOBJS	= ScintillaWin.o ScintillaBase.o Editor.o Document.o \ diff --git a/win32/scintilla.mak b/win32/scintilla.mak index f2bb0f8d3..a071db2f4 100644 --- a/win32/scintilla.mak +++ b/win32/scintilla.mak @@ -114,6 +114,7 @@ LEXOBJS=\  	$(DIR_O)\LexAVE.obj \  	$(DIR_O)\LexBaan.obj \  	$(DIR_O)\LexBullant.obj \ +	$(DIR_O)\LexCLW.obj \  	$(DIR_O)\LexConf.obj \  	$(DIR_O)\LexCPP.obj \  	$(DIR_O)\LexCrontab.obj \ @@ -257,6 +258,8 @@ $(DIR_O)\LexBaan.obj: ..\src\LexBaan.cxx $(LEX_HEADERS)  $(DIR_O)\LexBullant.obj: ..\src\LexBullant.cxx $(LEX_HEADERS) +$(DIR_O)\LexCLW.obj: ..\src\LexCLW.cxx $(LEX_HEADERS) +  $(DIR_O)\LexConf.obj: ..\src\LexConf.cxx $(LEX_HEADERS)  $(DIR_O)\LexCPP.obj: ..\src\LexCPP.cxx $(LEX_HEADERS) diff --git a/win32/scintilla_vc6.mak b/win32/scintilla_vc6.mak index 6720e2af3..571215aaf 100644 --- a/win32/scintilla_vc6.mak +++ b/win32/scintilla_vc6.mak @@ -116,6 +116,7 @@ LEXOBJS=\  	$(DIR_O)\LexAVE.obj \  	$(DIR_O)\LexBaan.obj \  	$(DIR_O)\LexBullant.obj \ +	$(DIR_O)\LexCLW.obj \  	$(DIR_O)\LexConf.obj \  	$(DIR_O)\LexCPP.obj \  	$(DIR_O)\LexCrontab.obj \ @@ -259,6 +260,8 @@ $(DIR_O)\LexBaan.obj: ..\src\LexBaan.cxx $(LEX_HEADERS)  $(DIR_O)\LexBullant.obj: ..\src\LexBullant.cxx $(LEX_HEADERS) +$(DIR_O)\LexCLW.obj: ..\src\LexCLW.cxx $(LEX_HEADERS) +  $(DIR_O)\LexConf.obj: ..\src\LexConf.cxx $(LEX_HEADERS)  $(DIR_O)\LexCPP.obj: ..\src\LexCPP.cxx $(LEX_HEADERS) | 
