Convert a Data File Format, Record Content & Field Expansion |
The SimoTime Home Page |
This suite of sample programs will show an approach to the task of File format conversion between Line Sequential and Record Sequential files. Also, record content conversion between ASCII and EBCDIC will be discussed. This example uses sequential files with 80-byte records.
The final step will describe how to read a sequential file with 80 byte records. The input record will be reformatted into a 512 byte, fixed length record with expanded field sizes. The new record will be written to an Indexed file.
The following terms and abbreviations will be used in this document.
| ||||||||||||||||
Terms or Abbreviations used in this Document |
Applications running on a mainframe system typically create, read and update sequential files. These files are EBCDIC encoded and typically contain records of fixed length with fields of fixed length. When transferring or sharing data between a Mainframe System and a Windows System running a Micro Focus sub-system it usually requires a file format and/or a record content conversion.
Explore the File Formats and various Numeric Formats being used in a multi-system complex consisting of Mainframe (z/OS), Linux, UNIX or Windows systems.
This suite of sample programs will describe possible approaches for the data file conversion process. However, in order to convert a file we need to have a file that has been populated with data. There are two choices, use an existing data file or create a new data file. This example contains a Windows command file that will create a number of sequential files starting with the creation of an ASCII/Text file that is populated with data. This file is then converted to other file formats with ASCII or EBCDIC encoded content. The following section will describe this process.
We have made a significant effort to ensure the documents and software technologies are correct and accurate. We reserve the right to make changes without notice at any time. The function delivered in this version is based upon the enhancement requests from a specific group of users. The intent is to provide changes as the need arises and in a timeframe that is dependent upon the availability of resources.
Copyright © 1987-2025
SimoTime Technologies and Services
All Rights Reserved
The following Microsoft Windows Command Files (referred to as scripts) will describe how to create an initial file with data and then convert this file to many other formats. Some of the scripts will run COBOL programs that have been compiled with Micro Focus Net Express. The COBOL programs were generated by the SimoTime Conversion technologies.
The following (D80CRTW1.cmd) is the Windows Command file that uses the Microsoft "ECHO" command to pipe instream data to an ASCII/Text file. Once the LSEQ file (or ASCII/Text file) is created it is used as input to create a Record Sequential (RSEQ) file of 80-byte, ASCII-encoded records. Next, the Line Sequential (LSEQ or ASCII/Text) file is read a second time. The record content is converted from ASCII to EBCDIC. A new Record Sequential (RSEQ) file is created with the EBCDIC-encoded records.
@echo OFF rem * ************************************************************************ rem * D80CRTW1.CMD - a Windows Command File * rem * This Job Script is provided by SimoTime Technologies * rem * (C) Copyright 1987-2019 All Rights Reserved * rem * Web Site URL: http://www.simotime.com * rem * e-mail: helpdesk@simotime.com * rem * ************************************************************************ rem * rem * Text - Create various sequential files with 80-byte records. rem * Author - SimoTime Technologies rem * Date - January 24, 1996 rem * rem * This procedure uses the Microsoft "ECHO" command to pipe instream rem * data to an ASCII/Text file. The following terms are used. rem * rem * LSEQ - a Line Sequential File or ASCII/Text File rem * RSEQ - a Record Sequential File. This example uses a file of rem * 80-byte records that may be ASCII or EBCDIC encoded. rem * rem * Once the LSEQ file is created it is used as input to create an rem * RSEQ file of 80-byte, ASCII-encoded records. rem * rem * Next, the LSEQ file is read a second time. The record content is rem * converted from ASCII to EBCDIC. A new RSEQ file is created with rem * the EBCDIC-encodd records. rem * rem * ******************************************************************* rem * Step 1, Delete any previously created file... rem * set CmdName=D80CRTW1 call ..\Env1BASE rem * call SimoNOTE "*******************************************************%CmdName%" call SimoNOTE "Starting JobName %CmdName%" :DeleteLSEQ call SimoNOTE "Identify JobStep DeleteLSEQ" set LSEQ0080=%BaseLib1%\DATA\Txt1\LSEQ0080.TXT if exist %LSEQ0080% del %LSEQ0080% rem * rem * ******************************************************************* rem * Step 2, Create a new output file. Use the "echo" command provided rem * with Microsoft Windows to pipe instream data to a new rem * ASCII/Text file. rem * :ExecuteCreateLSEQ call SimoNOTE "Identify JobStep ExecuteCreateLSEQ" rem ....:....1....:....2....:....3....:....4....:....5....:....6....:....7....:....8 echo 000100 Anderson Adrian 111 Peachtree Plaza Atlanta GA 26101 >%LSEQ0080% echo 000200 Brown Billie 222 Baker Boulevard Baltimore MD 35702 >>%LSEQ0080% echo 000300 Carson Cameron 333 Crenshaw Blvd. Cupertino CA 96154 >>%LSEQ0080% echo 000400 Davidson Dion 444 Main Street Wilmington DE 27323 >>%LSEQ0080% echo 000500 Everest Evan 555 5TH Avenue New York NY 10341 >>%LSEQ0080% echo 000600 Franklin Francis 666 66TH Avenue Bedrock NY 11903 >>%LSEQ0080% echo 000700 Garfunkel Gwen 777 77TH Street New York NY 16539 >>%LSEQ0080% echo 000800 Harrison Hilary 888 88TH Street Pocatello ID 79684 >>%LSEQ0080% echo 000900 Isley Isabel 999 99TH Avenue Indianapolis IN 38762 >>%LSEQ0080% echo 001000 Johnson Jamie 1010 Paradise Drive Larkspur CA 90504 >>%LSEQ0080% echo 001100 Kemper Kelly 1111 Oak Circle Kansas City KS 55651 >>%LSEQ0080% echo 001200 Lemond Lesley 1212 Lockwood Road Mohave Desert AZ 80303 >>%LSEQ0080% echo 001300 Mitchell Marlow 1313 Miller Creek Road Anywhere TX 77123 >>%LSEQ0080% echo 001400 Newman Noel 1414 Park Avenue Santa Monica CA 90210 >>%LSEQ0080% echo 001500 Osborn Owen 1515 Center Stage Rolling Rock PA 36613 >>%LSEQ0080% echo 001600 Powell Pierce PO Box 1616 Ventura CA 97712 >>%LSEQ0080% echo 001700 Quigley Quincy 1717 Farm Hill Road Oshkosh WI 43389 >>%LSEQ0080% echo 001800 Ripley Ray 1818 Alien Lane Wayout KS 55405 >>%LSEQ0080% echo 001900 Smith Sammy 1919 Carnoustie Drive Novato CA 94919 >>%LSEQ0080% echo 002000 Tucker Taylor 2020 Sanger Lane St. Paul MN 43998 >>%LSEQ0080% echo 002100 Underwood Ulysses 2121 Wall Street New York NY 17623 >>%LSEQ0080% echo 002200 Van Etten Valerie 2222 Vine Street Hollywood CA 98775 >>%LSEQ0080% echo 002300 Wilson Wiley 2323 Main Street Boston MA 01472 >>%LSEQ0080% echo 002400 Xray Xavier 2424 24TH Street Nashville TN 44190 >>%LSEQ0080% echo 002500 Young Yanni 2525 Yonge Street Toronto ON 6B74A6>>%LSEQ0080% echo 002600 Zenith Zebulon 2626 26TH Street Dallas TX 71922 >>%LSEQ0080% echo 123456 Doe John 123 Main Street Anywhere OR 88156 >>%LSEQ0080% echo 123457 Goetlieb Günther 4567 Main Street Anywhere OR 88156 >>%LSEQ0080% rem * if not exist %LSEQ0080% set JobStatus=0002 if not "%JobStatus%" == "0000" goto EojNok call SimoNOTE "Produced DataSet %LSEQ0080%" rem * :ConvertLSEQtoRSEQasc rem * rem * ******************************************************************* rem * Step 3, Read the previously created Line Sequential File (LSEQ) rem * and write a Record Sequential File (RSEQ) with 80-byte, rem * ASCII-encoded records. rem * call SimoNOTE "Identify JobStep ConvertLSEQtoRSEQasc" set GETLS080=%LSEQ0080% set PUTRS080=%BaseLib1%\DATA\Asc1\SIMOTIME.DATA.QSAM0080.DAT if exist %PUTRS080% del %PUTRS080% run CV80ALAR if not exist %PUTRS080% set JobStatus=0003 if not "%JobStatus%" == "0000" goto EojNok call SimoNOTE "Produced DataSet %PUTRS080%" rem * :ConvertLSEQtoRSEQebc rem * rem * ******************************************************************* rem * Step 4, Read the previously created Line Sequential File (LSEQ) rem * and write a Record Sequential File (RSEQ) with 80-byte, rem * EBCDIC-encoded records. rem * call SimoNOTE "Identify JobStep ConvertLSEQtoRSEQebc" set GETLS080=%LSEQ0080% set PUTRS080=%BaseLib1%\DATA\Ebc1\SIMOTIME.DATA.QSAM0080.DAT if exist %PUTRS080% del %PUTRS080% run CV80ALER if not exist %PUTRS080% set JobStatus=0004 if not "%JobStatus%" == "0000" goto EojNok call SimoNOTE "Produced DataSet %PUTRS080%" rem * rem * ******************************************************************* rem * :EojAok call SimoNOTE "Finished JobName %CmdName%, Job Status is %JobStatus%" goto :End :EojNok call SimoNOTE "ABENDING JobName %CmdName%, Job Status is %JobStatus%" :End call SimoNOTE "Conclude SysLog is %SYSLOG%" if not "%1" == "nopause" pause
The following (D80DELW1.cmd) is the Windows Command file that is used to delete the sequential files created by the D80CRTE1.CMD command
@echo OFF rem * ************************************************************************ rem * D80DELW1.CMD - a Windows Command File * rem * This program is provided by SimoTime Technologies * rem * (C) Copyright 1987-2019 All Rights Reserved * rem * Web Site URL: http://www.simotime.com * rem * e-mail: helpdesk@simotime.com * rem * ************************************************************************ rem * rem * Text - Delete various sequential files with 80-byte records. rem * Author - SimoTime Technologies rem * Date - January 24, 1996 rem * rem * This procedure will delete the sequential files created by rem * the D80CRTE1.CMD command. rem * rem * ******************************************************************* rem * Step 1, Delete any previously created file... rem * set CmdName=D80DELW1 call ..\ENV1BASE rem * call SimoNOTE "*******************************************************%CmdName%" call SimoNOTE "Starting JobName %CmdName%" :DeleteLSEQ call SimoNOTE "Identify JobStep DeleteLSEQ" set LSEQ0080=%BaseLib1%\DATA\Txt1\LSEQ0080.TXT if exist %LSEQ0080% del %LSEQ0080% rem * :DeleteRSEQasc call SimoNOTE "Identify JobStep DeleteRSEQasc" set PUTRS080=%BaseLib1%\DATA\Asc1\SIMOTIME.DATA.QSAM0080.DAT if exist %PUTRS080% del %PUTRS080% rem * :DeleteRSEQebc call SimoNOTE "Identify JobStep DeleteRSEQebc" set PUTRS080=%BaseLib1%\DATA\Ebc1\SIMOTIME.DATA.QSAM0080.DAT if exist %PUTRS080% del %PUTRS080% rem * :EojAok call SimoNOTE "Finished JobName %CmdName%, Job Status is %JobStatus%" goto :End :EojNok call SimoNOTE "ABENDING JobName %CmdName%, Job Status is %JobStatus%" :End call SimoNOTE "Conclude SysLog is %SYSLOG%" if not "%1" == "nopause" pause
The following (ALAR80E1.cmd) is the Windows Command file that is used to perform the file format conversion for a single file.
@echo OFF rem * ************************************************************************ rem * ALAR80E1.cmd - a Windows Command File * rem * This program is provided by SimoTime Technologies * rem * (C) Copyright 1987-2019 All Rights Reserved * rem * Web Site URL: http://www.simotime.com * rem * e-mail: helpdesk@simotime.com * rem * ************************************************************************ rem * This procedure will perform the following conversion for a single file. rem * 1. Read an ASCII-encoded, Line Sequential file having variable-length rem * records with a maximum record length of eighty-bytes. rem * 2. Write an ASCII-encoded, Record Sequential file having eighty-byte, rem * fixed-length records. rem * ************************************************************************ rem * This procedure calls the following Windows Command Files or Programs. rem * 1. ENV1BASE.cmd - this provides a single point for setting commonly rem * used environment variables. rem * 2. SIMONOTE.cmd - this provides a consistent process for displaying rem * messages to the screen and writing to a journal or log file. rem * 3. RUN CV80ALAR - For the specified file perform the following actions. rem * - Do the file format conversion between Line Sequential rem * and Record Sequential. rem * - Leave the records in their ASCII-encoded content. rem * ************************************************************************ set CmdName=ALAR80E1 call ..\ENV1BASE %CmdName% rem * call SIMONOTE "*******************************************************%CmdName%.cmd" call SIMONOTE "Starting JobName %CmdName%.cmd" rem * set GETLS080=%BaseLib1%\DATA\Txt1\LSEQ0080.TXT set PUTRS080=%BaseLib1%\DATA\Wrk1\SIMOTIME.DATA.QSAM0080.DAT call SIMONOTE "DataTAKE is %GETLS080%" call SIMONOTE "DataMAKE is %PUTRS080%" if exist %PUTRS080% erase %PUTRS080% run CV80ALAR if not "%ERRORLEVEL%" == "0" set JobStatus=0010 if not "%JobStatus%" == "0000" goto :EojNOK if not exist %PUTRS080% set JobStatus=0035 if not "%JobStatus%" == "0000" goto :EojNOK goto EojAok :EojAOK call SIMONOTE "Finished CmdName %CmdName%, Job Status is %JobStatus%" goto :End :EojNOK call SIMONOTE "ABENDING CmdName %CmdName%, Job Status is %JobStatus%" echo %DATE% - %TIME% Starting User ABEND Processing...>>%SYSLOG% set >>%SYSLOG% echo %DATE% - %TIME% Complete User ABEND Processing...>>%SYSLOG% goto :End :End call SIMONOTE "Conclude SysOut is %SYSOUT%" if not "%1" == "nopause" pause exit /B %JobStatus%
The following (ALER80E1.cmd) is the Windows Command file that is used to perform the file format conversion and a record content conversion for a single file.
@echo OFF rem * ************************************************************************ rem * ALER80E1.cmd - a Windows Command File * rem * This program is provided by SimoTime Technologies * rem * (C) Copyright 1987-2019 All Rights Reserved * rem * Web Site URL: http://www.simotime.com * rem * e-mail: helpdesk@simotime.com * rem * ************************************************************************ rem * This procedure will perform the following conversion for a single file. rem * Read an ASCII-encoded, Line Sequential file containing variable-length rem * records with a maximum record length of eighty-bytes. rem * Write an EBCDIC-encoded, Record Sequential file containing eighty-byte, rem * fixed-length records. rem * ************************************************************************ rem * This procedure calls the following Windows Command Files or Programs. rem * 1. ENV1BASE.cmd - this provides a single point for setting commonly rem * used environment variables. rem * 2. SIMONOTE.cmd - this provides a consistent process for displaying rem * messages to the screen and writing to a journal or log file. rem * 3. RUN CV80ALER - For the specified file perform the following actions. rem * - Do the file content conversion between EBCDIC & ASCII rem * - Do the file format conversion between Line Sequential rem * and Record Sequential. rem * ************************************************************************ set CmdName=ALER80E1 call ..\ENV1BASE %CmdName% rem * call SIMONOTE "*******************************************************%CmdName%.cmd" call SIMONOTE "Starting JobName %CmdName%.cmd" rem * set GETLS080=%BaseLib1%\DATA\TXT1\LSEQ0080.TXT set PUTRS080=%BaseLib1%\DATA\Wrk2\SIMOTIME.DATA.QSAM0080.DAT call SIMONOTE "DataTAKE is %GETLS080%" call SIMONOTE "DataMAKE is %PUTRS080%" run CV80ALER if not "%ERRORLEVEL%" == "0" set JobStatus=0010 if not "%JobStatus%" == "0000" goto :EojNOK if not exist %PUTRS080% set JobStatus=0035 if not "%JobStatus%" == "0000" goto :EojNOK goto EojAok :EojAOK call SIMONOTE "Finished CmdName %CmdName%, Job Status is %JobStatus%" goto :End :EojNOK call SIMONOTE "ABENDING CmdName %CmdName%, Job Status is %JobStatus%" echo %DATE% - %TIME% Starting User ABEND Processing...>>%SYSLOG% set >>%SYSLOG% echo %DATE% - %TIME% Complete User ABEND Processing...>>%SYSLOG% goto :End :End call SIMONOTE "Conclude SysOut is %SYSOUT%" if not "%1" == "nopause" pause exit /B %JobStatus%
The following two sub-sections of this document describe the scripts for converting a single file or converting multiple files using a user-defined list of file names.
The following (ERAL80E1.cmd) is the Windows Command file that is used to perform the file format conversion and a record content conversion for a single file.
@echo OFF rem * ************************************************************************ rem * ERAL80E1.CMD - a Windows Command File * rem * This program is provided by SimoTime Technologies * rem * (C) Copyright 1987-2019 All Rights Reserved * rem * Web Site URL: http://www.simotime.com * rem * e-mail: helpdesk@simotime.com * rem * ************************************************************************ rem * This procedure will perform the following conversion for a single file. rem * Read an EBCDIC-encoded, Record Sequential file containing eighty-byte, rem * fixed-length records. rem * Write an ASCII-encoded, Line Sequential file containing variable-length rem * records with a maximum record length of eighty-bytes. rem * ************************************************************************ rem * This procedure calls the following Windows Command Files or Programs. rem * 1. ENV1BASE.CMD - this provides a single point for setting commonly rem * used environment variables. rem * 2. SimoNOTE.CMD - this provides a consistent process for displaying rem * messages to the screen and writing to a journal or log file. rem * 3. RUN ERAL80C1 - For the specified file perform the following actions. rem * - Do the file content conversion between EBCDIC & ASCII rem * - Do the file format conversion between Line Sequential rem * and Record Sequential. rem * ************************************************************************ set CmdName=ERAL80E1 call ..\Env1BASE %CmdName% rem * call SimoNOTE "*******************************************************%CmdName%.CMD" call SimoNOTE "Starting JobName %CmdName%.CMD" rem * set GETRS080=%BaseLib1%\DATA\CblEbc\CblBitC1.CBL set PUTLS080=%BaseLib1%\DATA\CblASC\CblBitC1.CBL run CV80ERAL call SimoNOTE "Finished JobName %CmdName%.CMD" if not "%SimoGENS%" == "BATCH" pause endlocal
The following (ERAL80E2.cmd) is the Windows Command file that is used to perform the file format conversion and a record content conversion for multiple files.
@echo OFF rem * ************************************************************************ rem * ERAL80E2.CMD - a Windows Command File * rem * This program is provided by SimoTime Technologies * rem * (C) Copyright 1987-2019 All Rights Reserved * rem * Web Site URL: http://www.simotime.com * rem * e-mail: helpdesk@simotime.com * rem * ************************************************************************ rem * This procedure will perform the following conversion for multiple files. rem * Read an EBCDIC-encoded, Record Sequential file containing eighty-byte, rem * fixed-length records. rem * Write an ASCII-encoded, Line Sequential file containing variable-length rem * records with a maximum record length of eighty-bytes. rem * ************************************************************************ rem * This procedure calls the following Windows Command Files or Programs. rem * 1. Env1BASE.CMD - this provides a single point for setting commonly rem * used environment variables. rem * 2. SimoNOTE.CMD - this provides a consistent process for displaying rem * messages to the screen and writing to a journal or log file. rem * 3. DIR Command - this will create a file that is a list of all the rem * Cobol program in the specified directory. rem * 4. FOR Command - for each of the file names in the list file perform rem * the following actions. rem * - Do the file content conversion between EBCDIC & ASCII rem * - Do the file format conversion between Line Sequential rem * and Record Sequential. rem * ************************************************************************ set CmdName=ERAL80E2 call ..\Env1BASE %CmdName% rem * call SimoNOTE "*******************************************************%CmdName%.CMD" call SimoNOTE "Starting JobName %CmdName%.CMD" DIR /on /b /a-d %BaseLib1%\DATA\CblEbc\*.CBL>ListCobolSourceCode.TXT rem * FOR /F %%i in (ListCobolSourceCode.TXT) do (set GETRS080=%BaseLib1%\DATA\CblEbc\%%i set PUTLS080=%BaseLib1%\DATA\CblAsc\%%i run CV80ERAL) call SimoNOTE "Finished JobName %CmdName%.CMD" if not "%SimoGENS%" == "BATCH" pause endlocal
The following (CUSI80W1.cmd) is the Windows Command file that is used to perform the file format conversion for a single file.
@echo OFF rem * ******************************************************************* rem * CUSI80W1.CMD - a Windows Command File * rem * This program is provided by SimoTime Technologies * rem * (C) Copyright 1987-2019 All Rights Reserved * rem * Web Site URL: http://www.simotime.com * rem * e-mail: helpdesk@simotime.com * rem * ******************************************************************* rem * rem * Text - Read RSEQ, ASCII-80, write ASCII Customer Master. rem * Author - SimoTime Technologies rem * Date - January 24, 1996 rem * rem * The job will read an ASCII-encoded, Record Sequential file and rem * write to a VSAM, KSDS Customer Master File. rem * rem * ************ rem * * CUSI80W1 * rem * ********cmd* rem * * rem * * rem * ************ rem * * Env1BASE * rem * ********cmd* rem * * rem * * rem * ************ rem * * SimoNOTE * rem * ********cmd* rem * * rem * * rem * ************ rem * * RUN *---------------------------* rem * ********rts* * rem * * ************ ************ ************ rem * * * CUST0080 *-----* CUSI80C1 *-----* CUSTMAST * rem * * *******rseq* ********cbl* *******ksds* rem * ************ rem * * EOJ * rem * ************ rem * rem * ******************************************************************* rem * Step 1, Set Environment Variables rem * Delete any previously created ASCII-encoded file... rem * call ..\Env1BASE set CmdName=CUSI80W1 rem * call SimoNOTE "*******************************************************%CmdName%" call SimoNOTE "Starting JobName %CmdName%, User is %USERNAME%" call SimoNOTE "Identify JobStep Step-1, Housekeeping tasks" set CUST0080=%BaseLib1%\Data\asc1\SIMOTIME.DATA.QSAM0080.DAT set CUSTMAST=%BaseLib1%\Data\ASC1\SIMOTIME.DATA.CUSTMAST.DAT if exist %CUSTMAST% del %CUSTMAST% rem * rem * ******************************************************************* rem * Step 2, Read EBCDIC-encoded KSDS, create a new ASCII-encoded KSDS rem * call SimoNOTE "Identify JobStep Step-2, Execute EBCDIC to ASCII Conversion" call SimoNOTE "DataTake RSA CUST0080=%CUST0080%" call SimoNOTE "DataMake KSA CUSTMAST=%CUSTMAST%" run CUSI80C1 if not "%ERRORLEVEL%" == "0" set JobStatus=0010 if not "%JobStatus%" == "0000" goto EojNOK if exist %CUSTMAST% goto EojAOK set JobStatus=0020 goto EojNOK :EojAOK call SimoNOTE "Produced %CUSTMAST%" call SimoNOTE "Finished CmdName %CmdName%, Job Status is %JobStatus%" goto :End :EojNOK call SimoNOTE "ABENDING CmdName %CmdName%, Job Status is %JobStatus%" echo %DATE% - %TIME% Starting User ABEND Processing...>>%SYSLOG% set >>%SYSLOG% echo %DATE% - %TIME% Complete User ABEND Processing...>>%SYSLOG% goto :End :End call SimoNOTE "Conclude SysOut is %SYSOUT%" if not "%1" == "nopause" pause exit /B %JobStatus% pause
This section describes the COBOL programs that are used in this application suite.
The following (CV80ALAR.cbl) is the generated COBOL program that is used to perform the file format conversion for a single file.
IDENTIFICATION DIVISION. PROGRAM-ID. CV80ALAR. AUTHOR. SIMOTIME TECHNOLOGIES. ***************************************************************** * This program was generated by SimoZAPS * * A product of SimoTime Technologies * * Our e-mail address is: helpdesk@simotime.com * * Also, visit our Web Site at http://www.simotime.com * * * * Generation Date: 2020-03-20 Generation Time: 16:54:50:92 * * * * Record Record Key * * Function Name Organization Format Max-Min Pos-Len * * PRIMARY GETLS080 ASCII/CRLF VARIABLE 00080 * * * * SECONDARY PUTRS080 SEQUENTIAL FIXED 00080 * * * ***************************************************************** ENVIRONMENT DIVISION. INPUT-OUTPUT SECTION. FILE-CONTROL. SELECT GETLS080-FILE ASSIGN TO GETLS080 ORGANIZATION IS LINE SEQUENTIAL ACCESS MODE IS SEQUENTIAL FILE STATUS IS GETLS080-STATUS. SELECT PUTRS080-FILE ASSIGN TO PUTRS080 ORGANIZATION IS SEQUENTIAL ACCESS MODE IS SEQUENTIAL FILE STATUS IS PUTRS080-STATUS. ***************************************************************** DATA DIVISION. FILE SECTION. FD GETLS080-FILE DATA RECORD IS GETLS080-REC . 01 GETLS080-REC. 05 GETLS080-DATA-01 PIC X(00080). FD PUTRS080-FILE DATA RECORD IS PUTRS080-REC . 01 PUTRS080-REC. 05 PUTRS080-DATA-01 PIC X(00080). ***************************************************************** * This program was created with the SYSMASK1.TXT file as input. * * The SYSMASK1 provides for the sequential reading of the input * * file and the sequential writing of the output file. * * * * If the output file is indexed then the input file must be in * * sequence by the field that will be used to provide the key * * for the output file. This is a sequential load process. * * * * If the key field is not in sequence then refer to SYSMASK2 * * to provide for a random add or update of the indexed file. * * * * This program mask will have the ASCII/EBCDIC table inserted * * for use by the /TRANSLATE function of SimoZAPS. * * * * For more information or questions please contact SimoTime * * Technologies. The version control number is 20.00.00 * * * * Our e-mail address is: helpdesk@simotime.com * * Also, visit our Web Site at http://www.simotime.com * ***************************************************************** WORKING-STORAGE SECTION. 01 SIM-TITLE. 05 T1 pic X(11) value '* CV80ALAR '. 05 T2 pic X(34) value 'Convert 80/80 ASC_LSEQ to ASC_RSEQ'. 05 T3 pic X(10) value ' v20.00.00'. 05 T4 pic X(24) value ' helpdesk@simotime.com'. 01 SIM-COPYRIGHT. 05 C1 pic X(11) value '* CV80ALAR '. 05 C2 pic X(32) value 'This Data File Convert Member wa'. 05 C3 pic X(32) value 's generated by SimoTime Technolo'. 05 C4 pic X(04) value 'gies'. 01 GETLS080-STATUS. 05 GETLS080-STATUS-L pic X. 05 GETLS080-STATUS-R pic X. 01 GETLS080-EOF pic X value 'N'. 01 GETLS080-OPEN-FLAG pic X value 'C'. 01 PUTRS080-STATUS. 05 PUTRS080-STATUS-L pic X. 05 PUTRS080-STATUS-R pic X. 01 PUTRS080-EOF pic X value 'N'. 01 PUTRS080-OPEN-FLAG pic X value 'C'. 01 GETLS080-LRECL pic 9(5) value 00080. 01 PUTRS080-LRECL pic 9(5) value 00080. 01 GETLS080-LRECL-MAX pic 9(5) value 00080. 01 PUTRS080-LRECL-MAX pic 9(5) value 00080. ***************************************************************** * The following buffers are used to create a four-byte status * * code that may be displayed. * ***************************************************************** 01 IO-STATUS. 05 IO-STAT1 pic X. 05 IO-STAT2 pic X. 01 IO-STATUS-04. 05 IO-STATUS-0401 pic 9 value 0. 05 IO-STATUS-0403 pic 999 value 0. 01 TWO-BYTES-BINARY pic 9(4) BINARY. 01 TWO-BYTES-ALPHA redefines TWO-BYTES-BINARY. 05 TWO-BYTES-LEFT pic X. 05 TWO-BYTES-RIGHT pic X. ***************************************************************** * Message Buffer used by the Z-DISPLAY-MESSAGE-TO-SYSOUT routine. * ***************************************************************** 01 MESSAGE-BUFFER. 05 MESSAGE-HEADER pic X(011) value '* CV80ALAR '. 05 MESSAGE-TEXT. 10 MESSAGE-TEXT-1 pic X(068) value SPACES. 10 MESSAGE-TEXT-2 pic X(188) value SPACES. 01 MSG-LSB pic 9(5) value 267. ***************************************************************** 01 PROGRAM-NAME pic X(8) value 'CV80ALAR'. 01 INFO-STATEMENT. 05 INFO-SHORT. 10 INFO-ID pic X(8) value 'Starting'. 10 filler pic X(2) value ', '. 10 filler pic X(34) value 'Convert 80/80 ASC_LSEQ to ASC_RSEQ'. 05 filler pic X(24) value ' http://www.SimoTime.com'. 01 APPL-RESULT pic S9(9) comp. 88 APPL-AOK value 0. 88 APPL-EOF value 16. 01 WRITE-FLAG pic X value 'Y'. 01 GETLS080-TOTAL. 05 GETLS080-RDR pic 9(9) value 0. 05 filler pic X(3) value ' - '. 05 filler pic X(23) value 'Line count for GETLS080'. 01 PUTRS080-TOTAL. 05 PUTRS080-ADD pic 9(9) value 0. 05 filler pic X(3) value ' - '. 05 filler pic X(23) value 'Line count for PUTRS080'. ***************************************************************** PROCEDURE DIVISION. move all '*' to MESSAGE-TEXT-1 perform Z-DISPLAY-MESSAGE-TO-SYSOUT move INFO-STATEMENT to MESSAGE-TEXT-1 perform Z-DISPLAY-MESSAGE-TO-SYSOUT move all '*' to MESSAGE-TEXT-1 perform Z-DISPLAY-MESSAGE-TO-SYSOUT perform Z-POST-COPYRIGHT perform GETLS080-OPEN perform PUTRS080-OPEN * USRSOJ Processing not specified... perform until GETLS080-STATUS not = '00' perform GETLS080-READ if GETLS080-STATUS = '00' add 1 to GETLS080-RDR move 'Y' to WRITE-FLAG perform BUILD-OUTPUT-RECORD if WRITE-FLAG = 'Y' perform PUTRS080-WRITE if PUTRS080-STATUS = '00' add 1 to PUTRS080-ADD end-if end-if end-if end-perform * USREOJ Processing not specified... move GETLS080-TOTAL to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move PUTRS080-TOTAL to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS if APPL-EOF move 'Complete' to INFO-ID else move 'ABENDING' to INFO-ID end-if move INFO-STATEMENT to MESSAGE-TEXT(1:79) perform Z-DISPLAY-MESSAGE-TO-SYSOUT perform PUTRS080-CLOSE perform GETLS080-CLOSE GOBACK. ***************************************************************** BUILD-OUTPUT-RECORD. * TransINIT process... move ALL X'20' to PUTRS080-REC * TransCOPY... move GETLS080-REC(00001:00080) to PUTRS080-REC(00001:00080) exit. ***************************************************************** * I/O Routines for the INPUT File... * ***************************************************************** GETLS080-CLOSE. add 8 to ZERO giving APPL-RESULT. close GETLS080-FILE if GETLS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'CLOSE Failure with GETLS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move GETLS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. *---------------------------------------------------------------* GETLS080-READ. read GETLS080-FILE if GETLS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT else if GETLS080-STATUS = '10' add 16 to ZERO giving APPL-RESULT else add 12 to ZERO giving APPL-RESULT end-if end-if if APPL-AOK CONTINUE else if APPL-EOF move 'Y' to GETLS080-EOF else move 'READ Failure with GETLS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move GETLS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if end-if exit. *---------------------------------------------------------------* GETLS080-OPEN. add 8 to ZERO giving APPL-RESULT. open input GETLS080-FILE if GETLS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT move 'O' to GETLS080-OPEN-FLAG else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'OPEN Failure with GETLS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move GETLS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. ***************************************************************** * I/O Routines for the OUTPUT File... * ***************************************************************** PUTRS080-WRITE. if PUTRS080-OPEN-FLAG = 'C' perform PUTRS080-OPEN end-if write PUTRS080-REC if PUTRS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT else if PUTRS080-STATUS = '10' add 16 to ZERO giving APPL-RESULT else add 12 to ZERO giving APPL-RESULT end-if end-if. if APPL-AOK CONTINUE else move 'WRITE Failure with PUTRS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move PUTRS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. *---------------------------------------------------------------* PUTRS080-OPEN. add 8 to ZERO giving APPL-RESULT. open OUTPUT PUTRS080-FILE if PUTRS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT move 'O' to PUTRS080-OPEN-FLAG else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'OPEN Failure with PUTRS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move PUTRS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. *---------------------------------------------------------------* PUTRS080-CLOSE. add 8 to ZERO giving APPL-RESULT. close PUTRS080-FILE if PUTRS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT move 'C' to PUTRS080-OPEN-FLAG else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'CLOSE Failure with PUTRS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move PUTRS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. ***************************************************************** * The following Z-ROUTINES provide administrative functions * * for this program. * ***************************************************************** * ABEND the program, post a message to the console and issue * * a STOP RUN. * ***************************************************************** Z-ABEND-PROGRAM. if MESSAGE-TEXT not = SPACES perform Z-DISPLAY-MESSAGE-TO-USERS end-if move 'PROGRAM-IS-ABENDING...' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS add 12 to ZERO giving RETURN-CODE STOP RUN. * exit. ***************************************************************** Z-CALCULATE-MESSAGE-LSB. add 267 to ZERO giving MSG-LSB perform until MSG-LSB < 80 or MESSAGE-BUFFER(MSG-LSB:1) not = SPACE if MESSAGE-BUFFER(MSG-LSB:1) = SPACE subtract 1 from MSG-LSB end-if end-perform exit. ***************************************************************** * Post message to the SYSOUT device, clear message buffer... * ***************************************************************** Z-DISPLAY-MESSAGE-TO-SYSOUT. perform Z-CALCULATE-MESSAGE-LSB display MESSAGE-BUFFER(1:MSG-LSB) move all SPACES to MESSAGE-TEXT exit. ***************************************************************** * Display message to console, do not clear message buffer... * ***************************************************************** Z-DISPLAY-MESSAGE-TO-CONSOLE. perform Z-CALCULATE-MESSAGE-LSB display MESSAGE-BUFFER(1:MSG-LSB) upon console exit. ***************************************************************** * Display message to console and post to SYSOUT device... * ***************************************************************** Z-DISPLAY-MESSAGE-TO-USERS. perform Z-DISPLAY-MESSAGE-TO-CONSOLE perform Z-DISPLAY-MESSAGE-TO-SYSOUT exit. ***************************************************************** * Display the file status bytes. This routine will display as * * four digits. If the full two byte file status is numeric it * * will display as 00nn. If the 1st byte is a numeric nine (9) * * the second byte will be treated as a binary number and will * * display as 9nnn. * ***************************************************************** Z-DISPLAY-IO-STATUS. if IO-STATUS not NUMERIC or IO-STAT1 = '9' move IO-STAT1 to IO-STATUS-04(1:1) subtract TWO-BYTES-BINARY from TWO-BYTES-BINARY move IO-STAT2 to TWO-BYTES-RIGHT add TWO-BYTES-BINARY to ZERO giving IO-STATUS-0403 move 'File Status is: nnnn' to MESSAGE-TEXT move IO-STATUS-04 to MESSAGE-TEXT(17:4) perform Z-DISPLAY-MESSAGE-TO-USERS else move '0000' to IO-STATUS-04 move IO-STATUS to IO-STATUS-04(3:2) move 'File Status is: nnnn' to MESSAGE-TEXT move IO-STATUS-04 to MESSAGE-TEXT(17:4) perform Z-DISPLAY-MESSAGE-TO-USERS end-if exit. ***************************************************************** Z-POST-COPYRIGHT. display SIM-TITLE display SIM-COPYRIGHT exit. ***************************************************************** * This program was generated by SimoZAPS * * A product of SimoTime Technologies * * Our e-mail address is: helpdesk@simotime.com * * Also, visit our Web Site at http://www.simotime.com * * * * Generation Date: 2020-03-20 Generation Time: 16:54:50:94 * *****************************************************************
The following (CV80ALER.cbl) is the generated COBOL program that is used to perform the file format conversion and record content conversion for a single file.
IDENTIFICATION DIVISION. PROGRAM-ID. CV80ALER. AUTHOR. SIMOTIME TECHNOLOGIES. ***************************************************************** * This program was generated by SimoZAPS * * A product of SimoTime Technologies * * Our e-mail address is: helpdesk@simotime.com * * Also, visit our Web Site at http://www.simotime.com * * * * Generation Date: 2020-03-20 Generation Time: 16:54:51:22 * * * * Record Record Key * * Function Name Organization Format Max-Min Pos-Len * * PRIMARY GETLS080 ASCII/CRLF VARIABLE 00080 * * * * SECONDARY PUTRS080 SEQUENTIAL FIXED 00080 * * * * * * Translation Mode is ASCII to EBCDIC * * * ***************************************************************** ENVIRONMENT DIVISION. INPUT-OUTPUT SECTION. FILE-CONTROL. SELECT GETLS080-FILE ASSIGN TO GETLS080 ORGANIZATION IS LINE SEQUENTIAL ACCESS MODE IS SEQUENTIAL FILE STATUS IS GETLS080-STATUS. SELECT PUTRS080-FILE ASSIGN TO PUTRS080 ORGANIZATION IS SEQUENTIAL ACCESS MODE IS SEQUENTIAL FILE STATUS IS PUTRS080-STATUS. ***************************************************************** DATA DIVISION. FILE SECTION. FD GETLS080-FILE DATA RECORD IS GETLS080-REC . 01 GETLS080-REC. 05 GETLS080-DATA-01 PIC X(00080). FD PUTRS080-FILE DATA RECORD IS PUTRS080-REC . 01 PUTRS080-REC. 05 PUTRS080-DATA-01 PIC X(00080). ***************************************************************** * This program was created with the SYSMASK1.TXT file as input. * * The SYSMASK1 provides for the sequential reading of the input * * file and the sequential writing of the output file. * * * * If the output file is indexed then the input file must be in * * sequence by the field that will be used to provide the key * * for the output file. This is a sequential load process. * * * * If the key field is not in sequence then refer to SYSMASK2 * * to provide for a random add or update of the indexed file. * * * * This program mask will have the ASCII/EBCDIC table inserted * * for use by the /TRANSLATE function of SimoZAPS. * * * * For more information or questions please contact SimoTime * * Technologies. The version control number is 20.00.00 * * * * Our e-mail address is: helpdesk@simotime.com * * Also, visit our Web Site at http://www.simotime.com * ***************************************************************** WORKING-STORAGE SECTION. 01 SIM-TITLE. 05 T1 pic X(11) value '* CV80ALER '. 05 T2 pic X(34) value 'Convert 80/80 ASC_LSEQ to EBC_RSEQ'. 05 T3 pic X(10) value ' v20.00.00'. 05 T4 pic X(24) value ' helpdesk@simotime.com'. 01 SIM-COPYRIGHT. 05 C1 pic X(11) value '* CV80ALER '. 05 C2 pic X(32) value 'This Data File Convert Member wa'. 05 C3 pic X(32) value 's generated by SimoTime Technolo'. 05 C4 pic X(04) value 'gies'. 01 GETLS080-STATUS. 05 GETLS080-STATUS-L pic X. 05 GETLS080-STATUS-R pic X. 01 GETLS080-EOF pic X value 'N'. 01 GETLS080-OPEN-FLAG pic X value 'C'. 01 PUTRS080-STATUS. 05 PUTRS080-STATUS-L pic X. 05 PUTRS080-STATUS-R pic X. 01 PUTRS080-EOF pic X value 'N'. 01 PUTRS080-OPEN-FLAG pic X value 'C'. 01 GETLS080-LRECL pic 9(5) value 00080. 01 PUTRS080-LRECL pic 9(5) value 00080. 01 GETLS080-LRECL-MAX pic 9(5) value 00080. 01 PUTRS080-LRECL-MAX pic 9(5) value 00080. ***************************************************************** * The following buffers are used to create a four-byte status * * code that may be displayed. * ***************************************************************** 01 IO-STATUS. 05 IO-STAT1 pic X. 05 IO-STAT2 pic X. 01 IO-STATUS-04. 05 IO-STATUS-0401 pic 9 value 0. 05 IO-STATUS-0403 pic 999 value 0. 01 TWO-BYTES-BINARY pic 9(4) BINARY. 01 TWO-BYTES-ALPHA redefines TWO-BYTES-BINARY. 05 TWO-BYTES-LEFT pic X. 05 TWO-BYTES-RIGHT pic X. ***************************************************************** * Message Buffer used by the Z-DISPLAY-MESSAGE-TO-SYSOUT routine. * ***************************************************************** 01 MESSAGE-BUFFER. 05 MESSAGE-HEADER pic X(011) value '* CV80ALER '. 05 MESSAGE-TEXT. 10 MESSAGE-TEXT-1 pic X(068) value SPACES. 10 MESSAGE-TEXT-2 pic X(188) value SPACES. 01 MSG-LSB pic 9(5) value 267. ***************************************************************** 01 PROGRAM-NAME pic X(8) value 'CV80ALER'. 01 INFO-STATEMENT. 05 INFO-SHORT. 10 INFO-ID pic X(8) value 'Starting'. 10 filler pic X(2) value ', '. 10 filler pic X(34) value 'Convert 80/80 ASC_LSEQ to EBC_RSEQ'. 05 filler pic X(24) value ' http://www.SimoTime.com'. 01 APPL-RESULT pic S9(9) comp. 88 APPL-AOK value 0. 88 APPL-EOF value 16. 01 WRITE-FLAG pic X value 'Y'. 01 GETLS080-TOTAL. 05 GETLS080-RDR pic 9(9) value 0. 05 filler pic X(3) value ' - '. 05 filler pic X(23) value 'Line count for GETLS080'. 01 PUTRS080-TOTAL. 05 PUTRS080-ADD pic 9(9) value 0. 05 filler pic X(3) value ' - '. 05 filler pic X(23) value 'Line count for PUTRS080'. ***************************************************************** * The following copy file contains the translation tables for * * the ASCII and EBCDIC conversion. Also, sections of the tables * * may be used for case conversion. * ***************************************************************** COPY ASCEBCB1. ***************************************************************** PROCEDURE DIVISION. move all '*' to MESSAGE-TEXT-1 perform Z-DISPLAY-MESSAGE-TO-SYSOUT move INFO-STATEMENT to MESSAGE-TEXT-1 perform Z-DISPLAY-MESSAGE-TO-SYSOUT move all '*' to MESSAGE-TEXT-1 perform Z-DISPLAY-MESSAGE-TO-SYSOUT perform Z-POST-COPYRIGHT perform GETLS080-OPEN perform PUTRS080-OPEN * USRSOJ Processing not specified... perform until GETLS080-STATUS not = '00' perform GETLS080-READ if GETLS080-STATUS = '00' add 1 to GETLS080-RDR move 'Y' to WRITE-FLAG perform BUILD-OUTPUT-RECORD if WRITE-FLAG = 'Y' perform PUTRS080-WRITE if PUTRS080-STATUS = '00' add 1 to PUTRS080-ADD end-if end-if end-if end-perform * USREOJ Processing not specified... move GETLS080-TOTAL to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move PUTRS080-TOTAL to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS if APPL-EOF move 'Complete' to INFO-ID else move 'ABENDING' to INFO-ID end-if move INFO-STATEMENT to MESSAGE-TEXT(1:79) perform Z-DISPLAY-MESSAGE-TO-SYSOUT perform PUTRS080-CLOSE perform GETLS080-CLOSE GOBACK. ***************************************************************** BUILD-OUTPUT-RECORD. * TransMODE is A2E... * TransINIT process... move ALL X'40' to PUTRS080-REC * TransLATE... move GETLS080-REC(00001:00080) to PUTRS080-REC(00001:00080) inspect PUTRS080-REC(1:80) converting A-INFO to E-INFO exit. ***************************************************************** * I/O Routines for the INPUT File... * ***************************************************************** GETLS080-CLOSE. add 8 to ZERO giving APPL-RESULT. close GETLS080-FILE if GETLS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'CLOSE Failure with GETLS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move GETLS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. *---------------------------------------------------------------* GETLS080-READ. read GETLS080-FILE if GETLS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT else if GETLS080-STATUS = '10' add 16 to ZERO giving APPL-RESULT else add 12 to ZERO giving APPL-RESULT end-if end-if if APPL-AOK CONTINUE else if APPL-EOF move 'Y' to GETLS080-EOF else move 'READ Failure with GETLS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move GETLS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if end-if exit. *---------------------------------------------------------------* GETLS080-OPEN. add 8 to ZERO giving APPL-RESULT. open input GETLS080-FILE if GETLS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT move 'O' to GETLS080-OPEN-FLAG else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'OPEN Failure with GETLS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move GETLS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. ***************************************************************** * I/O Routines for the OUTPUT File... * ***************************************************************** PUTRS080-WRITE. if PUTRS080-OPEN-FLAG = 'C' perform PUTRS080-OPEN end-if write PUTRS080-REC if PUTRS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT else if PUTRS080-STATUS = '10' add 16 to ZERO giving APPL-RESULT else add 12 to ZERO giving APPL-RESULT end-if end-if. if APPL-AOK CONTINUE else move 'WRITE Failure with PUTRS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move PUTRS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. *---------------------------------------------------------------* PUTRS080-OPEN. add 8 to ZERO giving APPL-RESULT. open OUTPUT PUTRS080-FILE if PUTRS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT move 'O' to PUTRS080-OPEN-FLAG else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'OPEN Failure with PUTRS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move PUTRS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. *---------------------------------------------------------------* PUTRS080-CLOSE. add 8 to ZERO giving APPL-RESULT. close PUTRS080-FILE if PUTRS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT move 'C' to PUTRS080-OPEN-FLAG else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'CLOSE Failure with PUTRS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move PUTRS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. ***************************************************************** * The following Z-ROUTINES provide administrative functions * * for this program. * ***************************************************************** * ABEND the program, post a message to the console and issue * * a STOP RUN. * ***************************************************************** Z-ABEND-PROGRAM. if MESSAGE-TEXT not = SPACES perform Z-DISPLAY-MESSAGE-TO-USERS end-if move 'PROGRAM-IS-ABENDING...' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS add 12 to ZERO giving RETURN-CODE STOP RUN. * exit. ***************************************************************** Z-CALCULATE-MESSAGE-LSB. add 267 to ZERO giving MSG-LSB perform until MSG-LSB < 80 or MESSAGE-BUFFER(MSG-LSB:1) not = SPACE if MESSAGE-BUFFER(MSG-LSB:1) = SPACE subtract 1 from MSG-LSB end-if end-perform exit. ***************************************************************** * Post message to the SYSOUT device, clear message buffer... * ***************************************************************** Z-DISPLAY-MESSAGE-TO-SYSOUT. perform Z-CALCULATE-MESSAGE-LSB display MESSAGE-BUFFER(1:MSG-LSB) move all SPACES to MESSAGE-TEXT exit. ***************************************************************** * Display message to console, do not clear message buffer... * ***************************************************************** Z-DISPLAY-MESSAGE-TO-CONSOLE. perform Z-CALCULATE-MESSAGE-LSB display MESSAGE-BUFFER(1:MSG-LSB) upon console exit. ***************************************************************** * Display message to console and post to SYSOUT device... * ***************************************************************** Z-DISPLAY-MESSAGE-TO-USERS. perform Z-DISPLAY-MESSAGE-TO-CONSOLE perform Z-DISPLAY-MESSAGE-TO-SYSOUT exit. ***************************************************************** * Display the file status bytes. This routine will display as * * four digits. If the full two byte file status is numeric it * * will display as 00nn. If the 1st byte is a numeric nine (9) * * the second byte will be treated as a binary number and will * * display as 9nnn. * ***************************************************************** Z-DISPLAY-IO-STATUS. if IO-STATUS not NUMERIC or IO-STAT1 = '9' move IO-STAT1 to IO-STATUS-04(1:1) subtract TWO-BYTES-BINARY from TWO-BYTES-BINARY move IO-STAT2 to TWO-BYTES-RIGHT add TWO-BYTES-BINARY to ZERO giving IO-STATUS-0403 move 'File Status is: nnnn' to MESSAGE-TEXT move IO-STATUS-04 to MESSAGE-TEXT(17:4) perform Z-DISPLAY-MESSAGE-TO-USERS else move '0000' to IO-STATUS-04 move IO-STATUS to IO-STATUS-04(3:2) move 'File Status is: nnnn' to MESSAGE-TEXT move IO-STATUS-04 to MESSAGE-TEXT(17:4) perform Z-DISPLAY-MESSAGE-TO-USERS end-if exit. ***************************************************************** Z-POST-COPYRIGHT. display SIM-TITLE display SIM-COPYRIGHT exit. ***************************************************************** * This program was generated by SimoZAPS * * A product of SimoTime Technologies * * Our e-mail address is: helpdesk@simotime.com * * Also, visit our Web Site at http://www.simotime.com * * * * Generation Date: 2020-03-20 Generation Time: 16:54:51:22 * *****************************************************************
The following (CV80ERAL.cbl) is the generated COBOL program that is used to perform the file format conversion and record content conversion for a single file.
IDENTIFICATION DIVISION. PROGRAM-ID. CV80ERAL. AUTHOR. SIMOTIME TECHNOLOGIES. ***************************************************************** * This program was generated by SimoZAPS * * A product of SimoTime Technologies * * Our e-mail address is: helpdesk@simotime.com * * Also, visit our Web Site at http://www.simotime.com * * * * Generation Date: 2020-03-20 Generation Time: 16:54:52:38 * * * * Record Record Key * * Function Name Organization Format Max-Min Pos-Len * * PRIMARY GETRS080 SEQUENTIAL FIXED 00080 * * * * SECONDARY PUTLS080 ASCII/CRLF VARIABLE 00080 * * * * * * Translation Mode is EBCDIC to ASCII * * * ***************************************************************** ENVIRONMENT DIVISION. INPUT-OUTPUT SECTION. FILE-CONTROL. SELECT GETRS080-FILE ASSIGN TO GETRS080 ORGANIZATION IS SEQUENTIAL ACCESS MODE IS SEQUENTIAL FILE STATUS IS GETRS080-STATUS. SELECT PUTLS080-FILE ASSIGN TO PUTLS080 ORGANIZATION IS LINE SEQUENTIAL ACCESS MODE IS SEQUENTIAL FILE STATUS IS PUTLS080-STATUS. ***************************************************************** DATA DIVISION. FILE SECTION. FD GETRS080-FILE DATA RECORD IS GETRS080-REC . 01 GETRS080-REC. 05 GETRS080-DATA-01 PIC X(00080). FD PUTLS080-FILE DATA RECORD IS PUTLS080-REC . 01 PUTLS080-REC. 05 PUTLS080-DATA-01 PIC X(00080). ***************************************************************** * This program was created with the SYSMASK1.TXT file as input. * * The SYSMASK1 provides for the sequential reading of the input * * file and the sequential writing of the output file. * * * * If the output file is indexed then the input file must be in * * sequence by the field that will be used to provide the key * * for the output file. This is a sequential load process. * * * * If the key field is not in sequence then refer to SYSMASK2 * * to provide for a random add or update of the indexed file. * * * * This program mask will have the ASCII/EBCDIC table inserted * * for use by the /TRANSLATE function of SimoZAPS. * * * * For more information or questions please contact SimoTime * * Technologies. The version control number is 20.00.00 * * * * Our e-mail address is: helpdesk@simotime.com * * Also, visit our Web Site at http://www.simotime.com * ***************************************************************** WORKING-STORAGE SECTION. 01 SIM-TITLE. 05 T1 pic X(11) value '* CV80ERAL '. 05 T2 pic X(34) value 'Convert 80/80 EBC_RSEQ to ASC_LSEQ'. 05 T3 pic X(10) value ' v20.00.00'. 05 T4 pic X(24) value ' helpdesk@simotime.com'. 01 SIM-COPYRIGHT. 05 C1 pic X(11) value '* CV80ERAL '. 05 C2 pic X(32) value 'This Data File Convert Member wa'. 05 C3 pic X(32) value 's generated by SimoTime Technolo'. 05 C4 pic X(04) value 'gies'. 01 GETRS080-STATUS. 05 GETRS080-STATUS-L pic X. 05 GETRS080-STATUS-R pic X. 01 GETRS080-EOF pic X value 'N'. 01 GETRS080-OPEN-FLAG pic X value 'C'. 01 PUTLS080-STATUS. 05 PUTLS080-STATUS-L pic X. 05 PUTLS080-STATUS-R pic X. 01 PUTLS080-EOF pic X value 'N'. 01 PUTLS080-OPEN-FLAG pic X value 'C'. 01 GETRS080-LRECL pic 9(5) value 00080. 01 PUTLS080-LRECL pic 9(5) value 00080. 01 GETRS080-LRECL-MAX pic 9(5) value 00080. 01 PUTLS080-LRECL-MAX pic 9(5) value 00080. ***************************************************************** * The following buffers are used to create a four-byte status * * code that may be displayed. * ***************************************************************** 01 IO-STATUS. 05 IO-STAT1 pic X. 05 IO-STAT2 pic X. 01 IO-STATUS-04. 05 IO-STATUS-0401 pic 9 value 0. 05 IO-STATUS-0403 pic 999 value 0. 01 TWO-BYTES-BINARY pic 9(4) BINARY. 01 TWO-BYTES-ALPHA redefines TWO-BYTES-BINARY. 05 TWO-BYTES-LEFT pic X. 05 TWO-BYTES-RIGHT pic X. ***************************************************************** * Message Buffer used by the Z-DISPLAY-MESSAGE-TO-SYSOUT routine. * ***************************************************************** 01 MESSAGE-BUFFER. 05 MESSAGE-HEADER pic X(011) value '* CV80ERAL '. 05 MESSAGE-TEXT. 10 MESSAGE-TEXT-1 pic X(068) value SPACES. 10 MESSAGE-TEXT-2 pic X(188) value SPACES. 01 MSG-LSB pic 9(5) value 267. ***************************************************************** 01 PROGRAM-NAME pic X(8) value 'CV80ERAL'. 01 INFO-STATEMENT. 05 INFO-SHORT. 10 INFO-ID pic X(8) value 'Starting'. 10 filler pic X(2) value ', '. 10 filler pic X(34) value 'Convert 80/80 EBC_RSEQ to ASC_LSEQ'. 05 filler pic X(24) value ' http://www.SimoTime.com'. 01 APPL-RESULT pic S9(9) comp. 88 APPL-AOK value 0. 88 APPL-EOF value 16. 01 WRITE-FLAG pic X value 'Y'. 01 GETRS080-TOTAL. 05 GETRS080-RDR pic 9(9) value 0. 05 filler pic X(3) value ' - '. 05 filler pic X(23) value 'Line count for GETRS080'. 01 PUTLS080-TOTAL. 05 PUTLS080-ADD pic 9(9) value 0. 05 filler pic X(3) value ' - '. 05 filler pic X(23) value 'Line count for PUTLS080'. ***************************************************************** * The following copy file contains the translation tables for * * the ASCII and EBCDIC conversion. Also, sections of the tables * * may be used for case conversion. * ***************************************************************** COPY ASCEBCB1. ***************************************************************** PROCEDURE DIVISION. move all '*' to MESSAGE-TEXT-1 perform Z-DISPLAY-MESSAGE-TO-SYSOUT move INFO-STATEMENT to MESSAGE-TEXT-1 perform Z-DISPLAY-MESSAGE-TO-SYSOUT move all '*' to MESSAGE-TEXT-1 perform Z-DISPLAY-MESSAGE-TO-SYSOUT perform Z-POST-COPYRIGHT perform GETRS080-OPEN perform PUTLS080-OPEN * USRSOJ Processing not specified... perform until GETRS080-STATUS not = '00' perform GETRS080-READ if GETRS080-STATUS = '00' add 1 to GETRS080-RDR move 'Y' to WRITE-FLAG perform BUILD-OUTPUT-RECORD if WRITE-FLAG = 'Y' perform PUTLS080-WRITE if PUTLS080-STATUS = '00' add 1 to PUTLS080-ADD end-if end-if end-if end-perform * USREOJ Processing not specified... move GETRS080-TOTAL to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move PUTLS080-TOTAL to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS if APPL-EOF move 'Complete' to INFO-ID else move 'ABENDING' to INFO-ID end-if move INFO-STATEMENT to MESSAGE-TEXT(1:79) perform Z-DISPLAY-MESSAGE-TO-SYSOUT perform PUTLS080-CLOSE perform GETRS080-CLOSE GOBACK. ***************************************************************** BUILD-OUTPUT-RECORD. * TransMODE is E2A... * TransINIT process... move ALL X'20' to PUTLS080-REC * TransLATE... move GETRS080-REC(00001:00080) to PUTLS080-REC(00001:00080) inspect PUTLS080-REC(1:80) converting E-INFO to A-INFO exit. ***************************************************************** * I/O Routines for the INPUT File... * ***************************************************************** GETRS080-CLOSE. add 8 to ZERO giving APPL-RESULT. close GETRS080-FILE if GETRS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'CLOSE Failure with GETRS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move GETRS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. *---------------------------------------------------------------* GETRS080-READ. read GETRS080-FILE if GETRS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT else if GETRS080-STATUS = '10' add 16 to ZERO giving APPL-RESULT else add 12 to ZERO giving APPL-RESULT end-if end-if if APPL-AOK CONTINUE else if APPL-EOF move 'Y' to GETRS080-EOF else move 'READ Failure with GETRS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move GETRS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if end-if exit. *---------------------------------------------------------------* GETRS080-OPEN. add 8 to ZERO giving APPL-RESULT. open input GETRS080-FILE if GETRS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT move 'O' to GETRS080-OPEN-FLAG else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'OPEN Failure with GETRS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move GETRS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. ***************************************************************** * I/O Routines for the OUTPUT File... * ***************************************************************** PUTLS080-WRITE. if PUTLS080-OPEN-FLAG = 'C' perform PUTLS080-OPEN end-if write PUTLS080-REC if PUTLS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT else if PUTLS080-STATUS = '10' add 16 to ZERO giving APPL-RESULT else add 12 to ZERO giving APPL-RESULT end-if end-if. if APPL-AOK CONTINUE else move 'WRITE Failure with PUTLS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move PUTLS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. *---------------------------------------------------------------* PUTLS080-OPEN. add 8 to ZERO giving APPL-RESULT. open OUTPUT PUTLS080-FILE if PUTLS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT move 'O' to PUTLS080-OPEN-FLAG else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'OPEN Failure with PUTLS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move PUTLS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. *---------------------------------------------------------------* PUTLS080-CLOSE. add 8 to ZERO giving APPL-RESULT. close PUTLS080-FILE if PUTLS080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT move 'C' to PUTLS080-OPEN-FLAG else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'CLOSE Failure with PUTLS080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS move PUTLS080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. ***************************************************************** * The following Z-ROUTINES provide administrative functions * * for this program. * ***************************************************************** * ABEND the program, post a message to the console and issue * * a STOP RUN. * ***************************************************************** Z-ABEND-PROGRAM. if MESSAGE-TEXT not = SPACES perform Z-DISPLAY-MESSAGE-TO-USERS end-if move 'PROGRAM-IS-ABENDING...' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TO-USERS add 12 to ZERO giving RETURN-CODE STOP RUN. * exit. ***************************************************************** Z-CALCULATE-MESSAGE-LSB. add 267 to ZERO giving MSG-LSB perform until MSG-LSB < 80 or MESSAGE-BUFFER(MSG-LSB:1) not = SPACE if MESSAGE-BUFFER(MSG-LSB:1) = SPACE subtract 1 from MSG-LSB end-if end-perform exit. ***************************************************************** * Post message to the SYSOUT device, clear message buffer... * ***************************************************************** Z-DISPLAY-MESSAGE-TO-SYSOUT. perform Z-CALCULATE-MESSAGE-LSB display MESSAGE-BUFFER(1:MSG-LSB) move all SPACES to MESSAGE-TEXT exit. ***************************************************************** * Display message to console, do not clear message buffer... * ***************************************************************** Z-DISPLAY-MESSAGE-TO-CONSOLE. perform Z-CALCULATE-MESSAGE-LSB display MESSAGE-BUFFER(1:MSG-LSB) upon console exit. ***************************************************************** * Display message to console and post to SYSOUT device... * ***************************************************************** Z-DISPLAY-MESSAGE-TO-USERS. perform Z-DISPLAY-MESSAGE-TO-CONSOLE perform Z-DISPLAY-MESSAGE-TO-SYSOUT exit. ***************************************************************** * Display the file status bytes. This routine will display as * * four digits. If the full two byte file status is numeric it * * will display as 00nn. If the 1st byte is a numeric nine (9) * * the second byte will be treated as a binary number and will * * display as 9nnn. * ***************************************************************** Z-DISPLAY-IO-STATUS. if IO-STATUS not NUMERIC or IO-STAT1 = '9' move IO-STAT1 to IO-STATUS-04(1:1) subtract TWO-BYTES-BINARY from TWO-BYTES-BINARY move IO-STAT2 to TWO-BYTES-RIGHT add TWO-BYTES-BINARY to ZERO giving IO-STATUS-0403 move 'File Status is: nnnn' to MESSAGE-TEXT move IO-STATUS-04 to MESSAGE-TEXT(17:4) perform Z-DISPLAY-MESSAGE-TO-USERS else move '0000' to IO-STATUS-04 move IO-STATUS to IO-STATUS-04(3:2) move 'File Status is: nnnn' to MESSAGE-TEXT move IO-STATUS-04 to MESSAGE-TEXT(17:4) perform Z-DISPLAY-MESSAGE-TO-USERS end-if exit. ***************************************************************** Z-POST-COPYRIGHT. display SIM-TITLE display SIM-COPYRIGHT exit. ***************************************************************** * This program was generated by SimoZAPS * * A product of SimoTime Technologies * * Our e-mail address is: helpdesk@simotime.com * * Also, visit our Web Site at http://www.simotime.com * * * * Generation Date: 2020-03-20 Generation Time: 16:54:52:38 * *****************************************************************
The following (CUSI80C1.cbl) is the generated COBOL program that is used to perform the file format conversion for a single file.
IDENTIFICATION DIVISION. PROGRAM-ID. CUSI80C1. AUTHOR. SIMOTIME TECHNOLOGIES. ***************************************************************** * This program was generated by SimoZAPS * * A product of SimoTime Technologies * * Our e-mail address is: helpdesk@simotime.com * * Also, visit our Web Site at http://www.simotime.com * * * * Generation Date: 2018-10-10 Generation Time: 20:28:24:10 * * * * Record Record Key * * Function Name Organization Format Max-Min Pos-Len * * PRIMARY CUST0080 SEQUENTIAL FIXED 00080 * * * * SECONDARY CUSTMAST INDEXED VARIABLE 00512 00001 * * 00012 00012 * * * * Translation Mode is ASCII to ASCII * * * ***************************************************************** ENVIRONMENT DIVISION. INPUT-OUTPUT SECTION. FILE-CONTROL. SELECT CUST0080-FILE ASSIGN TO CUST0080 ORGANIZATION IS SEQUENTIAL ACCESS MODE IS SEQUENTIAL FILE STATUS IS CUST0080-STATUS. SELECT CUSTMAST-FILE ASSIGN TO CUSTMAST ORGANIZATION IS INDEXED ACCESS MODE IS SEQUENTIAL RECORD KEY IS CUSTMAST-PKEY-00001-00012 FILE STATUS IS CUSTMAST-STATUS. ***************************************************************** DATA DIVISION. FILE SECTION. FD CUST0080-FILE DATA RECORD IS CUST0080-REC . 01 CUST0080-REC. 05 CUST0080-DATA-01 PIC X(00080). FD CUSTMAST-FILE DATA RECORD IS CUSTMAST-REC . 01 CUSTMAST-REC. 05 CUSTMAST-PKEY-00001-00012 PIC X(00012). 05 CUSTMAST-DATA-00013-00500 PIC X(00500). ***************************************************************** * This program was created with the SYSMASK1.TXT file as input. * * The SYSMASK1 provides for the sequential reading of the input * * file and the sequential writing of the output file. * * * * If the output file is indexed then the input file must be in * * sequence by the field that will be used to provide the key * * for the output file. This is a sequential load process. * * * * If the key field is not in sequence then refer to SYSMASK2 * * to provide for a random add or update of the indexed file. * * * * This program mask will have the ASCII/EBCDIC table inserted * * for use by the /TRANSLATE function of SimoZAPS. * * * * For more information or questions please contact SimoTime * * Technologies. The version control number is 16.01.01 * * * * Our e-mail address is: helpdesk@simotime.com * * Also, visit our Web Site at http://www.simotime.com * ***************************************************************** WORKING-STORAGE SECTION. 01 SIM-TITLE. 05 T1 pic X(11) value '* CUSI80C1 '. 05 T2 pic X(34) value 'Sequential, RSEQ-80 to KSEQ-512 '. 05 T3 pic X(10) value ' v16.01.01'. 05 T4 pic X(24) value ' helpdesk@simotime.com'. 01 SIM-COPYRIGHT. 05 C1 pic X(11) value '* CUSI80C1 '. 05 C2 pic X(32) value 'This Data File Convert Member wa'. 05 C3 pic X(32) value 's generated by SimoTime Technolo'. 05 C4 pic X(04) value 'gies'. 01 CUST0080-STATUS. 05 CUST0080-STATUS-L pic X. 05 CUST0080-STATUS-R pic X. 01 CUST0080-EOF pic X value 'N'. 01 CUST0080-OPEN-FLAG pic X value 'C'. 01 CUSTMAST-STATUS. 05 CUSTMAST-STATUS-L pic X. 05 CUSTMAST-STATUS-R pic X. 01 CUSTMAST-EOF pic X value 'N'. 01 CUSTMAST-OPEN-FLAG pic X value 'C'. 01 CUST0080-LRECL pic 9(5) value 00080. 01 CUSTMAST-LRECL pic 9(5) value 00512. 01 CUST0080-LRECL-MAX pic 9(5) value 00080. 01 CUSTMAST-LRECL-MAX pic 9(5) value 00512. ***************************************************************** * The following buffers are used to create a four-byte status * * code that may be displayed. * ***************************************************************** 01 IO-STATUS. 05 IO-STAT1 pic X. 05 IO-STAT2 pic X. 01 IO-STATUS-04. 05 IO-STATUS-0401 pic 9 value 0. 05 IO-STATUS-0403 pic 999 value 0. 01 TWO-BYTES-BINARY pic 9(4) BINARY. 01 TWO-BYTES-ALPHA redefines TWO-BYTES-BINARY. 05 TWO-BYTES-LEFT pic X. 05 TWO-BYTES-RIGHT pic X. ***************************************************************** * Message Buffer used by the Z-DISPLAY-MESSAGE-TEXT routine. * ***************************************************************** 01 MESSAGE-BUFFER. 05 MESSAGE-HEADER pic X(011) value '* CUSI80C1 '. 05 MESSAGE-TEXT. 10 MESSAGE-TEXT-1 pic X(068) value SPACES. 10 MESSAGE-TEXT-2 pic X(188) value SPACES. 01 MSG-LSB pic 9(5) value 267. ***************************************************************** 01 PROGRAM-NAME pic X(8) value 'CUSI80C1'. 01 INFO-STATEMENT. 05 INFO-SHORT. 10 INFO-ID pic X(8) value 'Starting'. 10 filler pic X(2) value ', '. 10 filler pic X(34) value 'Sequential, RSEQ-80 to KSEQ-512 '. 05 filler pic X(24) value ' http://www.SimoTime.com'. 01 APPL-RESULT pic S9(9) comp. 88 APPL-AOK value 0. 88 APPL-EOF value 16. 01 WRITE-FLAG pic X value 'Y'. 01 CUST0080-TOTAL. 05 CUST0080-RDR pic 9(9) value 0. 05 filler pic X(3) value ' - '. 05 filler pic X(23) value 'Line count for CUST0080'. 01 CUSTMAST-TOTAL. 05 CUSTMAST-ADD pic 9(9) value 0. 05 filler pic X(3) value ' - '. 05 filler pic X(23) value 'Line count for CUSTMAST'. ***************************************************************** PROCEDURE DIVISION. move all '*' to MESSAGE-TEXT-1 perform Z-DISPLAY-MESSAGE-TEXT move INFO-STATEMENT to MESSAGE-TEXT-1 perform Z-DISPLAY-MESSAGE-TEXT move all '*' to MESSAGE-TEXT-1 perform Z-DISPLAY-MESSAGE-TEXT perform Z-POST-COPYRIGHT perform CUST0080-OPEN perform CUSTMAST-OPEN * USRSOJ Processing not specified... perform until CUST0080-STATUS not = '00' perform CUST0080-READ if CUST0080-STATUS = '00' add 1 to CUST0080-RDR perform BUILD-OUTPUT-RECORD if WRITE-FLAG = 'Y' perform CUSTMAST-WRITE if CUSTMAST-STATUS = '00' add 1 to CUSTMAST-ADD end-if end-if end-if end-perform * USREOJ Processing not specified... move CUST0080-TOTAL to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TEXT move CUSTMAST-TOTAL to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TEXT if APPL-EOF move 'Complete' to INFO-ID else move 'ABENDING' to INFO-ID end-if move INFO-STATEMENT to MESSAGE-TEXT(1:79) perform Z-DISPLAY-MESSAGE-TEXT perform CUSTMAST-CLOSE perform CUST0080-CLOSE GOBACK. ***************************************************************** BUILD-OUTPUT-RECORD. * TransMODE is A2A... * TransINIT process... move ALL SPACES to CUSTMAST-REC * TransCOPY... move CUST0080-REC(00001:00006) to CUSTMAST-REC(00007:00006) * TransCOPY... move CUST0080-REC(00008:00015) to CUSTMAST-REC(00014:00015) * TransCOPY... move CUST0080-REC(00023:00010) to CUSTMAST-REC(00042:00010) * TransCOPY... move CUST0080-REC(00033:00024) to CUSTMAST-REC(00082:00024) * TransCOPY... move CUST0080-REC(00057:00015) to CUSTMAST-REC(00178:00015) * TransCOPY... move CUST0080-REC(00072:00003) to CUSTMAST-REC(00206:00003) * TransCOPY... move CUST0080-REC(00075:00006) to CUSTMAST-REC(00234:00006) * TransFILL... move '000000' to CUSTMAST-REC(00001:00006) * TransFILL... move X'0000250F' to CUSTMAST-REC(00300:00004) * TransFILL... move X'0000' to CUSTMAST-REC(00304:00002) * TransFILL... move '00000' to CUSTMAST-REC(00306:00005) * TransFILL... move '00000000' to CUSTMAST-REC(00311:00008) * TransFILL... move X'0000' to CUSTMAST-REC(00319:00002) * TransFILL... move '00000' to CUSTMAST-REC(00321:00005) * TransFILL... move '00000000' to CUSTMAST-REC(00326:00008) * TransFILL... move X'0000' to CUSTMAST-REC(00334:00002) * TransFILL... move '00000' to CUSTMAST-REC(00336:00005) * TransFILL... move '00000000' to CUSTMAST-REC(00341:00008) * TransFILL... move '20080124' to CUSTMAST-REC(00349:00008) * TransFILL... move '13053000' to CUSTMAST-REC(00357:00008) * TransDATE... accept CUSTMAST-REC(00349:00008) from DATE YYYYMMDD * TransTIME... accept CUSTMAST-REC(00357:00008) from TIME * TransFILL... move '000' to CUSTMAST-REC(00365:00003) exit. ***************************************************************** * I/O Routines for the INPUT File... * ***************************************************************** CUST0080-CLOSE. add 8 to ZERO giving APPL-RESULT. close CUST0080-FILE if CUST0080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'CLOSE Failure with CUST0080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TEXT move CUST0080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. *---------------------------------------------------------------* CUST0080-READ. read CUST0080-FILE if CUST0080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT else if CUST0080-STATUS = '10' add 16 to ZERO giving APPL-RESULT else add 12 to ZERO giving APPL-RESULT end-if end-if if APPL-AOK CONTINUE else if APPL-EOF move 'Y' to CUST0080-EOF else move 'READ Failure with CUST0080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TEXT move CUST0080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if end-if exit. *---------------------------------------------------------------* CUST0080-OPEN. add 8 to ZERO giving APPL-RESULT. open input CUST0080-FILE if CUST0080-STATUS = '00' subtract APPL-RESULT from APPL-RESULT move 'O' to CUST0080-OPEN-FLAG else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'OPEN Failure with CUST0080' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TEXT move CUST0080-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. ***************************************************************** * I/O Routines for the OUTPUT File... * ***************************************************************** CUSTMAST-WRITE. if CUSTMAST-OPEN-FLAG = 'C' perform CUSTMAST-OPEN end-if write CUSTMAST-REC if CUSTMAST-STATUS = '00' subtract APPL-RESULT from APPL-RESULT else if CUSTMAST-STATUS = '10' add 16 to ZERO giving APPL-RESULT else add 12 to ZERO giving APPL-RESULT end-if end-if. if APPL-AOK CONTINUE else move 'WRITE Failure with CUSTMAST' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TEXT move CUSTMAST-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. *---------------------------------------------------------------* CUSTMAST-OPEN. add 8 to ZERO giving APPL-RESULT. open OUTPUT CUSTMAST-FILE if CUSTMAST-STATUS = '00' subtract APPL-RESULT from APPL-RESULT move 'O' to CUSTMAST-OPEN-FLAG else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'OPEN Failure with CUSTMAST' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TEXT move CUSTMAST-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. *---------------------------------------------------------------* CUSTMAST-CLOSE. add 8 to ZERO giving APPL-RESULT. close CUSTMAST-FILE if CUSTMAST-STATUS = '00' subtract APPL-RESULT from APPL-RESULT move 'C' to CUSTMAST-OPEN-FLAG else add 12 to ZERO giving APPL-RESULT end-if if APPL-AOK CONTINUE else move 'CLOSE Failure with CUSTMAST' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TEXT move CUSTMAST-STATUS to IO-STATUS perform Z-DISPLAY-IO-STATUS perform Z-ABEND-PROGRAM end-if exit. ***************************************************************** * The following Z-ROUTINES provide administrative functions * * for this program. * ***************************************************************** * ABEND the program, post a message to the console and issue * * a STOP RUN. * ***************************************************************** Z-ABEND-PROGRAM. if MESSAGE-TEXT not = SPACES perform Z-DISPLAY-MESSAGE-TEXT end-if move 'PROGRAM-IS-ABENDING...' to MESSAGE-TEXT perform Z-DISPLAY-MESSAGE-TEXT add 12 to ZERO giving RETURN-CODE STOP RUN. * exit. ***************************************************************** Z-CALCULATE-MESSAGE-LSB. add 267 to ZERO giving MSG-LSB perform until MSG-LSB < 80 or MESSAGE-BUFFER(MSG-LSB:1) not = SPACE if MESSAGE-BUFFER(MSG-LSB:1) = SPACE subtract 1 from MSG-LSB end-if end-perform exit. ***************************************************************** * Display CONSOLE messages... * ***************************************************************** Z-DISPLAY-MESSAGE-TEXT. perform Z-CALCULATE-MESSAGE-LSB display MESSAGE-BUFFER(1:MSG-LSB) move all SPACES to MESSAGE-TEXT exit. ***************************************************************** * Display the file status bytes. This routine will display as * * four digits. If the full two byte file status is numeric it * * will display as 00nn. If the 1st byte is a numeric nine (9) * * the second byte will be treated as a binary number and will * * display as 9nnn. * ***************************************************************** Z-DISPLAY-IO-STATUS. if IO-STATUS not NUMERIC or IO-STAT1 = '9' move IO-STAT1 to IO-STATUS-04(1:1) subtract TWO-BYTES-BINARY from TWO-BYTES-BINARY move IO-STAT2 to TWO-BYTES-RIGHT add TWO-BYTES-BINARY to ZERO giving IO-STATUS-0403 move 'File Status is: nnnn' to MESSAGE-TEXT move IO-STATUS-04 to MESSAGE-TEXT(17:4) perform Z-DISPLAY-MESSAGE-TEXT else move '0000' to IO-STATUS-04 move IO-STATUS to IO-STATUS-04(3:2) move 'File Status is: nnnn' to MESSAGE-TEXT move IO-STATUS-04 to MESSAGE-TEXT(17:4) perform Z-DISPLAY-MESSAGE-TEXT end-if exit. ***************************************************************** Z-POST-COPYRIGHT. display SIM-TITLE display SIM-COPYRIGHT exit. ***************************************************************** * This program was generated by SimoZAPS * * A product of SimoTime Technologies * * Our e-mail address is: helpdesk@simotime.com * * Also, visit our Web Site at http://www.simotime.com * * * * Generation Date: 2018-10-10 Generation Time: 20:28:24:13 * *****************************************************************
This section describes the command files that are used or called from other command files to perform various system or sub-system oriented tasks. For example, setting the commonly used environment variables in a single, callable command simplifies the process and makes it easier to adjust if the environment changes.
Explore How to use Common or Shared Routines that perform repetitive tasks in a consistent manner. This link will provide information about setting common environment variables and many other utilitarian tasks.
The following (ENV1BASE.cmd) is the Windows Command file that is used to set the environment variables that are commonly used across the application.
@echo OFF rem * ******************************************************************* rem * ENV1BASE.cmd - a Windows Command File * rem * This program is provided by SimoTime Technologies * rem * (C) Copyright 1987-2021 All Rights Reserved * rem * Web Site URL: http://www.simotime.com * rem * e-mail: helpdesk@simotime.com * rem * ******************************************************************* rem * rem * Text - Provide a single point to set common environment variables. rem * Author - SimoTime Technologies rem * Date - January 24, 1996 rem * rem * Set the commonly used environment variables. This is used to provide rem * a single point for managing the commonly used environment variables. rem * set SimoLIBR=c:\SimoLIBR set BASELIB1=c:\SIMOSAM1\DEVL set BASELIB8=c:\SimoSAM8 set BaseWIP1=c:\SimoSAM1\WIP1 set DATAZERO=c:\SIMODATA\DEVL\DATA\ZERO set BASEAPP=%BaseLib1% set BASESYS=%BaseLib1%\SYS1 set BASECAT=%BaseLib1%\DATA set UMAPALIB=%BASECAT%\ASC1 set UMAPELIB=%BASECAT%\EBC1 set SYSLOG=%BASESYS%\LOGS\SYSLOG_USER.DAT set SYSOUT=%BASEAPP%\LOGS\SYSOUT_SIMSAM01.txt set SLZMSG=%BASEAPP%\LOGS\SLZMSG_USER.TXT set PostNOTE=%BASEAPP%\LOGS\JOBLOG_SIMONOTE.TXT set SIMONOTE=%BASEAPP%\LOGS\JOBLOG_SIMONOTE.txt set USERPOST=%BASEAPP%\LOGS\ASSIGNED_USER_POST_FILE.txt if [%1]==[] goto NO_POST set SYSOUT=%BaseLib1%\LOGS\SYSOUT_%1.txt call SIMONOTE "+ ENV1BASE *" call SIMONOTE "+ ENV1BASE ********************************************************************%1" call SIMONOTE "+ ENV1BASE is preparing the System Environment..." call SIMONOTE "+ SIMOLIBR is %SIMOLIBR%" call SIMONOTE "+ MIFOSYS1 is %MIFOSYS1%" call SIMONOTE "+ BASELIB1 is %BASELIB1%" :NO_POST call SIMONOTE "+ SIMONOTE Job Log File is %SIMONOTE% " rem * set MQBASE=C:\Program Files\IBM\WebSphere MQ rem * rem * Set the location for the Apache-Tomcat Server... set CATALINA_HOME=C:\APACHETC\apache-tomcat-7.0.52 rem set CATALINA_HOME=C:\Program Files (x86)\Java\jdk1.8.0_112 rem * rem * Set the Environment for the Java Environment... rem set JAVABASE=C:\APACHETC\apache-tomcat-7.0.52 set JAVABASE=C:\Program Files (x86)\Java\jdk1.8.0_112 set JAVASDK="%JAVABASE%\bin" set JAVA_HOME=%JAVABASE% set JRE_HOME=%JAVABASE% set SIMOTCAT=%CATALINA_HOME%\webapps\simotcat set SIMPACKS=%CATALINA_HOME%\webapps\simotcat\WEB-INF\classes\simpacks rem * rem * Set the environment for the Micro Focus technology... set MIFOEDEV=C:\Program Files (x86)\Micro Focus\Enterprise Developer set MIFOVCBL=C:\Program Files (x86)\Micro Focus\Visual COBOL Build Tools set MIFOESTU=C:\Program Files (x86)\Micro Focus\Studio Enterprise Edition 6.0 set MIFOEMFE="C:\Program Files (x86)\Micro Focus\Mainframe Express" rem * rem * Large file support, performance tuning and record locking of the File Handler set EXTFH=%BASESYS%\CONFIG\EXTFHBIG.CFG rem * rem * For IMS Support set ES_IMSLIB=%BASEAPP%\IMSLIB set ES_ACBLIB=%BASEAPP%\IMSLIB rem * rem * EZASOKETS Check EZASOKETS Enabled box or set ES_EZASOKET_SUPPORT=YES set EZACONFG=BASESYS1\CONFIG\EZACONFG.dat rem * rem * Resource Allocation and Performance for SORT and non-Relational Data rem set MFJSENGINE=SYNCSORT set SORTSCHEME=1 set SORTSPACE=750000000 set TMP=C:\SORTWORK rem * set ES_ALLOC_OVERRIDE=%BASESYS%\CONFIG\CATMAPA1.cfg rem * For CORE_ON_ERROR function, ABEND Dump rem * set COBCONFIG_=%BASESYS%\CONFIG\diagnose.cfg rem * rem * Consolidated Trace Facility (CTF) rem * set MFTRACE_CONFIG=%BASESYS%\CONFIG\ctf.cfg rem * set MFTRACE_LOGS=c:\ctflogs rem * rem * For Job Restart, ABEND Recovery set MF_UCC11=Y set ES_JES_RESTART=Y rem * rem * Set environment for MFBSI (Micro Focus Batch Scheduling Interface) set ES_EMP_EXIT_1=mfbsiemx set MFBSI_DIR=%BASESYS%\LOGS\%JESSERVERNAME% set MFBSIEOP_CMD=ENABLE set MFBSIEOP_CSV=ENABLE set MFBSIEOP_HTM=ENABLE set MFBSIEOP_XML=ENABLE rem * rem * Set Behavior and Trace Flags for GETJOBDD rem * Position=12345678/12345678 set JDDFLAGS=nnnWnnnn/YYnnnnnn rem * rem * If not already set then set the PATH for Micro Focus Directories if "%SIMOPATH%" == "Y" goto JUMPPATH if "%MIFOSYS1%" == "EDEV" goto JUMPEDEV if "%MIFOSYS1%" == "VCBL" goto JUMPVCBL if "%MIFOSYS1%" == "ESTU" goto JUMPESTU if "%MIFOSYS1%" == "EMFE" goto JUMPEMFE :JUMPEDEV set path=%BASESYS%\LOADLIB;%MIFOEDEV%\bin;%JAVASDK%;%BASEAPP%\JAVA;%PATH%; set CobCpy=%BASEAPP%\CobCpy1;%BASEAPP%\CobCpy2;%BASEAPP%\CobCpy6;%SimoLIBR%;%MIFOEDEV%\CPYLIB set MIFOBASE=%MIFOEDEV% goto JUMPPATH :JUMPVCBL set path=%MIFOVCBL%\bin;%MIFOVCBL%;%JAVASDK%;%BASEAPP%\JAVA;%PATH%; set MIFOBASE=%MIFOVCBL% goto JUMPPATH :JUMPESTU set MIFOBASE=%MIFOESTU%\Base set MIFOBIN=%MIFOBASE%\bin set path=%BASESYS%\LOADLIB;%MIFOBASE%;%MIFOBIN%;%JAVASDK%;%BASEAPP%\JAVA;%PATH%; set CobCpy=%BASEAPP%\CobCpy1;%BASEAPP%\CobCpy2;%BASEAPP%\CobCpy6;%SimoLIBR%;%MIFOBASE%\SOURCE goto JUMPPATH :JUMPEMFE set MIFOBASE=%MIFOEMFE%\Base set MIFOBIN=%MIFOBASE%\bin set path=%BASESYS%\LOADLIB;%MIFOBASE%;%MIFOBIN%;%JAVASDK%;%BASEAPP%\JAVA;%PATH%; set CobCpy=%BASEAPP%\CobCpy1;%BASEAPP%\CobCpy2;%BASEAPP%\CobCpy6;%SimoLIBR%;%MIFOBASE%\SOURCE goto JUMPPATH rem * :JUMPPATH set SIMOPATH=Y rem * set MAINFRAME_FLOATING_POINT=true set COBIDY=%BASEAPP%\COBIDY set COBPATH=.;%BASEAPP%\LOADLIB;%BASEAPP%\LOADLIB\GNTS;%BASESYS%\LOADLIB;%SimoLIBR% set LIBPATH=.;%BASEAPP%\LOADLIB;%BASEAPP%\LOADLIB\GNTS;%BASESYS%\LOADLIB;%SimoLIBR% set TXDIR=%BASESYS%\LOADLIB;%MIFOBASE% set CobCpy=%BASEAPP%\CobCpy1;%BASEAPP%\CobCpy2;%BASEAPP%\CobCpy6;%SimoLIBR% rem * set USERCLASS=%BASELIB1%\LOADLIB set CLASSPATH=. set CLASSPATH=%CLASSPATH%;%JAVABASE% set CLASSPATH=%CLASSPATH%;%JAVABASE%\lib set CLASSPATH=%CLASSPATH%;\%USERCLASS%\simpacks set CLASSPATH=%CLASSPATH%;C:\APACHETC\apache-tomcat-7.0.52\webapps\simotcat\WEB-INF\classes set CLASSPATH=%CLASSPATH%;C:\APACHETC\apache-tomcat-7.0.52\webapps\simotcat\WEB-INF\classes\simpacks rem * if "%MIFOSYS1%" == "ESTU" set CLASSPATH=%CLASSPATH%;%MIFOBIN% if "%MIFOSYS1%" == "EDEV" set CLASSPATH=%CLASSPATH%;%MIFOEDEV% if "%MIFOSYS1%" == "VCBL" set CLASSPATH=%CLASSPATH%;%MIFOVCBL% if "%MIFOSYS1%" == "VCBL" set CLASSPATH=%CLASSPATH%;%MIFOVCBL%\bin\mfcobol.jar rem * set JobStatus=0000 call SIMONOTE "+ ENV1BASE is returning to caller"
The following (SIMONOTE.cmd) is typically called from other command files to display a message to the screen and write the message to a log file with a time stamp.
@echo OFF rem * ******************************************************************* rem * SIMONOTE.cmd - a Windows Command File * rem * This program is provided by SimoTime Technologies * rem * (C) Copyright 1987-2019 All Rights Reserved * rem * Web Site URL: http://www.simotime.com * rem * e-mail: helpdesk@simotime.com * rem * ******************************************************************* rem * rem * Text - Display message on screen and write to a log file. rem * Author - SimoTime Technologies rem * rem * This script may be called from other scripts and expects a single rem * parameter enclosed in double quotes. The double quotes will be rem * removed. Before writing to the log file a date and time stamp rem * will be inserted in front of the message text. rem * rem * Note: The tilde (~) removes leading/trailing double-quotes. rem * if "%SimoNOTE%" == "" set SimoNOTE=c:\SimoLIBR\LOGS\SimoTime.LOG echo %date% %time% %~1>> %SimoNOTE% echo %~1
This suite of sample programs will show an approach to the task of File format conversion between Line Sequential and Record Sequential files. This document ,a be used as a tutorial for new programmers or as a quick reference for experienced programmers.
In the world of programming there are many ways to solve a problem. This documentation and software were developed and tested on systems that are configured for a SIMOTIME environment based on the hardware, operating systems, user requirements and security requirements. Therefore, adjustments may be needed to execute the jobs and programs when transferred to a system of a different architecture or configuration.
SIMOTIME Services has experience in moving or sharing data or application processing across a variety of systems. For additional information about SIMOTIME Services or Technologies please contact us using the information in the Contact or Feedback section of this document.
Software Agreement and Disclaimer
Permission to use, copy, modify and distribute this software, documentation or training material for any purpose requires a fee to be paid to SimoTime Technologies. Once the fee is received by SimoTime the latest version of the software, documentation or training material will be delivered and a license will be granted for use within an enterprise, provided the SimoTime copyright notice appear on all copies of the software. The SimoTime name or Logo may not be used in any advertising or publicity pertaining to the use of the software without the written permission of SimoTime Technologies.
SimoTime Technologies makes no warranty or representations about the suitability of the software, documentation or learning material for any purpose. It is provided "AS IS" without any expressed or implied warranty, including the implied warranties of merchantability, fitness for a particular purpose and non-infringement. SimoTime Technologies shall not be liable for any direct, indirect, special or consequential damages resulting from the loss of use, data or projects, whether in an action of contract or tort, arising out of or in connection with the use or performance of this software, documentation or training material.
This section includes links to documents with additional information that are beyond the scope and purpose of this document. The first group of documents may be available from a local system or via an internet connection, the second group of documents will require an internet connection.
Note: A SimoTime License is required for the items to be made available on a local system or server.
The following links may be to the current server or to the Internet.
Note: The latest versions of the SimoTime Documents and Program Suites are available on the Internet and may be accessed using the icon. If a user has a SimoTime Enterprise License the Documents and Program Suites may be available on a local server and accessed using the icon.
Explore An Enterprise System Model that describes and demonstrates how Applications that were running on a Mainframe System and non-relational data that was located on the Mainframe System were copied and deployed in a Microsoft Windows environment with Micro Focus Enterprise Server.
Explore the COBOL Connection for more examples of COBOL programming techniques and sample code.
Explore an Extended List of Software Technologies that are available for review and evaluation. The software technologies (or Z-Packs) provide individual programming examples, documentation and test data files in a single package. The Z-Packs are usually in zip format to reduce the amount of time to download.
Explore The ASCII and EBCDIC Translation Tables. These tables are provided for individuals that need to better understand the bit structures and differences of the encoding formats.
Explore The File Status Return Codes that are used to interpret the results of accessing VSAM data sets and/or QSAM files.
The following links will require an internet connect.
This suite of programs and documentation is available for download. Link to an Evaluation zPAK Option that includes the program members, documentation and control files.
A good place to start is The SimoTime Home Page for access to white papers, program examples and product information. This link requires an Internet Connection
Explore The Micro Focus Web Site for more information about products (including Micro Focus COBOL) and services available from Micro Focus. This link requires an Internet Connection.
Explore the Glossary of Terms for a list of terms and definitions used in this suite of documents and white papers.
This document was created and is maintained by SimoTime Technologies. If you have any questions, suggestions, comments or feedback please use the following contact information.
1. | Send an e-mail to our helpdesk. |
1.1. | helpdesk@simotime.com. |
2. | Our telephone numbers are as follows. |
2.1. | 1 415 763-9430 office-helpdesk |
2.2. | 1 415 827-7045 mobile |
We appreciate hearing from you.
SimoTime Technologies was founded in 1987 and is a privately owned company. We specialize in the creation and deployment of business applications using new or existing technologies and services. We have a team of individuals that understand the broad range of technologies being used in today's environments. Our customers include small businesses using Internet technologies to corporations using very large mainframe systems.
Quite often, to reach larger markets or provide a higher level of service to existing customers it requires the newer Internet technologies to work in a complementary manner with existing corporate mainframe systems. We specialize in preparing applications and the associated data that are currently residing on a single platform to be distributed across a variety of platforms.
Preparing the application programs will require the transfer of source members that will be compiled and deployed on the target platform. The data will need to be transferred between the systems and may need to be converted and validated at various stages within the process. SimoTime has the technology, services and experience to assist in the application and data management tasks involved with doing business in a multi-system environment.
Whether you want to use the Internet to expand into new market segments or as a delivery vehicle for existing business functions simply give us a call or check the web site at http://www.simotime.com
Return-to-Top |
Data File Format and Record Content Conversion |
Copyright © 1987-2025 SimoTime Technologies and Services All Rights Reserved |
When technology complements business |
http://www.simotime.com |