All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ibm.as400.data.XMLErrorHandler Maven / Gradle / Ivy

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: XMLErrorHandler.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2000 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.data;

import org.xml.sax.ErrorHandler;                                    // @C1A
import org.xml.sax.SAXParseException;                               // @C1A

class XMLErrorHandler extends Object implements ErrorHandler        // @C1C
{
    private String			m_filename;
    private int				m_headerLineCount;
    private boolean			m_ignorePCML = false;

    private ParseException	m_exc;

 	public XMLErrorHandler(String sxml, int headerLineCount)
 	{
 		m_filename = sxml;
 		m_headerLineCount = headerLineCount;
 	}

    public void error(SAXParseException spe)                        // @C1C
    {			  
        int lineNumber = spe.getLineNumber();                       // @C1A
        int columnNumber = spe.getColumnNumber();                   // @C1A
        
    	// Filename is either the source file or the DTD file 
    	// based on the line number because the DTD was prepended to the
    	// source as an inline DTD.
    	String fname;

    	// Adjust the line number to account for the PCML header
    	if (!(lineNumber - m_headerLineCount > 0))
    	{
    		// We have an error in the DTD.
    		// Change the filename and ignore any subsequent PCML errors.
    		fname = "pcml.dtd";
    		m_ignorePCML = true;
    	}
    	else
    	{
    		// Error is in the PCML.  Suppress if errors occurred in the DTD.
    		if (m_ignorePCML)                                       // @C1C
    		    return;                                             // @C1A
    		    
        	fname = m_filename;
    	    lineNumber -= m_headerLineCount;
    	}

    	// If exception object doesn't exist, create it
    	if (m_exc == null)
    	{
    		m_exc = new ParseException(SystemResourceFinder.format(DAMRI.FAILED_TO_PARSE, new Object[] {fname} ) );
    	}

		// Add the formatted message
   		m_exc.addMessage("[" + lineNumber + "," + (columnNumber - 1) + "]: " + spe.getMessage() );
    }
    
    public void fatalError(SAXParseException spe)                   // @C1A
    {                                                               // @C1A
        error(spe);                                                 // @C1A
    }
    
    public void warning(SAXParseException spe)                      // @C1A
    {                                                               // @C1A
        int lineNumber = spe.getLineNumber();                       // @C1A
        int columnNumber = spe.getColumnNumber();                   // @C1A
        
    	// Filename is either the source file or the DTD file 
    	// based on the line number because the DTD was prepended to the
    	// source as an inline DTD.
    	String fname;                                               // @C1A

    	// Adjust the line number to account for the PCML header
    	if (!(lineNumber - m_headerLineCount > 0))                  // @C1A
    	{                                                           // @C1A
    		// We have an error in the DTD.
    		// Change the filename.
    		fname = "pcml.dtd";                                     // @C1A
    	}                                                           // @C1A
    	else                                                        // @C1A
    	{                                                           // @C1A
        	fname = m_filename;                                     // @C1A
    	    lineNumber -= m_headerLineCount;                        // @C1A
    	}                                                           // @C1A

   		System.err.println(fname + "[" + lineNumber + "," + (columnNumber - 1) + "]: " + spe.getMessage() ); // @C1A
    }                                                               // @C1A

    public ParseException getException()
    {
    	return m_exc;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy