You are on page 1of 11

*&---------------------------------------------------------------------*

*& Module Pool


ZREPORT_SCREEN_01
*&
*&---------------------------------------------------------------------*
*&
*&
*&---------------------------------------------------------------------*
Copyright Disclaimer Under Section 107
of the Copyright Act 1976, allowance
is made for "fair use" for purposes
such as criticism, comment, news reporting,
teaching, scholarship, and research.
Fair use is a use permitted by copyright
statute that might otherwise be infringing.
Non-profit, educational or personal use
tips the balance in favor of fair use
PROGRAM ZREPORT_SCREEN_01.
TABLES: zgpas, t001k, t001, zgpas_item.
TYPES:
BEGIN OF ty_table,
item type zgpas_item-item,
MATNR TYPE zgpas_item-matnr,
MAKTX TYPE zgpas_item-maktx,
MENGE TYPE zgpas_item-menge,
MEINS TYPE zgpas_item-meins,
DOCNO TYPE zgpas_item-docno,
DOCitem TYPE zgpas_item-docitem,
VENCUSNO TYPE zgpas_item-vencusno,
VENCUSNAME TYPE zgpas_item-vencusname,
VENCUSLOC TYPE zgpas_item-vencusloc,
PURPOS TYPE zgpas_item-purpos,
GATEPASSNUM TYPE zgpas_item-gatepassnum,
END OF ty_table.
TYPE-POOLs vrm.
DATA: g_gpas-BUKRS TYPE zgpas-bukrs,
g_gpas-werks TYPE zgpas-werks.
DATA: id TYPE vrm_id,
wa_vrm TYPE vrm_value,
it_vrm type vrm_values.
DATA: it_t001 TYPE TABLE OF t001 WITH HEADER LINE,
it_table TYPE TABLE OF ty_table WITH HEADER LINE,
wa_table TYPE ty_table,
it_t001k TYPE TABLE OF t001k WITH HEADER LINE,
wa_t001k TYPE t001k.
*
ok_code TYPE sy-ucomm.
DATA gw_gpas TYPE zgpas.
DATA it_zgpas TYPE TABLE OF zgpas.
DATA: wa_t001 TYPE t001.
START-OF-SELECTION.
CALL SCREEN 9501.
*&---------------------------------------------------------------------*
*&
Module USER_COMMAND_9500 INPUT
*&---------------------------------------------------------------------*
*
text
*----------------------------------------------------------------------*
MODULE USER_COMMAND_9500 INPUT.

CASE SY-UCOMM .
WHEN 'CREATE' .
CALL SCREEN 9501.
WHEN 'DISPLAY'.
CALL SCREEN 9503.
WHEN 'CHANGE'.
CALL SCREEN 9502.
WHEN 'PRINT'.
CALL SCREEN 9504.
WHEN 'REPORT'.
CALL SCREEN 9505.
WHEN 'BACK'.
LEAVE PROGRAM.
ENDCASE.
ENDMODULE.
" USER_COMMAND_9500 INPUT
*&---------------------------------------------------------------------*
*&
Module STATUS_9500 OUTPUT
*&---------------------------------------------------------------------*
*
text
*----------------------------------------------------------------------*
MODULE STATUS_9500 OUTPUT.
* DATA l_dynnr TYPE sy-dynnr.
SET PF-STATUS 'ZSTATUS_GATEPASS'.
SET TITLEBAR 'ZTITLE_GATEPASS'.
ENDMODULE.

" STATUS_9500 OUTPUT

*&---------------------------------------------------------------------*
*&
Module STATUS_9501 OUTPUT
*&---------------------------------------------------------------------*
*
text
*----------------------------------------------------------------------*
MODULE STATUS_9501 OUTPUT.
*
SET PF-STATUS 'ZSTATUS_GATEPASS1'.
SET TITLEBAR 'ZTITLE_GATEPASS1'.
*
**MESSAGE i888(sabapdocu) WITH IO.
ENDMODULE.
" STATUS_9501 OUTPUT
*&---------------------------------------------------------------------*
" USER_COMMAND_9501 INPUT
*&---------------------------------------------------------------------*
*&
Module bukrs INPUT
*&---------------------------------------------------------------------*
*
text
*----------------------------------------------------------------------*
MODULE bukrs INPUT.
SELECT bukrs butxt FROM t001
INTO CORRESPONDING FIELDS OF TABLE it_t001
WHERE spras = 'E' .
LOOP AT it_t001 INTO wa_t001.
wa_vrm-key = wa_t001-bukrs.
wa_vrm-text = wa_t001-bukrs.
APPEND wa_vrm to it_vrm.
ENDLOOP.
*
id = gw_gpas-bukrs.
CALL FUNCTION 'VRM_SET_VALUES'
EXPORTING
ID
= 'G_GPAS-BUKRS'

