/******************************************************************************* * Copyright (c) 2015 Bruno Medeiros and other Contributors. * 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: * Bruno Medeiros - initial API and implementation *******************************************************************************/ package melnorme.lang.tooling.parser.lexer; import melnorme.lang.utils.parse.ICharacterReader; public interface IPredicateLexingRule { /** * Evaluate the rule using given reader. * If the rule succeeds, the reader position will be at the end of the token. * If the rule fails, the reader position will remain unchanged. */ default boolean tryMatch(ICharacterReader parentReader) { CharacterReader_SubReader reader = new CharacterReader_SubReader(parentReader); boolean sucess = doEvaluate(reader); if(sucess) { reader.consumeInParentReader(); } return sucess; } public boolean doEvaluate(ICharacterReader reader); }