Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Class List | Directories | File List | Namespace Members | Class Members | File Members | Related Pages

ErrorHandler.H

Go to the documentation of this file.
00001 /*---------------------------------------------------------------------*
00002  | Library QgarLib, graphics analysis and recognition                  |
00003  | Copyright (C) 2003  Qgar Project, LORIA                             |
00004  |                                                                     |
00005  | This library is free software; you can redistribute it and/or       |
00006  | modify it under the terms of the GNU Lesser General Public          |
00007  | License version 2.1, as published by the Free Software Foundation.  |
00008  |                                                                     |
00009  | This library is distributed in the hope that it will be useful,     |
00010  | but WITHOUT ANY WARRANTY; without even the implied warranty of      |
00011  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.                |
00012  | See the GNU Lesser General Public License for more details.         |
00013  |                                                                     |
00014  | The GNU Lesser General Public License is included in the file       |
00015  | LICENSE.LGPL, in the root directory of the Qgar packaging. See      |
00016  | http://www.gnu.org/licenses/lgpl.html for the terms of the license. |
00017  | To receive a paper copy, write to the Free Software Foundation,     |
00018  | Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.       |
00019  |                                                                     |
00020  | Contact Project Qgar for any information:                           |
00021  |   LORIA - équipe Qgar                                               |
00022  |   B.P. 239, 54506 Vandoeuvre-lès-Nancy Cedex, France                |
00023  |   email: qgar-contact@loria.fr                                      |
00024  |   http://www.qgar.org/                                              |
00025  *---------------------------------------------------------------------*/
00026 
00027 
00028 #ifndef __ERRORHANDLER_H_INCLUDED__
00029 #define __ERRORHANDLER_H_INCLUDED__
00030 
00031 
00032 /**
00033  * @file     ErrorHandler.H
00034  * @brief    Header file of class qgxml::ErrorHandler
00035  *
00036  * @author   <a href="mailto:qgar-contact@loria.fr?subject=Qgar fwd Jan Rendek">Jan Rendek</a>
00037  * @date     March 10, 2003  15:56
00038  * @since    Qgar 2.1.1
00039  */
00040 
00041 
00042 // For RCS/CVS use: Do not delete
00043 /* $Id: ErrorHandler.H,v 1.5 2004/07/02 20:36:43 masini Exp $ */
00044 
00045 
00046 
00047 namespace qgxml {
00048 
00049 class SAXParseException;
00050 
00051 /**
00052  * @class ErrorHandler ErrorHandler.H <qgarlib/sax/ErrorHandler.H>
00053  * @ingroup XML
00054  * @brief Basic interface for SAX error handlers.
00055  *
00056  * If a SAX application needs to implement customized error handling,
00057  * it must implement this interface and then register an instance with
00058  * the XML reader using the setErrorHandler method. The parser will
00059  * then report all errors and warnings through this interface.
00060  * 
00061  * <b> This class is an adaptation for C++ of the interface of the same
00062  * name implemented in the Java SAX API (http://www.saxproject.org).
00063  * </b>
00064  * 
00065  * @author <a href="mailto:qgar-contact@loria.fr?subject=Qgar fwd Jan Rendek">Jan Rendek</a> (Adaptation).
00066  * @date   March 10, 2003  15:56
00067  * @since  Qgar 2.1.1
00068  */
00069 class ErrorHandler {
00070 
00071 // -------------------------------------------------------------------
00072 // P U B L I C    M E M B E R S
00073 // -------------------------------------------------------------------
00074 public:
00075 
00076 /** @name Destructor */
00077 //        ==========
00078 //@{
00079 
00080 /**
00081  * @brief Destructor
00082  */
00083   virtual ~ErrorHandler() { }
00084 
00085 //@}
00086 
00087 /**
00088  * @brief Receive notification of a recoverable error.
00089  *
00090  * @param exception The error information encapsulated in a SAX parse
00091  *                  exception. 
00092  */
00093   virtual void error(const SAXParseException& exception) = 0;
00094    
00095 /**
00096  * @brief Receive notification of a non-recoverable error.
00097  *
00098  * @param exception The error information encapsulated in a SAX parse
00099  *                  exception.
00100  */
00101   virtual void fatalError(const SAXParseException& exception) = 0;
00102    
00103 /**
00104  * @brief Receive notification of a warning.
00105  *
00106  * @param exception The warning information encapsulated in a SAX
00107  *                  parse exception.
00108  */
00109   virtual void warning(const SAXParseException& exception) = 0;
00110 
00111 
00112 // -------------------------------------------------------------------
00113 
00114 }; // class ErrorHandler
00115 
00116 } // namespace qgxml
00117 
00118 
00119 #endif /* __ERRORHANDLER_H_INCLUDED__ */