mirror of
				https://github.com/pocketpy/pocketpy
				synced 2025-10-20 19:40:18 +00:00 
			
		
		
		
	add a=b=1 syntax
				
					
				
			This commit is contained in:
		
							parent
							
								
									ada232c079
								
							
						
					
					
						commit
						274f74818f
					
				| @ -30,7 +30,7 @@ The easiest way to test a feature is to [try it on your browser](https://pocketp | |||||||
| 8.  `else` clause in try..except. | 8.  `else` clause in try..except. | ||||||
| 9.  Inplace methods like `__iadd__` and `__imul__`. | 9.  Inplace methods like `__iadd__` and `__imul__`. | ||||||
| 10. `__del__` in class definition. | 10. `__del__` in class definition. | ||||||
| 11. `a = b = 1`, use `a, b = 1, 1` instead. | 11. Multiple inheritance. | ||||||
| 
 | 
 | ||||||
| ## Different behaviors | ## Different behaviors | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -646,40 +646,42 @@ __SUBSCR_END: | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     bool try_compile_assignment(){ |     bool try_compile_assignment(){ | ||||||
|         Expr* lhs_p = ctx()->s_expr.top().get(); |  | ||||||
|         bool inplace; |  | ||||||
|         switch (curr().type) { |         switch (curr().type) { | ||||||
|             case TK("+="): case TK("-="): case TK("*="): case TK("/="): case TK("//="): case TK("%="): |             case TK("+="): case TK("-="): case TK("*="): case TK("/="): case TK("//="): case TK("%="): | ||||||
|             case TK("<<="): case TK(">>="): case TK("&="): case TK("|="): case TK("^="): { |             case TK("<<="): case TK(">>="): case TK("&="): case TK("|="): case TK("^="): { | ||||||
|  |                 Expr* lhs_p = ctx()->s_expr.top().get(); | ||||||
|  |                 if(lhs_p->is_starred()) SyntaxError(); | ||||||
|                 if(ctx()->is_compiling_class) SyntaxError(); |                 if(ctx()->is_compiling_class) SyntaxError(); | ||||||
|                 inplace = true; |  | ||||||
|                 advance(); |                 advance(); | ||||||
|                 auto e = make_expr<BinaryExpr>(); |                 auto e = make_expr<BinaryExpr>(); | ||||||
|                 e->op = prev().type - 1; // -1 to remove =
 |                 e->op = prev().type - 1; // -1 to remove =
 | ||||||
|                 e->lhs = ctx()->s_expr.popx(); |                 e->lhs = ctx()->s_expr.popx(); | ||||||
|                 EXPR_TUPLE(); |                 EXPR_TUPLE(); | ||||||
|                 e->rhs = ctx()->s_expr.popx(); |                 e->rhs = ctx()->s_expr.popx(); | ||||||
|                 ctx()->s_expr.push(std::move(e)); |                 if(e->is_starred()) SyntaxError(); | ||||||
|             } break; |                 e->emit(ctx()); | ||||||
|             case TK("="): |  | ||||||
|                 inplace = false; |  | ||||||
|                 advance(); |  | ||||||
|                 EXPR_TUPLE(); |  | ||||||
|                 break; |  | ||||||
|             default: return false; |  | ||||||
|         } |  | ||||||
|         // std::cout << ctx()->_log_s_expr() << std::endl;
 |  | ||||||
|         Expr_ rhs = ctx()->s_expr.popx(); |  | ||||||
| 
 |  | ||||||
|         if(lhs_p->is_starred() || rhs->is_starred()){ |  | ||||||
|             SyntaxError("can't use starred expression here"); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         rhs->emit(ctx()); |  | ||||||
|                 bool ok = lhs_p->emit_store(ctx()); |                 bool ok = lhs_p->emit_store(ctx()); | ||||||
|                 if(!ok) SyntaxError(); |                 if(!ok) SyntaxError(); | ||||||
|         if(!inplace) ctx()->s_expr.pop(); |             } return true; | ||||||
|         return true; |             case TK("="): { | ||||||
|  |                 int n = 0; | ||||||
|  |                 while(match(TK("="))){ | ||||||
|  |                     EXPR_TUPLE(); | ||||||
|  |                     n += 1; | ||||||
|  |                 } | ||||||
|  |                 // stack size is n+1
 | ||||||
|  |                 Expr_ val = ctx()->s_expr.popx(); | ||||||
|  |                 val->emit(ctx()); | ||||||
|  |                 for(int i=1; i<n; i++) ctx()->emit(OP_DUP_TOP, BC_NOARG, BC_KEEPLINE); | ||||||
|  |                 for(int i=0; i<n; i++){ | ||||||
|  |                     auto e = ctx()->s_expr.popx(); | ||||||
|  |                     if(e->is_starred()) SyntaxError(); | ||||||
|  |                     bool ok = e->emit_store(ctx()); | ||||||
|  |                     if(!ok) SyntaxError(); | ||||||
|  |                 } | ||||||
|  |             } return true; | ||||||
|  |             default: return false; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void compile_stmt() { |     void compile_stmt() { | ||||||
|  | |||||||
							
								
								
									
										10
									
								
								tests/32_assign.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								tests/32_assign.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,10 @@ | |||||||
|  | a = b = 1,2 | ||||||
|  | 
 | ||||||
|  | assert a == b | ||||||
|  | assert a == (1,2) | ||||||
|  | 
 | ||||||
|  | a = 1,2 | ||||||
|  | 
 | ||||||
|  | a = b = c = d = '123' | ||||||
|  | 
 | ||||||
|  | assert a == b == c == d == '123' | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user