*DECK DMLWRT                                                            001850
      PROC DMLWRT (FIT,NEXT,RORD,PKORD,ERRRTRN);
  BEGIN                                                                 001870
 #
* *   DMLWRT - WRITE INTERFACE ROUTINE
*     R. E. FOX                                      4/27/77
* 
* DC  PURPOSE 
* 
*     ISSUE A WRITE REQUEST TO CDCS AND 
*     CHECK FOR AN ERROR CONDITION UPON RETURNING FROM CDCS.
*     ON ERROR, CAUSES A BRANCH TO AN ALTERNATE RETURN IN THE 
*     APPLICATION PROGRAM IF SPECIFIED, ELSE, RETURNS NORMALLY. 
*     RETURN THE FIT STATUS FIELD TO THE APPLICATION PROGRAM
* 
* DC  ENTRY CONDITIONS
* 
* DC  PARAMETERS
* 
*     FIT  --    APPLICATION PROGRAM FIT FOR REALM
* 
*     NEXT --  NEXT FLAG  -- UNUSED PARAMETER 
* 
*     RORD  -- ORDINAL OF THE RECORD TO BE WRITTEN
* 
*     PKORD  --  PRIMARY KEY ORDINAL
* 
*     ERRRTRN  --  (OPTIONAL) ALTERNATE RETURN ON ERROR (FTN 5 ONLY)
*                  WARNING:  DO NOT REFERENCE - MAY NOT BE PRESENT
* 
* DC  ASSUMPTIONS 
* 
*     COMMON BLOCK DB0000 HAS BEEN GENERATED AND INITIALIZED
*     FIT SAVE AREAS ARE INITIALIZED
* 
* 
* DC  EXIT CONDITIONS 
* 
*     UPON RETURN FROM CDCS, THE FIT ES FIELD IS STORED 
*     IN DBSTAT AND IN DBSXXXX AND DBREALM IS SET TO THE
*     NAME OF THE REALM IN THE DML STATEMENT. 
*     CONTROL IS RETURNED TO THE APPLICATION PROGRAM. 
*     THE RETURN POINT CAN BE ALTERED GIVEN AN *ON ERROR* 
*     LABEL AND THE DETECTION OF AN ERROR (FTN 5 ONLY). 
* 
* DC  CALLING ROUTINES
* 
*     DMLWRT IS CALLED FROM THE APPLICATION PROGRAM 
*     AS A RESULT OF A DML WRITE STATEMENT. 
* 
* DC  CALLED ROUTINES 
* 
*     DB$WR2  --     CDCS WRITE INTERFACE ROUTINE 
* 
*     DMLRTRN  --  RETURN ROUTINE--SETS REGISTER TO RETURN PARAMETER
* 
* DC  NON-LOCAL VARIABLES 
* 
*     VARIABLES IN DB0000 WHICH ARE MODIFIED ARE: 
*     DBSTAT, DBSXXXX, DBREALM
*     FIT FIELDS ARE RESTORED FROM THE FIT SAVE AREA. 
* 
* DC  DESCRIPTION 
* 
*     A CALL TO DMLWRT IS GENERATED BY THE PREPASS AS 
*     A RESULT OF A DML WRITE STATEMENT. DMLWRT ISSUES THE WRITE
*     REQUEST TO CDCS, RETURNS THE FIT STATUS FIELDS TO THE APPLICATION 
*     PROGRAM, AND RETURNS CONTROL TO THE APPLICATION PROGRAM.
*     WITH FORTRAN 5, AN ALTERNATE RETURN CAN BE SPECIFIED.  IF AN
*     ERROR IS DETECTED, CONTROL IS PASSED TO THE SPECIFIED LABEL 
*     IN THE APPLICATION PROGRAM. 
* 
 #
      CONTROL EJECT;                                                    001880
      CONTROL DISJOINT;                                                 001890
      CONTROL INERT;                                                    001900
                                                                        001910
                                        #-------------DEFS-------------#
  
      DEF FITSIZE     #35#;             # SIZE OF FIT IN WORDS         #001940
                                                                        001950
