mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Add a CHECK_FOR_INTERRUPTS() in _bt_buildadd(). This fixes problem
with not responding to query cancel during the last stage of btree index creation.
This commit is contained in:
		| @@ -56,7 +56,7 @@ | |||||||
|  * Portions Copyright (c) 1994, Regents of the University of California |  * Portions Copyright (c) 1994, Regents of the University of California | ||||||
|  * |  * | ||||||
|  * IDENTIFICATION |  * IDENTIFICATION | ||||||
|  *	  $PostgreSQL: pgsql/src/backend/access/nbtree/nbtsort.c,v 1.99 2006/03/05 15:58:21 momjian Exp $ |  *	  $PostgreSQL: pgsql/src/backend/access/nbtree/nbtsort.c,v 1.100 2006/03/10 20:18:15 tgl Exp $ | ||||||
|  * |  * | ||||||
|  *------------------------------------------------------------------------- |  *------------------------------------------------------------------------- | ||||||
|  */ |  */ | ||||||
| @@ -461,6 +461,12 @@ _bt_buildadd(BTWriteState *wstate, BTPageState *state, IndexTuple itup) | |||||||
| 	Size		pgspc; | 	Size		pgspc; | ||||||
| 	Size		itupsz; | 	Size		itupsz; | ||||||
|  |  | ||||||
|  | 	/* | ||||||
|  | 	 * This is a handy place to check for cancel interrupts during the | ||||||
|  | 	 * btree load phase of index creation. | ||||||
|  | 	 */ | ||||||
|  | 	CHECK_FOR_INTERRUPTS(); | ||||||
|  |  | ||||||
| 	npage = state->btps_page; | 	npage = state->btps_page; | ||||||
| 	nblkno = state->btps_blkno; | 	nblkno = state->btps_blkno; | ||||||
| 	last_off = state->btps_lastoff; | 	last_off = state->btps_lastoff; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user