| SCAN | 
The SCAN command is used to search for a
                  		  string of characters within an object, with the option to replace the string
                  		  with another string.
               
You can scan single objects, all objects with a specific prefix, all objects within a library or all objects of a specific object type. If Predict is installed, you can also scan objects contained in a Predict set.
Important:
The source work area is used by the
                     		  SCAN command. Therefore, a SAVE or
                     		  STOW command
                     		  should be issued before using the SCAN command.
                     		  
                  
This document covers the following topics:
When you enter the SCAN command, the
                  			 SCAN menu will be displayed, providing the
                  			 following:
               
| Field | Input setting | |
|---|---|---|
| Code | T | Statistics Returns the following information: 
 | 
| L | List of Objects Containing Scan
                                 						  Value Displays a list of all objects in which the scan setting was found. From the list, you can select individual objects for further processing. If you wish, you can modify the lines directly in the
                              						  result screens or by using the appropriate  To modify the entire object, enter the
                              						   Once the object has been edited, the object should be saved and the editor terminated. Scan processing can then continue. | |
| S |  Object Lines
                                 						  with Scan Value Displays one after another each source-code line in which the scan value was found. If you wish, you can modify the lines directly in the
                              						  result screens or by using the appropriate  To modify the entire object, enter the
                              						   Once the object has been edited, the object should be saved and the editor terminated. Scan processing can then continue. | |
| Scan value | The string of characters to be scanned for. Note: | |
| Replace value | The value which is to replace the scan value. The Replace value option has no effect with maps, data areas, recordings, dialogs or locked objects (Locking of Source Objects). | |
| Library | The ID of the library to be scanned. Default is the current library. If the library specified is  | |
| Object name | The object(s) to be scanned: | |
| blank | all objects | |
| * | ||
| object-name> | all objects whose names are greater than or equal to name | |
| object-name< | all objects whose names are less than or equal to name | |
| If you wish to scan within
                           						a certain range of objects, you can use asterisk notation (*) and wildcard
                           						notation (?) for the object name, in the same manner as described for the
                           						system command LIST.See also Object Naming Conventions in the Using Natural documentation. | ||
| Selection list | Y | Display a list of objects as specified by
                           						Library, Name, Type(s) for Code TorS(see above).From this list, you can select individual objects (by marking them with any character) from scan processing. | 
| N | By default, no selection is displayed. | |
| Object type(s) | You can restrict the search
                           						to specific object types. One or several types may be specified. For a selection list of possible types, enter a question mark (?) in this field. If you leave this field blank or enter an asterisk (*), objects of any type will be scanned. | |
| Absolute scan | Y | The scan will be "absolute"; that is, the value to be scanned for will be found in any form, even as part of a longer character string. | 
| N | By default, the scan is not absolute. | |
| Trace | Y | Activates the trace facility. | 
| N | By default, the trace facility is deactivated. | |
| Predict set number | Predict set number to be
                           						scanned. Note: A one- or two-digit number that identifies the retained
                              						  set to be used for the names of the objects to be processed. A retained set is
                              						  created with the save set option of the  The value specified for Library is used as Predict set library. If the Predict set number is specified, the value specified for Object name must be an asterisk (*) instead. For detailed information on Predict sets, refer to the Predict documentation. | |
| Predict set user | The ID of the user who
                           						created the Predict set. Note: *USER(see also the System Variables documentation) is
                           						used. | |
| Ignore case | Y | Any combination of upper and lower-case letters will be found. | 
| N | By default, the exact scan value is searched. | |
| Ignore comments | Y | Values found within comments are not displayed or replaced. | 
| N | By default, all values found are displayed or replaced. | |
Note:
For possible restrictions, see
                     			 SCAN under Natural
                        			 Security.
                  
The following edit commands can be entered in the command line(s) of
                  			 the SCAN editor generated by the scan operation:
               
The line length of the source object in the result screen is
                        					 limited to 72 characters. Lines exceeding 72 characters are marked with an
                        					 L and cannot be modified.
                     
If the Replace value option is used
                        					 and/or an object is modified in the result screen, the object will always be
                        					 saved unless an I, Q or
                        					 dot (.) is specified before the next object is
                        					 scanned.
                     
