1 | ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc |
---|
2 | c Simply create a welcome message |
---|
3 | ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc |
---|
4 | Integer FUNCTION HELLOF(zoo_main_cfg,zoo_inputs,zoo_outputs) |
---|
5 | & RESULT (R) |
---|
6 | Integer R, ls, iLenStr |
---|
7 | CHARACTER*(1024) zoo_main_cfg(10,30),zoo_inputs(10,30), |
---|
8 | & zoo_outputs(10,30) |
---|
9 | CHARACTER*(1024) TMP |
---|
10 | |
---|
11 | write(0,*) 'Hello '//zoo_inputs(4,1)//' from the Fortran world !' |
---|
12 | |
---|
13 | ls = iLenStr(zoo_inputs(4,1)) |
---|
14 | TMP = zoo_inputs(4,1) |
---|
15 | zoo_outputs(1,1) = 'name'//CHAR(0) |
---|
16 | zoo_outputs(2,1) = 'result'//CHAR(0) |
---|
17 | zoo_outputs(3,1) = 'value'//CHAR(0) |
---|
18 | zoo_outputs(4,1) = 'Hello '//TMP(1:ls)// |
---|
19 | & ' from the Fortran world !'//CHAR(0) |
---|
20 | zoo_outputs(5,1) = 'datatype'//CHAR(0) |
---|
21 | zoo_outputs(6,1) = 'string'//CHAR(0) |
---|
22 | |
---|
23 | R = 3 |
---|
24 | Return |
---|
25 | END |
---|
26 | |
---|
27 | Integer Function iLenStr(cString) |
---|
28 | ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc |
---|
29 | c Compute String Length (thanks to Abdelatif Djerboua from RHEA™) |
---|
30 | ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc |
---|
31 | Character*(*) cString |
---|
32 | Integer iLen,i |
---|
33 | |
---|
34 | iLen = Len(cString) |
---|
35 | Do i=iLen,1,-1 |
---|
36 | If(ichar(cString(i:i)).NE.0) Goto 10 |
---|
37 | EndDo |
---|
38 | i = 1 |
---|
39 | 10 Continue |
---|
40 | iLenStr = i |
---|
41 | |
---|
42 | Return |
---|
43 | End Function iLenStr |
---|
44 | |
---|