diff --git a/src/backend/commands/trigger.c b/src/backend/commands/trigger.c index aef7838eb6e..251c3e81a2f 100644 --- a/src/backend/commands/trigger.c +++ b/src/backend/commands/trigger.c @@ -7,7 +7,7 @@ * Portions Copyright (c) 1994, Regents of the University of California * * IDENTIFICATION - * $PostgreSQL: pgsql/src/backend/commands/trigger.c,v 1.262 2010/02/26 02:00:39 momjian Exp $ + * $PostgreSQL: pgsql/src/backend/commands/trigger.c,v 1.262.4.1 2010/08/19 15:46:24 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -2928,6 +2928,7 @@ afterTriggerAddEvent(AfterTriggerEventList *events, else events->tail->next = chunk; events->tail = chunk; + /* events->tailfree is now out of sync, but we'll fix it below */ } /* @@ -3329,6 +3330,15 @@ afterTriggerInvokeEvents(AfterTriggerEventList *events, { chunk->freeptr = CHUNK_DATA_START(chunk); chunk->endfree = chunk->endptr; + + /* + * If it's last chunk, must sync event list's tailfree too. Note + * that delete_ok must NOT be passed as true if there could be + * stacked AfterTriggerEventList values pointing at this event + * list, since we'd fail to fix their copies of tailfree. + */ + if (chunk == events->tail) + events->tailfree = chunk->freeptr; } }