SYNTAX
------

C Syntax
^^^^^^^^

.. code-block:: c

    int MPI_Type_create_hvector(int count, int blocklength, MPI_Aint
        stride, MPI_Datatype oldtype, MPI_Datatype* newtype)

    int MPI_Type_create_hvector_c(MPI_Count count, MPI_Count
        blocklength, MPI_Count stride, MPI_Datatype oldtype,
        MPI_Datatype* newtype)

Fortran Syntax
^^^^^^^^^^^^^^

.. code-block:: fortran

    USE MPI
    ! or the older form: INCLUDE 'mpif.h'
    MPI_TYPE_CREATE_HVECTOR(COUNT, BLOCKLENGTH, STRIDE, OLDTYPE, NEWTYPE, IERROR)
    	INTEGER COUNT, BLOCKLENGTH, OLDTYPE, NEWTYPE, IERROR
    	INTEGER(KIND=MPI_ADDRESS_KIND) STRIDE

Fortran 2008 Syntax
^^^^^^^^^^^^^^^^^^^

.. code-block:: fortran

    USE mpi_f08
    MPI_Type_create_hvector(count, blocklength, stride, oldtype, newtype, ierror)
    	INTEGER, INTENT(IN) :: count, blocklength
    	INTEGER(KIND=MPI_ADDRESS_KIND), INTENT(IN) :: stride
    	TYPE(MPI_Datatype), INTENT(IN) :: oldtype
    	TYPE(MPI_Datatype), INTENT(OUT) :: newtype
    	INTEGER, OPTIONAL, INTENT(OUT) :: ierror

    MPI_Type_create_hvector(count, blocklength, stride, oldtype, newtype, ierror)
    	INTEGER(KIND=MPI_COUNT_KIND), INTENT(IN) :: count, blocklength, stride
    	TYPE(MPI_Datatype), INTENT(IN) :: oldtype
    	TYPE(MPI_Datatype), INTENT(OUT) :: newtype
    	INTEGER, OPTIONAL, INTENT(OUT) :: ierror
