org.eclipse.jface.text.rules.RuleBasedPartitionScanner Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of org.eclipse.jface.text Show documentation
Show all versions of org.eclipse.jface.text Show documentation
This is org.eclipse.jface.text jar used by Scout SDK
The newest version!
/*******************************************************************************
* Copyright (c) 2000, 2011 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.jface.text.rules;
import org.eclipse.jface.text.IDocument;
/**
* Scanner that exclusively uses predicate rules.
*
* If a partial range is set (see {@link #setPartialRange(IDocument, int, int, String, int)} with
* content type that is not null
then this scanner will first try the rules that match
* the given content type.
*
*
* @since 2.0
*/
public class RuleBasedPartitionScanner extends BufferedRuleBasedScanner implements IPartitionTokenScanner {
/** The content type of the partition in which to resume scanning. */
protected String fContentType;
/** The offset of the partition inside which to resume. */
protected int fPartitionOffset;
/**
* Disallow setting the rules since this scanner
* exclusively uses predicate rules.
*
* @param rules the sequence of rules controlling this scanner
*/
@Override
public void setRules(IRule[] rules) {
throw new UnsupportedOperationException();
}
/*
* @see RuleBasedScanner#setRules(IRule[])
*/
public void setPredicateRules(IPredicateRule[] rules) {
super.setRules(rules);
}
@Override
public void setRange(IDocument document, int offset, int length) {
setPartialRange(document, offset, length, null, -1);
}
/**
* {@inheritDoc}
*
* If the given content type is not null
then this scanner will first try the rules
* that match the given content type.
*
*/
@Override
public void setPartialRange(IDocument document, int offset, int length, String contentType, int partitionOffset) {
fContentType= contentType;
fPartitionOffset= partitionOffset;
if (partitionOffset > -1) {
int delta= offset - partitionOffset;
if (delta > 0) {
super.setRange(document, partitionOffset, length + delta);
fOffset= offset;
return;
}
}
super.setRange(document, offset, length);
}
@Override
public IToken nextToken() {
if (fContentType == null || fRules == null) {
//don't try to resume
return super.nextToken();
}
// inside a partition
fColumn= UNDEFINED;
boolean resume= (fPartitionOffset > -1 && fPartitionOffset < fOffset);
fTokenOffset= resume ? fPartitionOffset : fOffset;
IPredicateRule rule;
IToken token;
for (int i= 0; i < fRules.length; i++) {
rule= (IPredicateRule) fRules[i];
token= rule.getSuccessToken();
if (fContentType.equals(token.getData())) {
token= rule.evaluate(this, resume);
if (!token.isUndefined()) {
fContentType= null;
return token;
}
}
}
// haven't found any rule for this type of partition
fContentType= null;
if (resume)
fOffset= fPartitionOffset;
return super.nextToken();
}
}