CICS - Guide rapide

CICS est un système DB / DC utilisé dans les applications en ligne. CICS a été développé parce que le système d'exploitation par lots ne peut exécuter que des programmes par lots. Les programmes CICS peuvent être écrits en COBOL, C, C ++, Java, etc. De nos jours, les utilisateurs veulent des informations en quelques secondes et en temps réel. Pour fournir un service aussi rapide, nous avons besoin d'un système capable de traiter les informations en ligne. CICS permet aux utilisateurs de communiquer avec le système dorsal pour obtenir les informations souhaitées. Des exemples de programmes en ligne incluent le système bancaire en ligne, la réservation de vol, etc. L'image suivante montre les composants de CICS et comment ils sont interdépendants -

Fonctions de CICS

Les principales fonctions exécutées par CICS dans une application sont les suivantes:

  • CICS gère les demandes d'utilisateurs simultanés dans une application.

  • Bien que plusieurs utilisateurs travaillent sur le système CICS, cela donne l'impression à l'utilisateur qu'il est le seul utilisateur.

  • CICS donne accès aux fichiers de données pour les lire ou les mettre à jour dans une application.

Caractéristiques de CICS

Les fonctionnalités de CICS sont les suivantes -

  • CICS est un système d'exploitation en lui-même, car il gère son propre stockage de processeur, possède son propre gestionnaire de tâches qui gère l'exécution de plusieurs programmes et fournit ses propres fonctions de gestion de fichiers.

  • CICS fournit un environnement en ligne dans un système d'exploitation par lots. Les travaux soumis sont exécutés immédiatement.

  • CICS est une interface de traitement de transaction généralisée.

  • Il est possible d'avoir deux régions CICS ou plus en même temps, car CICS s'exécute en tant que travail par lots dans le système d'exploitation du back-end.

CICS lui-même agit comme un système d'exploitation. Son travail est de fournir un environnement pour l'exécution en ligne des programmes d'application. CICS s'exécute dans une région ou une partition ou un espace d'adressage. CICS gère la planification des programmes exécutés en dessous. CICS s'exécute comme un travail par lots et nous pouvons l'afficher dans le spool en émettant la commande PREFIX CICS *. Il existe cinq services principaux fournis par le SCIC. Tous ces services exécutent ensemble une tâche.

Environnement CICS

Voici les services dont nous discuterons en détail étape par étape -

  • Services système
  • Services de communication de données
  • Services de traitement des données
  • Services de programmation d'applications
  • Services de surveillance
  • Services système

CICS maintient des fonctions de contrôle pour gérer l'allocation ou la désaffectation des ressources au sein du système qui sont les suivantes:

  • Task Control- Le contrôle des tâches fournit des fonctionnalités de planification des tâches et de multitâche. Il prend en charge l'état de toutes les tâches CICS. Le contrôle des tâches alloue le temps processeur entre les tâches CICS simultanées. C'est appelémultitasking. CICS essaie de prioriser le temps de réponse à la tâche la plus importante.

  • Program Control- Program Control gère le chargement et la libération des programmes d'application. Dès qu'une tâche commence, il devient nécessaire d'associer la tâche au programme d'application approprié. Bien que de nombreuses tâches puissent nécessiter l'utilisation du même programme d'application, CICS ne charge qu'une seule copie du code en mémoire. Chaque tâche parcourt ce code indépendamment, de sorte que de nombreux utilisateurs peuvent tous exécuter des transactions qui utilisent simultanément la même copie physique d'un programme d'application.

  • Storage Control- Le contrôle du stockage gère l'acquisition et la libération du stockage principal. Le contrôle du stockage acquiert, contrôle et libère le stockage dynamique. Le stockage dynamique est utilisé pour les zones d'entrée / sortie, les programmes, etc.

  • Interval Control - Le contrôle d'intervalle offre des services de minuterie.

Services de communication de données

Les services de communication de données s'interfacent avec des méthodes d'accès aux télécommunications telles que BTAM, VTAM et TCAM pour traiter les demandes de communication de données provenant de programmes d'application.

  • CICS libère les programmes d'application du fardeau de traiter les problèmes matériels des terminaux grâce à l'utilisation de Basic Mapping Support (BMS).

  • CICS fournit une opération multirégionale (MRO) à travers laquelle plusieurs régions CICS du même système peuvent communiquer.

  • CICS fournit une communication inter-système (ISC) à travers laquelle une région CICS d'un système peut communiquer avec la région CICS d'un autre système.

Services de traitement des données

L'interface des services de traitement des données avec des méthodes d'accès aux données telles que BDAM, VSAM, etc.

  • CICS facilite le traitement des demandes de traitement des données des programmes d'application. CICS fournit aux programmeurs d'applications un ensemble de commandes permettant de gérer l'accès à l'ensemble de données et à la base de données et les opérations associées.

  • Les services de traitement des données s'interfacent avec les méthodes d'accès aux bases de données telles que IMS / DB, DB2, etc. et facilitent le traitement des demandes de base de données des programmes d'application.

  • CICS facilite la gestion de l'intégrité des données en contrôlant les mises à jour simultanées des enregistrements, la protection des données en tant que tâches ABEND et la protection des données en cas de défaillance du système.

Services de programmation d'applications

Interface des services de programmation d'application avec les programmes d'application. Les services de programmation d'application de CICS fournissent des fonctionnalités telles que la traduction de niveau de commande, CEDF (la fonction de débogage) et CECI (la fonction d'interprétation de commande). Nous en discuterons plus en détail dans les prochains modules.

Services de surveillance

Les services de surveillance surveillent divers événements dans l'espace d'adressage CICS. Il fournit une série d'informations statistiques qui peuvent être utilisées pour le réglage du système.

Nous devons connaître les termes de base utilisés dans CICS pour mieux comprendre son fonctionnement. Les programmes d'application utilisent CICS pour la communication avec les terminaux et sous-systèmes distants et locaux.

IBM 3270 Terminal

Le système d'affichage d'informations 3270 est une famille de terminaux d'affichage et d'imprimante. 3270 terminaux étaient utilisés pour se connecter au mainframe via des contrôleurs IBM. Aujourd'hui, le logiciel d'émulation 3270 est disponible, ce qui signifie que même les PC normaux peuvent être utilisés comme terminaux 3270. Les terminaux 3270 sont des terminaux stupides et n'effectuent aucun traitement eux-mêmes. Tout le traitement doit être effectué par le programme d'application. Les terminaux IBM se composent des composants suivants -

Moniteur CRT

Le moniteur CRT affiche la sortie ou les champs d'entrée du programme d'application. Une capture d'écran d'un modèle 3278 de moniteur CRT est présentée ci-dessous. Il présente les caractéristiques suivantes -

  • Il est capable d'afficher 1920 caractères.

  • Chacune de ces 1920 positions de caractères est adressable individuellement.

  • Un programme d'application COBOL peut envoyer des données à toutes les positions de l'écran.

  • Les caractéristiques d'affichage telles que l'intensité, protégée, non protégée du champ peuvent être définies à l'aide de BMS dont nous parlerons en détail dans les prochains modules.

Clavier

