diff options
| -rw-r--r-- | doc/ScintillaHistory.html | 5 | ||||
| -rw-r--r-- | lexers/LexProgress.cxx | 76 | 
2 files changed, 59 insertions, 22 deletions
| diff --git a/doc/ScintillaHistory.html b/doc/ScintillaHistory.html index c70134661..a80398289 100644 --- a/doc/ScintillaHistory.html +++ b/doc/ScintillaHistory.html @@ -480,6 +480,7 @@  	<td>Yury Dubinsky</td>  	<td>Sam Hocevar</td>  	<td>Luyomi</td> +	<td>Matt Gilarde</td>      </tr>      </table>      <p> @@ -509,6 +510,10 @@  	<a href="http://sourceforge.net/p/scintilla/bugs/1799/">Bug #1799</a>.<br />  	</li>  	<li> +	The Progress lexer supports single-line comments, abbreviated keywords and +	extends nested comments to unlimited levels. +	</li> +	<li>  	For Qt, release builds have assertions turned off.  	</li>  	<li> diff --git a/lexers/LexProgress.cxx b/lexers/LexProgress.cxx index 844b635ae..88fed1452 100644 --- a/lexers/LexProgress.cxx +++ b/lexers/LexProgress.cxx @@ -9,7 +9,6 @@  /** TODO:  WebSpeed support in html lexer  Support "end triggers" expression of the triggers phrase -Support more than 6 comments levels  **/  #include <stdlib.h>  #include <string.h> @@ -44,13 +43,26 @@ static inline bool IsAWordStart(int ch) {  enum SentenceStart { SetSentenceStart = 0xf, ResetSentenceStart = 0x10}; // true -> bit = 0  static void Colourise4glDoc(Sci_PositionU startPos, Sci_Position length, int initStyle, WordList *keywordlists[], -                            Accessor &styler) { +							Accessor &styler) { + +	WordList &keywords1 = *keywordlists[0];   // regular keywords +	WordList &keywords2 = *keywordlists[1];   // block opening keywords, only when SentenceStart +	WordList &keywords3 = *keywordlists[2];   // block opening keywords +	//WordList &keywords4 = *keywordlists[3]; // preprocessor keywords. Not implemented -    WordList &keywords1 = *keywordlists[0];   // regular keywords -    WordList &keywords2 = *keywordlists[1];   // block opening keywords, only when SentenceStart -    WordList &keywords3 = *keywordlists[2];   // block opening keywords -    //WordList &keywords4 = *keywordlists[3]; // preprocessor keywords. Not implemented +	Sci_Position currentLine = styler.GetLine(startPos); +	// Initialize the block comment /* */ nesting level, if we are inside such a comment. +	int blockCommentLevel = 0; +	if (initStyle == SCE_4GL_COMMENT1 || +		initStyle == SCE_4GL_COMMENT1_) { +		blockCommentLevel = styler.GetLineState(currentLine - 1); +	} +	// Do not leak single-line comments onto next line +	if (initStyle == SCE_4GL_COMMENT2 || +		initStyle == SCE_4GL_COMMENT2_) { +		initStyle = SCE_4GL_DEFAULT; +	}  	int visibleChars = 0;  	int mask; @@ -65,6 +77,19 @@ static void Colourise4glDoc(Sci_PositionU startPos, Sci_Position length, int ini  			visibleChars = 0;  		} +		if (sc.atLineEnd) { +			// Update the line state, so it can be seen by next line +			currentLine = styler.GetLine(sc.currentPos); +			if (sc.state == SCE_4GL_COMMENT1 || +				sc.state == SCE_4GL_COMMENT1_) { +				// Inside a block comment, we set the line state +				styler.SetLineState(currentLine, blockCommentLevel); +			} else { +				// Reset the line state +				styler.SetLineState(currentLine, 0); +			} +		} +  		// Handle line continuation generically.  		if ((sc.state & 0xf) < SCE_4GL_COMMENT1) {  		if (sc.ch == '~') { @@ -104,10 +129,10 @@ static void Colourise4glDoc(Sci_PositionU startPos, Sci_Position length, int ini  				if (!IsAWordChar(sc.ch) && sc.ch != '-') {  					char s[1000];  					sc.GetCurrentLowered(s, sizeof(s)); -					if ((((sc.state & 0x10) == 0) && keywords2.InList(s)) || keywords3.InList(s)) { +					if ((((sc.state & 0x10) == 0) && keywords2.InListAbbreviated(s, '(')) || keywords3.InListAbbreviated(s, '(')) {  						sc.ChangeState(SCE_4GL_BLOCK | ResetSentenceStart);  					} -					else if (keywords1.InList(s)) { +					else if (keywords1.InListAbbreviated(s, '(')) {  						if ((s[0] == 'e' && s[1] =='n' && s[2] == 'd' && !isalnum(s[3]) && s[3] != '-') ||  							(s[0] == 'f' && s[1] =='o' && s[2] == 'r' && s[3] == 'w' && s[4] =='a' && s[5] == 'r' && s[6] == 'd'&& !isalnum(s[7]))) {  							sc.ChangeState(SCE_4GL_END | ResetSentenceStart); @@ -141,20 +166,23 @@ static void Colourise4glDoc(Sci_PositionU startPos, Sci_Position length, int ini  					sc.ForwardSetState(SCE_4GL_DEFAULT | mask);  				}  				break; -			default: -				if ((sc.state & 0xf) >= SCE_4GL_COMMENT1) { -					if (sc.ch == '*' && sc.chNext == '/') { -						sc.Forward(); -						if ((sc.state & 0xf) == SCE_4GL_COMMENT1) { -							sc.ForwardSetState(SCE_4GL_DEFAULT | mask); -						} -						else -							sc.SetState((sc.state & 0x1f) - 1); -					} else if (sc.ch == '/' && sc.chNext == '*') { -						sc.Forward(); -						sc.SetState((sc.state & 0x1f) + 1); +			case SCE_4GL_COMMENT1: +				if (sc.Match('/', '*')) { +					blockCommentLevel++; +					sc.Forward(); +				} else if (sc.Match('*', '/') && blockCommentLevel > 0) { +					blockCommentLevel--; +					sc.Forward(); +					if (blockCommentLevel == 0) { +						sc.ForwardSetState(SCE_4GL_DEFAULT | mask);  					}  				} +				break; +			case SCE_4GL_COMMENT2: +				if (sc.atLineEnd) { +					sc.ForwardSetState(SCE_4GL_DEFAULT | mask); +				} +				break;  		}  		// Determine if a new state should be entered. @@ -164,9 +192,13 @@ static void Colourise4glDoc(Sci_PositionU startPos, Sci_Position length, int ini  				sc.SetState(SCE_4GL_NUMBER | ResetSentenceStart);  			} else if (IsAWordStart(sc.ch) || (sc.ch == '@')) {  				sc.SetState(SCE_4GL_IDENTIFIER | mask); -			} else if (sc.ch == '/' && sc.chNext == '*') { +			} else if (sc.Match('/', '*')) { +				blockCommentLevel = 1;  				sc.SetState(SCE_4GL_COMMENT1 | mask);  				sc.Forward(); +			} else if (sc.Match('/', '/') && +					   (sc.atLineStart || sc.chPrev == ' ')) { +				sc.SetState(SCE_4GL_COMMENT2 | mask);  			} else if (sc.ch == '\"') {  				sc.SetState(SCE_4GL_STRING | ResetSentenceStart);  			} else if (sc.ch == '\'') { @@ -199,7 +231,7 @@ static void Colourise4glDoc(Sci_PositionU startPos, Sci_Position length, int ini  }  static bool IsStreamCommentStyle(int style) { -	return (style & 0xf) >= SCE_4GL_COMMENT1 ; +	return (style & 0xf) == SCE_4GL_COMMENT1 ;  }  // Store both the current line's fold level and the next lines in the | 