VALUES
= it_vrm
EXCEPTIONS
ID_ILLEGAL_NAME
= 1
OTHERS
= 2
.
IF SY-SUBRC <> 0.
* MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
*
WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
ENDIF.
ENDMODULE.
" bukrs INPUT
*&---------------------------------------------------------------------*
*&
Module plant INPUT
*&---------------------------------------------------------------------*
*
text
*----------------------------------------------------------------------*
MODULE plant INPUT.
CLEAR wa_vrm.
REFRESH it_vrm.
SELECT bwkey bukrs FROM t001k
INTO CORRESPONDING FIELDS OF TABLE it_t001k .
LOOP AT it_t001k INTO wa_t001k.
wa_vrm-key = wa_t001k-bukrs.
wa_vrm-text = wa_t001k-bwkey.
APPEND wa_vrm to it_vrm.
ENDLOOP.
*
id = gw_gpas-bukrs.
CALL FUNCTION 'VRM_SET_VALUES'
EXPORTING
ID
= 'G_GPAS-WERKS'
VALUES
= it_vrm
EXCEPTIONS
ID_ILLEGAL_NAME
= 1
OTHERS
= 2
.
IF SY-SUBRC <> 0.
* MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
*
WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
ENDIF.
ENDMODULE.
" plant INPUT
*&---------------------------------------------------------------------*
*&
Module USER_COMMAND_9501 INPUT
*&---------------------------------------------------------------------*
*
text
*----------------------------------------------------------------------*
MODULE USER_COMMAND_9501 INPUT.
CLEAR GW_GPAS.
DATA: l_pass TYPE n LENGTH 10.
if sy-ucomm eq 'SAVE'.
gw_gpas-bukrs = g_gpas-BUKRS.
gw_gpas-WERKS = g_gpas-WERKS.
gw_gpas-GPASTYP = zgpas-GPASTYP.
gw_gpas-USERBY = zgpas-USERBY .
gw_gpas-USERDPT = zgpas-USERDPT .
gw_gpas-REFDOCTYP = zgpas-REFDOCTYP .
gw_gpas-MJAHR = zgpas-MJAHR .
gw_gpas-TEXT = zgpas-TEXT .
gw_gpas-VEHCLENO = zgpas-VEHCLENO .

gw_gpas-VEHCLTYP = zgpas-VEHCLTYP .
gw_gpas-DRIVERNAME = zgpas-DRIVERNAME .
gw_gpas-DRIVERTELE = zgpas-DRIVERTELE .
gw_gpas-NAME1 = zgpas-NAME1 .
gw_gpas-LIFNR = zgpas-LIFNR .
gw_gpas-VENCUST = zgpas-VENCUST .
gw_gpas-ADDRESS = zgpas-ADDRESS .

*
*
*
*
*
*

CALL FUNCTION 'NUMBER_GET_NEXT'


EXPORTING
NR_RANGE_NR
OBJECT
QUANTITY
SUBOBJECT
TOYEAR
IGNORE_BUFFER
IMPORTING
NUMBER
QUANTITY
RETURNCODE
EXCEPTIONS
INTERVAL_NOT_FOUND
NUMBER_RANGE_NOT_INTERN
OBJECT_NOT_FOUND
QUANTITY_IS_0
QUANTITY_IS_NOT_1
INTERVAL_OVERFLOW
BUFFER_OVERFLOW
OTHERS
.
IF SY-SUBRC = 0.
gw_gpas-GATEPASSNUM = l_pass.
ENDIF.

=
=
=
=
=
=

'01'
'ZGPAS'
'1'
' '
'0000'
' '

= l_pass
=
=
=
=
=
=
=
=
=
=

1
2
3
4
5
6
7
8

INSERT ZGPAS FROM gw_gpas.


