REINPUT 
                                   
                         |  
                               
                         [FULL] 
                                   [(statement-parameters)]
                                   
                         |  
                               
                        
                                   
                            
  |  
                               
                        
                                    USING HELP
                                       
                         |  
                               
                        
                                   
                            
  |  
                              
                     
| WITH-TEXT-option | ||||
| [MARK-option] | ||||
| [ALARM-option] | 
This document covers the following topics:
For an explanation of the symbols used in the syntax diagram, see Syntax Symbols.
Related Statements: DEFINE
                            WINDOW | INPUT | SET WINDOW
Belongs to Function Group: Screen Generation for Interactive Processing
The REINPUT statement is used to return to and re-execute
                       an INPUT statement. It is
                       generally used to display a message indicating that the data input as a result
                       of the previous INPUT statement were invalid. See
                       Example
                          1.
               
No WRITE or
                       DISPLAY statements may be
                       executed between an INPUT statement and its corresponding
                       REINPUT statement. The REINPUT statement is not valid
                       in batch mode.
               
The REINPUT statement, when executed, repositions the
                       program status regarding subroutine, special condition and loop processing as
                       it existed when the INPUT statement was executed (as long as the
                       status of the INPUT statement is still active). If the loop was
                       initiated after the execution of the INPUT statement and the
                       REINPUT statement is within this loop, the loop will be
                       discontinued and then restarted after the INPUT statement has been
                       reprocessed as a result of REINPUT.
               
If a hierarchy of subroutines was invoked after the execution of the
                       INPUT statement, and the REINPUT is performed within
                       a subroutine, Natural will trace back all subroutines automatically and
                       reposition the program status to that of the INPUT statement.
               
It is not possible, however, to have an INPUT statement
                       positioned within a loop, a subroutine or a special condition block, and then
                       execute the REINPUT statement when the status under which the
                       INPUT statement was executed has already been terminated. An error
                       message will be produced and program execution terminated when this error
                       condition is detected.
               
Note:
The execution of a REINPUT statement (without
                           FULL option) does not reset the MODIFIED status of an
                           attribute control variable used in the corresponding INPUT
                           statement. To check if an attribute control variable has been assigned the
                           status MODIFIED, use the
                           MODIFIED
                           option.
                  
| Syntax Element | Description | |
|---|---|---|
                                    REINPUT FULL
                                    
                         |  
                                
                         
                                    
                            FULL Option:  
                                    
                           If you specify the  
 Note: Another characteristic of the   |  
                               
                     |
                                    statement-parameters |  
                                
                         
                                    
                            Parameters:  
                                    
                           Parameters specified in a  Any parameter specified at element (field) level (see MARK Option) will override any corresponding parameter at statement level.  |  
                               
                     |
Parameters that can be specified with the
                                    REINPUT statement:
                         |  
                                
                        Specification (S = at statement level, E = at element level) | |
AD - Attribute
                                    Definition * |  
                                
                        SE | |
CD - Color
                                    Definition
                         |  
                                
                        S | |
|  
                                    
                            * If  The individual session parameters are described in the Parameter Reference.  |  
                               
                     ||
 USING HELP 
                         |  
                                
                         
                                    
                            USING HELP Option:  
                                    
                           This option causes the helproutine defined for the
                                         
 Example: REINPUT USING HELP MARK 3 As a result, the helproutine defined for the third field in the
                                          |  
                               
                     |
 WITH-TEXT-option
                                    
                         |  
                                
                         
                                    
                            WITH TEXT Option:  
                                    
                           The  See WITH TEXT Option below.  |  
                               
                     |
 MARK-option
                                    
                         |  
                                
                         
                                    
                            MARK Option  
                                    
                           With the   |  
                               
                     |
 ALARM-option
                                    
                         |  
                                
                         
                                    
                            ALARM Option:  
                                    
                           This option causes the sound alarm feature of the terminal to be
                                        activated when the  See ALARM Option below.  |  
                               
                     |
WITH TEXT is used to provide text which is to be displayed
                        in the message line. This is usually a message indicating what action should be
                        taken to process the screen or to correct an error.
               
 [WITH] [TEXT] 
                         |  
                                 
                        
                                     
                            
  |  
                                 
                        
                                     
                            
  |  
                                 
                         [(attributes)]
                                     [,operand3] |  
                                
                     
Operand Definition Table:
| Operand | Possible Structure | Possible Formats | Referencing Permitted | Dynamic Definition | ||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
 operand1 
                         |  
                                 
                        C | S | N | P | I | B * | yes | no | ||||||||||||
 operand2 
                         |  
                                 
                        C | S | A | U | yes | no | ||||||||||||||
 operand3 
                         |  
                                 
                        C | S | A | U | N | P | I | F | B | D | T | L | yes | no | ||||||
* Format B of
                        operand1 may be used only with a length
                        of less than or equal to 4.
               
