1 // Copyright (C) 2007-2008 CEA/DEN, EDF R&D, OPEN CASCADE
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
22 // File : SALOME_Exception.idl
23 // Author : Paul RASCLE, EDF
26 /*! \file SALOME_Exception.idl \brief This file contains the objects defining the main exception used
27 in %SALOME application.
29 The idl SALOME_Exception provides a generic CORBA exception for SALOME,
30 with an attribute that gives an exception type,a message, plus optional source file name and line number.
31 This idl is intended to serve for all user CORBA exceptions raised in SALOME code, as IDL specification
32 does not support exception inheritance. So, all the user CORBA exceptions from SALOME could be
33 handled in a single catch.
36 #ifndef _SALOME_EXCEPTION_IDL_
37 #define _SALOME_EXCEPTION_IDL_
40 Module %SALOME contains all base interfaces of %SALOME Kernel
46 //! This enumeration contains the elements indicating the type of the exception which can be raised during %SALOME session.
49 COMM, /*!< Communication problem */
50 BAD_PARAM, /*!< Bad User parameters */
51 INTERNAL_ERROR /*!< Application level problem, irrecoverable */
53 //! This struct contains a set of fields defining the structure of the exception.
54 struct ExceptionStruct
56 ExceptionType type; /*!<Type of the exception.*/
57 string text; /*!<Message which is shown when the exception is raised.*/
58 string sourceFile; /*!<The source file where the exception is raised.*/
59 unsigned long lineNumber; /*!<Number of the line of the source file where the exception is raised.*/
61 /*! \brief The main exception in %SALOME application.
63 The idl SALOME_Exception provides a generic CORBA exception for SALOME,
64 with an attribute that gives an exception type,a message, plus optional source file name and line number.
65 This idl is intended to serve for all user CORBA exceptions raised in SALOME code, as IDL specification
66 does not support exception inheritance. So, all the user CORBA exceptions from SALOME could be
67 handled in a single catch.
69 exception SALOME_Exception
71 ExceptionStruct details; /*!<Structure of the exception.*/