CLEAR: wa_table, zgpas, g_gpas-bukrs, g_gpas-werks.
endif.
IF sy-ucomm = 'BACK'.
LEAVE TO SCREEN 9500.
ENDIF.
*
WHEN OTHERS.
*ENDCASE.
ENDMODULE.
" USER_COMMAND_9501 INPUT
*&---------------------------------------------------------------------*
*&
Module DB_UPDATE INPUT
*&---------------------------------------------------------------------*
*
text
*----------------------------------------------------------------------*
MODULE DB_UPDATE INPUT.
DATA lw_table TYPE TABLE OF zgpas_item WITH HEADER LINE.
CLEAR ZGPAS_ITEM.
if sy-ucomm = 'SAVE'.
lw_table-item = IT_TABLE-ITEM.
lw_table-MATNR = IT_TABLE-MATNR.
lw_table-MAKTX
= IT_TABLE-MAKTX .
lw_table-MENGE
= IT_TABLE-MENGE .
lw_table-MEINS
= IT_TABLE-MEINS .
lw_table-MEINS
= IT_TABLE-MEINS .
lw_table-DOCNO
= IT_TABLE-DOCNO .

lw_table-DOCitem
lw_table-VENCUSNO
lw_table-VENCUSNAME
lw_table-VENCUSLOC
lw_table-PURPOS
lw_table-GATEPASSNUM
APPEND lw_table .

= IT_TABLE-DOCITEM .
= IT_TABLE-VENCUSNO .
= G_TABLE_CONTRL_WA-VENCUSNAME .
= IT_TABLE-VENCUSLOC .
= IT_TABLE-PURPOS .
= gw_gpas-GATEPASSNUM.

INSERT INTO zgpas_item VALUES lw_table.


ENDIF.
ENDMODULE.
" DB_UPDATE INPUT
*&SPWIZARD: DECLARATION OF TABLECONTROL 'TC' ITSELF
CONTROLS: TC TYPE TABLEVIEW USING SCREEN 9501.
*&SPWIZARD: LINES OF TABLECONTROL 'TC'
DATA:
G_TC_LINES LIKE SY-LOOPC.
DATA:

OK_CODE LIKE SY-UCOMM.

*&SPWIZARD: OUTPUT MODULE FOR TC 'TC'. DO NOT CHANGE THIS LINE!


*&SPWIZARD: UPDATE LINES FOR EQUIVALENT SCROLLBAR
MODULE TC_CHANGE_TC_ATTR OUTPUT.
DESCRIBE TABLE IT_TABLE LINES TC-lines.
ENDMODULE.
*&SPWIZARD: OUTPUT MODULE FOR TC 'TC'. DO NOT CHANGE THIS LINE!
*&SPWIZARD: GET LINES OF TABLECONTROL
MODULE TC_GET_LINES OUTPUT.
G_TC_LINES = SY-LOOPC.
ENDMODULE.
*&SPWIZARD: INPUT MODULE FOR TC 'TC'. DO NOT CHANGE THIS LINE!
*&SPWIZARD: MODIFY TABLE
MODULE TC_MODIFY INPUT.
MODIFY IT_TABLE
INDEX TC-CURRENT_LINE.
ENDMODULE.
*&SPWIZARD: INPUT MODULE FOR TC 'TC'. DO NOT CHANGE THIS LINE!
*&SPWIZARD: PROCESS USER COMMAND
MODULE TC_USER_COMMAND INPUT.
OK_CODE = SY-UCOMM.
PERFORM USER_OK_TC USING
'TC'
'IT_TABLE'
' '
CHANGING OK_CODE.
SY-UCOMM = OK_CODE.
ENDMODULE.
*----------------------------------------------------------------------*
* INCLUDE TABLECONTROL_FORMS
*
*----------------------------------------------------------------------*
*&---------------------------------------------------------------------*
*&
Form USER_OK_TC
*
*&---------------------------------------------------------------------*
FORM USER_OK_TC USING
P_TC_NAME TYPE DYNFNAM
P_TABLE_NAME
P_MARK_NAME

CHANGING P_OK

LIKE SY-UCOMM.

*&SPWIZARD: BEGIN OF LOCAL DATA----------------------------------------*