Les touches du clavier IBM sont divisées en deux catégories suivantes:

  • Non-AID Keys- Toutes les autres touches pour les alphabets, les chiffres, la ponctuation, etc. sont des touches sans aide. Lorsque l'utilisateur saisit du texte ou des nombres à l'aide de touches non d'aide, CICS ne saura même pas si l'utilisateur saisit quelque chose ou non.

  • AID Keys- Les clés AID sont appelées clés d'identification d'attention. CICS ne peut détecter que les clés AID. Après avoir tapé toutes les entrées, uniquement lorsque l'utilisateur appuie sur l'une des touches AID, CICS prend le contrôle. Touches AID: ENTER, PF1 à PF24, PA1 à PA3, CLEAR. Les clés AID sont divisées en deux catégories -

    • PF Keys- Les touches PF sont appelées touches de fonction. Les touches PF permettent le transfert de données du terminal vers CICS. Les touches PF sont ENTER et PF1 à PF24.

    • PA Keys- Les touches PA sont appelées touches d'accès au programme. Les clés PA ne permettent pas le transfert de données entre le terminal et CICS. Les touches PA sont PA1 à PA3 et CLEAR.

    Transaction

    Un programme CICS est appelé via une transaction. Une transaction CICS est un ensemble de programmes liés logiquement dans une application. L'ensemble de l'application peut être logiquement divisé en plusieurs transactions.

    • Les identifiants de transaction de 1 à 4 caractères sont utilisés pour identifier les transactions que les utilisateurs souhaitent effectuer.

    • Un programmeur lie un programme à l'identificateur de transaction qui est utilisé pour appeler tous les programmes d'application pour cette transaction particulière.

    Tâche

    Une Tâche est une unité de travail spécifique à un utilisateur.

    • Les utilisateurs appellent une application à l'aide de l'un des identificateurs de transaction. CICS recherche l'identificateur de transaction pour savoir quel programme appeler en premier pour effectuer le travail demandé. Il crée une tâche pour effectuer le travail et transfère le contrôle au programme mentionné.

    • Une transaction peut être complétée par plusieurs tâches.

    • Une tâche peut recevoir et envoyer des données au terminal qui l'a démarrée. Il peut lire et écrire des fichiers et peut également démarrer d'autres tâches.

    Tâche vs transaction

    La différence entre une transaction et une tâche est que plusieurs utilisateurs peuvent invoquer une transaction mais chaque utilisateur lance sa propre tâche.

    LUW

    LUW signifie unité logique de travail. LUW déclare qu'un travail doit être effectué complètement ou pas du tout. Une tâche peut contenir plusieurs unités logiques d'oeuvres dans CICS. Nous en discuterons plus dans les prochains modules.

    Application

    Une application est une série de programmes regroupés de manière logique pour former plusieurs transactions qui sont utilisées pour accomplir une tâche spécifique pour l'utilisateur final.

    Les cinq composants système CICS décrits précédemment constituent un regroupement pratique de programmes système CICS, chacun remplissant ses propres fonctions spécialisées. Le noyau de CICS connu sous le nom de CICS Nucleus, qui se compose de programmes de contrôle et de tables de contrôle CICS fournis par IBM.

    Programmes de contrôle

    Le noyau CICS est construit par les programmes de contrôle et les tables de contrôle correspondantes. Il offre des avantages uniques. Cela rend le système CICS extrêmement flexible et donc facile à entretenir. Voici les programmes de contrôle importants de CICS -

    TCP

    TCP is known as Terminal Control Program.

    • TCP is used to receive messages from the terminal.

    • It maintains hardware communication requirements.

    • It requests CICS to initiate the tasks.

    KCP

    KCP is known as Task Control Program.

    • KCP is used to simultaneously control the execution of tasks and its related properties.

    • It handles all the issues related to multi-tasking.

    PCP

    PCP is known as Program Control Program.

    • PCP is used to locate and load programs for execution.

    • It transfers the control between programs and in the end, it returns the control back to the CICS.

    FCP

    FCP is known as File Control Program.

    • FCP is used to provide application programs with services like read, insert, update or delete records in a file.

    • It keeps exclusive control over the records in order to maintain data integrity during record updates.

    SCP

    SCP is known as Storage Control Program. It is used to control allocation and deallocation of storage within a CICS region.

    Control Tables

    CICS consists of IBM-supplied CICS control programs and tables. These tables need to be updated accordingly with the application information for successful execution of CICS application programs. Following are the important Control Tables −

    TCT

    TCT is known as Terminal Control Table.

    • When we login to a CICS terminal, an entry is made in the TCT table.

    • TCT contains the terminal ID's that are connected to current CICS region.

    • Terminal Control Program along with terminal control table recognize the incoming data from the terminal.

    PCT

    PCT is known as Program Control Table.

    • It contains the Transaction IDs (TRANSID) and the corresponding program names or program IDs.

    • TRANSID is unique in PCT table.

    PPT

    PPT is known as Processing Program Table. PPT contains Program name or Mapset name, Task Use Counter, Language, Size, Main storage address, Load library address, etc.

    • Program or Mapset name is unique in a PPT table.

    • CICS receives the transaction and a corresponding program name is allocated to the transaction from the PCT. It checks if the program is loaded or not. If it is loaded, then the task use counter is increased by 1. If the program is not loaded, then the program is first loaded and the task use counter is set to 1. It gets the load library address from the PPT table.

    FCT

    FCT is known as File Control Table.

    • It contains File names, File type, record length, etc.

    • All the files used in a CICS program must be declared in FCT and they are opened and closed by CICS itself.

    Transaction

    When a transaction identifier TP02 is entered on the CICS terminal, first it checks if there is a program associated with this Transaction identifier in the PCT table. If it finds one, then it checks in the PPT table to find the location of the Program to execute it.

    If the program is already available in the memory, it starts executing that particular program; if not, it loads the program to the memory from the secondary storage and then starts executing it.

    Transaction Life Cycle

    The transaction life cycle has the following steps −

    Step 1

    The terminal operator initiates the transaction by typing a 1 to 4 character transaction-id and pressing the ENTER key.

    Step 2

    The TCP periodically checks all the terminals for input. When a message is received, it does the following −

    • Instructs the SCP to create a TIOA.

    • Places the message in the TIOA.

    • Passes the control to the KCP.

    Step 3

    The KCP takes control from the TCP and does the following −

    • Validates the transaction-id and security.

    • Instructs the SCP to create a task control area.

    • Assigns priority to the task based on Terminal priority (Set in TCT), Operator priority (Set in SNT), and Transaction priority (Set in PCT).

    • Adds the task to the queue of waiting programs.

    • Dispatches waiting programs in the order of priority.

    • Passes the control to the PCP.

    Step 4

    The PCP takes control from the KCP and does the following −

    • Locates the program and loads it, if necessary.

    • Transfers the control to the Application program.

    Step 5

    The Application program takes control from the PCP and does the following −

    • Requests the TCP to place the message into the program’s WORKING STORAGE area.

    • Requests the FCP to retrieve records from the files.

    Step 6

    The FCP takes control from the Application program and does the following −

    • Requests a File work area from the SCP.

    • Informs the KCP that this task can wait until the I/O is complete.

    Step 7

    The KCP does the following −

    • Dispatches the next task in the queue.

    • Re-dispatches the old task when I/O is complete.

    • Transfers the control to the FCP.

    Step 8

    The FCP returns control to the Application program.

    Step 9

    The Application program does the following −

    • Processes the file data.

    • Requests TCP to send an I/O message.

    • Returns control to the PCP.

    Step 10

    The PCP returns the control back to the KCP requesting it to end the task.

    Step 11

    The KCP instructs the SCP to free all the storage allocated to the task (except TIOA).

    Step 12

    The TCP does the following −

    • Sends the output to the terminal.

    • Requests the SCP to release the TIOA.

    CICS transactions are used to perform multiple operations in the CICS region. We will be discussing the important CICS transactions supplied by IBM in detail.

    CESN

    CESN is known as CICS Execute Sign On.

    • CESN is used to Sign on to the CICS region.

    • We need to provide the User-Id and Password given by the CICS administrator to log on to CICS. The following screenshot shows how the sign-on screen looks like −

    CEDA

    CEDA is known as CICS Execute Definition and Administration. It is used by CICS System Administrators to define CICS table entries and other administration activities.

    CEMT

    CEMT is known as CICS Execute Master Terminal. It is used to inquire and update the status of CICS environments and also for other system operations.

    • Using CEMT command, we can manage transactions, tasks, files, programs, etc.

    • To get all the possible options, type CEMT and press ENTER. It will display all the options.

    • CEMT is basically used for loading a new program into the CICS or for loading a new copy of the program into the CICS after the program or mapset is changed.

    Example

    One can overwrite the status of the file displayed to change it. Following example shows how to close a file −

    CEMT 
      
    ** Press ENTER & Following Screen is displayed **  
    
    STATUS: ENTER ONE OF THE FOLLOWING 
    Inquire 
    Perform 
    Set 
     
    ** Command to close a file **
      
    CEMT SET FILE (file-name) 
    CEMT I FILE (file-name)

    CECI

    CECI is known as CICS Execute Command Interpreter. Many CICS commands can be executed using CECI.

    • CECI is used to check the syntax of the command. It executes the command, only if the syntax is correct.

    • Type the CECI option on the empty CICS screen after having logged in. It gives you the list of options available.

    Example

    Following example shows how to send mapped output data to terminal. We will be discussing about MAPS in the upcoming modules.

    CECI SEND MAP (map-name) MAPSET (mapset-name) ERASE

    CEDF

    CEDF is known as CICS Execute Debug Facility. It is used for debugging the program step by step, which helps in finding the errors.

    Type CEDF and press enter in the CICS region. The terminal is in EDF mode message will be displayed. Now type the transaction id and press the enter key. After initiation, with each enter key, a line is executed. Before executing any CICS command, it shows the screen in which we can modify the values before proceeding further.

    CMAC

    CMAC is known as CICS Messages for Abend Codes. It is used to find the explanation and reasons for CICS Abend Codes.

    Example

    Following example shows how to check details for an Abend code −

    CMAC abend-code

    CESF

    CESF is known as CICS Execute Sign Off. It is used to Sign Off from the CICS region.

    Example

    Following example shows how to log off from the CICS region −

    CESF LOGOFF

    CEBR

    CEBR is known as CICS Execute Temporary storage Browse. It is used to display contents of a temporary storage queue or TSQ.

    CEBR is used while debugging to check if the items of the queue are being written and retrieved properly. We will discuss more about TSQ in the upcoming modules.

    Example

    Following example shows how to invoke the CEBR command −

    CEBR queue-id

    CICS Concepts

    Each command could be achieved by executing a series of CICS macros. We will discuss some basic features which will help us understand the concepts better −

    Multitasking

    This feature of operating system allows more than one task to be executed concurrently. The task may be sharing the same program or using different programs. The CICS schedules the task in its own region.

    Multi-threading

    This feature of the operating system allows more than one task to be executed concurrently sharing the same program. For multi-threading to be possible, an application program should be a re-entrant program under the operating system or a quasi-reentrant under the CICS.

    Re-entrancy

    A re-entrant program is one which does not modify itself and can re-enter in itself and continue processing after an interruption by the operating system.

    Quasi-reentrancy

    A quasi-reentrant program is a re-entrant program under CICS environment. CICS ensures re-entrancy by acquiring a unique storage area for each task. Between CICS commands, the CICS has the exclusive right to use the CPU resources and it can execute other CICS commands of other tasks.

    There are times when many users are concurrently using the same program; this is what we call multi-threading. For example, let’s suppose 50 users are using a program A. Here the CICS will provide 50 working storage for that program but one Procedure Division. And this technique is known as quasi-reentrancy.

    CICS programs are written in COBOL language in Mainframes. We will be discussing about writing a simple COBOL-CICS program, compiling it, and then executing it.

    CICS Program

    We will be writing a simple COBOL-CICS program which displays some message on the CICS output screen. This program is to demonstrate the steps involved in executing a COBOL-CICS program. Following are the steps to code a simple program −

    Step 1

    Login to Mainframes and open a TSO Session.

    Step 2

    Create a new PDS in which we will be coding our program.

    Step 3

    Create a new member inside the PDS and code the following program −

    IDENTIFICATION DIVISION.
    PROGRAM-ID. HELLO.
    DATA DIVISION.
    FILE SECTION.
    WORKING-STORAGE SECTION.
    01 WS-MESSAGE PIC X(40).
    01 WS-LENGTH  PIC S9(4) COMP.
    PROCEDURE DIVISION.
    A000-MAIN-PARA.
       MOVE 'Hello World' TO WS-MESSAGE
       MOVE '+12' TO WS-LENGTH
       EXEC CICS SEND TEXT 
          FROM (WS-MESSAGE)
          LENGHT(WS-LENGTH)  
       END-EXEC
       EXEC CICS RETURN
       END-EXEC.

    Step 4

    After coding the program, we need to compile it. We can compile the program using the following JCL −

    //SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C  
    //CICSCOB  EXEC CICSCOB,                                                
    //COPYLIB = ABC.XYZ.COPYLIB,                            
    //LOADLIB = ABC.XYZ.LOADLIB 
    //LIB        JCLLIB ORDER = CICSXXX.CICS.XXXPROC                
    //CPLSTP     EXEC DFHEITVL                                
    //TRN.SYSIN  DD DSN = ABC.XYZ.PDS(HELLO),DISP = SHR     
    //LKED.SYSIN DD *                                        
       NAME HELLO(R)                                          
    //

    Step 5

    Open a CICS session.

    Step 6

    We will now install the program using the following command −

    CEMT SET PROG(HELLO) NEW.

    Step 7

    Execute the program using the associated transaction-id. Transaction-id is provided by the Administrator. It will show the following output −

    Program Compilation

    The following flowchart shows the steps used in compiling a COBOL-CICS program −

    Translator

    The function of a translator is to check for syntax errors in CICS commands. It translates them into equivalent COBOL statements.

    Compiler

    The function of a compiler is to expand the COBOL copy books. It compiles the code after checking the source code for syntax errors.

    Linkage Editor

    The function of a Linkage Editor is to link different object modules to create a single load module.

    BMS is known as Basic Mapping Support. An application consists of formatted screens which act as a bridge between the terminal and the CICS programs. For communication to occur between the terminal and the CICS programs, we use CICS terminal input/output services. We use BMS to create screen designs with proper positions and attributes. Following are the functions of BMS −

    • BMS acts as an interface between the terminal and the CICS programs.

    • The design and format of the screen is separate from the logic of application.

    • BMS makes the application hardware independent.

    Formatted Screen

    The screen shown below is a Menu Screen and can be designed using BMS. Its key points are as follows −

    • The screen could have a Title, date, and any other information that is to be displayed.

    • The Option 1, 2, and 3 are the Unnamed fields which are the titles of the screen.

    • In the Selection field, we need to provide the input. This input is then sent to the CICS program for further processing.

    • At the bottom of the screen, Action keys are displayed.

    • All the fields and the screen itself is defined with BMS macros. When the whole map is defined, we can use JCL to assemble it.

    BMS Basic Terms

    Following are the basic terms which we will be using in the upcoming modules −

    Map

    Map is a single screen format which can be designed using BMS macros. It can have names containing 1 to 7 chars.

    Mapset

    Mapset is a collection of maps which are linked together to form a load module. It should have a PPT entry. It can have names from 1 to 7 chars.

    BMS Macros

    BMS map is a program which is written in Assembly language to manage screens. The three macros that are used to define the screen are DFHMSD, DFHMDI, and DFHMDF.

    DFHMSD

    DFHMSD macro generates Mapset definition. It is macro identifier which shows that we are starting a mapset. The mapset name is the load module name and an entry in PPT table must be present. The following table shows the list of parameters which can be used in DFHMSD −

    Sr.No Parameter & Description
    1

    TYPE

    TYPE is used to define the map type. If TYPE =
    MAP - Physical map is created
    DSECT - Symbolic map is created
    &&SYSPARM - Physical & Symbolic, both are created
    FINAL - To indicate the end of a mapset coding.

    2

    MODE

    MODE is used to indicate input/output operations. IF MODE =
    IN - For an input map only
    OUT - For an output map only
    INOUT For both input & output map

    3

    LANG

    LANG = ASM/COBOL/PL1
    It decides the language of the DSECT structure, for copying into the application program.

    4

    STORAGE

    If STORAGE =
    AUTO - To acquire a separate symbolic map area for each mapset
    BASE - To have the same storage base for the symbolic maps of from more than one mapset

    5

    CTRL

    CRTL is used to define the device control requests. If CTRL =
    FREEKB - To unlock the keyboard
    FRSET - To reset MDT to zero status
    ALARM - To set an alarm at screen display time
    PRINT - To indicate the mapset to be sent to the printer.

    6

    TERM

    TERM = type ensures device independence,required if other than 3270 terminal is being used.

    7

    TIOAPFX

    TIOAPFX = YES/NO
    YES - To reserve the prefix space (12 bytes) for BMS commands to access TIOA properly. Required for the CICS command level.

    Example

    The following example shows how to code a mapset definition −

    MPST01  DFHMSD TYPE = &SYSPARM, X
       CTRL = (FREEKB,FRSET), X
       LANG = COBOL, X 
       STORAGE = AUTO, X
       TIOAPFX = YES, X
       MODE = INOUT, X
       TERM = 3270
       DFHMSD TYPE = FINAL 
    END

    DFHMDI

    DFHMDI macro generates map definitions. It shows that we are starting a new map. Mapname is followed by the DFHMDI macro. Mapname is used to send or receive maps. The following table shows the parameters which we use inside a DFHMDI macro −

    Sr.No Parameter & Description
    1

    SIZE

    SIZE = (Line,Column)
    This parameter gives the size of the map. BMS allows us to build a screen using several maps, and this parameter becomes important when we are using more than one maps in a single mapset.

    2

    LINE

    It indicates the starting line number of the map.

    3

    COLUMN

    It indicates the starting column number of the map.

    4

    JUSTIFY

    It is used to specify the entire map or the map fields to be left or right justified.

    5

    CTRL

    CRTL is used to define the device control requests. If CTRL =
    FREEKB - To unlock the keyboard
    FRSET - To reset MDT to zero status
    ALARM - To set an alarm at screen display time
    PRINT - To indicate the map to be sent to the printer

    6

    TIOAPFX

    TIOAPFX = YES/NO

    YES - To reserve the prefix space (12 bytes) for BMS commands to access TIOA properly. Required for the CICS command level.

    Example

    The following example shows how to code a map definition −

    MAPSTD DFHMDI SIZE = (20,80), X
       LINE = 01, X
       COLUMN = 01, X
       CTRL = (FREEKB,FRSET)

    DFHMDF

    DFHMDF macro is used to define field names. The field name is mentioned against which DFHMDF macro is coded. This field name is used inside the program. We do not write field name against constant field which we do not want to use inside the program. The following table shows the list of parameters which can be used inside a DFHMDF macro −

    Sr.No Parameter & Description
    1

    POS

    This is the position on the screen where the field should appear. A field starts with its attribute byte, so if you code POS = (1,1), the attribute byte for that field is on line 1 in column 1, and the actual data starts in column 2.

    2

    LENGTH

    This is the length of the field, not counting the attribute byte.

    3

    INITIAL

    This is the character data for an output field. We use this to specify labels and titles for the screen and keep them independent of the program. For the first field in the menu screen, for example, we will code: INITIAL = 'MENU'.

    4

    JUSTIFY

    It is used to specify the entire map or the map fields to be left or right justified.

    5

    ATTRB

    ATTRB = (ASKIP/PROT/UNPROT, NUM, BRT/NORM/DRK, IC, FSET) It describes the attributes of the field.

    ASKIP - Autoskip. Data cannot be entered in this field. The cursor skips to the next field.

    PROT - Protected field. Data cannot be entered into this field. If data is entered, it will cause the input-inhibit status.

    UNPROT - Unprotected field. Data can be entered and this is used for all input fields.

    NUM - Numeric field. Only numbers (0 to 9) and special characters('.' and '-') are allowed.

    BRT - Bright display of a field (highlight).

    NORM - Normal display.

    DRK - Dark display.

    IC - Insert cursor. The cursor will be positioned in this field. In case, IC is specified more than once, the cursor is placed in the last field.

    FSET - Field set. MDT is set on so that the field data is to be sent from the terminal to the host computer regardless of whether the field is actually modified by the user.

    6

    PICIN

    PICIN applies to the data field which is used as input like PICIN = 9(8).

    7

    PICOUT

    PICIN applies to the data field which is used as output like PICOUT = Z(8).

    Example

    The following example shows how to code a field definition −

    DFHMDF POS = (01,01), X
       LENGTH = 7, X
       INITIAL = ‘SCREEN1’, X
          ATTRB = (PROT,NORM)
          STDID DFHMDF POS = (01,70), X
          LENGTH = 08, X
          ATTRB = (PROT,NORM)

    BMS receives the data entered by the user and then formats it into a symbolic map area. The application program has access only to the data present in the symbolic map. The application program processes the data and the output is sent to the symbolic map. BMS will merge the output of the symbolic data with the physical map.

    Physical Map

    Physical Map is a load module in the load library which contains information about how the map should be displayed.

    • It contains the details about the attributes of all the fields in the map and their positions.

    • It contains the display format of the map for a given terminal.

    • It is coded using BMS macros. It is assembled separately and link edited into the CICS library.

    Symbolic Map

    A Symbolic Map is a Copy book in the library. The Copy book is used by the CICS application program to send and receive data from the terminal.

    • It contains all the variable data which is copied into program's WORKINGSTORAGE section.

    • It has all the named fields. The application programmer uses these fields to read and write data into the map.

    Skipper and Stopper Field

    For an unprotected named field, in a map, if we have specified a length of 10, this means that the name field can take values whose length cannot exceed 10. But when you display this map using CICS and start entering values for this field on the screen, we can enter more than 10 Characters, i.e., till the end of the screen and we can enter even in the next line. To prevent this, we use Skipper field or stopper field. A Skipper field would generally be an Unnamed field of length 1, specified after a named field.

    Skipper Field

    If we place a skipper field after the named unprotected field, then while entering the value, once the specified length is reached, the cursor will automatically position to the next unprotected field. The following example shows how to add a skipper field −

    NUMBER  DFHMDF POS = (01,01), X
       LENGTH = 5, X
       ATTRB = (UNPROT,IC)
          DFHMDF POS = (01,07), X
          LENGTH = 1, X
          ATTRB = (ASKIP)

    Stopper Field

    If we place a stopper field after the named unprotected field, then while entering the value, once the specified length is reached, the cursor will stop its positioning. The following example shows how to add a stopper field −

    NUMBER  DFHMDF POS = (01,01), X
       LENGTH = 5, X
    	ATTRB = (UNPROT,IC)
    	   DFHMDF POS = (01,07), X
          LENGTH = 1, X
          ATTRB = (PROT)

    Attribute Byte

    The attribute byte of any field stores information about the physical properties of the field. The following diagram and the table explain the significance of each bit.

    Bit Position Description Bit Settings
    0 & 1   Determined by contents of bit 2 to 7
    2 & 3 Protection & Shift 00 - Unprotected Alphanumeric
    01 - Unprotected Numeric
    10 - Protected Stop
    11 - Protected Skip
    4 & 5 Intensity 00 - Normal
    01 - Normal
    10 - Bright
    11 - No-display ( Dark )
    6   Must be Zero Always
    7 Modified Data Tag 0 - Field has not been modified
    1 - Field has been modified

    Modified Data Tag

    Modified Data Tag (MDT) is the last bit in the attribute byte.

    • MDT is a flag which holds a single bit. It specifies whether the value is to be transferred to the system or not.

    • Its default value is 1, when the field value is changed.

    • If MDT is 0, then data cannot be transferred; and if MDT is 1, then data can be transferred.

    Send Map

    The send map command writes formatted output to the terminal. It is used to send the map to the terminal from the application program. The following code segment shows how to send a map to the terminal −

    EXEC CICS SEND 
       MAP('map-name')
       MAPSET('mapset-name')
       [FROM(data-area)]
       [LENGTH(data_value)]
       [DATAONLY]
       [MAPONLY]
       [CURSOR]
       [ERASE/ERASEAUP]
       [FREEKB] 
       [FRSET]
    END-EXEC

    The following table lists the parameters used in a send map command along with their significance.

    Sr.No Parameter & Description
    1

    Map-name

    It is the name of the map which we want to send. It is mandatory.

    2

    Mapset-name

    It is the name of the map set that contains the mapname. The mapset name is needed unless it is the same as the map name.

    3

    FROM

    It is used if we have decided to use a different DSECT name, we must use the option FROM (dsect-name) along with SEND MAP command.

    4

    MAPONLY

    It means that no data from your program is to be merged into the map and only the information in the map is transmitted.

    5

    DATAONLY

    It is the logical opposite of MAPONLY. We use it to modify the variable data in a display that has already been created. Only the data from your program is sent to the screen. The constants in the map are not sent.

    6

    ERASE

    It causes the entire screen to be erased before what we are sending is shown.

    7

    ERASEUP

    It causes only unprotected fields to be erased.

    8

    FRSET

    Flag Reset turns off the modified data tag in the attribute byte for all the fields on the screen before what you are sending is placed there.

    9

    CURSOR

    It can be used to position the cursor on the terminal screen. Cursor can be set by moving -1 to the L part of the field and then sending the map.

    10

    ALARM

    It causes the audible alarm to be sounded.

    11

    FREEKB.

    The keyboard is unlocked if we specify FREEKB in either the map or the SEND command.

    12

    PRINT

    It allows the output of a SEND command to be printed on a printer.

    13

    FORMFEED

    It causes the printer to restore the paper to the top of the next page before the output is printed.

    Receive Map

    When we want to receive input from a terminal, we use the RECEIVE MAP command. The MAP and MAPSET parameters have exactly the same meaning as for the SEND MAP command. The following code segment shows how to receive a map −

    EXEC CICS RECEIVE 
       MAP('map-name')
       MAPSET('mapset-name')
       [INTO(data-area)]
       [FROM(data-area)]
       [LENGTH(data_value)]
    END-EXEC

    Mapset Execution

    The following steps are necessary to develop and execute a mapset −

    • Step 1 − Open a TSO session.

    • Step 2 − Create a new PDS.

    • Step 3 − Code a mapset in a new member according to the requirement.

    • Step 4 − Assemble the mapset using the JCL provided by the CICS administrator.

    • Step 5 − Open a CICS Session.

    • Step 6 − Install the program using the command −

      CEMT SET PROG(mapset-name) NEW

    • Step 7 − Type the following command to send the Map to the terminal −

      CECI SEND MAP(map-name) MAPSET(mapset-name) ERASE FREEKB

    Any application program would require an interface to interact with the CICS. EIB (Execute Interface Block) acts as an interface to allow application programs communicate with the CICS. EIB contains the information required during the execution of a program.

    Restricted COBOL Verbs

    While coding a CICS program, we cannot use the commands which return the control directly to the MVS. If we code these COBOL verbs, it will not give any compilation error, but we may get unpredictable results. Following are the COBOL verbs which should not be used in a CICS program −

    • File I/O statements like Open, Read, Write, Rewrite, Close, Delete, and Start. All file I/O in CICS is handled by the file control module and they have their own set of statements like READ, WRITE, REWRITE, and DELETE which we will be discussing in the upcoming modules.

    • File Section and Environment Division is not required.

    • COBOL statements that invoke operating system functions like Accept, Date/Time cannot be used.

    • Do not use DISPLAY, MERGE, STOP RUN, and GO BACK.

    Execute Interface Block

    Execute Interface Block (EIB) is a control block which is loaded automatically by the CICS for every program.

    • The EIB is unique to a task and it exists for the duration of the task. It contains a set of system related information corresponding to the task.

    • It contains information about transaction identifier, time, date, etc., which is used by the CICS during the execution of an application program.

    • Every program that executes as a part of the task has access to the same EIB.

    • The data in EIB at runtime can be viewed by executing the program in CEDF mode.

    EIB Fields

    The following table provides a list of fields which are present in EIB −

    EIB Field PIC Clause Description
    EIBAID X(1) Aid key Pressed
    EIBCALEN S9(4) COMP It contains length of DFHCOMMAREA
    EIBDATE S9(7) COMP-3 It contains Current System Date
    EIBRCODE X(6) It contains Return code of the last transaction
    EIBTASKN S9(7) COMP-3 It contains Task number
    EIBTIME S9(7) COMP-3 It contains Current System Time
    EIBTRMID X(4) Terminal Identifier
    EIBTRNID X(4) Transaction Identifier

    CICS Programs Classification

    CICS Programs are classified in the following three categories which we will discuss one by one −

    • Non-Conversational Programs
    • Conversational Programs
    • Pseudo-Conversational Programs - We will discuss in the next module

    Non Conversational Programs

    While executing non-conversational programs, no human intervention is required. All the necessary inputs are provided when the program is started.

    • They are similar to batch programs that run in the batch mode. So in CICS, they are rarely developed.

    • We can say they are used just for displaying a sequence of screens at regular intervals of time.

    Example

    The following example shows a non-conversational program which will simply display "HELLO WORLD" on the CICS terminal as output −

    IDENTIFICATION DIVISION.                                
    PROGRAM-ID. HELLO.                                      
    DATA DIVISION.                                          
    WORKING-STORAGE SECTION.                                
    01 WS-MESSAGE          PIC X(30).                       
    PROCEDURE DIVISION.                                     
    ********************************************************
    * SENDING DATA TO SCREEN                               * 
    ********************************************************
       MOVE 'HELLO WORLD' TO WS-MESSAGE                
       EXEC CICS SEND TEXT                             
          FROM (WS-MESSAGE)                          
       END-EXEC                                        
    ********************************************************
    * TASK TERMINATES WITHOUT ANY INTERACTION FROM THE USER* 
    ********************************************************
       EXEC CICS RETURN                                
    END-EXEC.

    Conversational Program

    Sending a message to the terminal and receiving a response from the user is called a conversation. An online application achieves a conversation between the user and the application program by a pair of SEND and RECEIVE command. The key points of a Conversational program are as follows −

    • The system sends a message to the screen and waits for the user’s response.

    • The time taken by user to respond is known as Think Time. This time is considerably high, which is a major drawback of Conversational programs.

    • The user provides the necessary input and presses an AID key.

    • The application processes the user’s input and sends the output.

    • The program is loaded into the main storage at the beginning and is retained till the task ends.

    Example

    The following example shows a conversion program which takes input from the user and then simply displays the same input on the CICS terminal as output −

    IDENTIFICATION DIVISION.                               
    PROGRAM-ID. HELLO.                                     
    DATA DIVISION.                                         
    WORKING-STORAGE SECTION.                               
    01 WS-MESSAGE          PIC X(30) VALUE SPACES.         
    PROCEDURE DIVISION.                                    
       MOVE 'ENTER MESSAGE' TO WS-MESSAGE           
    ********************************************************
    * SENDING DATA FROM PROGRAM TO SCREEN                  * 
    ********************************************************
       EXEC CICS SEND TEXT                            
          FROM (WS-MESSAGE)                         
       END-EXEC                                       
    ********************************************************
    * GETTING INPUT FROM USER                              * 
    ********************************************************
       EXEC CICS RECEIVE                              
          INTO(WS-MESSAGE)                          
       END-EXEC                                       
       EXEC CICS SEND TEXT                            
          FROM (WS-MESSAGE)                         
       END-EXEC                                       
    ********************************************************
    * COMMAND TO TERMINATE THE TRANSACTION                 * 
    ********************************************************
       EXEC CICS RETURN                               
    END-EXEC.

