mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-31 10:30:33 +03:00 
			
		
		
		
	It seems potentially useful to label our shared libraries with version information, now that a facility exists for retrieving that. This patch labels them with the PG_VERSION string. There was some discussion about using semantic versioning conventions, but that doesn't seem terribly helpful for modules with no SQL-level presence; and for those that do have SQL objects, we typically expect them to support multiple revisions of the SQL definitions, so it'd still not be very helpful. I did not label any of src/test/modules/. It seems unnecessary since we don't install those, and besides there ought to be someplace that still provides test coverage for the original PG_MODULE_MAGIC macro. Author: Tom Lane <tgl@sss.pgh.pa.us> Discussion: https://postgr.es/m/dd4d1b59-d0fe-49d5-b28f-1e463b68fa32@gmail.com
		
			
				
	
	
		
			85 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * contrib/btree_gist/btree_gist.c
 | |
|  */
 | |
| #include "postgres.h"
 | |
| 
 | |
| #include "access/cmptype.h"
 | |
| #include "access/stratnum.h"
 | |
| #include "utils/builtins.h"
 | |
| 
 | |
| PG_MODULE_MAGIC_EXT(
 | |
| 					.name = "btree_gist",
 | |
| 					.version = PG_VERSION
 | |
| );
 | |
| 
 | |
| PG_FUNCTION_INFO_V1(gbt_decompress);
 | |
| PG_FUNCTION_INFO_V1(gbtreekey_in);
 | |
| PG_FUNCTION_INFO_V1(gbtreekey_out);
 | |
| PG_FUNCTION_INFO_V1(gist_stratnum_btree);
 | |
| 
 | |
| /**************************************************
 | |
|  * In/Out for keys
 | |
|  **************************************************/
 | |
| 
 | |
| 
 | |
| Datum
 | |
| gbtreekey_in(PG_FUNCTION_ARGS)
 | |
| {
 | |
| 	Oid			typioparam = PG_GETARG_OID(1);
 | |
| 
 | |
| 	ereport(ERROR,
 | |
| 			(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
 | |
| 			 errmsg("cannot accept a value of type %s",
 | |
| 					format_type_extended(typioparam, -1,
 | |
| 										 FORMAT_TYPE_ALLOW_INVALID))));
 | |
| 
 | |
| 	PG_RETURN_VOID();			/* keep compiler quiet */
 | |
| }
 | |
| 
 | |
| Datum
 | |
| gbtreekey_out(PG_FUNCTION_ARGS)
 | |
| {
 | |
| 	/* Sadly, we do not receive any indication of the specific type */
 | |
| 	ereport(ERROR,
 | |
| 			(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
 | |
| 			 errmsg("cannot display a value of type %s", "gbtreekey?")));
 | |
| 
 | |
| 	PG_RETURN_VOID();			/* keep compiler quiet */
 | |
| }
 | |
| 
 | |
| 
 | |
| /*
 | |
| ** GiST DeCompress methods
 | |
| ** do not do anything.
 | |
| */
 | |
| Datum
 | |
| gbt_decompress(PG_FUNCTION_ARGS)
 | |
| {
 | |
| 	PG_RETURN_POINTER(PG_GETARG_POINTER(0));
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Returns the btree number for supported operators, otherwise invalid.
 | |
|  */
 | |
| Datum
 | |
| gist_stratnum_btree(PG_FUNCTION_ARGS)
 | |
| {
 | |
| 	CompareType cmptype = PG_GETARG_INT32(0);
 | |
| 
 | |
| 	switch (cmptype)
 | |
| 	{
 | |
| 		case COMPARE_EQ:
 | |
| 			PG_RETURN_UINT16(BTEqualStrategyNumber);
 | |
| 		case COMPARE_LT:
 | |
| 			PG_RETURN_UINT16(BTLessStrategyNumber);
 | |
| 		case COMPARE_LE:
 | |
| 			PG_RETURN_UINT16(BTLessEqualStrategyNumber);
 | |
| 		case COMPARE_GT:
 | |
| 			PG_RETURN_UINT16(BTGreaterStrategyNumber);
 | |
| 		case COMPARE_GE:
 | |
| 			PG_RETURN_UINT16(BTGreaterEqualStrategyNumber);
 | |
| 		default:
 | |
| 			PG_RETURN_UINT16(InvalidStrategy);
 | |
| 	}
 | |
| }
 |