/* * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. * * Copyright 1997-2010 Oracle and/or its affiliates. All rights reserved. * * Oracle and Java are registered trademarks of Oracle and/or its affiliates. * Other names may be trademarks of their respective owners. * * The contents of this file are subject to the terms of either the GNU * General Public License Version 2 only ("GPL") or the Common * Development and Distribution License("CDDL") (collectively, the * "License"). You may not use this file except in compliance with the * License. You can obtain a copy of the License at * http://www.netbeans.org/cddl-gplv2.html * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the * specific language governing permissions and limitations under the * License. When distributing the software, include this License Header * Notice in each file and include the License file at * nbbuild/licenses/CDDL-GPL-2-CP. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the GPL Version 2 section of the License file that * accompanied this code. If applicable, add the following below the * License Header, with the fields enclosed by brackets [] replaced by * your own identifying information: * "Portions Copyrighted [year] [name of copyright owner]" * * Contributor(s): * * Portions Copyrighted 2007 Sun Microsystems, Inc. */ package org.netbeans.modules.spellchecker.bindings.ruby; import javax.swing.text.BadLocationException; import org.netbeans.api.html.lexer.HTMLTokenId; import org.netbeans.api.lexer.TokenId; import org.netbeans.api.lexer.TokenSequence; import org.netbeans.editor.BaseDocument; import org.netbeans.modules.ruby.lexer.RubyTokenId; import org.netbeans.modules.ruby.rhtml.lexer.api.RhtmlTokenId; import org.openide.filesystems.FileObject; import org.openide.filesystems.FileUtil; /** * Tokenize RHTML for spell checking: Spell check Ruby comments AND HTML text content! * * @author Tor Norbye */ public class RhtmlTokenList extends RubyTokenList { private boolean hidden = false; public RhtmlTokenList(BaseDocument doc) { super(doc); } @Override public void setStartOffset(int offset) { super.setStartOffset (offset); FileObject fileObject = FileUtil.getConfigFile ("Spellcheckers/RHTML"); Boolean b = (Boolean) fileObject.getAttribute ("Hidden"); hidden = Boolean.TRUE.equals (b); } /** Given a sequence of Ruby tokens, return the next span of eligible comments */ @Override protected int[] findNextSpellSpan(TokenSequence<? extends TokenId> ts, int offset) throws BadLocationException { if (ts == null || hidden) { return new int[]{-1, -1}; } int diff = ts.move(offset); while (ts.moveNext()) { TokenId id = ts.token().id(); /*if (id == RhtmlTokenId.RUBYCOMMENT) { return new int[] {ts.offset(), ts.offset() + ts.token().length()}; } else*/ if (id == RhtmlTokenId.HTML) { // Tokenize the text and TokenSequence<? extends HTMLTokenId> t = ts.embedded(HTMLTokenId.language()); if (t != null) { t.move(offset); while (t.moveNext()) { TokenId tid = t.token().id(); if (tid == HTMLTokenId.TEXT) { return new int[]{t.offset(), t.offset() + t.token().length()}; } } } } else if (id == RhtmlTokenId.RUBY || id == RhtmlTokenId.RUBY_EXPR) { TokenSequence<? extends RubyTokenId> t = ts.embedded(RubyTokenId.language()); if (t != null) { // Tokenize Ruby segment int[] span = super.findNextSpellSpan(t, Math.max(offset,ts.offset())); if (span[0] != -1) { return span; } } } } return new int[]{-1, -1}; } }