/*
  This file contains Fortran stubs for Options routines.
  These are not generated automatically since they require passing strings
  between Fortran and C.
*/

#include <petsc/private/fortranimpl.h>

#if defined(PETSC_HAVE_FORTRAN_CAPS)
#define petscobjectcompose_        PETSCOBJECTCOMPOSE
#define petscobjectquery_          PETSCOBJECTQUERY
#define petscobjectreference_      PETSCOBJECTREFERENCE
#define petscobjectdereference_    PETSCOBJECTDEREFERENCE
#define petscobjectgetreference_   PETSCOBJECTGETREFERENCE
#define petsccudainitialize_       PETSCCUDAINITIALIZE
#elif !defined(PETSC_HAVE_FORTRAN_UNDERSCORE)
#define petscobjectcompose_        petscobjectcompose
#define petscobjectquery_          petscobjectquery
#define petscobjectreference_      petscobjectreference
#define petscobjectdereference_    petscobjectdereference
#define petscobjectgetreference_   petscobjectgetreference
#define petsccudainitialize_       petsccudainitialize
#endif

/* ---------------------------------------------------------------------*/

#if defined(PETSC_HAVE_CUDA)
PETSC_EXTERN void PETSC_STDCALL petsccudainitialize_(MPI_Fint *comm, PetscErrorCode *ierr)
{
  *ierr = PetscCUDAInitialize(MPI_Comm_f2c(*(comm)));
}
#endif

PETSC_EXTERN void PETSC_STDCALL petscobjectcompose_(PetscObject *obj, char *name PETSC_MIXED_LEN(len), PetscObject *ptr, PetscErrorCode *ierr PETSC_END_LEN(len))
{
  char *n1;

  FIXCHAR(name,len,n1);
  *ierr = PetscObjectCompose(*obj, n1, *ptr);if (*ierr) return;
  FREECHAR(name,n1);
}

PETSC_EXTERN void PETSC_STDCALL petscobjectquery_(PetscObject *obj, char *name PETSC_MIXED_LEN(len), PetscObject *ptr, PetscErrorCode *ierr PETSC_END_LEN(len))
{
  char *n1;

  FIXCHAR(name,len,n1);
  *ierr = PetscObjectQuery(*obj, n1, ptr);if (*ierr) return;
  FREECHAR(name,n1);
}

PETSC_EXTERN void  petscobjectreference_(PetscObject *obj,PetscErrorCode *ierr)
{
  *ierr = PetscObjectReference(*obj);
}

PETSC_EXTERN void  petscobjectdereference_(PetscObject *obj,PetscErrorCode *ierr)
{
  *ierr = PetscObjectDereference(*obj);
}

PETSC_EXTERN void  petscobjectgetreference_(PetscObject *obj,PetscInt *ref,PetscErrorCode *ierr)
{
  *ierr = PetscObjectGetReference(*obj,ref);
}
