ABAP Keyword Documentation → ABAP - Reference → Program Flow Logic → Exception Handling → Exceptions Before Class-Based Exceptions → Non-Class-Based Exceptions
MESSAGE - RAISING
Other versions: 7.31 | 7.40 | 7.54
Syntax
MESSAGE { msg |
text } RAISING exception [WITH dobj1 ... dobj4].
Effect
The statement MESSAGE with the
addition RAISING raises a non-class-based exception exception
and only sends a message if the exception is not handled. The semantics of
msg, text,
and WITH is the same as in the statement MESSAGE without the addition RAISING.
This addition only makes sense during the processing of methods and function modules in which the non-class-based exception exception is defined. Furthermore, it cannot be used in the same
processing block as
the statement RAISE EXCEPTION or the addition THROW in a
conditional expression to raise class-based exceptions.
-
If the
MESSAGE-statement is processed with the additionRAISINGduring processing of a method or a function module whose caller assigns a return value to the exceptionexceptionwith the additionEXCEPTIONSof the statementCALL, it has the same effect as the statementRAISE. -
If no return value is assigned to the exception
exception, the addition RAISING is ignored and the message is sent using the statementMESSAGEand processed in accordance with its message type.
The system fields of the statement MESSAGE are populated in both cases and
are available in the calling program after handling an exception raised with MESSAGE ...RAISING. This is especially true if a function module was called through Remote Function Call
(RFC).
Notes
-
The statement
MESSAGE ... RAISINGis primarily a statement for raising exceptions and not for sending messages. An exception of this type should always be handled like an exception raised usingRAISE, since the behavior of the message depends strongly on the context and is usually unpredictable when the function module is created. -
Using
MESSAGE ... RAISINGin cases in which non class-based exceptions must still be used is preferable to using theRAISEstatement, because it offers the option of providing additional text information with an exception. -
A return value can be assigned to messages that are sent in function modules without the addition
RAISING by using the predefined exception
error_message. -
Messages sent as messages when a function module is called and not caught (despite
RAISING) are processed as witherror_message. -
If a procedure is exited by raising an exception, the content of the formal parameter for which the
pass by value is defined is not assigned to the respective actual parameters.
Example
When the message is called for the first time, an
information message is sent. The second time, an exception is raised instead, which is handled by sy-subrc.
CLASS c1 DEFINITION.
PUBLIC SECTION.
CLASS-METHODS m1 EXCEPTIONS exc1.
ENDCLASS.
CLASS c1 IMPLEMENTATION.
METHOD m1.
MESSAGE 'Message in a Method' TYPE 'I' RAISING exc1.
ENDMETHOD.
ENDCLASS.
...
c1=>m1( ).
c1=>m1( EXCEPTIONS exc1 = 4 ).
IF sy-subrc = 4.
...
ENDIF.