Actual source code: zsnesf90.c
1: #include <petscsnes.h>
2: #include <petsc/private/f90impl.h>
4: #if defined(PETSC_HAVE_FORTRAN_CAPS)
5: #define snesgetconvergencehistoryf90_ SNESGETCONVERGENCEHISTORYF90
6: #define snesdestroy_ SNESDESTROY
7: #elif !defined(PETSC_HAVE_FORTRAN_UNDERSCORE)
8: #define snesgetconvergencehistoryf90_ snesgetconvergencehistoryf90
9: #define snesdestroy_ snesdestroy
10: #endif
12: PETSC_EXTERN void snesgetconvergencehistoryf90_(SNES *snes, F90Array1d *r, F90Array1d *fits, PetscInt *n, int *ierr PETSC_F90_2PTR_PROTO(ptrd1) PETSC_F90_2PTR_PROTO(ptrd2))
13: {
14: PetscReal *hist;
15: PetscInt *its;
16: *ierr = SNESGetConvergenceHistory(*snes, &hist, &its, n);
17: if (*ierr) return;
18: *ierr = F90Array1dCreate(hist, MPIU_REAL, 1, *n, r PETSC_F90_2PTR_PARAM(ptrd1));
19: if (*ierr) return;
20: *ierr = F90Array1dCreate(its, MPIU_INT, 1, *n, fits PETSC_F90_2PTR_PARAM(ptrd2));
21: }
23: PETSC_EXTERN void snesdestroy_(SNES *x, int *ierr)
24: {
25: PETSC_FORTRAN_OBJECT_F_DESTROYED_TO_C_NULL(x);
26: *ierr = SNESDestroy(x);
27: if (*ierr) return;
28: PETSC_FORTRAN_OBJECT_C_NULL_TO_F_DESTROYED(x);
29: }