Syntax Element Description:
| Syntax Element | Description | 
|---|---|
 
                                     operand1  
                         |  
                                 
                         
                                     
                             Message Text from Natural Message File:
                                              
                                     
                             You can retrieve either user-defined messages or Natural system messages: 
 See also Example 4 - WITH TEXT Options. Natural message files are created and maintained with theSYSERR utility as described in the
                                     relevant documentation.
                         |  
                                
                     
 
                                     operand2 
                         |  
                                 
                         
                                     
                             Message Text:   
                                     
                             See also Example 4 - WITH TEXT Options.  |  
                                
                     
                                     attributes
                                     
                         |  
                                 
                         
                                     
                            Output Attributes:  
                                     
                           It is possible to assign various output attributes for
                                           |  
                                
                     
 
                                     operand3 
                         |  
                                 
                         
                                     
                             Dynamic Replacement of Message Text:
                                              
                                     
                             The values provided are used to replace parts of a message text
                                         that are either specified with  The notation  See also Example 4 - WITH TEXT Options. Note: Leading zeros or trailing blanks will be removed from the field value before it is displayed in a message.  |  
                                
                     
attributes indicates the output attributes to be used for text display. Attributes may be:
| 
                                      
                            
  |  
                                  
                         
                                      
                             
                                            |  
                                  
                        
                                      
                            
  |  
                                  
                        |
| 
                            
  |  
                                 
                     
For the possible session parameter values, refer to the corresponding sections in the Parameter Reference documentation:
Note:
 The compiler actually accepts more than one attribute value for an
                            output field. For example, you may specify: AD=BDI. In such a
                            case, however, only the last value applies. In the given example, only the
                            value I will become effective and the output field will be
                            displayed intensified.
                  
With the MARK option, you can mark a specific field, that
                        is, specify a field in which the cursor is to be placed when the
                        REINPUT statement is executed. You can also mark a specific
                        position within a field. Moreover, you can make fields input-protected, and
                        change their display and color attributes.
               
                                      MARK [POSITION 
                                     
                                        operand4  [IN]] [FIELD] 
                         |  
                                 
                        
                                     
                            
  |  
                                 
                        
                                     
                            
  |  
                                 
                        
                                     
                            
  |  
                                 
                        [(attributes)] | 
                                     
                            
  |  
                                 
                        ||
| 
                            
  |  
                                
                     
Operand Definition Table:
| Operand | Possible Structure | Possible Formats | Referencing Permitted | Dynamic Definition | ||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
 operand4 
                         |  
                                 
                        C | S | N | P | I | yes | no | |||||||||||||
 operand5 
                         |  
                                 
                        C | S | A | N | P | I | yes | no | ||||||||||||
Syntax Element Description:
| Syntax Element | Description | 
|---|---|
|  
                                     
                             Field to be Marked:   
                                     
                           All  The  If the corresponding  INPUT #ARRAY (A1/1:5) ... REINPUT (AD=P) 'TEXT' MARK *#ARRAY (2:3) If  RESET #X(N2/1:2) INPUT #ARRAY ... ... REINPUT (AD=P) 'TEXT' MARK #X (1:2)  |  
                                
                     |
                                     MARK
                                        POSITION 
                         |  
                                 
                         
                                     
                            MARK POSITION Option:  
                                     
                           With this option, you can have the cursor placed at a specific
                                         position - as specified with   |  
                                
                     
                                     operand4
                                     
                         |  
                                 
                         
                                     
                            Cursor Position:  
                                     
                           
 
  |  
                                
                     
                                     
                                     attributes 
                         |  
                                 
                         
                                     
                            Attribute Assignments:  
                                     
                           See Attribute Assignments below.  |  
                                
                     
With explicit attributes, you can define the display presentation and
                        color of the WITH TEXT message and also the layout of the
                        MARK field (which is positioned by the REINPUT
                        statement).
               
| 
                                     
                            
  |  
                                 
                        
                                     
                            
  |  
                                 
                         B
                                     
                         |  
                                 
                        
                                     
                            
  |  
                                 
                        
                                     
                            
  |  
                                 
                        
                                     
                            
  |  
                                 
                        
                                     
                            
  |  
                                 
                         BL
                                     
                         |  
                                 
                        
                                     
                            
  |  
                                 
                        
                                     
                            
  |  
                                 
                        ||||
 C
                                     
                         |  
                                 
                         GR
                                     
                         |  
                                 
                        ||||||||||||
 D
                                     
                         |  
                                 
                         NE
                                     
                         |  
                                 
                        ||||||||||||
 AD=[P] 
                         |  
                                 
                         
                                        I |  
                                 
                         CD= 
                         |  
                                 
                         PI
                                     
                         |  
                                 
                        [CV=operand6]
                         | 
                                 
                                
                     |||||||||
 N
                                     
                         |  
                                 
                         RE
                                     
                         |  
                                 
                        ||||||||||||
 U
                                     
                         |  
                                 
                         TU
                                     
                         |  
                                 
                        ||||||||||||
 V
                                     
                         |  
                                 
                         YE
                                     
                         |  
                                 
                        
Operand Definition Table:
| Operand | Possible Structure | Possible Formats | Referencing Permitted | Dynamic Definition | ||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
 operand6 
                         |  
                                 
                        S | C | no | no | ||||||||||||||||
