Search in sources :

Example 11 with RuleBasedScanner

use of org.eclipse.jface.text.rules.RuleBasedScanner in project eclipse.platform.text by eclipse.

the class WordRuleTest method testBug163116.

/*
	 * https://bugs.eclipse.org/bugs/show_bug.cgi?id=163116
	 */
@Test
public void testBug163116() throws Exception {
    IWordDetector detector = new IWordDetector() {

        @Override
        public boolean isWordPart(char c) {
            return true;
        }

        @Override
        public boolean isWordStart(char c) {
            return true;
        }
    };
    WordRule rule = new WordRule(detector, new Token(this));
    RuleBasedScanner scanner = new RuleBasedScanner();
    scanner.setRules(new IRule[] { rule });
    scanner.setRange(new Document(), 0, 0);
    IToken token = null;
    int i = 0;
    while (token != Token.EOF && i++ < 1000) token = scanner.nextToken();
    assertTrue(i < 1000);
}
Also used : IWordDetector(org.eclipse.jface.text.rules.IWordDetector) IToken(org.eclipse.jface.text.rules.IToken) IToken(org.eclipse.jface.text.rules.IToken) Token(org.eclipse.jface.text.rules.Token) WordRule(org.eclipse.jface.text.rules.WordRule) Document(org.eclipse.jface.text.Document) IDocument(org.eclipse.jface.text.IDocument) RuleBasedScanner(org.eclipse.jface.text.rules.RuleBasedScanner) Test(org.junit.Test)

Example 12 with RuleBasedScanner

use of org.eclipse.jface.text.rules.RuleBasedScanner in project tmdm-studio-se by Talend.

the class ElementFKInfoConfiguration method getStringScanner.

private RuleBasedScanner getStringScanner() {
    RuleBasedScanner scanner = new RuleBasedScanner();
    ElementFKInfoColorProvider colorProvider = getEditorColorProvider();
    scanner.setDefaultReturnToken(colorProvider.getToken(PREF_COLOR_STRING));
    return scanner;
}
Also used : RuleBasedScanner(org.eclipse.jface.text.rules.RuleBasedScanner)

Example 13 with RuleBasedScanner

use of org.eclipse.jface.text.rules.RuleBasedScanner in project webtools.sourceediting by eclipse.

the class WordRuleTest method testBug144355.

/*
	 * https://bugs.eclipse.org/bugs/show_bug.cgi?id=144355
	 */
public void testBug144355() throws Exception {
    IWordDetector detector = new SimpleWordDetector();
    String defaultTokenString = "defaultToken";
    Token defaultToken = new Token(defaultTokenString);
    String testTokenStringNormal = "TestTokenString";
    String testTokenStringDifferentCapitalization = "TestTOKENString";
    String testTokenStringCompletelyDifferent = "XXX";
    Token normalToken = new Token(testTokenStringNormal);
    WordRule rule = new WordRule(detector, defaultToken, true);
    rule.addWord(testTokenStringNormal, normalToken);
    // scenario 1
    // pre: pass in a normal string ("TestTokenString")
    // post: expect the normal token to be returned
    RuleBasedScanner scanner = new RuleBasedScanner();
    scanner.setRules(new IRule[] { rule });
    scanner.setRange(new Document(testTokenStringNormal), 0, testTokenStringNormal.length());
    assertTrue(scanner.nextToken().getData().equals(testTokenStringNormal));
    // scenario 2
    // pre: pass in a normal string but different capitalization ("TestTOKENString")
    // post: expect the normal token to be returned
    scanner = new RuleBasedScanner();
    scanner.setRules(new IRule[] { rule });
    scanner.setRange(new Document(testTokenStringDifferentCapitalization), 0, testTokenStringDifferentCapitalization.length());
    assertTrue(scanner.nextToken().getData().equals(testTokenStringNormal));
    // scenario 3
    // pre: pass in a completely different string ("XXX")
    // post: expect the default token to be returned because the string can't be matched
    scanner = new RuleBasedScanner();
    scanner.setRules(new IRule[] { rule });
    scanner.setRange(new Document(testTokenStringCompletelyDifferent), 0, testTokenStringCompletelyDifferent.length());
    assertTrue(scanner.nextToken().getData().equals(defaultTokenString));
    WordRule ruleWithoutIgnoreCase = new WordRule(detector, defaultToken);
    ruleWithoutIgnoreCase.addWord(testTokenStringNormal, normalToken);
    // scenario 4
    // pre: pass in a normal string ("TestTokenString")
    // post: expect the normal token to be returned
    scanner = new RuleBasedScanner();
    scanner.setRules(new IRule[] { ruleWithoutIgnoreCase });
    scanner.setRange(new Document(testTokenStringNormal), 0, testTokenStringNormal.length());
    assertTrue(scanner.nextToken().getData().equals(testTokenStringNormal));
    // scenario 5
    // pre: pass in a normal string but different capitalization ("TestTOKENString")
    // post: expect the default token to be returned
    scanner = new RuleBasedScanner();
    scanner.setRules(new IRule[] { ruleWithoutIgnoreCase });
    scanner.setRange(new Document(testTokenStringDifferentCapitalization), 0, testTokenStringDifferentCapitalization.length());
    assertTrue(scanner.nextToken().getData().equals(defaultTokenString));
}
Also used : IWordDetector(org.eclipse.jface.text.rules.IWordDetector) IToken(org.eclipse.jface.text.rules.IToken) Token(org.eclipse.jface.text.rules.Token) WordRule(org.eclipse.jface.text.rules.WordRule) Document(org.eclipse.jface.text.Document) IDocument(org.eclipse.jface.text.IDocument) RuleBasedScanner(org.eclipse.jface.text.rules.RuleBasedScanner)

