diff options
| author | nyamatongwe <unknown> | 2008-04-18 10:45:43 +0000 | 
|---|---|---|
| committer | nyamatongwe <unknown> | 2008-04-18 10:45:43 +0000 | 
| commit | 71c30fc4aa2cea19dc884ede105fa098cc99a210 (patch) | |
| tree | afb2fc3c057a308ecbcbc2137441076efcdbf689 /src | |
| parent | 0b8dcb9c99a80e857e8eaa470fec07e3ea9cf829 (diff) | |
| download | scintilla-mirror-71c30fc4aa2cea19dc884ede105fa098cc99a210.tar.gz | |
Bug #1945318 handle more compiler directives.
Diffstat (limited to 'src')
| -rw-r--r-- | src/LexFortran.cxx | 13 | 
1 files changed, 11 insertions, 2 deletions
| diff --git a/src/LexFortran.cxx b/src/LexFortran.cxx index c68c5b62f..e66b37ebe 100644 --- a/src/LexFortran.cxx +++ b/src/LexFortran.cxx @@ -84,7 +84,15 @@ static void ColouriseFortranDoc(unsigned int startPos, int length, int initStyle  		int toLineStart = sc.currentPos - posLineStart;  		if (isFixFormat && (toLineStart < 6 || toLineStart > 72)) {  			if (toLineStart == 0 && (tolower(sc.ch) == 'c' || sc.ch == '*') || sc.ch == '!') { -				sc.SetState(SCE_F_COMMENT); +                if (sc.MatchIgnoreCase("cdec$") || sc.MatchIgnoreCase("*dec$") || sc.MatchIgnoreCase("!dec$") || +                    sc.MatchIgnoreCase("cdir$") || sc.MatchIgnoreCase("*dir$") || sc.MatchIgnoreCase("!dir$") || +                    sc.MatchIgnoreCase("cms$")  || sc.MatchIgnoreCase("*ms$")  || sc.MatchIgnoreCase("!ms$")  || +                    sc.chNext == '$') { +                    sc.SetState(SCE_F_PREPROCESSOR); +				} else { +					sc.SetState(SCE_F_COMMENT); +				} +  				while (!sc.atLineEnd && sc.More()) sc.Forward(); // Until line end  			} else if (toLineStart > 72) {  				sc.SetState(SCE_F_COMMENT); @@ -198,7 +206,8 @@ static void ColouriseFortranDoc(unsigned int startPos, int length, int initStyle  		// Determine if a new state should be entered.  		if (sc.state == SCE_F_DEFAULT) {  			if (sc.ch == '!') { -				if (sc.chNext == '$') { +                if (sc.MatchIgnoreCase("!dec$") || sc.MatchIgnoreCase("!dir$") || +                    sc.MatchIgnoreCase("!ms$") || sc.chNext == '$') {  					sc.SetState(SCE_F_PREPROCESSOR);  				} else {  					sc.SetState(SCE_F_COMMENT); | 
