/*
* Copyright 2005-2015 by BerryWorks Software, LLC. All rights reserved.
*
* This file is part of EDIReader. You may obtain a license for its use directly from
* BerryWorks Software, and you may also choose to use this software under the terms of the
* GPL version 3. Other products in the EDIReader software suite are available only by licensing
* with BerryWorks. Only those files bearing the GPL statement below are available under the GPL.
*
* EDIReader is free software: you can redistribute it and/or modify it under the terms of the
* GNU General Public License as published by the Free Software Foundation, either version 3 of
* the License, or (at your option) any later version.
*
* EDIReader is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without
* even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with EDIReader. If not,
* see <http://www.gnu.org/licenses/>.
*/
package com.berryworks.edireader.error;
/**
* An EDISyntaxExceptionHandler defines a callback interface by which
* a program using EDIReader can control whether or not parsing should
* continue after a particular EDI syntax issue.
*/
public interface EDISyntaxExceptionHandler {
/**
* Process a syntax exception corresponding to invalid EDI noted
* during EDIReader parsing. Processing will typically involve logging
* or auditing of some kind, and a decision whether parsing should
* continue or not. If the method returns true, parsing will continue;
* if the method returns false, then EDIReader will immediately throw
* this exception.
*
* @param syntaxException detected by EDIReader
* @return true if EDIReader should continue parsing
*/
boolean process(RecoverableSyntaxException syntaxException);
}