/*
* @(#)$Id: DebugController.java,v 1.18 2001/08/30 21:05:08 Bear Exp $
*
* Copyright 2001 Sun Microsystems, Inc. All Rights Reserved.
*
* This software is the proprietary information of Sun Microsystems, Inc.
* Use is subject to license terms.
*
*/
package com.sun.msv.driver.textui;
import org.xml.sax.InputSource;
import org.xml.sax.Locator;
import org.xml.sax.SAXException;
import org.xml.sax.EntityResolver;
import com.sun.msv.reader.GrammarReaderController;
import java.io.PrintStream;
/**
* GrammarReaderController that prints all errors and warnings.
*
* @author <a href="mailto:kohsuke.kawaguchi@eng.sun.com">Kohsuke KAWAGUCHI</a>
*/
public class DebugController implements GrammarReaderController {
/** if true, warnings are reported. If false, not reported. */
private boolean displayWarning;
/** set to true after "there are warnings..." message is once printed. */
private boolean warningReported = false;
/** entity resolution is delegated to this object. can be null. */
public EntityResolver externalEntityResolver;
/** messages are sent to this object. */
protected PrintStream out;
public DebugController( boolean displayWarning ) {
// for backward compatibility. Can be removed later.
this( displayWarning, false );
}
public DebugController( boolean displayWarning, boolean quiet ) {
this( displayWarning, quiet, System.out );
}
public DebugController( boolean displayWarning, boolean quiet, EntityResolver externalEntityResolver ) {
this( displayWarning, quiet, System.out, externalEntityResolver );
}
public DebugController( boolean displayWarning, boolean quiet, PrintStream outDevice ) {
this( displayWarning, quiet, outDevice, null );
}
public DebugController( boolean displayWarning, boolean quiet, PrintStream outDevice, EntityResolver externalEntityResolver ) {
this.out = outDevice;
this.displayWarning = displayWarning;
this.warningReported = quiet;
this.externalEntityResolver = externalEntityResolver;
}
public void warning( Locator[] loc, String errorMessage ) {
if(!displayWarning) {
if( !warningReported )
out.println( Driver.localize(Driver.MSG_WARNING_FOUND) );
warningReported = true;
return;
}
out.println(errorMessage);
if(loc==null || loc.length==0)
out.println(" location unknown");
else
for( int i=0; i<loc.length; i++ )
printLocation(loc[i]);
}
public void error( Locator[] loc, String errorMessage, Exception nestedException ) {
if( nestedException instanceof SAXException ) {
out.println("SAXException: " + nestedException.getLocalizedMessage() );
SAXException se = (SAXException)nestedException;
if(se.getException()!=null) {
out.println(" nested exception: " + se.getException().getLocalizedMessage() );
se.getException().printStackTrace(System.out);
}
} else {
out.println(errorMessage);
// Thread.currentThread().dumpStack();
// nestedException.printStackTrace();
if(nestedException!=null)
System.out.println(nestedException);
}
if(loc==null || loc.length==0)
out.println(" location unknown");
else
for( int i=0; i<loc.length; i++ )
printLocation(loc[i]);
}
private void printLocation( Locator loc ) {
String col="";
if(loc.getColumnNumber()>=0)
col = ":"+loc.getColumnNumber();
out.println( " "+
loc.getLineNumber()+
col+
"@"+
loc.getSystemId() );
}
public InputSource resolveEntity( String publicId, String systemId ) throws java.io.IOException, SAXException {
if(externalEntityResolver!=null) {
// System.out.println("using external resolver");
return externalEntityResolver.resolveEntity(publicId,systemId);
}
return null;
}
}