static PetscErrorCode oursnesfunction(SNES snes,Vec x,Vec f,void *ctx) { #if defined(PETSC_HAVE_F90_2PTR_ARG) void* ptr; PetscObjectGetFortranCallback((PetscObject)snes,PETSC_FORTRAN_CALLBACK_CLASS,_cb.function_pgiptr,NULL,&ptr); #endif PetscObjectUseFortranCallback(snes,_cb.function,(SNES*,Vec*,Vec*,void*,PetscErrorCode* PETSC_F90_2PTR_PROTO_NOVAR),(&snes,&x,&f,_ctx,&ierr PETSC_F90_2PTR_PARAM(ptr))); }
#include <petscvec.h> #include <../src/sys/f90-src/f90impl.h> #if defined(PETSC_HAVE_FORTRAN_CAPS) #define vecsetvaluessection_ VECSETVALUESSECTION #elif !defined(PETSC_HAVE_FORTRAN_UNDERSCORE) && !defined(FORTRANDOUBLEUNDERSCORE) #define vecsetvaluessection_ vecsetvaluessection #endif /* Definitions of Fortran Wrapper routines */ PETSC_EXTERN void PETSC_STDCALL vecsetvaluessection_(Vec *v, PetscSection *section, PetscInt *point, F90Array1d *ptr, InsertMode *mode, int *__ierr PETSC_F90_2PTR_PROTO(ptrd)) { PetscScalar *array; *__ierr = F90Array1dAccess(ptr, PETSC_SCALAR, (void**) &array PETSC_F90_2PTR_PARAM(ptrd));if (*__ierr) return; *__ierr = VecSetValuesSection(*v, *section, *point, array, *mode); }
#include "../src/sys/f90-src/f90impl.h" #include "petscda.h" #if defined(PETSC_HAVE_FORTRAN_CAPS) #define dmcompositegetaccessvpvp_ DMCOMPOSITEGETACCESSVPVP #define dmcompositerestoreaccessvpvp_ DMCOMPOSITERESTOREACCESSVPVP #elif !defined(PETSC_HAVE_FORTRAN_UNDERSCORE) #define dmcompositegetaccessvpvp_ dmcompositegetaccessvpvp #define dmcompositerestoreaccessvpvp_ dmcompositerestoreaccessvpvp #endif EXTERN_C_BEGIN void PETSC_STDCALL dmcompositegetaccessvpvp_(DMComposite *dm,Vec *v,Vec *v1,F90Array1d *p1,Vec *v2,F90Array1d *p2,PetscErrorCode *ierr PETSC_F90_2PTR_PROTO(ptrd1) PETSC_F90_2PTR_PROTO(ptrd2)) { PetscScalar *pp1,*pp2; PetscInt np1,np2; *ierr = DMCompositeGetEntries(*dm,0,&np1,0,&np2); *ierr = DMCompositeGetAccess(*dm,*v,v1,&pp1,v2,&pp2); *ierr = F90Array1dCreate(pp1,PETSC_SCALAR,0,np1-1,p1 PETSC_F90_2PTR_PARAM(ptrd1)); *ierr = F90Array1dCreate(pp2,PETSC_SCALAR,0,np2-1,p2 PETSC_F90_2PTR_PARAM(ptrd2)); } void PETSC_STDCALL dmcompositerestoreaccessvpvp_(DMComposite *dm,Vec *v,Vec *v1,F90Array1d *p1,Vec *v2,F90Array1d *p2,PetscErrorCode *ierr PETSC_F90_2PTR_PROTO(ptrd1) PETSC_F90_2PTR_PROTO(ptrd2)) { *ierr = DMCompositeRestoreAccess(*dm,*v,v1,0,v2,0); *ierr = F90Array1dDestroy(p1,PETSC_SCALAR PETSC_F90_2PTR_PARAM(ptrd1)); *ierr = F90Array1dDestroy(p2,PETSC_SCALAR PETSC_F90_2PTR_PARAM(ptrd2)); } EXTERN_C_END