mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-24 01:29:19 +03:00 
			
		
		
		
	Convert oidvector and int2vector into variable-length arrays. This
change saves a great deal of space in pg_proc and its primary index, and it eliminates the former requirement that INDEX_MAX_KEYS and FUNC_MAX_ARGS have the same value. INDEX_MAX_KEYS is still embedded in the on-disk representation (because it affects index tuple header size), but FUNC_MAX_ARGS is not. I believe it would now be possible to increase FUNC_MAX_ARGS at little cost, but haven't experimented yet. There are still a lot of vestigial references to FUNC_MAX_ARGS, which I will clean up in a separate pass. However, getting rid of it altogether would require changing the FunctionCallInfoData struct, and I'm not sure I want to buy into that.
This commit is contained in:
		| @@ -8,7 +8,7 @@ | ||||
|  * | ||||
|  * | ||||
|  * IDENTIFICATION | ||||
|  *	  $PostgreSQL: pgsql/src/backend/utils/adt/arrayfuncs.c,v 1.117 2005/03/24 21:50:37 tgl Exp $ | ||||
|  *	  $PostgreSQL: pgsql/src/backend/utils/adt/arrayfuncs.c,v 1.118 2005/03/29 00:17:08 tgl Exp $ | ||||
|  * | ||||
|  *------------------------------------------------------------------------- | ||||
|  */ | ||||
| @@ -56,7 +56,7 @@ | ||||
|  * | ||||
|  * | ||||
|  * There are also some "fixed-length array" datatypes, such as NAME and | ||||
|  * OIDVECTOR.  These are simply a sequence of a fixed number of items each | ||||
|  * POINT.  These are simply a sequence of a fixed number of items each | ||||
|  * of a fixed-length datatype, with no overhead; the item size must be | ||||
|  * a multiple of its alignment requirement, because we do no padding. | ||||
|  * We support subscripting on these types, but array_in() and array_out() | ||||
|   | ||||
		Reference in New Issue
	
	Block a user