xref: /aoo4110/main/sw/source/core/except/errhdl.cxx (revision b1cdbd2c)
1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_sw.hxx"
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski #ifdef DBG_UTIL
28*b1cdbd2cSJim Jagielski 
29*b1cdbd2cSJim Jagielski #define _ERRHDL_CXX
30*b1cdbd2cSJim Jagielski 
31*b1cdbd2cSJim Jagielski 
32*b1cdbd2cSJim Jagielski #include "stdlib.h"
33*b1cdbd2cSJim Jagielski #include <tools/debug.hxx>
34*b1cdbd2cSJim Jagielski #include <vcl/svapp.hxx>
35*b1cdbd2cSJim Jagielski #include <vcl/sound.hxx>
36*b1cdbd2cSJim Jagielski #include <errhdl.hxx>
37*b1cdbd2cSJim Jagielski #include <error.h>				// fuer die defines von ERR_SW6MSG_ ...
38*b1cdbd2cSJim Jagielski 
39*b1cdbd2cSJim Jagielski #ifndef CVBREAK
40*b1cdbd2cSJim Jagielski #define CVBREAK
41*b1cdbd2cSJim Jagielski #endif
42*b1cdbd2cSJim Jagielski 
43*b1cdbd2cSJim Jagielski sal_Bool bAssertFail = sal_False;			// ist gerade eine Assertbox oben ?
44*b1cdbd2cSJim Jagielski sal_Bool bAssert = sal_False;				// sal_True, wenn mal ein ASSERT kam.
45*b1cdbd2cSJim Jagielski 
46*b1cdbd2cSJim Jagielski /*------------------------------------------------------------------------
47*b1cdbd2cSJim Jagielski 	Ausgabe einer Fehlermeldung inkl. Bedingung, Dateiname und Zeilennummer
48*b1cdbd2cSJim Jagielski 	wo der Fehler auftrat.
49*b1cdbd2cSJim Jagielski 	Die Funktion wird durch das ASSERT Makro gerufen!
50*b1cdbd2cSJim Jagielski 	Parameter:
51*b1cdbd2cSJim Jagielski 				char	*pError		Fehlermeldung
52*b1cdbd2cSJim Jagielski 				char	*pFileName	Filename in dem der Fehler auftrat
53*b1cdbd2cSJim Jagielski 				sal_uInt16	nLine		Zeilennummer in dem der Fehler auftrat
54*b1cdbd2cSJim Jagielski ------------------------------------------------------------------------*/
55*b1cdbd2cSJim Jagielski 
AssertFail(const sal_Char * pError,const sal_Char * pFileName,sal_uInt16 nLine)56*b1cdbd2cSJim Jagielski void AssertFail( const sal_Char* pError, const sal_Char* pFileName, sal_uInt16 nLine )
57*b1cdbd2cSJim Jagielski {
58*b1cdbd2cSJim Jagielski 	CVBREAK;
59*b1cdbd2cSJim Jagielski 	// NOTE4("ASSERT: %s at %d: %s\n", pFileName, nLine, pError);
60*b1cdbd2cSJim Jagielski 	bAssert = sal_True;
61*b1cdbd2cSJim Jagielski 
62*b1cdbd2cSJim Jagielski 	if( !bAssertFail && GetpApp() && GetpApp()->IsInMain() )
63*b1cdbd2cSJim Jagielski 	{
64*b1cdbd2cSJim Jagielski 		bAssertFail = sal_True;
65*b1cdbd2cSJim Jagielski 		ByteString	aErr;
66*b1cdbd2cSJim Jagielski 		aErr = "Assertion failed\n==================\nFILE      :  ";
67*b1cdbd2cSJim Jagielski 		aErr += pFileName;
68*b1cdbd2cSJim Jagielski 		aErr += " at line ";
69*b1cdbd2cSJim Jagielski 		aErr += ByteString::CreateFromInt32( nLine );
70*b1cdbd2cSJim Jagielski 		aErr += "\nERROR :  ";
71*b1cdbd2cSJim Jagielski 		aErr += pError;
72*b1cdbd2cSJim Jagielski 
73*b1cdbd2cSJim Jagielski 		ByteString aTmp( getenv( "SW_NOBEEP" ) );
74*b1cdbd2cSJim Jagielski 		if ( aTmp != "sal_True" )
75*b1cdbd2cSJim Jagielski 			Sound::Beep(SOUND_ERROR);
76*b1cdbd2cSJim Jagielski 
77*b1cdbd2cSJim Jagielski #if defined( UNX ) && !defined( DBG_UTIL )
78*b1cdbd2cSJim Jagielski 		DBG_ERROR( aErr.GetBuffer() ); // DbgErr ist in UNIX-nicht Produkt-Versionen nicht definiert
79*b1cdbd2cSJim Jagielski #else
80*b1cdbd2cSJim Jagielski 		DbgError( aErr.GetBuffer() );
81*b1cdbd2cSJim Jagielski #endif
82*b1cdbd2cSJim Jagielski 		bAssertFail = sal_False;
83*b1cdbd2cSJim Jagielski 	}
84*b1cdbd2cSJim Jagielski 	else
85*b1cdbd2cSJim Jagielski 	{
86*b1cdbd2cSJim Jagielski 		Sound::Beep(SOUND_ERROR);
87*b1cdbd2cSJim Jagielski 		Sound::Beep(SOUND_ERROR);
88*b1cdbd2cSJim Jagielski 		Sound::Beep(SOUND_ERROR);
89*b1cdbd2cSJim Jagielski 		if( !bAssertFail )
90*b1cdbd2cSJim Jagielski 			*(short *)0 = 4711; 		// UAE ausloesen
91*b1cdbd2cSJim Jagielski 	}
92*b1cdbd2cSJim Jagielski }
93*b1cdbd2cSJim Jagielski 
94*b1cdbd2cSJim Jagielski /*------------------------------------------------------------------------
95*b1cdbd2cSJim Jagielski 	Ausgabe einer Fehlermeldung inkl. Bedingung, Dateiname und Zeilennummer
96*b1cdbd2cSJim Jagielski 	wo der Fehler auftrat.
97*b1cdbd2cSJim Jagielski 	Die Funktion wird durch das ASSERT Makro gerufen!
98*b1cdbd2cSJim Jagielski 	Parameter:
99*b1cdbd2cSJim Jagielski 				sal_uInt16	nErrorId	Id fuer Fehlermeldung
100*b1cdbd2cSJim Jagielski 				char	*pFileName	Filename in dem der Fehler auftrat
101*b1cdbd2cSJim Jagielski 				sal_uInt16	nLine		Zeilennummer in dem der Fehler auftrat
102*b1cdbd2cSJim Jagielski ------------------------------------------------------------------------*/
103*b1cdbd2cSJim Jagielski 
AssertFail(sal_uInt16 nErrorId,const sal_Char * pFileName,sal_uInt16 nLine)104*b1cdbd2cSJim Jagielski void AssertFail( sal_uInt16 nErrorId, const sal_Char* pFileName, sal_uInt16 nLine )
105*b1cdbd2cSJim Jagielski {
106*b1cdbd2cSJim Jagielski 	// Umsetzung der ErrorId in eine Fehlermeldung
107*b1cdbd2cSJim Jagielski 	static const sal_Char
108*b1cdbd2cSJim Jagielski 		/* Error Fehlermeldungen zugriffe ausserhalb eines Bereiches */
109*b1cdbd2cSJim Jagielski 		sERR_VAR_IDX[]		= "Op[]",
110*b1cdbd2cSJim Jagielski 		sERR_OUTOFSCOPE[]	= "Zugriff ausserhalb des Bereiches",
111*b1cdbd2cSJim Jagielski 		/* Error Codes fuer Numerierungsregeln */
112*b1cdbd2cSJim Jagielski 		sERR_NUMLEVEL[] 	= "Falscher Num-Level",
113*b1cdbd2cSJim Jagielski 		/* Error Codes fuer TxtNode */
114*b1cdbd2cSJim Jagielski 		sERR_NOHINTS[]		= "Zugriff auf ungueltiges HintsArray",
115*b1cdbd2cSJim Jagielski 		sERR_UNKNOWN[]		= "???";
116*b1cdbd2cSJim Jagielski 
117*b1cdbd2cSJim Jagielski 	static const sal_Char* aErrStrTab[ ERR_SWGMSG_END - ERR_SWGMSG_START +1 ] =
118*b1cdbd2cSJim Jagielski 	{
119*b1cdbd2cSJim Jagielski 		sERR_VAR_IDX, sERR_OUTOFSCOPE, sERR_NUMLEVEL, sERR_NOHINTS
120*b1cdbd2cSJim Jagielski 	};
121*b1cdbd2cSJim Jagielski 
122*b1cdbd2cSJim Jagielski 	const sal_Char* pMsg;
123*b1cdbd2cSJim Jagielski 	if( nErrorId >= ERR_SWGMSG_START && nErrorId < ERR_SWGMSG_END )
124*b1cdbd2cSJim Jagielski 		pMsg = aErrStrTab[ nErrorId - ERR_SWGMSG_START ];
125*b1cdbd2cSJim Jagielski 	else
126*b1cdbd2cSJim Jagielski 		pMsg = sERR_UNKNOWN;
127*b1cdbd2cSJim Jagielski 
128*b1cdbd2cSJim Jagielski 	AssertFail( pMsg, pFileName, nLine );
129*b1cdbd2cSJim Jagielski }
130*b1cdbd2cSJim Jagielski 
131*b1cdbd2cSJim Jagielski #endif // DBG_UTIL
132*b1cdbd2cSJim Jagielski 
133