Running | Descriptions of Run-time Switches |
You can configure certain run-time behavior through the run-time configurables. There are three types of run-time configurable: environment variables, run-time tunables, and run-time switches.
This chapter lists and describes the run-time tunables you can use. See the appendix Micro Focus Environment Variables for a list of environment variables used by Server Express. See the chapter Descriptions of Run-time Switches for a list of run-time switches.
When your run-time system or linked executable starts up, it attempts to read the run-time configuration file. The run-time configuration file specifies values for the run-time configurables. It is shared by all users of Server Express.
The run-time configuration file is a text file, which you can edit with your standard text editor. It is an optional file (no error will be issued if it does not exist) with the default name $COBDIR/etc/cobconfig. You can specify a filename for the configuration file by setting the environment variable COBCONFIG; for example:
COBCONFIG=$HOME/myconfig export COBCONFIG
Each run-time configurable appears on a new line. Blank lines are ignored. A comment line starts with a #; however, as the configuration file is processed at run-time, we advise that you limit your comments, in order to keep to a minimum the time it takes to process it. The maximum number of characters permitted in a comment line is 80, including any new-line or carriage return characters that may be placed at the end of the line by some editors.
You can use the configuration file to:
Each run-time configurable is specified on one line in the run-time configuration file. The format for run-time tunables is:
set configurable_name=value
while for environment variables, the format is:
setenv configurable_name value
The parameters are:
configurable_name
|
The name of the run-time configurable. This will be the name of a run-time tunable described in this chapter, or an environment variable described in the appendix Micro Focus Environment Variables. For details on dd_ filename mappings see your File Handling. |
value |
The value to be assigned to the run-time configurable.
The values that can be assigned to a run-time tunable are described in
this chapter. For a run-time tunable, value is validated
according to the type and values allowed for that tunable, and the value
of cobconfig_error_report .
Where value is numeric, a leading zero indicates that the value should be treated as octal (that is, base 8). For example, 07 (octal) is 7 (decimal), while 010 (octal) is 8 (decimal); however, 08 (octal) and 09 (octal) are invalid octal values. Hexadecimal values can also be set by using numeric values that begin with with 0x. |
Note that each space in the definition can be replaced with tabs or more than one space.
setenv dd_MYFILE /usr/mydir/myfile set cobconfig_error_report=TRUE
The following sections describe the run-time tunables available.
set arguments_are_initial={TRUE|FALSE}
TRUE or FALSE
This tunable affects the COBOL command line arguments returned from the syntax ACCEPT ... FROM ARGUMENT-NUMBER and ACCEPT ... FROM ARGUMENT-VALUE. See the Language Reference for more details of this syntax.
If TRUE, the COBOL command line arguments are the same as the initial ones passed to the run-unit by the operating system. When using a trigger, such as cobrun, argument 0 is the trigger name and argument 1 is the name of the main COBOL program.
If FALSE, the COBOL command line arguments do not contain any trigger name. Instead, argument 0 is always the name of the main COBOL program.
If you are using a system executable to start your application, argument 0 is always the name of the executable (which, by default, is also the name of the main COBOL program), irrespective of the setting of this tunable.
When set to FALSE this tunable gives consistent results no matter how your application is packaged. For details on packaging applications, see the chapter Packaging Applications .
Set this tunable to TRUE for compatibility with Micro Focus Object COBOL Developer Suite V4.1 for UNIX and earlier.
FALSE
The command line:
myapp arg1 arg2
always returns myapp
as argument 0.
The command line:
cobrun myapp arg1 arg2
returns myapp
as argument 0 when this tunable is set to
FALSE; when the tunable is set to TRUE the trigger name (cobrun)
is returned as argument 0 and myapp
as argument 1.
set bll_cell_address_check={TRUE|FALSE}
TRUE or FALSE
If TRUE, a test is run to determine if the top bit of the address of any BLL cell is set. If this bit is set, run-time system error 181 "Invalid parameter error" might be returned when testing the address of shared memory.
If FALSE, the test is suppressed. This is the recommended setting if BLL cells are being allocated in shared memory.
TRUE
set cobconfig_error_report={TRUE|FALSE}
TRUE or FALSE
If FALSE, do not report any errors during processing of the configuration file.
TRUE. Any errors detected are reported and the run-time system terminates. Unknown or misspelled run-time tunables names are not reported.
set command_line_accept={TRUE|FALSE}
TRUE or FALSE
If TRUE, the first ACCEPT or READ from STDIN takes the input from the command line.
FALSE. The first ACCEPT or READ from STDIN takes the input from the user. This provides direct ANSI conformance. You should set this if you want to execute a program that has been generated from convert3 or convert5.
set command_line_linkage={TRUE|FALSE}
TRUE or FALSE.
If TRUE, enables you to call a program and pass the command line to the main program as a parameter to be accessed via the Linkage Section. See the chapter Writing Programs in your Programmer's Guide to Writing Programs for information on passing the command line to a main program.
TRUE
set core_on_error=integer
integer
where integer specifies in what circumstances a core file is produced. You can look at core files with Animator. See your Debugging Handbook for details.
integer can be:
0 | The run-time system never produces a core file on any signal or run-time system error. This is the default behavior of the run-time system. |
1 | The run-time system produces a core file when any system signal is received that would normally produce a core file on the host system; for example, SIGILL, SIGSEGV (which would usually produce a run-time system error 114), and so on. |
You can animate core files to determine the cause of the problem if you have the appropriate Animator information files.
Note: When a core file is produced, the run-time system itself cannot clean up COBOL file buffers or free system resources. This could lead to data file corruption that might not have occurred if no core file was produced.
0
set current_day=integer
integer |
A value in the range 1 through 31, representing the required day of the month. The value you specify is returned when you use the ACCEPT identifier FROM DATE syntax or the CURRENT-DATE intrinsic function. |
The current day specified by the system clock.
set current_month=integer
integer |
A value in the range 1 through 12, representing the required month of the year. The value you specify is returned when you use the ACCEPT identifier FROM DATE syntax or the CURRENT-DATE intrinsic function. |
The current month specified by the system clock.
set current_year=integer
integer |
A value representing the required year. The value you specify is returned when you use the ACCEPT identifier FROM DATE or ACCEPT identifier FROM DAY syntax or the CURRENT-DATE intrinsic function. |
The current year specified by the system clock.
set debug_on_error={0|1}
0 or 1.
If you want to use just-in-time debugging, set this tunable to 1; this enables the Animator to start if a running program terminates with a run-time error.
0
For more details of just-in-time debugging, see your Debugging Handbook.
set debugger_command="debugger"
debugger specifies the command to start the debugger. This can be one of the commands listed in the chapter Starting Animator in your Debugging Handbook.
You use this tunable in combination with the debug_on_error
tunable.
cobanim
For more details of just-in-time debugging, see your Debugging Handbook.
set detect_alt_ctrl={TRUE|FALSE}
TRUE or FALSE.
Most UNIX environments do not detect input when the Ctrl, Alt,
or Shift keys are available on a keyboard and are pressed by
themselves. In these cases, detect_alt_ctr
l must be set to
FALSE. The operating system SCO Open Desktop from version 2 onwards does
detect these keys individually and detect_alt_ctrl can be set to TRUE.
If detect_alt_ctrl
is set to TRUE, then the run-time
system detects the Ctrl, Alt, and Shift keys.
These keys can then be used for COBOL utilities that would otherwise use
the alternate key sequences of /c for Ctrl or /a for Alt.
For example, the Development Environment is easier to use if detect_alt_ctrl
can be set to TRUE.
FALSE
set dynamic_dictionary_limit=integer
integer
where integer
is the maximum size of memory to be
allocated dynamically at run time for use by virtual heaps.
The Compiler uses virtual heaps when processing your programs, and this size is operating system dependent. If the memory limit is exceeded, the memory allocated to virtual heaps is paged by the Micro Focus COBOL system onto disk. If the amount of memory allocated to virtual heaps is not large enough to process your programs, then the compilation and generation times can be increased due to the overheads of paging the virtual heap accesses to disk.
This run-time tunable is equivalent to the -d run-time switch. The value of -d is used if the values are different.
30 buffers of 8K.
set dynamic_memory_limit=integer
integer
where integer
is the maximum size of memory to be
allocated dynamically at run time, and is operating system dependent. For
any programs canceled before this memory limit is reached, the memory
occupied by them is not released. The program is available to be reused
and hence the performance of CALL/CANCEL statements performance is greatly
increased. This mode of working is called "logical cancelling".
As far as your program is concerned, the behavior of logical and real cancels is identical. If the dynamically allocated memory requirements exceed the size you set for dynamic_memory_limit, then all the memory that should have been freed by any CANCEL statements is freed. If you set this limit to zero, logical cancels are disabled.
This run-time tunable is equivalent to the -l run-time switch. The value of -l is used if the values are different.
Logical cancels are used.
set faultfind_level=n
n can be any positive value. Specifying this tunable turns on FaultFinder; the last n events are dumped to a FaultFinder report if abnormal application termination occurs. The greater the value of n, the more memory is used.
See the chapter FaultFinder in your Debugging Handbook for information on FaultFinder.
0 (off)
faultfind_outfile
faultfind_recsize
set faultfind_outfile="[>>]filename"
filename is the file to which a FaultFinder report is written.
If you specify >>
, the output is appended to filename,
if it already exists, otherwise a new file named filename is
created.
If filename contains the string %p, this string is replaced by the process ID of the program that started FaultFinder.
See the chapter FaultFinder in your Debugging Handbook for information on FaultFinder.
fltfnd_out.pid, in the current working directory, where pid is the process ID of the the process that triggered the FaultFinder output.
faultfind_level
faultfind_recsize
set faultfind_recsize=record_size
record_size is a numeric value, in bytes, that specifies the internal cache size used to store read/write data for the operation traceback log. All read/write data is stored and reported. By using this configurable you might improve performance. The default value is 64 and the maximum is 1024.
The maximum value of record_size can be 1024 bytes.
See the chapter FaultFinder in your Debugging Handbook for information on FaultFinder.
64 bytes
faultfind_level
faultfind_outfile
set filename_quote_char="character"
or:
set filename_quote_char='character'
character specifies the quotation character used when interpreting filenames provided to the run-time system in calls such as CBL_OPEN_FILE. Within a quoted filename, two adjacent quote characters are interpreted as a single quote when deriving the filename. It is necessary to quote filenames that have embedded spaces within them.
" (the double quote character)
set filename_escape_char="character"
or:
set filename_escape_char='character'
character specifies the escape character used when interpreting filenames provided to the run-time system in calls such as CBL_OPEN_FILE. The escape character is not treated as part of the filename but instead quotes the character immediately following the escape character (such as a space). It is necessary to quote filenames that have embedded spaces within them.
\0 (no character is used as an escape character)
set intra_process_record_locking={TRUE|FALSE}
TRUE or FALSE
TRUE enables the run-time system to share a file and to set record locks against a file within a process; this occurs if a file is opened more than once in different programs, or if a file is opened in different threads. Closing a shared file only releases the record locks obtained by opening the file.
If this tunable is set to FALSE, the ability to share a file and to set record locks against a file within a process is not defined by this system but by the operating system itself.
Note: The same_proc_excl_detection
tunable, which provides file locking within a process, overrides the
intra_process_record_locking
tunable.
TRUE
set lock_mode={0|1|2|3}
0, 1, 2, or 3
Selects the locking implementation to be used, as follows:
Lock Mode |
Description |
---|---|
0 | Uses the locking mechanism provided by Micro Focus COBOL V3.1 and earlier versions. |
1 | Provides compatibility with DOS and OS/2 locking mechanisms. |
2 | Provides interlanguage locking. This method causes record locks to lock the physical record. |
3 | Provides compatibility with C-ISAM version 5 and above. |
2
Note: This tunable is only applicable if the file handler configuration option FILEMAXSIZE is set to 4. See the chapter File Handler Configuration in your File Handling book for information on the FILEMAXSIZE option.
set long_filenames={TRUE|FALSE}
TRUE or FALSE
Specifies whether file-names longer than 14 characters are to be
allowed. If you create a file on a device that does not support long
file-names you must set long_filenames
to FALSE when
accessing that file on a device that does support long file-names.
TRUE
set pc_mono_palette=integer
integer selects the style of monochrome attribute palette that will be used by the run-time system when a call to the call-by-name routine CBL_SCR_SET_PC_ATTRIBUTES is made and a terminfo for which there is no color information is being used.
integer can be:
0 | Selects a CGA-emulation palette. This is the default, and is the recommended setting. |
1 | Selects a backwards-compatible palette that works in the same manner as COBOL for UNIX products prior to and including V4.0. This palette should not be used as it is incorrect (it does not conform to any actual PC monochrome palette), but is provided in case certain programs or files rely upon it (for instance, character screen sets saved using Dialog System when running under this incorrect palette). Wherever possible, you should attempt to convert such programs or files to use the correct palette. |
0
set multi_close_limit=integer
integer is a value in the range 0 - 1500, representing the number of logical closes after which a file is physically closed.
Every time a file is opened, the run-time system calls the operating system to open it - a physical open. When a file that has been opened more than once in the same process (without corresponding closes) is closed, in order that all locks are preserved, the run-time system closes the file (logical close) but does not call the operating system to close it. The run-time system only calls the operating system to physically close the file when a corresponding close has been done for each of the opens. This is the default behavior.
When set to a non-zero value, the run-time system forces a physical operating system close on a file which has been opened more than once within the same process if more than integer closes have occurred. The run-time system does a physical close for each of the integer logical closes, and then re-applies all outstanding locks on that file.
You should use this tunable with care as, due to the way in which the operating system does a physical close, all locks against all opens on a file are lost until the run-time system has time to reinstate them. We recommend that where possible, any multiple opens are nested so that all are closed prior to multiple re-opens. If you do need to keep a file open for a significant amount of time while other programs and/or threads open and close that file you need to use this tunable.
set program_search_order=integer
integer selects the program search order to be used, and can be a value from 1 to 4 as shown as shown in the following table:
Search Order |
Description |
---|---|
1 | Uses the following search sequence:
|
2 | Uses the following search sequence:
|
3 | Uses the following search sequence:
|
4 | Uses the following search sequence:
|
Set program_search_order
to 2 for compatibility with
previous UNIX versions of Micro Focus COBOL, or to 3 for compatibility
with previous DOS versions.
Note: If a program is called with a specific path the search
sequence is not affected by the value of program_search_order and instead:
1
set same_proc_excl_detection={TRUE|FALSE}
TRUE or FALSE
Detects if you have tried to open a file multiple times in one run unit. If TRUE, any OPEN request has conditions applied to determine whether or not it is already open, and if so, if it was opened exclusively, in which case a file error is generated. Currently, if the same file is opened twice by the same run unit, no file error is generated. This flag should be set to TRUE for RM COBOL compatibility.
Note: This tunable has been superseded by the intra_process_record_locking
tunable
which provides both file and record locking within a
process. If you want to use same_proc_excl_detection
,
whether set to TRUE or FALSE, you must always set intra_process_record_locking=FALSE
.
FALSE.
set shared_memory_segment_size=integer
integer
where integer
specifies, in bytes, the initial
size of the shared memory block allocated by the run-time system. The
minimum value you can specify for integer
is 8192
(8K).
65536 (64 K)
set signal_interface={TRUE|FALSE}
TRUE or FALSE
TRUE causes the run-time system to use the signal()
signal
handling interface as used in Micro Focus COBOL version 3.1 and before.
FALSE causes the run-time system to use the more robust sigaction()
signal handling interface.
The default value should not need to be changed unless you are using
signal handlers in non-COBOL programs. See the chapter
Mixed-language
Programming in your Programmer's Guide to Writing
Programs for more information on using signal handling in the
COBOL environment. See your operating system documentation for more
information on signal()
and sigaction().
FALSE
set signal_regime(sig)=integer
or:
set signal_regime=1
integer
Selects the action the run-time system takes for the signal sig. The value of sig must be between 1 and the maximum signal number on your operating system. See your operating system documentation for details on signal values.
You should only use this tunable when Server Express is being used with third party software that uses signals.
If you are using signal handling in you own applications, you should use
the cobpostsighandler()
interface, and not the operating
system signal handling interfaces, with this tunable. Also see the chapter
Mixed-language
Programming in your Programmer's Guide to Writing
Programs.
integer can have the following values:
Value |
Action |
---|---|
0 | The run-time system uses the signal sig if it
needs to.
By default, the run-time system sets up signal handlers for all signals whose operating system default action would cause termination. The run-time system can thus catch these signals and tidy up (for example, close any open files to prevent file corruption) before exiting. |
1 | The run-time system uses the signal sig if,
and only if, a handler was not already posted for this signal.
This is useful if the third-party software is invoked before Server Express and sets up a handler for signal sig. If this tunable is not set for this signal, the run-time system overwrites the third-party software's handler with its own; this leads to unpredictable behavior, such as run-time system error 115 ("Unexpected signal") being produced. If a handler was posted, the run-time system will not post any handlers for this signal and so any run-time system functionality which relies on this signal will not work. |
2 | The run-time system never uses the signal sig.
This is only of use if the third-party software is invoked after Server Express and sets up a handler for signal sig. Use of this setting is strongly discouraged for any signal whose operating system default action is to cause termination; if this signal is received between the run-time system being invoked and the third-party software setting up its handler, the default action of the operating system occurs, and the process exits without the run-time system being able to tidy up. This could lead to problems such as file corruption. Any run-time system functionality which relies on this signal will not work. |
0 for all signals
If you use the alternative syntax (set signal_regime=1), then the signal regime for all signals is set to 1. Note that, for this syntax, the only value you can set is 1.
Running | Descriptions of Run-time Switches |