📄 enforcehandler.java
字号:
/*
*
* The DbUnit Database Testing Framework
* Copyright (C)2002-2004, DbUnit.org
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
*/
package org.dbunit.dataset.csv.handlers;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.dbunit.dataset.csv.IllegalInputCharacterException;
/**
* author: fede
* 4-set-2003 10.20.45
* $Revision: 629 $
*/
public class EnforceHandler extends AbstractPipelineComponent {
/**
* Logger for this class
*/
private static final Logger logger = LoggerFactory.getLogger(EnforceHandler.class);
private PipelineComponent [] enforcedComponents;
private PipelineComponent theHandlerComponent;
private EnforceHandler(PipelineComponent [] components) {
setEnforcedComponents(components);
}
public static final PipelineComponent ENFORCE(PipelineComponent component) {
logger.debug("ENFORCE(component=" + component + ") - start");
return EnforceHandler.ENFORCE(new PipelineComponent [] {component});
}
public static final PipelineComponent ENFORCE(PipelineComponent [] components) {
logger.debug("ENFORCE(components=" + components + ") - start");
return createPipelineComponent(new EnforceHandler(components), new ENFORCE());
}
public boolean canHandle(char c) throws IllegalInputCharacterException {
logger.debug("canHandle(c=" + c + ") - start");
for (int i = 0; i < getEnforcedComponents().length; i++) {
if (getEnforcedComponents()[i].canHandle(c)) {
setTheHandlerComponent(getEnforcedComponents()[i]);
return true;
}
}
throw new IllegalInputCharacterException("(working on piece #" + getPipeline().getProducts().size() + ")"
+ getPipeline().getCurrentProduct().toString() + ": " + "Character '" + c + "' cannot be handled");
}
public void setPipeline(Pipeline pipeline) {
logger.debug("setPipeline(pipeline=" + pipeline + ") - start");
for (int i = 0; i < getEnforcedComponents().length; i++) {
getEnforcedComponents()[i].setPipeline(pipeline);
}
super.setPipeline(pipeline);
}
protected PipelineComponent[] getEnforcedComponents() {
logger.debug("getEnforcedComponents() - start");
return enforcedComponents;
}
protected void setEnforcedComponents(PipelineComponent[] enforcedComponents) {
logger.debug("setEnforcedComponents(enforcedComponents=" + enforcedComponents + ") - start");
this.enforcedComponents = enforcedComponents;
}
PipelineComponent getTheHandlerComponent() {
logger.debug("getTheHandlerComponent() - start");
return theHandlerComponent;
}
void setTheHandlerComponent(PipelineComponent theHandlerComponent) {
logger.debug("setTheHandlerComponent(theHandlerComponent=" + theHandlerComponent + ") - start");
this.theHandlerComponent = theHandlerComponent;
}
static private class ENFORCE extends Helper {
/**
* Logger for this class
*/
private static final Logger logger = LoggerFactory.getLogger(ENFORCE.class);
public void helpWith(char c) {
logger.debug("helpWith(c=" + c + ") - start");
try {
EnforceHandler handler = (EnforceHandler) getHandler();
handler.getTheHandlerComponent().handle(c);
getHandler().getPipeline().removeFront();
} catch (PipelineException e) {
throw new RuntimeException(e.getMessage());
} catch (IllegalInputCharacterException e) {
throw new RuntimeException(e.getMessage());
}
// ignore the char
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -