mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Detoast query in g_intbig_consistent and copy query in g_int_consistent
This commit is contained in:
		| @@ -32,17 +32,19 @@ Datum | ||||
| g_int_consistent(PG_FUNCTION_ARGS) | ||||
| { | ||||
| 	GISTENTRY  *entry = (GISTENTRY *) PG_GETARG_POINTER(0); | ||||
| 	ArrayType  *query = (ArrayType *) PG_GETARG_POINTER(1); | ||||
| 	ArrayType  *query = (ArrayType *) PG_DETOAST_DATUM_COPY(PG_GETARG_POINTER(1)); | ||||
| 	StrategyNumber strategy = (StrategyNumber) PG_GETARG_UINT16(2); | ||||
| 	bool		retval; | ||||
|  | ||||
| 	if (strategy == BooleanSearchStrategy) | ||||
| 		PG_RETURN_BOOL(execconsistent((QUERYTYPE *) query, | ||||
| 	if (strategy == BooleanSearchStrategy) { | ||||
| 		retval = execconsistent((QUERYTYPE *) query, | ||||
| 								   (ArrayType *) DatumGetPointer(entry->key), | ||||
| 									  GIST_LEAF(entry))); | ||||
| 									  GIST_LEAF(entry)); | ||||
|  | ||||
| 		pfree( query ); | ||||
| 		PG_RETURN_BOOL(retval); | ||||
| 	} | ||||
|  | ||||
| 	/* XXX are we sure it's safe to scribble on the query object here? */ | ||||
| 	/* XXX what about toasted input? */ | ||||
| 	/* sort query for fast search, key is already sorted */ | ||||
| 	CHECKARRVALID(query); | ||||
| 	if (ARRISVOID(query)) | ||||
| @@ -82,6 +84,7 @@ g_int_consistent(PG_FUNCTION_ARGS) | ||||
| 		default: | ||||
| 			retval = FALSE; | ||||
| 	} | ||||
| 	pfree( query ); | ||||
| 	PG_RETURN_BOOL(retval); | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user