Example 14 with RuleBasedScanner

use of org.eclipse.jface.text.rules.RuleBasedScanner in project eclipse-integration-commons by spring-projects.

the class StsTextViewerConfiguration method getPresentationReconciler.

@Override
public IPresentationReconciler getPresentationReconciler(ISourceViewer sourceViewer) {
    if (showHyperlinks) {
        return super.getPresentationReconciler(sourceViewer);
    }
    PresentationReconciler reconciler = new PresentationReconciler();
    reconciler.setDocumentPartitioning(getConfiguredDocumentPartitioning(sourceViewer));
    DefaultDamagerRepairer dr = new DefaultDamagerRepairer(new RuleBasedScanner());
    reconciler.setDamager(dr, IDocument.DEFAULT_CONTENT_TYPE);
    reconciler.setRepairer(dr, IDocument.DEFAULT_CONTENT_TYPE);
    return reconciler;
}
Also used : DefaultDamagerRepairer(org.eclipse.jface.text.rules.DefaultDamagerRepairer) PresentationReconciler(org.eclipse.jface.text.presentation.PresentationReconciler) IPresentationReconciler(org.eclipse.jface.text.presentation.IPresentationReconciler) RuleBasedScanner(org.eclipse.jface.text.rules.RuleBasedScanner)

Example 15 with RuleBasedScanner

use of org.eclipse.jface.text.rules.RuleBasedScanner in project syncope by apache.

the class HTMLSourceConfiguration method getScriptScanner.

protected RuleBasedScanner getScriptScanner() {
    if (scriptScanner == null) {
        scriptScanner = new RuleBasedScanner();
        RGB rgb = IHTMLColorConstants.SCRIPT;
        Color color = new Color(Display.getCurrent(), rgb);
        scriptScanner.setDefaultReturnToken(new Token(new TextAttribute(color)));
    }
    return scriptScanner;
}
Also used : TextAttribute(org.eclipse.jface.text.TextAttribute) Color(org.eclipse.swt.graphics.Color) Token(org.eclipse.jface.text.rules.Token) RGB(org.eclipse.swt.graphics.RGB) RuleBasedScanner(org.eclipse.jface.text.rules.RuleBasedScanner)

Aggregations

RuleBasedScanner (org.eclipse.jface.text.rules.RuleBasedScanner)17 Token (org.eclipse.jface.text.rules.Token)13 TextAttribute (org.eclipse.jface.text.TextAttribute)9 Document (org.eclipse.jface.text.Document)8 IDocument (org.eclipse.jface.text.IDocument)8 IToken (org.eclipse.jface.text.rules.IToken)8 WordRule (org.eclipse.jface.text.rules.WordRule)8 PatternRule (org.eclipse.jface.text.rules.PatternRule)6 IRule (org.eclipse.jface.text.rules.IRule)4 IWordDetector (org.eclipse.jface.text.rules.IWordDetector)4 Color (org.eclipse.swt.graphics.Color)4 RGB (org.eclipse.swt.graphics.RGB)4 Test (org.junit.Test)4 IPresentationReconciler (org.eclipse.jface.text.presentation.IPresentationReconciler)3 PresentationReconciler (org.eclipse.jface.text.presentation.PresentationReconciler)3 DefaultDamagerRepairer (org.eclipse.jface.text.rules.DefaultDamagerRepairer)3