OSDN Git Service

Do a CHECK_FOR_INTERRUPTS immediately before terminating a fastpath
authorTom Lane <tgl@sss.pgh.pa.us>
Wed, 14 Jun 2006 01:24:14 +0000 (01:24 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Wed, 14 Jun 2006 01:24:14 +0000 (01:24 +0000)
function call.  Previously, there may have been no CHECK_FOR_INTERRUPTS
at all in the fastpath code path, making it impossible to cancel an
operation such as \lo_import externally.  This addition doesn't ensure
you can cancel, since your SIGINT may arrive while the backend is idle
waiting for the client, but it gives the largest window we can easily
provide.  Noted while experimenting with new control-C code for psql.

src/backend/tcop/fastpath.c

index 3f769d9..c0ac339 100644 (file)
@@ -8,7 +8,7 @@
  *
  *
  * IDENTIFICATION
- *       $PostgreSQL: pgsql/src/backend/tcop/fastpath.c,v 1.87 2006/06/11 15:49:28 tgl Exp $
+ *       $PostgreSQL: pgsql/src/backend/tcop/fastpath.c,v 1.88 2006/06/14 01:24:14 tgl Exp $
  *
  * NOTES
  *       This cruft is the server side of PQfn.
@@ -382,6 +382,9 @@ HandleFunctionRequest(StringInfo msgBuf)
                retval = (Datum) 0;
        }
 
+       /* ensure we do at least one CHECK_FOR_INTERRUPTS per function call */
+       CHECK_FOR_INTERRUPTS();
+
        SendFunctionResult(retval, fcinfo.isnull, fip->rettype, rformat);
 
        return 0;