/*
* Copyright (c) 2005- michael lawley and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the GNU Lesser General Public License version 2.1 as published by the Free Software Foundation
* which accompanies this distribution, and is available by writing to
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*
* Contributors:
* michael lawley
*
*
*
*/
package tefkat.plugin;
import java.util.ArrayList;
import java.util.List;
import org.eclipse.jface.text.rules.EndOfLineRule;
import org.eclipse.jface.text.rules.IPredicateRule;
import org.eclipse.jface.text.rules.IToken;
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;
/**
* @author lawley
*
*/
public class TefkatPartitionScanner extends RuleBasedPartitionScanner {
public static final String MULTILINE_COMMENT = "__tefkat_multiline_comment";
public static final String[] TEFKAT_PARTITION_TYPES = { MULTILINE_COMMENT };
public TefkatPartitionScanner() {
IToken comment = new Token(MULTILINE_COMMENT);
List rules = new ArrayList();
// Add rule for single line comments
rules.add(new EndOfLineRule("//", Token.UNDEFINED));
// Add rule for strings
rules.add(new SingleLineRule("\"", "\"", Token.UNDEFINED, '\\'));
// Add rules for multi-line comments
rules.add(new MultiLineRule("/*", "*/", comment));
IPredicateRule[] ruleArray = new IPredicateRule[rules.size()];
rules.toArray(ruleArray);
setPredicateRules(ruleArray);
}
}