org.netbeans.editor.SyntaxUpdateTokens Maven / Gradle / Ivy
/*
* Sun Public License Notice
*
* The contents of this file are subject to the Sun Public License
* Version 1.0 (the "License"). You may not use this file except in
* compliance with the License. A copy of the License is available at
* http://www.sun.com/
*
* The Original Code is NetBeans. The Initial Developer of the Original
* Code is Sun Microsystems, Inc. Portions Copyright 1997-2003 Sun
* Microsystems, Inc. All Rights Reserved.
*/
package org.netbeans.editor;
import java.util.Collections;
import java.util.List;
import javax.swing.event.DocumentEvent;
import javax.swing.text.AbstractDocument;
import javax.swing.text.BadLocationException;
import javax.swing.text.Document;
import javax.swing.text.Element;
import javax.swing.undo.AbstractUndoableEdit;
import org.openide.ErrorManager;
/**
* Notification about the tokens being relexed as result of a document
* modification.
*
* The SPIs may use Document.putProperty(SyntaxUpdateNotify.class, inst)
* to assign an instance of this class to the particular document.
*
* The client DocumentListener
s can then retrieve
* the list of the relexed tokens of interest by using
*
* @author Miloslav Metelka
* @version 1.00
*/
public abstract class SyntaxUpdateTokens {
/**
* Retrieve unmodifiable list of relexed tokens of interest for the particular
* document event.
*
* @param evt document event for which the list of tokens is being retrieved.
* @return list of {@link TokenInfo}s describing the tokens of interest
* that were relexed because of the document modification.
*/
public static List getTokenInfoList(DocumentEvent evt) {
if (!(evt instanceof BaseDocumentEvent)) {
return Collections.EMPTY_LIST;
}
return ((BaseDocumentEvent)evt).getSyntaxUpdateTokenList();
}
/**
* Create list of tokens of interest for the whole document.
*
* Document is readlocked during this operation.
*
* @param doc document for which the list of tokens is being retrieved.
* @return list of {@link TokenInfo}s describing the tokens of interest
* throughout the whole document.
*/
public static List getTokenInfoList(Document doc) {
SyntaxUpdateTokens suTokens = (SyntaxUpdateTokens)doc.getProperty(SyntaxUpdateTokens.class);
if (suTokens == null || !(doc instanceof BaseDocument)) {
return Collections.EMPTY_LIST;
}
List tokenList;
BaseDocument bdoc = (BaseDocument)doc;
bdoc.readLock();
try {
suTokens.syntaxUpdateStart();
try {
bdoc.getSyntaxSupport().tokenizeText(
new AllTokensProcessor(suTokens), 0, bdoc.getLength(), true);
} catch (BadLocationException e) {
ErrorManager.getDefault().notify(ErrorManager.INFORMATIONAL, e);
} finally {
tokenList = suTokens.syntaxUpdateEnd();
}
} finally {
bdoc.readUnlock();
}
return tokenList;
}
/**
* Notification that updating of the lexical states is starting
* for the last performed modification.
*
* The list of the token infos should be cleared here.
*/
public abstract void syntaxUpdateStart();
/**
* Notification that updating of lexical states has ended
* so there will be no more tokens relexed for the modification.
*
* If there are any tokens of interest they should be returned
* from this method.
*
* @return list of tokens of interest. The returned list will
* be copied by the infrastructure so the originally returned
* instance can continue to be used.
*/
public abstract List syntaxUpdateEnd();
/**
* Notification that a token was found during updating
* of lexical states. If this class is interested in providing
* info about this token to clients then it should create
*
*/
public abstract void syntaxUpdateToken(TokenID id, TokenContextPath contextPath, int offset, int length);
public class TokenInfo {
private final TokenID id;
private final TokenContextPath contextPath;
private final int offset;
private final int length;
public TokenInfo(TokenID id, TokenContextPath contextPath, int offset, int length) {
this.id = id;
this.contextPath = contextPath;
this.offset = offset;
this.length = length;
}
public final TokenID getID() {
return id;
}
public final TokenContextPath getContextPath() {
return contextPath;
}
public final int getOffset() {
return offset;
}
public int getLength() {
return length;
}
public String toString() {
return "id=" + id + ", ctx=" + contextPath + ", off=" + offset + ", len=" + length; // NOI18N
}
}
static final class AllTokensProcessor implements TokenProcessor {
private SyntaxUpdateTokens suTokens;
private int bufferStartOffset;
AllTokensProcessor(SyntaxUpdateTokens suTokens) {
this.suTokens = suTokens;
}
public void nextBuffer(char[] buffer, int offset, int len, int startPos, int preScan, boolean lastBuffer) {
bufferStartOffset = startPos - offset;
}
public boolean token(TokenID tokenID, TokenContextPath tokenContextPath, int tokenBufferOffset, int tokenLength) {
suTokens.syntaxUpdateToken(tokenID, tokenContextPath, tokenBufferOffset, tokenLength);
return true;
}
public int eot(int offset) {
return 0;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy