Actual source code: version.c
  1: #include <petscsys.h>
  2: /*@C
  3:     PetscGetVersion - Gets the PETSc version information in a string.
  5:     Not Collective; No Fortran Support
  7:     Input Parameter:
  8: .   len - length of the string
 10:     Output Parameter:
 11: .   version - version string
 13:     Level: developer
 15:     Note:
 16:     For doing runtime checking of supported versions we recommend using `PetscGetVersionNumber()` instead of this routine.
 18: .seealso: `PetscGetProgramName()`, `PetscGetVersionNumber()`
 19: @*/
 21: PetscErrorCode PetscGetVersion(char version[], size_t len)
 22: {
 23: #if (PETSC_VERSION_RELEASE == 1)
 24:   PetscSNPrintf(version, len, "Petsc Release Version %d.%d.%d, %s ", PETSC_VERSION_MAJOR, PETSC_VERSION_MINOR, PETSC_VERSION_SUBMINOR, PETSC_VERSION_DATE);
 25: #else
 26:   PetscSNPrintf(version, len, "Petsc Development GIT revision: %s  GIT Date: %s", PETSC_VERSION_GIT, PETSC_VERSION_DATE_GIT);
 27: #endif
 28:   return 0;
 29: }
 31: /*@C
 32:     PetscGetVersionNumber - Gets the PETSc version information from the library
 34:     Not collective
 36:     Output Parameters:
 37: +   major - the major version (optional, pass NULL if not requested)
 38: .   minor - the minor version (optional, pass NULL if not requested)
 39: .   subminor - the subminor version (patch number)  (optional, pass NULL if not requested)
 40: -   release - indicates the library is from a release, not random git repository  (optional, pass NULL if not requested)
 42:     Level: developer
 44:     Notes:
 45:     The C macros `PETSC_VERSION_MAJOR`, `PETSC_VERSION_MINOR`, `PETSC_VERSION_SUBMINOR`, `PETSC_VERSION_RELEASE` provide the information at
 46:     compile time. This can be used to confirm that the shared library being loaded at runtime has the appropriate version updates.
 48:     This function can be called before `PetscInitialize()`
 50: .seealso: `PetscGetProgramName()`, `PetscGetVersion()`, `PetscInitialize()`
 51: @*/
 52: PetscErrorCode PetscGetVersionNumber(PetscInt *major, PetscInt *minor, PetscInt *subminor, PetscInt *release)
 53: {
 54:   if (major) *major = PETSC_VERSION_MAJOR;
 55:   if (minor) *minor = PETSC_VERSION_MINOR;
 56:   if (subminor) *subminor = PETSC_VERSION_SUBMINOR;
 57:   if (release) *release = PETSC_VERSION_RELEASE;
 58:   return 0;
 59: }