À partir de maintenant, nous avons couvert les programmes de non-conversion et de conversion. Les programmes de conversion ont un inconvénient majeur car leurthink timeest considérablement élevé. Pour surmonter ce problème, la programmation de pseudo-conversion est entrée en scène. Nous allons maintenant discuter plus en détail des programmes de pseudo-conversion.

Programme de pseudo-conversion

Voici la séquence d'événements qui ont lieu dans un programme de pseudo-conversion -

  • Step 1 - Le système envoie un message à l'écran et met fin à la transaction, en spécifiant la transaction à démarrer lorsque l'entrée de l'utilisateur est reçue.

  • Step 2- Le système alloue les ressources utilisées par cette transaction à d'autres transactions exécutées dans le système. Nous pouvons donc utiliser les ressources dans un programme de pseudo-conversion jusqu'à ce que l'utilisateur donne l'entrée.

  • Step 3- Le système interroge l'entrée du terminal à intervalles réguliers. Lorsque l'entrée est reçue, elle est traitée et la sortie est affichée.

  • Step 4 - Le programme d'application est chargé dans le stockage principal lorsque cela est nécessaire et libéré lorsqu'il n'est pas utilisé.

Techniques de pseudo-conversion

Le point important à noter dans la pseudo-conversation est le passage de données entre chaque tâche. Nous discuterons des techniques de transmission des données.

