1c4762a1bSJed Brown 2c4762a1bSJed Brown static char help[] = "Demonstrates PETSc error handlers.\n"; 3c4762a1bSJed Brown 4c4762a1bSJed Brown #include <petscsys.h> 5c4762a1bSJed Brown 6c4762a1bSJed Brown int CreateError(int n) 7c4762a1bSJed Brown { 82c71b3e2SJacob Faibussowitsch PetscCheckFalse(!n,PETSC_COMM_SELF,PETSC_ERR_USER,"Error Created"); 9*5f80ce2aSJacob Faibussowitsch CHKERRQ(CreateError(n-1)); 10c4762a1bSJed Brown return 0; 11c4762a1bSJed Brown } 12c4762a1bSJed Brown 13c4762a1bSJed Brown int main(int argc,char **argv) 14c4762a1bSJed Brown { 15c4762a1bSJed Brown PetscErrorCode ierr; 16c4762a1bSJed Brown ierr = PetscInitialize(&argc,&argv,(char*)0,help);if (ierr) return ierr; 17*5f80ce2aSJacob Faibussowitsch CHKERRQ(PetscFPrintf(PETSC_COMM_WORLD,stdout,"Demonstrates PETSc Error Handlers\n")); 18*5f80ce2aSJacob Faibussowitsch CHKERRQ(PetscFPrintf(PETSC_COMM_WORLD,stdout,"The error is a contrived error to test error handling\n")); 19*5f80ce2aSJacob Faibussowitsch CHKERRQ(PetscSynchronizedFlush(PETSC_COMM_WORLD,PETSC_STDOUT)); 20*5f80ce2aSJacob Faibussowitsch CHKERRQ(CreateError(5)); 21c4762a1bSJed Brown ierr = PetscFinalize(); 22c4762a1bSJed Brown return ierr; 23c4762a1bSJed Brown } 24c4762a1bSJed Brown 25c4762a1bSJed Brown /*TEST 26c4762a1bSJed Brown 27c4762a1bSJed Brown # Testing errors so only look for errors 28c4762a1bSJed Brown test: 29c4762a1bSJed Brown args: -error_output_stdout 30c4762a1bSJed Brown filter: egrep "(PETSC ERROR)" | egrep "(Error Created|CreateError\(\)|main\(\))" | cut -f1,2,3,4,5,6 -d " " 31c4762a1bSJed Brown TODO: Does not always produce exactly expected output on all systems for all runs 32c4762a1bSJed Brown 33c4762a1bSJed Brown TEST*/ 34