/*******************************************************************************
* Copyright (c) 2011 Subgraph.
* 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:
* Subgraph - initial API and implementation
******************************************************************************/
package com.subgraph.vega.ui.httpviewer.html;
import java.util.ArrayList;
import java.util.List;
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.Token;
public class HtmlPartitionScanner extends RuleBasedPartitionScanner {
public final static String HTML_COMMENT = "html_comment";
public final static String HTML_DOCTYPE = "html_doctype";
public final static String HTML_START_TAG = "html_start_tag";
public final static String HTML_END_TAG = "html_end_tag";
public final static String[] HTML_TYPES = {
HTML_COMMENT, HTML_DOCTYPE, HTML_START_TAG, HTML_END_TAG
};
public HtmlPartitionScanner() {
final List<IPredicateRule> rules = new ArrayList<IPredicateRule>();
rules.add(new MultiLineRule("<!--", "-->", new Token(HTML_COMMENT)));
rules.add(new MultiLineRule("</", ">", new Token(HTML_END_TAG)));
IToken startTagToken = new Token(HTML_START_TAG);
rules.add(new StartTagRule(startTagToken));
rules.add(new StartTagRule(startTagToken));
rules.add(new MultiLineRule("<!DOCTYPE", ">", new Token(HTML_DOCTYPE)));
final IPredicateRule[] rs = new IPredicateRule[rules.size()];
rules.toArray(rs);
setPredicateRules(rs);
}
}