COMMAREA

COMMAREA est connue sous le nom de zone de communication. COMMAREA est utilisé pour transmettre des données entre les tâches. L'exemple suivant montre comment transmettre COMMAREA où WSCOMMAREA et WS-COMMAREA-LENGTH sont déclarés dans Working Storage Section -

EXEC CICS RETURN
   TRANSID ('transaction-id')
   COMMAREA (WS-COMMAREA)
   LENGTH  (WS-COMMAREA-LENGTH)
END-EXEC.

DFHCOMMAREA

DFHCOMMAREA est une zone de mémoire spéciale qui est fournie par CICS à chaque tâche.

  • Il est utilisé pour transmettre des données d'un programme à un autre programme. Les programmes peuvent exister dans la même transaction ou dans une transaction différente également.

  • Il est déclaré dans la section Linkage du programme au niveau 01.

  • Il doit avoir la même clause d'image que WS-COMMAREA.

  • Les données peuvent être déplacées de DFHCOMMAREA vers WS-COMMAREA à l'aide d'une instruction MOVE.

MOVE DFHCOMMAREA TO WS-COMMAREA.

Exemple

Après l'envoi de la carte, la tâche se termine et attend la réponse de l'utilisateur. À ce stade, les données doivent être sauvegardées, car bien que la tâche soit terminée, la transaction ne l'a pas été. Lorsque cette transaction doit être reprise, elle nécessiterait le statut antérieur de la tâche. L'utilisateur entre l'entrée. Celui-ci doit maintenant être reçu par la commande RECEIVE MAP puis validé. L'exemple suivant montre comment déclarer COMMAREA et DFHCOMMAREA -