# THE FOLLOWING ARE PARAMETERS FROM THE "WRITE" CALLING SEQUENCE       #001960
                                                                        001970
      ARRAY FIT;                 # USER FIT                            #001980
*CALL FITDCLS                                                           001990
                                                                        002000
      ITEM NEXT;                        # NEXT FLAG                    #002010
      ITEM RORD;                        # RECORD ORDINAL               #002020
      ITEM PKORD;                       # PRIMARY KEY ORDINAL          #002030
      ITEM ERRRTRN;                     # ERROR RETURN PARAMETER       #
                                        # WARNING: DO NOT REFERENCE    #
                                                                        002040
# PRIMARY/ALTERNATE KEY ORDINAL PARAMETER TO PASS TO CDCS              #
  
      ARRAY PARM4 [0:0] S(1); 
        BEGIN 
          ITEM P4WORD U(0,0,60); # ENTIRE PARAMETER                    #
          ITEM RCORD U(0,36,12); # RECORD ORDINAL                      #
          ITEM KORD U(0,48,12);  # KEY ORDINAL                         #
        END 
  
# THE FOLLOWING DESCRIBES THE COMMON BLOCK CREATED IN THE FORTRAN      #002050
#     PROGRAM                                                          #002060
                                                                        002070
      COMMON DB0000;                                                    002080
*CALL DB0DCLS                                                           002090
                                                                        002100
                                        #------------XREFS-------------#
  
      XREF
        BEGIN 
        PROC DB$WR2;                    # WRITE INTERFACE ROUTINE      #
        PROC DMLRTRN;                   # SET RETURN REGISTER ROUTINE  #
        END 
  
                                        #----------LOCAL ITEMS---------#
  
      ITEM RTNPARM;                     # RETURN PARAMETER - DMLRTRN   #
  
      CONTROL EJECT;                                                    002180
                                                                        002190
# SET UP POINTER TO REALMBLOCK   #                                      002200
      P<REALMBLOCK> = LOC(FIT) - 4;                                     002210
      P<DBTXXXX> = LOC(FIT) + FITSIZE;                                  000130
                                                                        002220
# PICK UP WSA, KA, KP, KL, AND KT FIELDS FROM                          #002230
# SAVE AREA CREATED BY INVOKE. PUT THESE VALUES IN FIT.                #002240
                                                                        002250
      FITWSA[0] = DBWSA[0];                                             002260
      FITKA[0] = DBKA[0];                                               002270
      FITKEYFIELDS[0] = DBKEYFIELDS[0];                                 000160
      FITKT[0] = DBKT[0];                                               002300
      FITRL[0] = DBMRL[0];                                              000130
      FITMRL[0] = DBMRL[0];                                             000140
                                                                        002310
# SET UP PRIMARY/ALTERNATE KEY ORDINAL PARAMETER                       #
  
      P4WORD[0] = 0;             # ZERO FILL                           #
      RCORD[0] = RORD;           # RECORD ORDINAL                      #
      KORD[0] = PKORD;           # KEY ORDINAL                         #
  
# PERFORM WRITE CALL, PASSING FIT, NEXT FLAG, RECORD ORDINAL,          #002320
# AND PRIMARY/ALTERNATE KEY PARAMETER                                  #
  
      DB$WR2(FIT,NEXT,RORD,PARM4);
                                                                        002360
# RETURN ERROR STATUS FIELD OF FIT                                     #002370
                                                                        002380
      DBSTAT = FITES[0];                                                002390
      DBSXXXX = FITES[0];                                               000310
      DBREALM = DBRXXXX;                                                000320
                                                                        002420
# CHECK ERROR STATUS ON CDCS CALL                                      #
  
      IF (FITES[0] NQ 0)                # IF CDCS/CRM ERROR OCCURRED   #
      THEN
        RTNPARM = 1;                    # SET THE RETURN PARAMETER TO 1#
      ELSE                              #             ELSE             #
        RTNPARM = 0;                    # SET THE RETURN PARAMETER TO 0#
  
# SET THE RETURN REGISTER                                              #
  
      DMLRTRN(RTNPARM); 
  
# RETURN TO THE APPLICATION PROGRAM                                    #
  
      RETURN;                                                           002430
      END                                                               002440
TERM                                                                    002450
