LCOV - code coverage report
Current view: top level - src/backend/utils/error - assert.c (source / functions) Hit Total Coverage
Test: PostgreSQL Lines: 0 8 0.0 %
Date: 2017-09-29 15:12:54 Functions: 0 1 0.0 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : /*-------------------------------------------------------------------------
       2             :  *
       3             :  * assert.c
       4             :  *    Assert code.
       5             :  *
       6             :  * Portions Copyright (c) 1996-2017, PostgreSQL Global Development Group
       7             :  * Portions Copyright (c) 1994, Regents of the University of California
       8             :  *
       9             :  *
      10             :  * IDENTIFICATION
      11             :  *    src/backend/utils/error/assert.c
      12             :  *
      13             :  * NOTE
      14             :  *    This should eventually work with elog()
      15             :  *
      16             :  *-------------------------------------------------------------------------
      17             :  */
      18             : #include "postgres.h"
      19             : 
      20             : #include <unistd.h>
      21             : 
      22             : /*
      23             :  * ExceptionalCondition - Handles the failure of an Assert()
      24             :  */
      25             : void
      26           0 : ExceptionalCondition(const char *conditionName,
      27             :                      const char *errorType,
      28             :                      const char *fileName,
      29             :                      int lineNumber)
      30             : {
      31           0 :     if (!PointerIsValid(conditionName)
      32           0 :         || !PointerIsValid(fileName)
      33           0 :         || !PointerIsValid(errorType))
      34           0 :         write_stderr("TRAP: ExceptionalCondition: bad arguments\n");
      35             :     else
      36             :     {
      37           0 :         write_stderr("TRAP: %s(\"%s\", File: \"%s\", Line: %d)\n",
      38             :                      errorType, conditionName,
      39             :                      fileName, lineNumber);
      40             :     }
      41             : 
      42             :     /* Usually this shouldn't be needed, but make sure the msg went out */
      43           0 :     fflush(stderr);
      44             : 
      45             : #ifdef SLEEP_ON_ASSERT
      46             : 
      47             :     /*
      48             :      * It would be nice to use pg_usleep() here, but only does 2000 sec or 33
      49             :      * minutes, which seems too short.
      50             :      */
      51             :     sleep(1000000);
      52             : #endif
      53             : 
      54           0 :     abort();
      55             : }

Generated by: LCOV version 1.11