mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Split ExecStoreTuple into ExecStoreHeapTuple and ExecStoreBufferHeapTuple.
Upcoming changes introduce further types of tuple table slots, in preparation of making table storage pluggable. New storage methods will have different representation of tuples, therefore the slot accessor should refer explicitly to heap tuples. Instead of just renaming the functions, split it into one function that accepts heap tuples not residing in buffers, and one accepting ones in buffers. Previously one function was used for both, but that was a bit awkward already, and splitting will allow us to represent slot types for tuples in buffers and normal memory separately. This is split out from the patch introducing abstract slots, as this largely consists out of mechanical changes. Author: Ashutosh Bapat Reviewed-By: Andres Freund Discussion: https://postgr.es/m/20180220224318.gw4oe5jadhpmcdnm@alap3.anarazel.de
This commit is contained in:
		| @@ -1443,10 +1443,9 @@ postgresIterateForeignScan(ForeignScanState *node) | ||||
| 	/* | ||||
| 	 * Return the next tuple. | ||||
| 	 */ | ||||
| 	ExecStoreTuple(fsstate->tuples[fsstate->next_tuple++], | ||||
| 				   slot, | ||||
| 				   InvalidBuffer, | ||||
| 				   false); | ||||
| 	ExecStoreHeapTuple(fsstate->tuples[fsstate->next_tuple++], | ||||
| 					   slot, | ||||
| 					   false); | ||||
|  | ||||
| 	return slot; | ||||
| } | ||||
| @@ -3517,7 +3516,7 @@ store_returning_result(PgFdwModifyState *fmstate, | ||||
| 											NULL, | ||||
| 											fmstate->temp_cxt); | ||||
| 		/* tuple will be deleted when it is cleared from the slot */ | ||||
| 		ExecStoreTuple(newtup, slot, InvalidBuffer, true); | ||||
| 		ExecStoreHeapTuple(newtup, slot, true); | ||||
| 	} | ||||
| 	PG_CATCH(); | ||||
| 	{ | ||||
| @@ -3790,7 +3789,7 @@ get_returning_data(ForeignScanState *node) | ||||
| 												dmstate->retrieved_attrs, | ||||
| 												node, | ||||
| 												dmstate->temp_cxt); | ||||
| 			ExecStoreTuple(newtup, slot, InvalidBuffer, false); | ||||
| 			ExecStoreHeapTuple(newtup, slot, false); | ||||
| 		} | ||||
| 		PG_CATCH(); | ||||
| 		{ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user