6.7.1 ユーザ例外通知を利用するクライアントアプリケーションの例(COBOL)

ユーザ例外通知を利用するクライアントアプリケーションの処理の流れとコードの例を示します。太字で示しているコードは,同期型呼び出しのコードと異なる部分です。

なお,ユーザ例外通知を利用するクライアントアプリケーションの例外処理は,同期型呼び出しの場合と同様です。「6.2.3 例外処理のコードの例(COBOL)」を参照してください。

<この項の構成>
(1) サービス利用処理の流れ
(2) サービス利用処理のコード

(1) サービス利用処理の流れ

  1. COBOL adapter for TPBrokerの初期化処理
  2. TPBroker OTMの初期化処理
  3. TSCデーモンへの接続
  4. TSCユーザプロキシの生成および各種設定
  5. TSCユーザプロキシのメソッド呼び出し(サーバ側のオブジェクトの呼び出し)
  6. TSCユーザプロキシの削除
  7. TSCデーモンへの接続解放
  8. TPBroker OTMの終了処理

(2) サービス利用処理のコード

      IDENTIFICATION DIVISION.
      PROGRAM-ID. CLIENT.
      ENVIRONMENT DIVISION.
      CONFIGURATION SECTION.

      DATA DIVISION.
      WORKING-STORAGE SECTION.

      01 ORB-PTR               USAGE POINTER.
      01 DOMAIN-PTR            USAGE POINTER.
      01 CLIENT-PTR            USAGE POINTER.
      01 CLIENT-WAY            PIC S9(9) COMP.
      01 MY-DOMAIN-NAME        PIC X(10).
      01 MY-DOMAIN-NAME-PTR    USAGE POINTER.
      01 MY-DOMAIN-NAME-LEN    PIC S9(9) COMP.
      01 MY-TSCID              PIC X(10).
      01 MY-TSCID-PTR          USAGE POINTER.
      01 MY-TSCID-LEN          PIC S9(9) COMP.
      01 MY-DOMAIN-FLAG        PIC S9(9) COMP VALUE 1.
      01 ACCEPTOR-NAME         PIC X(20).
      01 ACCEPTOR-NAME-PTR     USAGE POINTER VALUE NULL.
      01 ACCEPTOR-NAME-LEN     PIC S9(9) COMP.
      01 PROXY-PTR             USAGE POINTER.

      01 INIT-CLIENT-FLAG      PIC S9(9) COMP.
      01 DOMAIN-CREATE-FLAG    PIC S9(9) COMP.
      01 GET-CLIENT-FLAG       PIC S9(9) COMP.
      01 TSCPRXY-CREATE-FLAG   PIC S9(9) COMP.

      01 CORBA-ENVIRONMENT.
       02 MAJOR                PIC 9(9) COMP.
        88 CORBA-NO-EXCEPTION     VALUE 0.
        88 CORBA-USER-EXCEPTION   VALUE 1.
        88 CORBA-SYSTEM-EXCEPTION VALUE 2.
       02 EXCEP                USAGE POINTER.
       02 FUNC-NAME            PIC X(256).

      01 ERR-CODE              PIC S9(9) COMP.

     * Sequence
      01 EXCEPTION-NAME-PTR        USAGE POINTER.
      01 EXCEPTION-NAME-LEN        PIC S9(9) COMP.
      01 EXCEPTION-NAME            PIC X(30).
      01 EXCEPTION-HANDLE          USAGE POINTER.
      01 EXCEPTION-VALUE           PIC S9(9) COMP.

      LINKAGE SECTION.
      01 ARGC                  PIC 9(9) COMP.
      01 ARGV                  USAGE POINTER.

      PROCEDURE DIVISION USING
              BY VALUE ARGC
              BY VALUE ARGV.

      MOVE 0 TO RETURN-CODE.
      MOVE 0 TO INIT-CLIENT-FLAG.
      MOVE 0 TO DOMAIN-CREATE-FLAG.
      MOVE 0 TO GET-CLIENT-FLAG.
      MOVE 0 TO TSCPRXY-CREATE-FLAG.

     * ORBの初期化処理
      CALL 'CORBA-STUB-INIT-EEEfile'.

     * 1. COBOL adapter for TPBrokerの初期化処理
      CALL 'CORBA_orb_init' USING
              BY REFERENCE ARGC
              BY REFERENCE ARGV
              BY REFERENCE CORBA-ENVIRONMENT
          RETURNING ORB-PTR.
     * 例外チェック
      IF NOT CORBA-NO-EXCEPTION THEN
          CALL 'EXCEPTION-HANDLER' USING
                  BY REFERENCE MAJOR
                  BY REFERENCE CORBA-ENVIRONMENT
          CALL 'CORBA_FreeException' USING
                  EXCEP OF CORBA-ENVIRONMENT
          MOVE 1 TO RETURN-CODE
          GO TO PROG-END
      END-IF.
      DISPLAY 'Success CORBA_orb_init'.

     * 2. TPBroker OTMの初期化処理
      CALL 'TSCAdm-initClient' USING
              BY REFERENCE ARGC
              BY REFERENCE ARGV
              BY VALUE     ORB-PTR
              BY REFERENCE CORBA-ENVIRONMENT.
     * 例外チェック
      IF NOT CORBA-NO-EXCEPTION THEN
          CALL 'OTM-EXCEPTION-HANDLER' USING
                  BY REFERENCE MAJOR
                  BY REFERENCE CORBA-ENVIRONMENT
          CALL 'TSCSysExcept-DELETE' USING
                  BY VALUE EXCEP OF CORBA-ENVIRONMENT
          MOVE 1 TO RETURN-CODE
          GO TO PROG-END
      END-IF.
      DISPLAY 'Success TSCAdm-initClient'.
      MOVE 1 TO INIT-CLIENT-FLAG.

     * 3. TSCデーモンへの接続
     * (1) TSCDomainの生成
      SET MY-DOMAIN-NAME-PTR TO NULL.
      SET MY-TSCID-PTR TO NULL.
      MOVE 1 TO MY-DOMAIN-FLAG.
      CALL 'TSCDomain-NEW' USING
              BY VALUE     MY-DOMAIN-NAME-PTR
              BY VALUE     MY-TSCID-PTR
              BY VALUE     MY-DOMAIN-FLAG
              BY REFERENCE CORBA-ENVIRONMENT
          RETURNING DOMAIN-PTR.
     * 例外チェック
      IF NOT CORBA-NO-EXCEPTION THEN
          CALL 'OTM-EXCEPTION-HANDLER' USING
                  BY REFERENCE MAJOR
                  BY REFERENCE CORBA-ENVIRONMENT
          CALL 'TSCSysExcept-DELETE' USING
                  BY VALUE EXCEP OF CORBA-ENVIRONMENT
          MOVE 1 TO RETURN-CODE
          GO TO PROG-END
      END-IF.
      DISPLAY 'Success TSCDomain-NEW:DomainName = '
                                          MY-DOMAIN-NAME.
      MOVE 1 TO DOMAIN-CREATE-FLAG.

     * (2) TSCClientの取得
      MOVE 1 TO CLIENT-WAY.
      CALL 'TSCAdm-getTSCClient' USING
              BY VALUE     DOMAIN-PTR
              BY VALUE     CLIENT-WAY
              BY REFERENCE CORBA-ENVIRONMENT
          RETURNING CLIENT-PTR.
     * 例外チェック
      IF NOT CORBA-NO-EXCEPTION THEN
          CALL 'OTM-EXCEPTION-HANDLER' USING
                  BY REFERENCE MAJOR
                  BY REFERENCE CORBA-ENVIRONMENT
          CALL 'TSCSysExcept-DELETE' USING
                  BY VALUE EXCEP OF CORBA-ENVIRONMENT
          MOVE 1 TO RETURN-CODE
          GO TO PROG-END
      END-IF.
      DISPLAY 'Success TSCAdm-getTSCClient'.
      MOVE 1 TO GET-CLIENT-FLAG.

     * 4. TSCユーザプロキシの生成および各種設定
     *    IDLインタフェース"CBLClass"用のTSCProxy生成
      SET ACCEPTOR-NAME-PTR TO NULL.
      CALL 'CBLClass_TSCprxy-NEW' USING
              BY VALUE     CLIENT-PTR
              BY VALUE     ACCEPTOR-NAME-PTR
              BY REFERENCE CORBA-ENVIRONMENT
          RETURNING PROXY-PTR.
     * 例外チェック
      IF NOT CORBA-NO-EXCEPTION THEN
          CALL 'OTM-EXCEPTION-HANDLER' USING
                  BY REFERENCE MAJOR
                  BY REFERENCE CORBA-ENVIRONMENT
          CALL 'TSCSysExcept-DELETE' USING
                  BY VALUE EXCEP OF CORBA-ENVIRONMENT
          MOVE 1 TO RETURN-CODE
          GO TO PROG-END
      END-IF.
      DISPLAY 'Success CBLClass_TSCprxy-NEW'.
      MOVE 1 TO TSCPRXY-CREATE-FLAG.

     * 5. TSCユーザプロキシのメソッド呼び出し
     *    (サーバ側のオブジェクトの呼び出し)
     ****************************************************
     * サーバメソッドの呼び出し
     ****************************************************
      DISPLAY 'Start CBLClass-call'.
      CALL 'CBLClass-call' USING
              BY VALUE     PROXY-PTR
              BY REFERENCE CORBA-ENVIRONMENT.
     * 例外チェック
      IF NOT CORBA-NO-EXCEPTION THEN
          CALL 'OTM-EXCEPTION-HANDLER' USING
                  BY REFERENCE MAJOR
                  BY REFERENCE CORBA-ENVIRONMENT
          IF CORBA-SYSTEM-EXCEPTION THEN
              CALL 'TSCSysExcept-DELETE' USING
                      BY VALUE EXCEP OF CORBA-ENVIRONMENT
              MOVE 1 TO RETURN-CODE
              GO TO PROG-END
          END-IF
     * ユーザ例外受信時の処理
          IF CORBA-USER-EXCEPTION THEN
              CALL 'CORBA-get-exception-name' USING
                      BY REFERENCE EXCEP
                  RETURNING EXCEPTION-NAME-PTR
              MOVE 30 TO EXCEPTION-NAME-LEN
              CALL 'CORBA_string_get' USING
                      BY REFERENCE EXCEPTION-NAME-PTR
                      BY REFERENCE EXCEPTION-NAME-LEN
                      BY REFERENCE EXCEPTION-NAME
              DISPLAY 'Exception-name = ' EXCEPTION-NAME
              CALL 'CORBA-GetExceptionHandle' USING
                      BY REFERENCE EXCEP
                  RETURNING EXCEPTION-HANDLE
              CALL 'GET-value-UserExcept' USING
                      BY VALUE EXCEPTION-HANDLE
                  RETURNING EXCEPTION-VALUE
              DISPLAY 'Exception-value = ' EXCEPTION-VALUE
          END-IF
      END-IF.
      DISPLAY 'Success CBLClass-call'.

      PROG-END.

     * 6. TSCユーザプロキシの削除
     *    領域の解放
          IF TSCPRXY-CREATE-FLAG = 1 THEN
              CALL 'CBLClass_TSCprxy-DEL' USING
                      BY VALUE PROXY-PTR
                      BY REFERENCE CORBA-ENVIRONMENT
     * 例外チェック
              IF NOT CORBA-NO-EXCEPTION THEN
                  CALL 'OTM-EXCEPTION-HANDLER' USING
                          BY REFERENCE MAJOR
                          BY REFERENCE CORBA-ENVIRONMENT
                  CALL 'TSCSysExcept-DELETE' USING
                          BY VALUE EXCEP OF CORBA-ENVIRONMENT
                  MOVE 1 TO RETURN-CODE
              END-IF
          END-IF.

     * 7. TSCデーモンへの接続解放
          IF GET-CLIENT-FLAG = 1 THEN
              CALL 'TSCAdm-releaseTSCClient' USING
                      BY VALUE CLIENT-PTR
                      BY REFERENCE CORBA-ENVIRONMENT
     * 例外チェック
              IF NOT CORBA-NO-EXCEPTION THEN
                  CALL 'OTM-EXCEPTION-HANDLER' USING
                          BY REFERENCE MAJOR
                          BY REFERENCE CORBA-ENVIRONMENT
                  CALL 'TSCSysExcept-DELETE' USING
                          BY VALUE EXCEP OF CORBA-ENVIRONMENT
                  MOVE 1 TO RETURN-CODE
              ELSE
                  DISPLAY 'Success TSCAdm-releaseTSCClient'
              END-IF
          END-IF.

          IF DOMAIN-CREATE-FLAG = 1 THEN
              CALL 'TSCDomain-DELETE' USING
                      BY VALUE DOMAIN-PTR
                      BY REFERENCE CORBA-ENVIRONMENT
     * 例外チェック
              IF NOT CORBA-NO-EXCEPTION THEN
                  CALL 'OTM-EXCEPTION-HANDLER' USING
                          BY REFERENCE MAJOR
                          BY REFERENCE CORBA-ENVIRONMENT
                  CALL 'TSCSysExcept-DELETE' USING
                          BY VALUE EXCEP OF CORBA-ENVIRONMENT
                  MOVE 1 TO RETURN-CODE
              END-IF
          END-IF.

     * 8. TPBroker OTMの終了処理
          IF INIT-CLIENT-FLAG = 1 THEN
              CALL 'TSCAdm-endClient' USING
                      BY REFERENCE CORBA-ENVIRONMENT
     * 例外チェック
              IF NOT CORBA-NO-EXCEPTION THEN
                  CALL 'OTM-EXCEPTION-HANDLER' USING
                          BY REFERENCE MAJOR
                          BY REFERENCE CORBA-ENVIRONMENT
                  CALL 'TSCSysExcept-DELETE' USING
                          BY VALUE EXCEP OF CORBA-ENVIRONMENT
                  MOVE 1 TO RETURN-CODE
              ELSE
                  DISPLAY 'Success TSCAdm-endClient'
              END-IF
          END-IF.

      END PROGRAM CLIENT.