Lines containing PASSW, PASSWORD=,
                        					 CIPHER=, or CIPH= will be ignored.
                     
The SCAN functions may also be invoked
                  			 via direct command, in either online mode or batch mode. The
                  			 SCAN direct command can be specified with
                  			 keywords or with
                  			 positional
                     			 parameters.
               
In batch mode, the SCAN command will
                  			 process only one function per invocation to minimize the repercussions of
                  			 invalid data being specified. 
               
|  | Warning: If you use scan/replace values that contain lowercase characters or embedded blanks, we strongly recommend that you follow the instructions below to avoid unexpected results. | 
 To use SCAN with lowercase characters or embedded blanks in
                     				online mode
To use SCAN with lowercase characters or embedded blanks in
                     				online mode
Enter the command SCAN to activate the
                        					 SCAN menu.
                     
In the input fields of the SCAN
                        					 menu, enter all required values.
                     
 To use SCAN with lowercase characters or embedded blanks in batch
                     				mode
To use SCAN with lowercase characters or embedded blanks in batch
                     				mode
Specify the command SCAN to call the
                        					 SCAN menu.
                     
Specify the values in a separate data line and exactly in the order of the map fields (see Menu Options), for example:
SCAN S,MOVE LEFT,MOVE RIGHT,SYSTEM,*,N,P,N,N,1,SAG
In the example of a batch job above, the value MOVE
                           					 LEFT is replaced by MOVE RIGHT for all programs of Predict
                        					 Set 1 for the user SAG in the library
                        					 SYSTEM.
                     
This section covers the following topics:
The SCAN direct command with keywords
                  				consists of the command SCAN itself which is
                  				followed by keywords. 
               
Keywords can be specified in any order or can be omitted. If a keyword is not used, the default value will be assumed for this keyword.
|  | Warning: Do not mix keywords and positional parameters within the SCANdirect command
                              				to avoid unexpected results. | 
| SCANkeyword=value,... | 
| Keyword | Value | Explanation | 
|---|---|---|
| FUNC | T, L or S | Function code. For details, see the description of the menu field Code. | 
| LIB | max. 8 characters | Name of library to be scanned. For
                           						  details, see the description of the menu field
                           						  Library. Default value is the current library. | 
| OBJ | max. 9 characters | Object name. The object sources to be scanned. For details, see the description of the menu field Object name. | 
| TYPE | max. 14 characters | Object type. The object type(s) to be used for the selection. For details, see the description of the menu field Object type(s). | 
| SVAL | max. 32 characters | Scan value. The character string (without embedded blanks) to be scanned for in each object source. For details, see the description of the menu field Scan value. | 
| RVAL | max. 32 characters | Replace value. The character string (without embedded blanks) to be replaced by the scan value. For details, see description of the menu field Replace value. | 
| ABSOL | Y or N | Absolute scan. For details, see the description of the menu field Absolute scan. | 
| SETNO | max. 2 digits | Predict set number to be scanned. For details, see the description of the menu field Predict set number. | 
| SETUSER | max. 8 characters | Predict set user ID. The ID of the user who created the Predict set. For details, see the description of the menu field Predict set user. | 
| IGNORE-CASE | Y or N | Search is not case sensitive. For details, see the description of the menu field Ignore case. | 
| IGNORE-COMMENTS | Y or N | Search exlcudes values found in commentary text. For details, see the description of the menu field Ignore comments. | 
SCAN FUNC=S,LIB=SYSTEM,OBJ=PGM0*,TYPE=S,SVAL=FETCH
SCAN FUNC=S,SVAL=WRITE,RVAL=PRINT,OBJ=PGM1
SCAN FUNC=S,SETNO=1,TYPE=P,SVAL=GLOBAL
The SCAN direct command with positional
                  				parameters consists of the command SCAN itself which
                  				is followed by parameters that reference each word on the command line by their
                  				position within the command. The order of the positional parameters must be
                  				strictly adhered to.
               
