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); | ||||
| #endif | ||||
|  | ||||
| 	/* | ||||
| 	 * 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(); | ||||
| 	trg = createTrgmNFAInternal(®ex, graph, rcontext); | ||||
|  | ||||
| 	/* Clean up all the cruft we created */ | ||||
| 	/* Clean up all the cruft we created (including regex) */ | ||||
| 	MemoryContextSwitchTo(oldcontext); | ||||
| 	MemoryContextDelete(tmpcontext); | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user