DATA: L_OK
TYPE SY-UCOMM,
L_OFFSET
TYPE I.
*&SPWIZARD: END OF LOCAL DATA------------------------------------------*
*&SPWIZARD: Table control specific operations
*&SPWIZARD: evaluate TC name and operations
SEARCH P_OK FOR P_TC_NAME.
IF SY-SUBRC <> 0.
EXIT.
ENDIF.
L_OFFSET = STRLEN( P_TC_NAME ) + 1.
L_OK = P_OK+L_OFFSET.
*&SPWIZARD: execute general and TC specific operations
CASE L_OK.
WHEN 'INSR'.
"insert row
PERFORM FCODE_INSERT_ROW USING
P_TC_NAME
P_TABLE_NAME.
CLEAR P_OK.
WHEN 'DELE'.
"delete row
PERFORM FCODE_DELETE_ROW USING
P_TC_NAME
P_TABLE_NAME
P_MARK_NAME.
CLEAR P_OK.
WHEN 'P--' OR
'P-' OR
'P+' OR
'P++'.
PERFORM COMPUTE_SCROLLING_IN_TC
*
*
*
*
*
*
*
*
*
*
*
*

"top of list
"previous page
"next page
"bottom of list
USING P_TC_NAME
L_OK.

CLEAR P_OK.
WHEN 'L--'.
"total left
PERFORM FCODE_TOTAL_LEFT USING P_TC_NAME.
WHEN 'L-'.
"column left
PERFORM FCODE_COLUMN_LEFT USING P_TC_NAME.
WHEN 'R+'.
"column right
PERFORM FCODE_COLUMN_RIGHT USING P_TC_NAME.
WHEN 'R++'.
"total right
PERFORM FCODE_TOTAL_RIGHT USING P_TC_NAME.
WHEN 'MARK'.
"mark all filled lines
PERFORM FCODE_TC_MARK_LINES USING P_TC_NAME
P_TABLE_NAME
P_MARK_NAME .
CLEAR P_OK.
WHEN 'DMRK'.
"demark all filled lines
PERFORM FCODE_TC_DEMARK_LINES USING P_TC_NAME
P_TABLE_NAME
P_MARK_NAME .
CLEAR P_OK.

WHEN 'SASCEND'

OR

*
*

*
*
*

'SDESCEND'.
"sort column
PERFORM FCODE_SORT_TC USING P_TC_NAME
l_ok.
ENDCASE.
ENDFORM.

" USER_OK_TC

*&---------------------------------------------------------------------*
*&
Form FCODE_INSERT_ROW
*
*&---------------------------------------------------------------------*
FORM fcode_insert_row
USING
P_TC_NAME
TYPE DYNFNAM
P_TABLE_NAME
.
*&SPWIZARD: BEGIN OF LOCAL DATA----------------------------------------*
DATA L_LINES_NAME
LIKE FELD-NAME.
DATA L_SELLINE
LIKE SY-STEPL.
DATA L_LASTLINE
TYPE I.
DATA L_LINE
TYPE I.
DATA L_TABLE_NAME
LIKE FELD-NAME.
FIELD-SYMBOLS <TC>
TYPE CXTAB_CONTROL.
FIELD-SYMBOLS <TABLE>
TYPE STANDARD TABLE.
FIELD-SYMBOLS <LINES>
TYPE I.
*&SPWIZARD: END OF LOCAL DATA------------------------------------------*
ASSIGN (P_TC_NAME) TO <TC>.
*&SPWIZARD: get the table, which belongs to the tc
CONCATENATE P_TABLE_NAME '[]' INTO L_TABLE_NAME. "table body
ASSIGN (L_TABLE_NAME) TO <TABLE>.
"not headerline

*&SPWIZARD: get looplines of TableControl


CONCATENATE 'G_' P_TC_NAME '_LINES' INTO L_LINES_NAME.
ASSIGN (L_LINES_NAME) TO <LINES>.

*&SPWIZARD: get current line


GET CURSOR LINE L_SELLINE.
IF SY-SUBRC <> 0.
" append line to table
L_SELLINE = <TC>-LINES + 1.
*&SPWIZARD: set top line
IF L_SELLINE > <LINES>.
<TC>-TOP_LINE = L_SELLINE - <LINES> + 1 .
ELSE.
<TC>-TOP_LINE = 1.
ENDIF.
ELSE.
" insert line into table
L_SELLINE = <TC>-TOP_LINE + L_SELLINE - 1.
L_LASTLINE = <TC>-TOP_LINE + <LINES> - 1.
ENDIF.
*&SPWIZARD: set new cursor line
L_LINE = L_SELLINE - <TC>-TOP_LINE + 1.

