sapdev logo background
sapdev logo sapdev logo
Comments

ABAP DO VARYING Statement syntax, information and example SAP source code



Return to Statement index



DO - VARYING

Short Reference

ABAP Syntax(Obsolete) DO ... VARYING dobj FROM dobj1 NEXT dobj2 [RANGE range]
[VARYING ...].
[statement_block]
ENDDO.

What does it do? The addition VARYING assigns a new value to a variable dobj for each pass of a DO loop. It can be used more than once in a DO statement.
dobj1 and dobj2 are the first two data objects in a string of data objects that are the same distance apart in the memory. The data types of the data objects dobj , dobj1 , and
dobj2 must be flat .
In Unicode programs , dobj , dobj1 , and dobj2 must be
compatible . Also in Unicode programs, dobj1 and dobj2 must either be structure components that belong to the same structure, or subareas of the same data object specified by offset/length specifications.
In the first pass of the loop, the content of the data object
dobj1 is assigned to dobj , and in the second loop, the content of the data object dobj2 is assigned. In the subsequent loops, dobj is assigned the content of the data object that is the same distance in the memory from the previously assigned data object, as
dobj2 is from dobj1 . There is no type conversion.
If the processing block is exited correctly using ENDDO , CHECK , or EXIT , the content of the variable dobj
at the end of the loop pass is assigned to the previously assigned data object dobj1 or dobj2 without conversion. If it is exited using another statement, such as RETURN
or RAISE EXCEPTION , no conversion takes place.
The addition RANGE defines the memory area that can be processed using the addition VARYING . After RANGE , an elementary data object range of type c , n , or x
, or a structure can be specified. The memory area of range must include the ranges of dobj1 and dobj2 . In deep structures, the deep components are exceptions to the permitted area. The DO loop must be ended before non-permitted memory areas are accessed, that is, areas outside of range or their deep components. Otherwise an unhandleable exception is raised.
If RANGE is not explicitly specified, the permitted memory area is determined as follows:
In non-Unicode programs , the permitted memory area of dobj1 extends to the limit of the current data area of the ABAP program. If the RANGE addition is not specified, there is a danger of unintentionally overwriting the memory.
In Unicode programs , RANGE can only be omitted if it can be statically determined that dobj1
and dobj2 are components of the same structure. The permitted memory area is then determined from the smallest substructure that contains dobj1 and dobj2 .

Latest notes: Instead of the addition VARYING , the statement ASSIGN should be used in the loop with the addition INCREMENT .

Example ABAP Coding In the first DO loop, subareas of the data object
text are edited using offset/length access. In Unicode programs, the addition RANGE must be specified here. In the second DO
loop, the program accesses the components of the data object
text . In this case, it is not necessary to specify RANGE . The third DO loop shows how the functions of the second loop can be programmed using the statement
ASSIGN INCREMENT .
DATA: BEGIN OF text,
word1 TYPE c LENGTH 4 VALUE 'AAAA',
word2 TYPE c LENGTH 4 VALUE 'BBBB',
word3 TYPE c LENGTH 4 VALUE 'CCCC',
word4 TYPE c LENGTH 4 VALUE 'DDDD',
END OF text.

DATA: word TYPE c LENGTH 4,
char1 TYPE c LENGTH 1,
char2 TYPE c LENGTH 1,
leng TYPE i.

FIELD-SYMBOLS <(><<)>word> LIKE text-word1.
DATA inc TYPE i.

DESCRIBE FIELD text LENGTH leng IN CHARACTER MODE.
leng = leng / 2.

cl_demo_output=>begin_section( `First Loop` ).

DO leng TIMES VARYING char1 FROM text(1)
NEXT text+2(1) RANGE text
VARYING char2 FROM text+1(1)
NEXT text+3(1) RANGE text.
cl_demo_output=>write( |{ char1 } { char2 }| ).
char1 = 'x'.
char2 = 'y'.
ENDDO.

cl_demo_output=>next_section( `Second Loop` ).

DO 4 TIMES VARYING word FROM text-word1 NEXT text-word2.
cl_demo_output=>write( word ).
ENDDO.

cl_demo_output=>next_section( `Third Loop` ).

DO.
inc = sy-index - 1.
ASSIGN text-word1 INCREMENT inc TO <(><<)>word> RANGE text.
IF sy-subrc = 0.
cl_demo_output=>write( <(><<)>word> ).
ELSE.
EXIT.
ENDIF.
ENDDO.

cl_demo_output=>display( ).



Runtime Exceptions
Non-catchable Exceptions
Reason for error: Invalid access to deep components within the area specified by the RANGE -addition.
Runtime error: DO_WHILE_VARY_ILLEGAL_ACCESS
Reason for error: Access to data outside the range specified by the
RANGE addition.
Runtime error: DO_WHILE_VARY_NOT_IN_RANGE
Documentation extract taken from SAP system, � Copyright SAP AG. All rights reserved




DOWNLOAD
EDITOR-CALL




comments powered by Disqus