With the attribute AD=P, you can make an input
                        field (AD=A or AD=M) input-protected. 
               
Note:
You cannot use an attribute to make output-only fields
                           (AD=O) available for input.
                  
For information on the attributes AD,
                        CD and
                        CV, refer
                        to the Parameter Reference.
               
The attributes for
                        the WITH TEXT and MARK fields need not be specified
                        in a fixed manner, but can also be assigned dynamically by means of a control
                        variable, which is referenced in a
                        (CV=operand6) clause.
                        See Example 5 - REINPUT
                           with Attribute Assignment Using a Control Variable.
               
If both an AD and a CV
                        option are specified for the same field, the attributes from the
                        AD option are completely ignored, except
                        (AD=P) which remains in effect.
               
If a CD and a CV option
                        are specified for the same field, the color from the CV
                        option is used. If the CV variable contains no color
                        specification, the color from the CD option is applied
                        to that field.
               
If AD=P is specified at statement level, all fields except
                        those specified in the MARK option are
                        input-protected. See also Example 2 - REINPUT with Attribute
                           Assignment.
               
[AND] [SOUND] ALARM 
                         |  
                                
                     
This option causes the sound alarm feature of the terminal to be
                        activated when the REINPUT statement is executed. The appropriate
                        hardware must be available to be able to use this feature.
               
** Example 'REIEX1': REINPUT                                            
************************************************************************
DEFINE DATA LOCAL                                                       
1 #FUNCTION (A1)                                                        
1 #PARM     (A1)                                                        
END-DEFINE                                                              
*                                                                       
INPUT #FUNCTION #PARM                                                   
*                                                                       
DECIDE FOR FIRST CONDITION                                              
  WHEN #FUNCTION = 'A' AND #PARM = 'X'                                  
    REINPUT 'Function A with parameter X selected.'                     
            MARK *#PARM                                                 
  WHEN #FUNCTION = 'C' THRU 'D'                                         
    REINPUT 'Function C or D selected.'                                 
  WHEN #FUNCTION = 'X'                                                  
    STOP                                                                
  WHEN NONE                                                                 
    REINPUT 'Please enter a valid function.'                            
            MARK *#FUNCTION
END-DECIDE                 
*                          
END 
                    #FUNCTION A #PARM Y
PLEASE ENTER A VALID FUNCTION #FUNCTION A #PARM Y
** Example 'REIEX2': REINPUT  (with attributes)                         
************************************************************************
DEFINE DATA LOCAL                                                       
1 #A (A20)                                                              
1 #B (N7.2)                                                             
1 #C (A5)                                                               
1 #D (N3)                                                               
END-DEFINE                                                              
*                                                                       
INPUT (AD=A) #A  #B  #C  #D                                             
*                                                                       
IF #A = ' ' OR #B = 0                                                   
  REINPUT (AD=P) 'RETYPE VALUES'                                        
                 MARK *#A (AD=I CD=RE)    /* put cursor on first field  
                      *#B (AD=U CD=PI)    /* and change colors    
END-IF                                                                  
*                                                                       
END 
                    
                   
               ** Example 'REIEX3': REINPUT (with FULL and POSITION option) ************************************************************************ DEFINE DATA LOCAL 1 #A (A20) 1 #B (N7.2) 1 #C (A5) 1 #D (N3) END-DEFINE * INPUT (AD=M) #A #B #C #D * IF #A = ' ' COMPUTE #B = #B + #D RESET #D END-IF * IF #A = SCAN 'TEST' OR = ' ' REINPUT FULL 'RETYPE VALUES' MARK POSITION 5 IN *#A END-IF * END
RETYPE VALUES #A #B 0.00 #C #D 0
** Example 'REIEX4': REINPUT (with TEXT option) ************************************************************************ DEFINE DATA LOCAL 01 #NAME (A8) 01 #TEXT (A20) END-DEFINE * * INPUT WITH TEXT 'Enter a program name.' 'Program name:' #NAME * IF #NAME = ' ' REINPUT WITH TEXT 'Input missing. Enter a name.' END-IF * IF #NAME NE MASK (A) MOVE 'Invalid input.' TO #TEXT REINPUT WITH TEXT ':1: Name must start with a letter.',#TEXT ELSE /* Using Natural error message 7600 for demonstration COMPRESS *INIT-USER 'on' *DAT4I INTO #TEXT INPUT WITH TEXT *-7600,#NAME,#TEXT 'Input accepted.' END-IF END
DEFINE DATA LOCAL
1 #HELLO (A5)  INIT <'HELO'>
1 #VAR   (A20) INIT <'Enter "HELLO"'>
1 #CV (C)
END-DEFINE
*
INPUT (IP=OFF) #HELLO (AD=M)
*
IF #HELLO NE 'HELLO' THEN
  MOVE (AD=U CD=RE) TO #CV
  REINPUT FULL WITH TEXT #VAR (CD=YE)
               MARK *#HELLO   (CV=#CV)
END-IF
END