Salome HOME
CCAR: remove debug prints from the standard trace and put these prints
[modules/kernel.git] / idl / SALOME_Exception.idl
1 //  Copyright (C) 2007-2008  CEA/DEN, EDF R&D, OPEN CASCADE
2 //
3 //  Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 //  CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
5 //
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.
10 //
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.
15 //
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
19 //
20 //  See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22 //  File   : SALOME_Exception.idl
23 //  Author : Paul RASCLE, EDF
24 //  $Header$
25 //
26 /*! \file SALOME_Exception.idl \brief This file contains the objects defining the main exception used
27 in %SALOME application. 
28
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. 
34
35 */ 
36 #ifndef _SALOME_EXCEPTION_IDL_
37 #define _SALOME_EXCEPTION_IDL_
38
39 /*! \brief
40 Module %SALOME contains all base interfaces of %SALOME Kernel 
41
42 */ 
43
44 module SALOME
45 {
46 //!  This enumeration contains the elements indicating the type of the exception which can be raised during %SALOME session.
47   enum ExceptionType
48     { 
49       COMM,             /*!< Communication problem */
50       BAD_PARAM,        /*!< Bad User parameters */
51       INTERNAL_ERROR    /*!< Application level problem, irrecoverable */ 
52     };
53 //!  This struct contains a set of fields defining the structure of the exception.
54   struct ExceptionStruct
55   {
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.*/
60   };
61 /*! \brief The main exception in %SALOME application.
62
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.
68 */
69   exception SALOME_Exception
70   {
71     ExceptionStruct details; /*!<Structure of the exception.*/
72   };
73
74 };
75
76 #endif