*&SPWIZARD: insert initial line


INSERT INITIAL LINE INTO <TABLE> INDEX L_SELLINE.
<TC>-LINES = <TC>-LINES + 1.
*&SPWIZARD: set cursor
SET CURSOR LINE L_LINE.

ENDFORM.

" FCODE_INSERT_ROW

*&---------------------------------------------------------------------*
*&
Form FCODE_DELETE_ROW
*
*&---------------------------------------------------------------------*
FORM fcode_delete_row
USING
P_TC_NAME
TYPE DYNFNAM
P_TABLE_NAME
P_MARK_NAME .
*&SPWIZARD: BEGIN OF LOCAL DATA----------------------------------------*
DATA L_TABLE_NAME
LIKE FELD-NAME.
FIELD-SYMBOLS <TC>
TYPE cxtab_control.
FIELD-SYMBOLS <TABLE>
TYPE STANDARD TABLE.
FIELD-SYMBOLS <WA>.
FIELD-SYMBOLS <MARK_FIELD>.
*&SPWIZARD: END OF LOCAL DATA------------------------------------------*
ASSIGN (P_TC_NAME) TO <TC>.
*&SPWIZARD: get the table, which belongs to the tc
CONCATENATE P_TABLE_NAME '[]' INTO L_TABLE_NAME. "table body
ASSIGN (L_TABLE_NAME) TO <TABLE>.
"not headerline

*&SPWIZARD: delete marked lines


DESCRIBE TABLE <TABLE> LINES <TC>-LINES.

LOOP AT <TABLE> ASSIGNING <WA>.


*&SPWIZARD: access to the component 'FLAG' of the table header
ASSIGN COMPONENT P_MARK_NAME OF STRUCTURE <WA> TO <MARK_FIELD>.

IF <MARK_FIELD> = 'X'.
DELETE <TABLE> INDEX SYST-TABIX.
IF SY-SUBRC = 0.
<TC>-LINES = <TC>-LINES - 1.
ENDIF.
ENDIF.
ENDLOOP.
ENDFORM.

" FCODE_DELETE_ROW

*&---------------------------------------------------------------------*
*&
Form COMPUTE_SCROLLING_IN_TC
*&---------------------------------------------------------------------*
*
text
*----------------------------------------------------------------------*
*
-->P_TC_NAME name of tablecontrol
*
-->P_OK
ok code
*----------------------------------------------------------------------*
FORM COMPUTE_SCROLLING_IN_TC USING
P_TC_NAME
P_OK.
*&SPWIZARD: BEGIN OF LOCAL DATA----------------------------------------*
DATA L_TC_NEW_TOP_LINE
TYPE I.
DATA L_TC_NAME
LIKE FELD-NAME.
DATA L_TC_LINES_NAME
LIKE FELD-NAME.
DATA L_TC_FIELD_NAME
LIKE FELD-NAME.
FIELD-SYMBOLS <TC>
FIELD-SYMBOLS <LINES>

TYPE cxtab_control.
TYPE I.

*&SPWIZARD: END OF LOCAL DATA------------------------------------------*


ASSIGN (P_TC_NAME) TO <TC>.
*&SPWIZARD: get looplines of TableControl
CONCATENATE 'G_' P_TC_NAME '_LINES' INTO L_TC_LINES_NAME.
ASSIGN (L_TC_LINES_NAME) TO <LINES>.

*&SPWIZARD: is no line filled?


IF <TC>-LINES = 0.
*&SPWIZARD: yes, ...
L_TC_NEW_TOP_LINE = 1.
ELSE.
*&SPWIZARD: no, ...
CALL FUNCTION 'SCROLLING_IN_TABLE'
EXPORTING
ENTRY_ACT
= <TC>-TOP_LINE
ENTRY_FROM
= 1
ENTRY_TO
= <TC>-LINES
LAST_PAGE_FULL
= 'X'
LOOPS
= <LINES>
OK_CODE
= P_OK
OVERLAPPING
= 'X'
IMPORTING
ENTRY_NEW
= L_TC_NEW_TOP_LINE
EXCEPTIONS
*
NO_ENTRY_OR_PAGE_ACT = 01
*
NO_ENTRY_TO
= 02
*
NO_OK_CODE_OR_PAGE_GO = 03
OTHERS
= 0.
ENDIF.

