pasando arrays de caracteres de c ++ a fortran

Tengo problemas para pasar matrices de caracteres de c ++ a fortran (f90).

Aquí está mi archivo c ++, 'cmain.cxx':

<code>#include <iostream>

using namespace std;

extern "C" int ftest_( char (*string)[4] );

int main() {
    char string[2][4];

    strcpy(string[0],"abc");
    strcpy(string[1],"xyz");

    cout << "c++: string[0] = '" << string[0] << "'" << endl;
    cout << "c++: string[1] = '" << string[1] << "'" << endl;

    ftest_(string);

    return 0;
}
</code>

Aquí está mi archivo fortran, 'ftest.f90':

<code>SUBROUTINE FTEST(string)

CHARACTER*3 string(2)
CHARACTER*3 expected(2)
data expected(1)/'abc'/
data expected(2)/'xyz'/

DO i=1,2
    WRITE(6,10) i,string(i)
10  FORMAT("fortran: string(",i1,") = '", a, "'" )

    IF(string(i).eq.expected(i)) THEN
        WRITE(6,20) string(i),expected(i)
20      FORMAT("'",a,"' equals '",a,"'")
    ELSE
        WRITE(6,30) string(i),expected(i)
30      FORMAT("'",a,"' does not equal '",a,"'")
    END IF
ENDDO

RETURN
END
</code>

El proceso de construcción es:

<code>gfortran -c -m64   ftest.f90 
g++ -c  cmain.cxx
gfortran -m64 -lstdc++ -gnofor_main -o test ftest.o cmain.o
</code>

Edición: tenga en cuenta que el ejecutable también se puede construir a través de:

<code>g++ -lgfortran -o test ftest.o cmain.o
</code>

Además, se requiere el indicador -m64 ya que estoy ejecutando OSX 10.6.

La salida de la ejecución de 'prueba' es:

<code>c++: string[0] = 'abc'
c++: string[1] = 'xyz'
fortran: string(1) = 'abc'
'abc' equals 'abc'
fortran: string(2) = 'xy'
'xy' does not equal 'xyz'
</code>

Declarar las matrices de caracteres 'cadena' y 'esperado' en ftest.f90 con tamaño 4, es decir:

<code>CHARACTER*4 string(2)
CHARACTER*4 expected(2)
</code>

y la recompilación da el siguiente resultado:

<code>c++: string[0] = 'abc'
c++: string[1] = 'xyz'
fortran: string(1) = 'abc'
'abc' does not equal 'abc '
fortran: string(2) = 'xyz'
'xyz' does not equal 'xyz '
</code>

Declarar las matrices de caracteres en 'cmain.cxx' con tamaño 3, es decir:

<code>extern "C" int ftest_( char (*string)[3] );

int main() {
    char string[2][3];
</code>

y volviendo al tamaño original en el archivo fortran (3), es decir:

<code>CHARACTER*3 string(2)
CHARACTER*3 expected(2)
</code>

y la recompilación da el siguiente resultado:

<code>c++: string[0] = 'abcxyz'
c++: string[1] = 'xyz'
fortran: string(1) = 'abc'
'abc' equals 'abc'
fortran: string(2) = 'xyz'
'xyz' equals 'xyz'
</code>

Entonces, el último caso es el único que funciona, pero aquí asigné 3 caracteres a una matriz de caracteres de tamaño 3, lo que significa que falta el '\ 0' que termina, y conduce a la salida 'abcxyz'. Esto no es aceptable para mi aplicación prevista

Cualquier ayuda sería muy apreciada, esto me está volviendo loco!

Respuestas a la pregunta(3)

Su respuesta a la pregunta