Actual source code: ziscoloringf90.c
1: #include <petscis.h>
2: #include <petsc/private/ftnimpl.h>
4: #if defined(PETSC_HAVE_FORTRAN_CAPS)
5: #define iscoloringgetis_ ISCOLORINGGETIS
6: #define iscoloringrestoreis_ ISCOLORINGRESTOREIS
7: #elif !defined(PETSC_HAVE_FORTRAN_UNDERSCORE)
8: #define iscoloringgetis_ iscoloringgetis
9: #define iscoloringrestoreis_ iscoloringrestoreis
10: #endif
12: PETSC_EXTERN void iscoloringgetis_(ISColoring *iscoloring, PetscCopyMode *mode, PetscInt *n, F90Array1d *ptr, int *ierr PETSC_F90_2PTR_PROTO(ptrd))
13: {
14: IS *lis;
16: *ierr = ISColoringGetIS(*iscoloring, *mode, n, &lis);
17: if (*ierr) return;
18: *ierr = F90Array1dCreate(lis, MPIU_FORTRANADDR, 1, *n, ptr PETSC_F90_2PTR_PARAM(ptrd));
19: }
21: PETSC_EXTERN void iscoloringrestoreis_(ISColoring *iscoloring, PetscCopyMode *mode, F90Array1d *ptr, int *ierr PETSC_F90_2PTR_PROTO(ptrd))
22: {
23: IS *is;
25: *ierr = F90Array1dAccess(ptr, MPIU_FORTRANADDR, (void **)&is PETSC_F90_2PTR_PARAM(ptrd));
26: if (*ierr) return;
27: *ierr = F90Array1dDestroy(ptr, MPIU_FORTRANADDR PETSC_F90_2PTR_PARAM(ptrd));
28: if (*ierr) return;
29: *ierr = ISColoringRestoreIS(*iscoloring, *mode, &is);
30: }