如何在Cobol中打印变量名称

时间:2019-01-17 09:25:44

标签: c variables cobol

我试图将cobol程序中的变量名传递给C函数。

   01 Message.
         03 varA         PIC X(32).
         03 varB         PIC X(32).

考虑到这个函数将在许多程序中使用并且变量Message的结构每次都不同的事实,我如何将C的变量名传递给C函数? 我已经准备考虑使另一个组数据项包含变量名,但这对我来说不是一个好的解决方案。

我正在AIX上使用Microfocus Server Express v5.1。

1 个答案:

答案 0 :(得分:0)

  
    

如何将变量名称传递给C函数?

  

不可能直接用CALL USING传递变量名;至少,没有比组数据项更好的一个。

我在这里所做的是使用STRING语句和REPLACE语句创建一个类似JSON的对象来传递名称/值对。我之所以选择此方法,是因为C可以调用许多开源库来解码JSON对象。在文本长度和要传递的变量数方面,它也非常灵活。

[Ed。更改了代码,以将所有STRING语句数据项放置在REPLACE语句中。更改了一些名称以反映“名称/值”对。已将字符串长度代码删除到嵌套程序。]

   program-id. call-c.
   data division.
   working-storage section.
   1 msg.
    2 varA pic x(32) value "Message 1".
    2 varB pic x(32) value "Message 2".
   1 lengths binary.
    2 len-1 pic 9(4).
    2 len-2 pic 9(4).
   replace
       ==name-1== by =="varA"==
           ==value-1== by ==varA(1:len-1)==
       ==name-2== by =="varB"==
           ==value-2== by ==varB(1:len-2)==
       ==newline== by ==x"0a"==
       .
   1 json-string pic x(256).
   procedure division.
   begin.
       compute len-1 = function length (varA)
       call "rtrim-len" using varA len-1

       compute len-2 = function length (varB)
       call "rtrim-len" using varB len-2

       string
           "{" newline
               quote name-1 quote ": "
                 quote value-1 quote "," newline
               quote name-2 quote ": "
                 quote value-2 quote newline
           "}" x"00"
           delimited size into json-string
       call "c_prog" using
           by reference json-string
       stop run
       .

   program-id. rtrim-len.
   data division.
   linkage section.
   1 str pic x(256).
   1 str-len binary pic 9(4).
   procedure division using str str-len.
   begin.
       perform varying str-len from str-len by -1
       until str-len < 1 or str (str-len:1) not = space
           continue
       end-perform
       exit program
       .
   end program rtrim-len.
   end program call-c.

一个COBOL程序来代替被称为C的程序。

   program-id. "c_prog".
   data division.
   working-storage section.
   1 json-string-count binary pic 9(4).
   1 json-string-pos binary pic 9(4).
   1 json-text-count binary pic 9(4).
   1 json-text pic x(64).
   linkage section.
   1 json-string pic x(256).
   procedure division using json-string.
   begin.
       move 0 to json-string-count
       inspect json-string tallying
           json-string-count for characters before x"00"
       move 1 to json-string-pos
       perform until json-string-pos > json-string-count
           unstring json-string delimited x"0a" or x"00"
               into json-text count json-text-count
               pointer json-string-pos
           display json-text (1:json-text-count)
       end-perform
       exit program
       .
   end program "c_prog".

输出:

{
"varA": "Message 1",
"varB": "Message 2"
}

如果有TRIM函数可用,则不需要长度计算,数据项和嵌套程序,并且REPLACE语句变为

   replace
       ==name-1== by =="varA"==
           ==value-1== by ==trim(varA)==
       ==name-2== by =="varB"==
           ==value-2== by ==trim(varB)==
       ==newline== by ==x"0a"==
       .