mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Update contrib/trgm_regexp's memory management.
While no code change was necessary for this code to keep working, we don't need to use PG_TRY()/PG_FINALLY() with explicit clean-up while working with regexes anymore. Reviewed-by: Tom Lane <tgl@sss.pgh.pa.us> Discussion: https://postgr.es/m/CA%2BhUKGK3PGKwcKqzoosamn36YW-fsuTdOPPF1i_rtEO%3DnEYKSg%40mail.gmail.com
This commit is contained in:
		| @@ -549,22 +549,9 @@ createTrgmNFA(text *text_re, Oid collation, | |||||||
| 			   REG_ADVANCED | REG_NOSUB, collation); | 			   REG_ADVANCED | REG_NOSUB, collation); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| 	/* | 	trg = createTrgmNFAInternal(®ex, graph, rcontext); | ||||||
| 	 * Since the regexp library allocates its internal data structures with |  | ||||||
| 	 * malloc, we need to use a PG_TRY block to ensure that pg_regfree() gets |  | ||||||
| 	 * done even if there's an error. |  | ||||||
| 	 */ |  | ||||||
| 	PG_TRY(); |  | ||||||
| 	{ |  | ||||||
| 		trg = createTrgmNFAInternal(®ex, graph, rcontext); |  | ||||||
| 	} |  | ||||||
| 	PG_FINALLY(); |  | ||||||
| 	{ |  | ||||||
| 		pg_regfree(®ex); |  | ||||||
| 	} |  | ||||||
| 	PG_END_TRY(); |  | ||||||
|  |  | ||||||
| 	/* Clean up all the cruft we created */ | 	/* Clean up all the cruft we created (including regex) */ | ||||||
| 	MemoryContextSwitchTo(oldcontext); | 	MemoryContextSwitchTo(oldcontext); | ||||||
| 	MemoryContextDelete(tmpcontext); | 	MemoryContextDelete(tmpcontext); | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user