*&SPWIZARD: get actual tc and column


GET CURSOR FIELD L_TC_FIELD_NAME
AREA L_TC_NAME.

*
*

IF SYST-SUBRC = 0.
IF L_TC_NAME = P_TC_NAME.
*&SPWIZARD: et actual column
SET CURSOR FIELD L_TC_FIELD_NAME LINE 1.
ENDIF.
ENDIF.

*&SPWIZARD: set the new top line


<TC>-TOP_LINE = L_TC_NEW_TOP_LINE.

ENDFORM.

" COMPUTE_SCROLLING_IN_TC

*&---------------------------------------------------------------------*
*&
Form FCODE_TC_MARK_LINES
*&---------------------------------------------------------------------*
*
marks all TableControl lines
*----------------------------------------------------------------------*
*
-->P_TC_NAME name of tablecontrol
*----------------------------------------------------------------------*
FORM FCODE_TC_MARK_LINES USING P_TC_NAME
P_TABLE_NAME
P_MARK_NAME.
*&SPWIZARD: EGIN OF LOCAL DATA-----------------------------------------*

DATA L_TABLE_NAME
FIELD-SYMBOLS
FIELD-SYMBOLS
FIELD-SYMBOLS
FIELD-SYMBOLS
*&SPWIZARD: END

LIKE FELD-NAME.

<TC>
TYPE cxtab_control.
<TABLE>
TYPE STANDARD TABLE.
<WA>.
<MARK_FIELD>.
OF LOCAL DATA------------------------------------------*

ASSIGN (P_TC_NAME) TO <TC>.


*&SPWIZARD: get the table, which belongs to the tc
CONCATENATE P_TABLE_NAME '[]' INTO L_TABLE_NAME. "table body
ASSIGN (L_TABLE_NAME) TO <TABLE>.
"not headerline

*&SPWIZARD: mark all filled lines


LOOP AT <TABLE> ASSIGNING <WA>.

*&SPWIZARD: access to the component 'FLAG' of the table header


ASSIGN COMPONENT P_MARK_NAME OF STRUCTURE <WA> TO <MARK_FIELD>.

<MARK_FIELD> = 'X'.
ENDLOOP.
ENDFORM.

"fcode_tc_mark_lines

*&---------------------------------------------------------------------*
*&
Form FCODE_TC_DEMARK_LINES
*&---------------------------------------------------------------------*
*
demarks all TableControl lines
*----------------------------------------------------------------------*
*
-->P_TC_NAME name of tablecontrol
*----------------------------------------------------------------------*
FORM FCODE_TC_DEMARK_LINES USING P_TC_NAME
P_TABLE_NAME
P_MARK_NAME .
*&SPWIZARD: BEGIN OF LOCAL DATA----------------------------------------*
DATA L_TABLE_NAME
LIKE FELD-NAME.
FIELD-SYMBOLS
FIELD-SYMBOLS
FIELD-SYMBOLS
FIELD-SYMBOLS
*&SPWIZARD: END

<TC>
TYPE cxtab_control.
<TABLE>
TYPE STANDARD TABLE.
<WA>.
<MARK_FIELD>.
OF LOCAL DATA------------------------------------------*

ASSIGN (P_TC_NAME) TO <TC>.


*&SPWIZARD: get the table, which belongs to the tc
CONCATENATE P_TABLE_NAME '[]' INTO L_TABLE_NAME. "table body
ASSIGN (L_TABLE_NAME) TO <TABLE>.
"not headerline

*&SPWIZARD: demark all filled lines


LOOP AT <TABLE> ASSIGNING <WA>.

*&SPWIZARD: access to the component 'FLAG' of the table header


ASSIGN COMPONENT P_MARK_NAME OF STRUCTURE <WA> TO <MARK_FIELD>.

<MARK_FIELD> = SPACE.
ENDLOOP.
ENDFORM.
"fcode_tc_mark_lines
*&---------------------------------------------------------------------*
*&
Module validate INPUT

*&---------------------------------------------------------------------*
*
text
*----------------------------------------------------------------------*
MODULE validate INPUT.
ZGPAS-USERBY = sy-uname.
ENDMODULE.
" validate INPUT

You might also like