WORKING-STORAGE SECTION.
01 WS-COMMAREA.
   05 WS-DATA PIC X(10).
   
LINKAGE SECTION.
01 DFHCOMMAREA.
   05 LK-DATA PIC X(10).

Pseudo code

Ci-dessous, la logique du pseudo-code que nous utilisons dans la pseudo-programmation -

MOVE DFHCOMMAREA TO WS-COMMAREA
IF EIBCALEN = 0
   STEP1: SEND MAP
   STEP2: MOVE <internal-transaction-id1> to WS-COMMAREA
   STEP3: ISSUE CONDITIONAL RETURN
ELSE
   IF WS-COMMAREA = <internal-transaction-id1> 
      STEP4: RECEIVE MAP
      STEP5: PROCESS DATA
      STEP6: SEND OUTPUT MAP
      STEP7: MOVE <internal-transaction-ID2> to WS-COMMAREA
      STEP8: ISSUE CONDITIONAL RETURN 
   END-IF
END-IF      
STEP9: REPEAT STEP3 TO STEP7 UNTIL EXIT

Exemple

L'exemple suivant montre un programme de pseudo-conversion -

******************************************************************
* PROGRAM TO DEMONSTRATE PSEUDO-CONVERSATION                     *
******************************************************************
IDENTIFICATION DIVISION.                                         
PROGRAM-ID. HELLO.                                               
DATA DIVISION.                                                   
WORKING-STORAGE SECTION.                                         
01 WS-MESSAGE          PIC X(30).                                
01 WS-COMMAREA         PIC X(10) VALUE SPACES.                    
LINKAGE SECTION.                                                 
01 DFHCOMMAREA         PIC X(10).                                 
PROCEDURE DIVISION.
   MOVE DFHCOMMAREA TO WS-COMMAREA
   IF  WS-COMMAREA  =  SPACES                                   
