mirror of
				https://github.com/godotengine/godot.git
				synced 2025-10-25 18:54:43 +00:00 
			
		
		
		
	Properly support nested ternary expressions
Fixes 14324.
This commit is contained in:
		
							parent
							
								
									dfb3634c34
								
							
						
					
					
						commit
						2c190b975e
					
				
					 1 changed files with 7 additions and 4 deletions
				
			
		|  | @ -1140,6 +1140,7 @@ GDScriptParser::Node *GDScriptParser::_parse_expression(Node *p_parent, bool p_s | ||||||
| 			bool unary = false; | 			bool unary = false; | ||||||
| 			bool ternary = false; | 			bool ternary = false; | ||||||
| 			bool error = false; | 			bool error = false; | ||||||
|  | 			bool right_to_left = false; | ||||||
| 
 | 
 | ||||||
| 			switch (expression[i].op) { | 			switch (expression[i].op) { | ||||||
| 
 | 
 | ||||||
|  | @ -1194,11 +1195,13 @@ GDScriptParser::Node *GDScriptParser::_parse_expression(Node *p_parent, bool p_s | ||||||
| 				case OperatorNode::OP_TERNARY_IF: | 				case OperatorNode::OP_TERNARY_IF: | ||||||
| 					priority = 14; | 					priority = 14; | ||||||
| 					ternary = true; | 					ternary = true; | ||||||
|  | 					right_to_left = true; | ||||||
| 					break; | 					break; | ||||||
| 				case OperatorNode::OP_TERNARY_ELSE: | 				case OperatorNode::OP_TERNARY_ELSE: | ||||||
| 					priority = 14; | 					priority = 14; | ||||||
| 					error = true; | 					error = true; | ||||||
| 					break; // Errors out when found without IF (since IF would consume it)
 | 					// Rigth-to-left should be false in this case, otherwise it would always error.
 | ||||||
|  | 					break; | ||||||
| 
 | 
 | ||||||
| 				case OperatorNode::OP_ASSIGN: priority = 15; break; | 				case OperatorNode::OP_ASSIGN: priority = 15; break; | ||||||
| 				case OperatorNode::OP_ASSIGN_ADD: priority = 15; break; | 				case OperatorNode::OP_ASSIGN_ADD: priority = 15; break; | ||||||
|  | @ -1218,13 +1221,13 @@ GDScriptParser::Node *GDScriptParser::_parse_expression(Node *p_parent, bool p_s | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 			if (priority < min_priority) { | 			if (priority < min_priority || (right_to_left && priority == min_priority)) { | ||||||
|  | 				// < is used for left to right (default)
 | ||||||
|  | 				// <= is used for right to left
 | ||||||
| 				if (error) { | 				if (error) { | ||||||
| 					_set_error("Unexpected operator"); | 					_set_error("Unexpected operator"); | ||||||
| 					return NULL; | 					return NULL; | ||||||
| 				} | 				} | ||||||
| 				// < is used for left to right (default)
 |  | ||||||
| 				// <= is used for right to left
 |  | ||||||
| 				next_op = i; | 				next_op = i; | ||||||
| 				min_priority = priority; | 				min_priority = priority; | ||||||
| 				is_unary = unary; | 				is_unary = unary; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Bojidar Marinov
						Bojidar Marinov