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 T or S (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
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
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 SCAN direct command
to avoid unexpected results. |
SCAN
keyword=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 SCAN direct command to avoid unexpected
results. |
SCAN
func,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.