******************************************************************
* TRANSACTION GETTING EXECUTED FOR THE FIRST TIME                *
******************************************************************
   MOVE 'HELLO' TO WS-MESSAGE                               
   EXEC CICS SEND TEXT                                      
      FROM (WS-MESSAGE)                                   
   END-EXEC                                                 
   MOVE 'FIRST' TO WS-COMMAREA                              
******************************************************************
* TASK ENDS AS A RESULT OF RETURN. IF AID KEY PRESSED, NEXT      *
* TRANSACTION SHOULD BE TP002. DATA PASSED FROM WS-COMMAREA TO   *
* DFHCOMMAREA                                                    *
******************************************************************
   EXEC CICS RETURN                                         
      TRANSID('TP002')                                      
      COMMAREA(WS-COMMAREA)                                
   END-EXEC                                                 
******************************************************************
* IF  COMMAREA IS NOT EMPTY , THEN TP002 HAS BEEN EXECUTED ONCE  *
* ALREADY, USER INTERACTION IS FACILITATED BY RECEIVE            *
******************************************************************
   ELSE                                                         
      EXEC CICS RECEIVE                                        
         INTO(WS-MESSAGE)                                    
   END-EXEC
      EXEC CICS SEND TEXT                                      
      FROM (WS-MESSAGE)                                   
   END-EXEC                                                 
******************************************************************
* TASK ENDS AS A RESULT OF RETURN, NO NEXT TRANSACTION SPECIFIED *
* TO BE EXECUTED                                                 *
******************************************************************
   EXEC CICS RETURN                                         
   END-EXEC                                                 
END-IF.

Avantages de la pseudo conversion

Voici les avantages de la pseudo conversion -

  • Les ressources sont mieux utilisées. Les ressources sont libérées dès que le programme est temporairement suspendu.

  • On dirait qu'il est en mode conversationnel.

  • Il a un meilleur temps de réponse.

Déclarations de retour

Voici les deux types d'instructions de retour qui sont utilisées dans CICS -

Retour-1

Lorsque l'instruction de retour inconditionnel suivante est émise, la tâche et la transaction (programme) sont arrêtées.

EXEC CICS RETURN 
END-EXEC.

Retour-2

Lorsque le retour conditionnel suivant, c'est-à-dire return avec l'instruction TRANSID, est émis, le contrôle retourne au CICS avec le transid suivant à exécuter. La transaction suivante commence lorsque l'utilisateur appuie sur une touche AID.

EXEC CICS RETURN
   TRANSID ('trans-id')
   [COMMAREA(WS-COMMAREA)]
END-EXEC.

Comme nous l'avons vu dans les modules précédents, les clés AID sont appelées clés d'identification d'attention. CICS ne peut détecter que les clés AID. Après avoir tapé toutes les entrées, uniquement lorsque l'utilisateur appuie sur l'une des touches AID, le CICS prend le contrôle. Les touches AID incluent ENTER, PF1 à PF24, PA1 à PA3 et CLEAR.

Validation des clés AID

La touche enfoncée par l'utilisateur est vérifiée en utilisant EIBAID.

  • EIBAID a une longueur d'un octet et contient la valeur d'identificateur d'attention réelle utilisée dans le flux d'entrée 3270.

  • CICS nous fournit un ensemble pré-codé de variables qui peuvent être utilisées dans le programme d'application en écrivant l'instruction suivante -

    COPIER DFHAID

DFHAID

DFHAID est un cahier qui est utilisé dans les programmes d'application pour inclure un ensemble de variables pré-codées CICS. Le contenu suivant est présent dans le cahier DFHAID -

