/* * $Id$ * * Copyright (c) 2004-2005 by the TeXlapse Team. * 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 */ package net.sourceforge.texlipse.bibeditor; import org.eclipse.jface.text.Assert; import org.eclipse.jface.text.rules.ICharacterScanner; import org.eclipse.jface.text.rules.IRule; import org.eclipse.jface.text.rules.IToken; import org.eclipse.jface.text.rules.Token; /** * A rule for matching BibTeX -commands, '@' followed my letters. * * @author Oskar Ojala */ public class BibCommandRule implements IRule { /** The token to be returned when this rule is successful */ protected IToken fToken; /** * Creates a rule which will return the specified * token when a BibTeX-command starting with @ is detected * * @param token the token to be returned */ public BibCommandRule(IToken token) { Assert.isNotNull(token); fToken = token; } /* (non-Javadoc) * @see org.eclipse.jface.text.rules.IRule#evaluate(org.eclipse.jface.text.rules.ICharacterScanner) */ public IToken evaluate(ICharacterScanner scanner) { int c = scanner.read(); if (((char) c) == '@') { do { c = scanner.read(); } while (Character.isLetter((char) c)); scanner.unread(); return fToken; } scanner.unread(); return Token.UNDEFINED; } }