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: }