#include #include <../src/sys/f90-src/f90impl.h> #if defined(PETSC_HAVE_FORTRAN_CAPS) #define vecgetarraymystruct_ VECGETARRAYMYSTRUCT #define vecrestorearraymystruct_ VECRESTOREARRAYMYSTRUCT #elif !defined(PETSC_HAVE_FORTRAN_UNDERSCORE) #define vecgetarraymystruct_ vecgetarraymystruct #define vecrestorearraymystruct_ vecrestorearraymystruct #endif PETSC_EXTERN void PETSC_STDCALL vecgetarraymystruct_(Vec *x,F90Array1d *ptr,int *__ierr PETSC_F90_2PTR_PROTO(ptrd)) { PetscScalar *fa; PetscInt len; if (!ptr) { *__ierr = PetscError(((PetscObject)*x)->comm,__LINE__,PETSC_FUNCTION_NAME,__FILE__,__SDIR__,PETSC_ERR_ARG_BADPTR,PETSC_ERROR_INITIAL,"ptr==NULL, maybe #include is missing?"); return; } *__ierr = VecGetArray(*x,&fa); if (*__ierr) return; *__ierr = VecGetLocalSize(*x,&len); if (*__ierr) return; *__ierr = F90Array1dCreate(fa,PETSC_SCALAR,1,len,ptr PETSC_F90_2PTR_PARAM(ptrd)); } PETSC_EXTERN void PETSC_STDCALL vecrestorearraymystruct_(Vec *x,F90Array1d *ptr,int *__ierr PETSC_F90_2PTR_PROTO(ptrd)) { PetscScalar *fa; *__ierr = F90Array1dAccess(ptr,PETSC_SCALAR,(void**)&fa PETSC_F90_2PTR_PARAM(ptrd));if (*__ierr) return; *__ierr = F90Array1dDestroy(ptr,PETSC_SCALAR PETSC_F90_2PTR_PARAM(ptrd));if (*__ierr) return; *__ierr = VecRestoreArray(*x,&fa); }