blob: 448bb2b5f6309d7e1bb47a00bd98254750a333bd [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2005, 2007 IBM Corporation and others.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* SPDX-License-Identifier: EPL-2.0
*
*******************************************************************************/
package org.eclipse.dltk.javascript.internal.ui.text;
import static org.eclipse.dltk.javascript.ast.MultiLineComment.JSDOC_PREFIX;
import java.util.ArrayList;
import java.util.List;
import org.eclipse.dltk.javascript.ui.text.IJavaScriptPartitions;
import org.eclipse.jface.text.rules.EndOfLineRule;
import org.eclipse.jface.text.rules.ICharacterScanner;
import org.eclipse.jface.text.rules.IPredicateRule;
import org.eclipse.jface.text.rules.IToken;
import org.eclipse.jface.text.rules.IWordDetector;
import org.eclipse.jface.text.rules.MultiLineRule;
import org.eclipse.jface.text.rules.RuleBasedPartitionScanner;
import org.eclipse.jface.text.rules.SingleLineRule;
import org.eclipse.jface.text.rules.Token;
import org.eclipse.jface.text.rules.WordRule;
public class JavascriptPartitionScanner extends RuleBasedPartitionScanner {
private static class JavaScriptStringRule extends SingleLineRule {
public JavaScriptStringRule(String quote, IToken token) {
super(quote, quote, token, '\\', true, true);
}
}
/**
* Detector for empty comments.
*/
static class EmptyCommentDetector implements IWordDetector {
/*
* @see IWordDetector#isWordStart
*/
public boolean isWordStart(char c) {
return (c == '/');
}
/*
* @see IWordDetector#isWordPart
*/
public boolean isWordPart(char c) {
return (c == '*' || c == '/');
}
}
/**
* Word rule for empty comments.
*/
static class EmptyCommentRule extends WordRule implements IPredicateRule {
private IToken fSuccessToken;
/**
* Constructor for EmptyCommentRule.
*
* @param successToken
*/
public EmptyCommentRule(IToken successToken) {
super(new EmptyCommentDetector());
fSuccessToken = successToken;
addWord("/**/", fSuccessToken); //$NON-NLS-1$
}
/*
* @see IPredicateRule#evaluate(ICharacterScanner, boolean)
*/
public IToken evaluate(ICharacterScanner scanner, boolean resume) {
return evaluate(scanner);
}
/*
* @see IPredicateRule#getSuccessToken()
*/
public IToken getSuccessToken() {
return fSuccessToken;
}
}
/**
* Creates the partitioner and sets up the appropriate rules.
*/
public JavascriptPartitionScanner() {
super();
IToken string = new Token(IJavaScriptPartitions.JS_STRING);
IToken stringSingle = new Token(IJavaScriptPartitions.JS_STRING_SINGLE);
IToken multiLineComment = new Token(
IJavaScriptPartitions.JS_MULTI_LINE_COMMENT);
IToken singleLineComment = new Token(
IJavaScriptPartitions.JS_SINGLE_LINE_COMMENT);
IToken doc = new Token(IJavaScriptPartitions.JS_DOC);
List<IPredicateRule> rules = new ArrayList<IPredicateRule>();
rules.add(new EndOfLineRule("//", singleLineComment)); //$NON-NLS-1$
// Add special case word rule.
rules.add(new EmptyCommentRule(multiLineComment));
rules.add(new MultiLineRule(JSDOC_PREFIX, "*/", doc)); //$NON-NLS-1$
rules.add(new MultiLineRule("/*", "*/", multiLineComment)); //$NON-NLS-1$ //$NON-NLS-2$
// Add rule for character constants.
rules.add(new JavaScriptStringRule("'", stringSingle));
rules.add(new JavaScriptStringRule("\"", string));
IPredicateRule[] result = new IPredicateRule[rules.size()];
rules.toArray(result);
setPredicateRules(result);
}
}