mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Reject operator names >= NAMEDATALEN characters. These will not work
anyway, and in assert-enabled builds you are likely to get an assertion failure. Backpatch as far as 7.3; 7.2 seems not to have the problem.
This commit is contained in:
		| @@ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  * |  * | ||||||
|  * IDENTIFICATION |  * IDENTIFICATION | ||||||
|  *	  $Header: /cvsroot/pgsql/src/backend/parser/scan.l,v 1.102.2.1 2002/11/11 03:33:44 tgl Exp $ |  *	  $Header: /cvsroot/pgsql/src/backend/parser/scan.l,v 1.102.2.2 2005/08/16 00:48:58 tgl Exp $ | ||||||
|  * |  * | ||||||
|  *------------------------------------------------------------------------- |  *------------------------------------------------------------------------- | ||||||
|  */ |  */ | ||||||
| @@ -484,6 +484,15 @@ other			. | |||||||
| 							return yytext[0]; | 							return yytext[0]; | ||||||
| 					} | 					} | ||||||
|  |  | ||||||
|  | 					/* | ||||||
|  | 					 * Complain if operator is too long.  Unlike the case | ||||||
|  | 					 * for identifiers, we make this an error not a notice- | ||||||
|  | 					 * and-truncate, because the odds are we are looking at | ||||||
|  | 					 * a syntactic mistake anyway. | ||||||
|  | 					 */ | ||||||
|  | 					if (nchars >= NAMEDATALEN) | ||||||
|  | 						yyerror("operator too long"); | ||||||
|  |  | ||||||
| 					/* Convert "!=" operator to "<>" for compatibility */ | 					/* Convert "!=" operator to "<>" for compatibility */ | ||||||
| 					if (strcmp(yytext, "!=") == 0) | 					if (strcmp(yytext, "!=") == 0) | ||||||
| 						yylval.str = pstrdup("<>"); | 						yylval.str = pstrdup("<>"); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user