If a positional parameter is not specified, its default value will be assumed. If you want to indicate that a positional parameter is to be omitted, use a comma as shown in Examples of SCAN with Positional Parameters.
|  | Warning: Do not mix keywords and positional parameters within the SCANdirect command to avoid unexpected
                              				results. | 
| SCANfunc,scan-value,replace-value,library,object-name,object-type,absolute,set-number,set-user,ignore-case,ignore-comments | 
| Positional Parameter | Value | Explanation | 
|---|---|---|
| func | T, L or S | Function code. For details, see the description of the menu field Code. | 
| scan-value | max. 32 characters | Scan value. The character string (without embedded blanks) to be scanned for in each object source. For details, see the description of the menu field Scan value. | 
| replace-value | max. 32 characters | Replace value. The character string (without embedded blanks) to be replaced by the scan value. For details, see the description of the menu field Replace value. | 
| library | max. 8 characters | Name of library to be scanned. For
                           						  details, see the description of the menu field
                           						  Library. Default value is the current library. | 
| object-name | max. 9 characters | Object name. The object sources to be scanned. For details, see the description of the menu field Object name. | 
| object-type | max. 14 characters | Object type. The object type(s) to be used for the selection. For details, see the description of the menu field Object type(s). | 
| absolute | Y or N | Absolute scan. For details, see the description of the menu field Absolute scan. | 
| set-number | max. 2 digits | Predict set number to be scanned. For details, see the description of the menu field Predict set number. | 
| set-user | max. 8 characters | Predict set user ID. The ID of the user who created the Predict set. For details, see the description of the menu field Predict set user. | 
| ignore-case | Y or N | Search is not case sensitive. For details, see the description of the menu field Ignore case. | 
| ignore-comments | Y or N | Search exlcudes values found in commentary text. For details, see the description of the menu field Ignore comments. | 
SCAN S,ABC,,SYSTEM,PGM0*,P,N
SCAN S,ABC,DEF,SYSTEM,PGM1,*,Y
SCAN T,ABC,,SYSTEM,*,7,N,1,SAG
You can define an individual profile for the
                  			 SCAN command. For this purpose, the Natural
                  			 SCAN command provides the subcommand
                  			 SCANPROF or PF-Key PF10 ‘Prof’. 
               
This command invokes the profile maintenance tool that
creates a new SCAN profile with default values as
                        				  used internally, if the SCAN profile does not exist; 
                     
allows you to specify general values for single users for the
                        				  profile parameters in the SCAN profile (controlled by Natural
                        				  Security); 
                     
allows you to specify individual values for single users for the
                        				  profile parameters in the SCAN profile (controlled by Natural
                        				  Security); 
                     
provides a description of and help information on each profile parameter. The profile maintenance tool shows a map with the general profile parameters and their current values.
Using a PF-key or a command, you can switch to the settings of your own profile data.
Using line commands, parameters can be added to or removed from the user specific profile.
For further information, invoke the help screens of the single fields.
If new parameters are introduced, the profile maintenance tool
                  			 internal command UPDATE integrates the changes into the
                  			 SCAN profile. The SCAN profile itself is named
                  			 SCANPROF and located in library SYSLIB. The default
                  			 profile that is used for updates of the SCAN profile is named
                  			 SCANDEFP and is also located in library SYSLIB.
                  			 
               
The parameters contained in the SCAN profile
                  				correspond to the fields of the SCAN map, see
                  				Menu
                     				Options.
               
In a Natural Security environment, you can specify a library
                  			 security profile to disallow the use of the SCAN
                  			 system command for a particular library or restrict the use to avoid source
                  			 modifications. You have the following options:
               
Disallow the use of the SCAN system
                        				  command.
                     
Allow the use of the SCAN system
                        				  command, but disallow the system commands LIST and
                        				  EDIT.
                     
Disallow the replace function of the
                        				  SCAN system command. Additionally, disallow the use
                        				  of the SAVE system command to avoid source modifications through
                        				  the full-screen editor.
                     
For detailed information on restricting the use of the
                  			 SCAN system command, see
                  			 Command
                     			 Restrictions in the Library Maintenance
                  			 section of the Natural Security documentation.
               
If only structured mode is allowed for the library, objects in reporting mode can be scanned, but not modified.