diff options
author | Alain Magloire | 2003-10-14 04:48:15 +0000 |
---|---|---|
committer | Alain Magloire | 2003-10-14 04:48:15 +0000 |
commit | 53098e5a17076382829e79a0da75e10bb844ddb0 (patch) | |
tree | 728644a54a2e7388f4c7e3ad4506267148cda725 /build | |
parent | 952fdd89d690396186fb098d89e8ca85ceea75c3 (diff) | |
download | org.eclipse.cdt-53098e5a17076382829e79a0da75e10bb844ddb0.tar.gz org.eclipse.cdt-53098e5a17076382829e79a0da75e10bb844ddb0.tar.xz org.eclipse.cdt-53098e5a17076382829e79a0da75e10bb844ddb0.zip |
Return the default Token
Diffstat (limited to 'build')
-rw-r--r-- | build/org.eclipse.cdt.make.ui/src/org/eclipse/cdt/make/internal/ui/text/makefile/MakefileCodeScanner.java | 19 |
1 files changed, 13 insertions, 6 deletions
diff --git a/build/org.eclipse.cdt.make.ui/src/org/eclipse/cdt/make/internal/ui/text/makefile/MakefileCodeScanner.java b/build/org.eclipse.cdt.make.ui/src/org/eclipse/cdt/make/internal/ui/text/makefile/MakefileCodeScanner.java index d09bf686ef9..e68bcca03e0 100644 --- a/build/org.eclipse.cdt.make.ui/src/org/eclipse/cdt/make/internal/ui/text/makefile/MakefileCodeScanner.java +++ b/build/org.eclipse.cdt.make.ui/src/org/eclipse/cdt/make/internal/ui/text/makefile/MakefileCodeScanner.java @@ -20,7 +20,6 @@ import org.eclipse.jface.text.rules.ICharacterScanner; import org.eclipse.jface.text.rules.IRule; import org.eclipse.jface.text.rules.IToken; import org.eclipse.jface.text.rules.IWhitespaceDetector; -import org.eclipse.jface.text.rules.PatternRule; import org.eclipse.jface.text.rules.RuleBasedScanner; import org.eclipse.jface.text.rules.Token; import org.eclipse.jface.text.rules.WhitespaceRule; @@ -31,13 +30,18 @@ public class MakefileCodeScanner extends RuleBasedScanner { private final static String[] keywords = { "define", "endef", "ifdef", "ifndef", //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ "ifeq", "ifneq", "else", "endif", "include", //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ //$NON-NLS-5$ "-include", "sinclude", "override", "endef", //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ - "export", "unexport", "vpath" }; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ + "export", "unexport", "vpath" //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ + }; + private final static String[] functions = { "subst", "patsubst", "strip", //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ "findstring", "filter", "sort", "dir", "notdir", //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ //$NON-NLS-5$ "suffix", "basename", "addsuffix", "addprefix", //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ "join", "word", "words", "wordlist", //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ "firstword", "wildcard", "error", "warning", //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ - "shell", "origin", "foreach", "call" }; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ + "shell", "origin", "foreach", "call" //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ + }; + + /** * Constructor for MakefileCodeScanner */ @@ -53,7 +57,7 @@ public class MakefileCodeScanner extends RuleBasedScanner { List rules = new ArrayList(); // Add rule for single line comments. - rules.add(new EndOfLineRule("#", comment)); //$NON-NLS-1$ + rules.add(new EndOfLineRule("#", comment, '\\')); //$NON-NLS-1$ // Add generic whitespace rule. rules.add(new WhitespaceRule(new IWhitespaceDetector() { @@ -63,7 +67,7 @@ public class MakefileCodeScanner extends RuleBasedScanner { })); // Add word rule for keywords, types, and constants. - WordRule wordRule = new WordRule(new MakefileWordDetector(), Token.UNDEFINED); + WordRule wordRule = new WordRule(new MakefileWordDetector(), other); for (int i = 0; i < keywords.length; i++) wordRule.addWord(keywords[i], keyword); for (int i = 0; i < functions.length; i++) @@ -71,10 +75,13 @@ public class MakefileCodeScanner extends RuleBasedScanner { rules.add(wordRule); - rules.add(new PatternRule("$(", ")", macro, '\\', true)); //$NON-NLS-1$ //$NON-NLS-2$ + //rules.add(new PatternRule("$(", ")", macro, '\\', true)); //$NON-NLS-1$ //$NON-NLS-2$ + rules.add(new MakefileSimpleMacroRule(macro)); //$NON-NLS-1$ //$NON-NLS-2$ rules.add(new MacroRule(macro, other)); + setDefaultReturnToken(other); + IRule[] result = new IRule[rules.size()]; rules.toArray(result); |