01    DFHAID.                             
   02  DFHNULL   PIC  X  VALUE IS ' '.     
   02  DFHENTER  PIC  X  VALUE IS ''''.    
   02  DFHCLEAR  PIC  X  VALUE IS '_'.     
   02  DFHCLRP   PIC  X  VALUE IS '¦'.     
   02  DFHPEN    PIC  X  VALUE IS '='.     
   02  DFHOPID   PIC  X  VALUE IS 'W'.     
   02  DFHMSRE   PIC  X  VALUE IS 'X'.     
   02  DFHSTRF   PIC  X  VALUE IS 'h'.     
   02  DFHTRIG   PIC  X  VALUE IS '"'.     
   02  DFHPA1    PIC  X  VALUE IS '%'.     
   02  DFHPA2    PIC  X  VALUE IS '>'.     
   02  DFHPA3    PIC  X  VALUE IS ','.     
   02  DFHPF1    PIC  X  VALUE IS '1'.     
   02  DFHPF2    PIC  X  VALUE IS '2'.     
   02  DFHPF3    PIC  X  VALUE IS '3'.     
   02  DFHPF4    PIC  X  VALUE IS '4'.     
   02  DFHPF5    PIC  X  VALUE IS '5'.     
   02  DFHPF6    PIC  X  VALUE IS '6'.     
   02  DFHPF7    PIC  X  VALUE IS '7'.     
   02  DFHPF8    PIC  X  VALUE IS '8'.     
   02  DFHPF9    PIC  X  VALUE IS '9'.     
   02  DFHPF10   PIC  X  VALUE IS ':'.     
   02  DFHPF11   PIC  X  VALUE IS '#'.     
   02  DFHPF12   PIC  X  VALUE IS '@'.     
   02  DFHPF13   PIC  X  VALUE IS 'A'.     
   02  DFHPF14   PIC  X  VALUE IS 'B'.     
   02  DFHPF15   PIC  X  VALUE IS 'C'.   
   02  DFHPF16   PIC  X  VALUE IS 'D'.   
   02  DFHPF17   PIC  X  VALUE IS 'E'.   
   02  DFHPF18   PIC  X  VALUE IS 'F'.   
   02  DFHPF19   PIC  X  VALUE IS 'G'.   
   02  DFHPF20   PIC  X  VALUE IS 'H'.   
   02  DFHPF21   PIC  X  VALUE IS 'I'.   
   02  DFHPF22   PIC  X  VALUE IS '¢'.   
   02  DFHPF23   PIC  X  VALUE IS '.'.   
   02  DFHPF24   PIC  X  VALUE IS '<'.

Exemple

L'exemple suivant montre comment utiliser le cahier DFHAID dans un programme d'application -

IDENTIFICATION DIVISION.                                         
PROGRAM-ID. HELLO.                                               
DATA DIVISION.   
WORKING-STORAGE SECTION.
COPY DFHAID.
PROCEDURE DIVISION.
A000-AIDKEY-PARA.
   EVALUATE EIBAID
      WHEN DFHAID
         PERFORM A000-PROCES-PARA
      WHEN DFHPF1
         PERFORM A001-HELP-PARA
      WHEN DFHPF3
         PERFORM A001-EXIT-PARA
    END-EVALUATE.

Positionnement du curseur

Il existe deux façons de remplacer la position spécifiée dans la définition de carte.

  • Une méthode consiste à spécifier la position de l'écran par rapport au numéro de ligne et de colonne dans l'option CURSEUR de la commande d'envoi de carte.

  • Une autre façon est de déplacer -1 vers la variable de carte symbolique suffixée avec L. Ensuite, envoyez la carte avec une option CURSEUR dans le SEND MAP.

Exemple

L'exemple suivant montre comment remplacer la position du curseur pour le champ NAME -

MOVE -1 TO NAMEL
   EXEC CICS SEND 
      MAP ('map-name')
      MAPSET ('name-field')
      ERASE
      FREEKB
      CURSOR
   END-EXEC.

Modification dynamique des attributs

Lors de l'envoi d'une carte, si nous voulons avoir des attributs différents pour un champ autre que celui spécifié dans la carte, nous pouvons remplacer cela en définissant le champ dans le programme. Voici l'explication pour remplacer les attributs d'un champ -

  • Pour remplacer les attributs d'un champ, nous devons inclure DFHATTR dans le programme d'application. Il est fourni par CICS.

  • L'attribut requis peut être choisi dans la liste et déplacé vers la variable de champ symbolique avec le suffixe «A».

DFHATTR contient le contenu suivant -

01  CICS-ATTRIBUTES.
   05  ATTR-UXN            PIC X(01) VALUE SPACE.
   05  ATTR-UXMN           PIC X(01) VALUE 'A'.
   05  ATTR-UXNL           PIC X(01) VALUE 'D'.
   05  ATTR-UXMNL          PIC X(01) VALUE 'E'.
   05  ATTR-UXBL           PIC X(01) VALUE 'H'.
   05  ATTR-UXMBL          PIC X(01) VALUE 'I'.
   05  ATTR-UXD            PIC X(01) VALUE '<'.
   05  ATTR-UXMD           PIC X(01) VALUE '('.
   05  ATTR-U9N            PIC X(01) VALUE '&'.
   05  ATTR-U9MN           PIC X(01) VALUE 'J'.
   05  ATTR-U9NL           PIC X(01) VALUE 'M'.
   05  ATTR-U9MNL          PIC X(01) VALUE 'N'.
   05  ATTR-U9BL           PIC X(01) VALUE 'Q'.
   05  ATTR-U9MBL          PIC X(01) VALUE 'R'.
   05  ATTR-U9D            PIC X(01) VALUE '*'.
   05  ATTR-U9MD           PIC X(01) VALUE ')'.
   05  ATTR-PXN            PIC X(01) VALUE '-'.
   05  ATTR-PXMN           PIC X(01) VALUE '/'.
   05  ATTR-PXNL           PIC X(01) VALUE 'U'.
   05  ATTR-PXMNL          PIC X(01) VALUE 'V'.
   05  ATTR-PXBL           PIC X(01) VALUE 'Y'.
   05  ATTR-PXMBL          PIC X(01) VALUE 'Z'.
   05  ATTR-PXD            PIC X(01) VALUE '%'.
   05  ATTR-PSN            PIC X(01) VALUE '0'.
   05  ATTR-PSMN           PIC X(01) VALUE '1'.
   05  ATTR-PSNL           PIC X(01) VALUE '4'.
   05  ATTR-PSMNL          PIC X(01) VALUE '5'.
   05  ATTR-PSBL           PIC X(01) VALUE '8'.
   05  ATTR-PSMBL          PIC X(01) VALUE '9'.
   05  ATTR-PSD            PIC X(01) VALUE '@'.
   05  ATTR-PSMD           PIC X(01) VALUE "'".

CICS nous permet d'accéder aux données de fichiers de plusieurs manières. La plupart des accès aux fichiers sont aléatoires dans le système en ligne car les transactions à traiter ne sont pas groupées et triées dans n'importe quel type d'ordre. Par conséquent, CICS prend en charge les méthodes d'accès direct habituelles - VSAM et DAM (méthode d'accès direct). Cela nous permet également d'accéder aux données à l'aide de gestionnaires de bases de données.

Accès aléatoire

Voici les commandes qui sont utilisées pour le traitement aléatoire -

Sr.Non Commandes et description
1 LIS

La commande READ lit les données d'un fichier à l'aide de la clé primaire.

2 ÉCRIRE

La commande Write est utilisée pour ajouter de nouveaux enregistrements à un fichier.

3 RÉCRIRE

La commande REWRITE permet de modifier un enregistrement déjà présent dans un fichier.

4 EFFACER

La commande DELETE est utilisée pour supprimer un enregistrement présent dans un fichier.

Accès séquentiel

Voici les commandes utilisées pour le traitement séquentiel -

Sr.Non Commandes et description
1 STARTBR

STARTBR est connu sous le nom de démarrage de la navigation.

2 READNEXT / READPREV

Lorsque nous émettons une commande STARTBR, cela ne rend pas les enregistrements disponibles.

3 RESETBR

La commande RESETBR nous permet de réinitialiser notre point de départ au milieu d'un parcours.

4 ENDBR

Lorsque nous avons terminé la lecture séquentielle d'un fichier, nous terminons le parcours à l'aide de la commande ENDBR.

Il existe de nombreux types de abendset les erreurs auxquelles on peut faire face lors de l'utilisation d'une application CICS. Des erreurs peuvent survenir en raison de problèmes matériels et logiciels. Nous discuterons des erreurs et de la gestion des erreurs dans ce module.

Erreurs CICS

Voici les erreurs CICS qui peuvent survenir lors de l'exécution des applications CICS -

  • Certaines erreurs CICS attendues surviennent lorsque les conditions ne sont pas normales dans le système CICS. Par exemple, si nous lisons un enregistrement particulier et que l'enregistrement n'est pas trouvé, nous obtenons l'erreur "Not Found".Mapfailest une erreur similaire. Les erreurs de cette catégorie sont gérées par une logique explicite dans le programme.

  • Des erreurs logiques surviennent pour des raisons telles que la division par zéro, un caractère illégal dans le champ numérique ou une erreur d'identifiant de transaction.

  • Les erreurs liées au matériel ou à d'autres conditions système échappent au contrôle d'un programme d'application. Par exemple, obtenir une erreur d'entrée / sortie lors de l'accès à un fichier.

Commandes de gestion des erreurs

CICS fournit plusieurs mécanismes pour identifier les erreurs et les traiter dans nos programmes. Voici les commandes qui sont utilisées pour gérer les erreurs CICS attendues -

Sr.Non Gestion des commandes et description
1 État de la poignée

La condition de poignée est utilisée pour transférer le contrôle du programme vers un paragraphe ou une étiquette de procédure.

2 Gérer Abend

Si un programme s'arrête pour des raisons telles qu'une erreur d'entrée-sortie, il peut être géré à l'aide de la commande Handle Abend CICS.

3 Un virage

La commande Abend est utilisée pour terminer la tâche intentionnellement.

4 Ignorer la condition

La condition Ignorer est utilisée lorsque nous voulons qu'aucune action ne soit entreprise si une fin anormale ou une erreur particulière se produit, mentionnée dans la condition Ignorer.

5 Nohandle

Nohandle ne peut être spécifié pour aucune commande CICS.

Le programme de contrôle de programme CICS (PCP) gère le flux des programmes d'application. Tous les programmes d'application doivent avoir une entrée dans le tableau des programmes de traitement. Voici les commandes qui sont utilisées pour les services de contrôle de programme -

  • XCTL
  • Link
  • Load
  • Release
  • Return

Niveaux logiques du programme

Les programmes d'application qui s'exécutent sous CICS ont différents niveaux logiques. Le premier programme qui reçoit directement la commande se trouve au niveau logique le plus élevé, c'est-à-dire au niveau 1. Le programme lié est au niveau logique suivant du programme de liaison. Les programmes XCTL fonctionnent au même niveau. Ce sera clair quand nous passerons par Link et XCTL, plus loin dans ce module. L'image suivante montre les niveaux logiques -

XCTL

L'explication fondamentale de XCTL est la suivante -

  • La commande XCTL permet de passer le contrôle d'un programme à un autre au même niveau.

  • Il n'attend pas le retour du contrôle.

  • Elle est similaire à l'instruction GO TO.

  • Un programme XCTL peut être un pseudo-conversationnel.

Exemple

L'exemple suivant montre comment utiliser la commande XCTL pour passer le contrôle à un autre programme -

IDENTIFICATION DIVISION.                                         
PROGRAM-ID. PROG1.  
WORKING-STORAGE SECTION.
01 WS-COMMAREA    PIC X(100).                                             
PROCEDURE DIVISION.

EXEC CICS XCTL
   PROGRAM ('PROG2')
   COMMAREA (WS-COMMAREA)
   LENGTH (100)
END-EXEC.

Cette commande transfère le contrôle à passer au programme 'PROG2' avec 100 octets de données. COMMAREA est un paramètre facultatif et correspond au nom de la zone contenant les données à transmettre ou de la zone à laquelle les résultats doivent être renvoyés.

Lien

La commande Link est utilisée pour transférer le contrôle vers un autre programme de niveau inférieur. Il attend le contrôle de retour. Un programme lié ne peut pas être pseudo-conversationnel.

Exemple

L'exemple suivant montre comment utiliser la commande Link pour passer le contrôle à un autre programme -

IDENTIFICATION DIVISION.                                         
PROGRAM-ID. PROG1.  
WORKING-STORAGE SECTION.
01 WS-COMMAREA    PIC X(100).                                             
PROCEDURE DIVISION.

EXEC CICS LINK
   PROGRAM ('PROG2')
   COMMAREA (WS-COMMAREA)
   LENGTH (100)
END-EXEC.

Charge

La commande Load est utilisée pour charger un programme ou une table. Voici la syntaxe de la commande Load -

EXEC CICS LOAD
   PROGRAM ('name')
END-EXEC.

Libération

La commande Release est utilisée pour libérer un programme ou une table. Voici la syntaxe de la commande Release -

EXEC CICS RELEASE
   PROGRAM ('name')
END-EXEC.

Revenir

La commande de retour est utilisée pour ramener le contrôle au niveau logique supérieur suivant. Voici la syntaxe de la commande Return -

EXEC CICS RETURN
   PROGRAM ('name')
   COMMAREA (data-value)
   LENGTH (data-value)
END-EXEC.

Opérations de contrôle d'intervalle

Les opérations de contrôle d'intervalle sont des deux types suivants -

DEMANDER

ASKTIME est utilisé pour demander l'heure et la date actuelles ou l'horodatage. Nous déplaçons ensuite cette valeur vers la variable de stockage de travail à l'intérieur du programme. Voici la syntaxe de la commande ASKTIME -

EXEC CICS ASKTIME
   [ABSTIME(WS-TIMESTAMP)]
END-EXEC.

FORMATTIME

FORMATTIME met en forme l'horodatage dans le format requis en fonction des options, qui peuvent être AAAJJ, AAMMJJ ou AAJJM ​​pour la date. DATESEP indique le séparateur pour la DATE, tout comme la variable TIMESEP pour TIME. Voici la syntaxe de la commande FORMATTIME -

EXEC CICS FORMATTIME
   ABSTIME(WS-TIMESTAMP)
   [YYDDD(WS-DATE)]
   [YYMMDD(WS-DATE)]
   [YYDDMM(WS-DATE)]
   [DATESEP(WS-DATE-SEP)]
   [TIME(WS-TIME)]
   [TIMESEP(WS-TIME-SEP)]
END-EXEC.

Il existe différents blocs-notes disponibles dans CICS pour enregistrer des données ou pour transférer les données entre les transactions. Il y a cinq zones de stockage fournies par CICS, dont nous parlerons dans ce module.

COMMAREA

La COMMAREA se comporte comme un bloc-notes qui peut être utilisé pour transmettre des données d'un programme à un autre programme, soit dans la même transaction, soit à partir de transactions différentes. Il doit être défini dans la SECTION LINKAGE en utilisant le nom DFHCOMMAREA.

Zone de travail commune

Toute transaction dans la région CICS peut accéder à la zone de travail commune et, par conséquent, son format et son utilisation doivent être convenus par toutes les transactions du système qui décide de l'utiliser. Il n'y a qu'un seul CWA dans toute la région CICS.

Zone de travail de transaction

La zone de travail de transaction est utilisée pour transmettre des données entre les programmes d'application exécutés dans la même transaction. TWA n'existe que pour la durée de la transaction. Sa taille est définie dans la table de contrôle des programmes.

File d'attente de stockage temporaire

La file d'attente de stockage temporaire (TSQ) est une fonctionnalité fournie par le programme de contrôle du stockage temporaire (TSP).

  • Un TSQ est une file d'attente d'enregistrements qui peuvent être créés, lus et supprimés par différentes tâches ou programmes dans la même région CICS.

  • Un identifiant de file d'attente est utilisé pour identifier TSQ.

  • Un enregistrement dans un TSQ est identifié par la position relative connue sous le nom de numéro d'article.

  • Les enregistrements dans TSQ restent accessibles jusqu'à ce que tout le TSQ soit explicitement supprimé.

  • Les enregistrements dans TSQ peuvent être lus séquentiellement ou directement.

  • Les TSQ peuvent être écrites dans la mémoire principale ou dans la mémoire auxiliaire dans le DASD.

WRITEQ TS

Cette commande est utilisée pour ajouter des éléments à un TSQ existant. Nous pouvons également créer un nouveau TSQ à l'aide de cette commande. Voici la syntaxe de la commande WRITEQ TS -

Syntaxe

EXEC CICS WRITEQ TS
   QUEUE ('queue-name')
   FROM (queue-record)
   [LENGTH (queue-record-length)]
   [ITEM (item-number)]
   [REWRITE]
   [MAIN /AUXILIARY]
END-EXEC.

Voici les détails des paramètres utilisés dans la commande WRITEQ TS -

  • La QUEUE est identifiée par le nom qui est mentionné dans ce paramètre.

  • Les options FROM et LENGTH sont utilisées pour spécifier l'enregistrement à écrire dans la file d'attente et sa longueur.

  • Si l'option ITEM est spécifiée, CICS attribue un numéro d'élément à l'enregistrement dans la file d'attente et définit la zone de données fournie dans cette option sur le numéro d'élément. Si l'enregistrement démarre une nouvelle file d'attente, le numéro d'élément attribué est 1 et les numéros d'élément suivants suivent séquentiellement.

  • L'option REWRITE permet de mettre à jour un enregistrement déjà présent dans la file d'attente.

  • L'option MAIN / AUXILIAIRE est utilisée pour stocker les enregistrements dans la mémoire principale ou auxiliaire. La valeur par défaut est AUXILIAIRE.

READQ TS

Cette commande est utilisée pour lire la file d'attente de stockage temporaire. Voici la syntaxe de READQ TS -

Syntaxe

EXEC CICS READQ TS
   QUEUE ('queue-name')
   INTO (queue-record)
   [LENGTH (queue-record-length)]
   [ITEM (item-number)]
   [NEXT]
END-EXEC.

DELETEQ TS

Cette commande permet de supprimer la file d'attente de stockage temporaire. Voici la syntaxe de DELETEQ TS -

Syntaxe

EXEC CICS DELETEQ TS
   QUEUE ('queue-name')
END-EXEC.

File d'attente de données transitoires

La file d'attente de données transitoire est de nature transitoire car elle peut être créée et supprimée rapidement. Il n'autorise qu'un accès séquentiel.

  • Le contenu de la file d'attente ne peut être lu qu'une seule fois car il est détruit une fois qu'une lecture est effectuée et donc le nom Transient.

  • Il ne peut pas être mis à jour.

  • Il nécessite une entrée dans DCT.

WRITEQ TD

Cette commande est utilisée pour écrire des files d'attente de données transitoires et elles sont toujours écrites dans un fichier. Voici la syntaxe de la commande WRITEQ TD -

Syntaxe

EXEC CICS WRITEQ TD
   QUEUE ('queue-name')
   FROM (queue-record)
   [LENGTH (queue-record-length)]
END-EXEC.

READQ TD

Cette commande est utilisée pour lire la file d'attente de données transitoires. Voici la syntaxe de READQ TD -

Syntaxe

EXEC CICS READQ TD
   QUEUE ('queue-name')
   INTO (queue-record)
   [LENGTH (queue-record-length)]
END-EXEC.

DELETEQ TD

Cette commande est utilisée pour supprimer la file d'attente de données transitoires. Voici la syntaxe de DELETEQ TD -

Syntaxe

EXEC CICS DELETEQ TD
   QUEUE ('queue-name')
END-EXEC.

La communication mutuelle qui a lieu entre deux ou plusieurs systèmes est appelée intercommunication.

Avantages de l'intercommunication

Les avantages importants de l'intercommunication sont les suivants:

  • Nous n'avons pas besoin de répliquer les données sur tous les systèmes.

  • Les utilisateurs n'ont pas besoin de se connecter à plusieurs systèmes pour accéder aux données qui y sont stockées.

  • Il améliore les performances de l'application.

Terminologies de base

Il faut avoir une connaissance des terminologies de base utilisées dans le système CICS. Voici les termes de base -

Système local

Un système local est un système qui lance une demande d'intercommunication.

Ressource locale

Une ressource locale est une ressource qui se trouve sur le système local.

Système à distance

Un système distant est un système qui est lancé à la suite d'une demande d'intercommunication.

Ressource distante

Une ressource distante est une ressource qui se trouve sur le système distant.

MVS Sysplex

MVS Sysplex est une configuration de plusieurs systèmes d'exploitation MVS. Ils fonctionnent comme un système unique en partageant des fonctions et des programmes.

CICSPlex

CICSPlex est généralement décrit comme un ensemble de régions CICS interconnectées qui traitent la charge de travail du client. Un CICSPlex est un ensemble de régions CICS interconnectées qui possèdent des terminaux, des applications, des ressources, etc.

Méthodes d'intercommunication

CICS peut communiquer avec d'autres systèmes de deux manières:

  • MRO - Le fonctionnement multirégion est utilisé lorsque deux régions CICS au sein du même MVSPLEX doivent communiquer entre elles.

  • ISC - La communication inter-système est utilisée lorsqu'une région CICS d'un serveur LOCAL doit communiquer avec une région CICS du serveur REMOTE.

Lorsque vous travaillez avec CICS, vous pouvez rencontrer des fins anormales. Voici les codes d'abend courants avec leur description qui vous aideront à résoudre les problèmes -

Sr.Non Code et description
1

ASRA

Exception de vérification de programme

2

AEI0

Erreur d'ID de programme

3

AEI9

Condition d'échec de la carte

4

AEIO

Dupliquer la clé

5

AEIN

Enregistrement en double

6

AEID

Fin de fichier atteinte

sept

AEIS

Le fichier n'est pas ouvert

8

AEIP

Condition de demande non valide

9

AEY7

Non autorisé à utiliser la ressource

dix

APCT

Programme introuvable

11

AFCA

Ensemble de données introuvable

12

AKCT

Erreur de temporisation

13

ABM0

Carte spécifiée introuvable

14

AICA

Programme en boucle infinie

15

AAOW

Erreur de logique interne