mirror of
				https://github.com/astral-sh/ruff.git
				synced 2025-10-26 18:06:43 +00:00 
			
		
		
		
	 7b4103bcb6
			
		
	
	
		7b4103bcb6
		
			
		
	
	
	
		
			
	
		
	
	
		
			Some checks are pending
		
		
	
	CI / Determine changes (push) Waiting to run
				
			CI / cargo fmt (push) Waiting to run
				
			CI / cargo clippy (push) Blocked by required conditions
				
			CI / cargo test (linux) (push) Blocked by required conditions
				
			CI / cargo test (linux, release) (push) Blocked by required conditions
				
			CI / cargo test (windows) (push) Blocked by required conditions
				
			CI / cargo test (wasm) (push) Blocked by required conditions
				
			CI / cargo build (release) (push) Waiting to run
				
			CI / cargo build (msrv) (push) Blocked by required conditions
				
			CI / cargo fuzz build (push) Blocked by required conditions
				
			CI / fuzz parser (push) Blocked by required conditions
				
			CI / test scripts (push) Blocked by required conditions
				
			CI / ecosystem (push) Blocked by required conditions
				
			CI / Fuzz for new ty panics (push) Blocked by required conditions
				
			CI / cargo shear (push) Blocked by required conditions
				
			CI / python package (push) Waiting to run
				
			CI / pre-commit (push) Waiting to run
				
			CI / mkdocs (push) Waiting to run
				
			CI / formatter instabilities and black similarity (push) Blocked by required conditions
				
			CI / test ruff-lsp (push) Blocked by required conditions
				
			CI / check playground (push) Blocked by required conditions
				
			CI / benchmarks-instrumented (push) Blocked by required conditions
				
			CI / benchmarks-walltime (push) Blocked by required conditions
				
			[ty Playground] Release / publish (push) Waiting to run
				
			
		
			
				
	
	
	
	
		
			1.9 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	
			1.9 KiB
		
	
	
	
	
	
	
	
Binary operations on tuples
Concatenation for heterogeneous tuples
reveal_type((1, 2) + (3, 4))  # revealed: tuple[Literal[1, 2, 3, 4], ...]
reveal_type(() + (1, 2))  # revealed: tuple[Literal[1, 2], ...]
reveal_type((1, 2) + ())  # revealed: tuple[Literal[1, 2], ...]
reveal_type(() + ())  # revealed: tuple[()]
def _(x: tuple[int, str], y: tuple[None, tuple[int]]):
    reveal_type(x + y)  # revealed: tuple[int | str | None | tuple[int], ...]
    reveal_type(y + x)  # revealed: tuple[None | tuple[int] | int | str, ...]
Concatenation for homogeneous tuples
def _(x: tuple[int, ...], y: tuple[str, ...]):
    reveal_type(x + x)  # revealed: tuple[int, ...]
    reveal_type(x + y)  # revealed: tuple[int | str, ...]
    reveal_type((1, 2) + x)  # revealed: tuple[int, ...]
    reveal_type(x + (3, 4))  # revealed: tuple[int, ...]
    reveal_type((1, 2) + x + (3, 4))  # revealed: tuple[int, ...]
    reveal_type((1, 2) + y + (3, 4) + x)  # revealed: tuple[int | str, ...]
We get the same results even when we use a legacy type alias, even though this involves first
inferring the tuple[...] expression as a value form. (Doing so gives a generic alias of the
tuple type, but as a special case, we include the full detailed tuple element specification in
specializations of tuple.)
from typing import Literal
OneTwo = tuple[Literal[1], Literal[2]]
ThreeFour = tuple[Literal[3], Literal[4]]
IntTuple = tuple[int, ...]
StrTuple = tuple[str, ...]
def _(one_two: OneTwo, x: IntTuple, y: StrTuple, three_four: ThreeFour):
    reveal_type(x + x)  # revealed: tuple[int, ...]
    reveal_type(x + y)  # revealed: tuple[int | str, ...]
    reveal_type(one_two + x)  # revealed: tuple[int, ...]
    reveal_type(x + three_four)  # revealed: tuple[int, ...]
    reveal_type(one_two + x + three_four)  # revealed: tuple[int, ...]
    reveal_type(one_two + y + three_four + x)  # revealed: tuple[int | str, ...]