mirror of
				https://github.com/astral-sh/ruff.git
				synced 2025-10-26 18:06:43 +00:00 
			
		
		
		
	[syntax-errors]: implement F702 as semantic syntax error (#20869)
	
		
			
	
		
	
	
		
	
		
			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 (macos) (push) Blocked by required conditions
				
			
		
			
				
	
				CI / cargo test (wasm) (push) Blocked by required conditions
				
			
		
			
				
	
				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 / ty completion evaluation (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 (ruff) (push) Blocked by required conditions
				
			
		
			
				
	
				CI / benchmarks instrumented (ty) (push) Blocked by required conditions
				
			
		
			
				
	
				CI / benchmarks walltime (medium|multithreaded) (push) Blocked by required conditions
				
			
		
			
				
	
				CI / benchmarks walltime (small|large) (push) Blocked by required conditions
				
			
		
			
				
	
				[ty Playground] Release / publish (push) Waiting to run
				
			
		
		
	
	
				
					
				
			
		
			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 (macos) (push) Blocked by required conditions
				
			CI / cargo test (wasm) (push) Blocked by required conditions
				
			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 / ty completion evaluation (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 (ruff) (push) Blocked by required conditions
				
			CI / benchmarks instrumented (ty) (push) Blocked by required conditions
				
			CI / benchmarks walltime (medium|multithreaded) (push) Blocked by required conditions
				
			CI / benchmarks walltime (small|large) (push) Blocked by required conditions
				
			[ty Playground] Release / publish (push) Waiting to run
				
			<!-- Thank you for contributing to Ruff/ty! To help us out with reviewing, please consider the following: - Does this pull request include a summary of the change? (See below.) - Does this pull request include a descriptive title? (Please prefix with `[ty]` for ty pull requests.) - Does this pull request include references to any relevant issues? --> ## Summary <!-- What's the purpose of the change? What does it do, and why? --> This PR implements `F702` https://docs.astral.sh/ruff/rules/continue-outside-loop/ as semantic syntax error. ## Test Plan <!-- How was it tested? --> Tests are already previously written in F702 --------- Signed-off-by: 11happy <soni5happy@gmail.com>
This commit is contained in:
		
							parent
							
								
									fd568f0221
								
							
						
					
					
						commit
						73520e4acd
					
				
					 4 changed files with 16 additions and 38 deletions
				
			
		|  | @ -50,15 +50,6 @@ pub(crate) fn statement(stmt: &Stmt, checker: &mut Checker) { | |||
|                 pylint::rules::nonlocal_and_global(checker, nonlocal); | ||||
|             } | ||||
|         } | ||||
|         Stmt::Continue(_) => { | ||||
|             if checker.is_rule_enabled(Rule::ContinueOutsideLoop) { | ||||
|                 pyflakes::rules::continue_outside_loop( | ||||
|                     checker, | ||||
|                     stmt, | ||||
|                     &mut checker.semantic.current_statements().skip(1), | ||||
|                 ); | ||||
|             } | ||||
|         } | ||||
|         Stmt::FunctionDef( | ||||
|             function_def @ ast::StmtFunctionDef { | ||||
|                 is_async, | ||||
|  |  | |||
|  | @ -711,6 +711,12 @@ impl SemanticSyntaxContext for Checker<'_> { | |||
|                     self.report_diagnostic(pyflakes::rules::BreakOutsideLoop, error.range); | ||||
|                 } | ||||
|             } | ||||
|             SemanticSyntaxErrorKind::ContinueOutsideLoop => { | ||||
|                 // F702
 | ||||
|                 if self.is_rule_enabled(Rule::ContinueOutsideLoop) { | ||||
|                     self.report_diagnostic(pyflakes::rules::ContinueOutsideLoop, error.range); | ||||
|                 } | ||||
|             } | ||||
|             SemanticSyntaxErrorKind::ReboundComprehensionVariable | ||||
|             | SemanticSyntaxErrorKind::DuplicateTypeParameter | ||||
|             | SemanticSyntaxErrorKind::MultipleCaseAssignment(_) | ||||
|  |  | |||
|  | @ -1,9 +1,6 @@ | |||
| use ruff_python_ast::{self as ast, Stmt}; | ||||
| 
 | ||||
| use ruff_macros::{ViolationMetadata, derive_message_formats}; | ||||
| use ruff_text_size::Ranged; | ||||
| 
 | ||||
| use crate::{Violation, checkers::ast::Checker}; | ||||
| use crate::Violation; | ||||
| 
 | ||||
| /// ## What it does
 | ||||
| /// Checks for `continue` statements outside of loops.
 | ||||
|  | @ -29,28 +26,3 @@ impl Violation for ContinueOutsideLoop { | |||
|         "`continue` not properly in loop".to_string() | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| /// F702
 | ||||
| pub(crate) fn continue_outside_loop<'a>( | ||||
|     checker: &Checker, | ||||
|     stmt: &'a Stmt, | ||||
|     parents: &mut impl Iterator<Item = &'a Stmt>, | ||||
| ) { | ||||
|     let mut child = stmt; | ||||
|     for parent in parents { | ||||
|         match parent { | ||||
|             Stmt::For(ast::StmtFor { orelse, .. }) | Stmt::While(ast::StmtWhile { orelse, .. }) => { | ||||
|                 if !orelse.contains(child) { | ||||
|                     return; | ||||
|                 } | ||||
|             } | ||||
|             Stmt::FunctionDef(_) | Stmt::ClassDef(_) => { | ||||
|                 break; | ||||
|             } | ||||
|             _ => {} | ||||
|         } | ||||
|         child = parent; | ||||
|     } | ||||
| 
 | ||||
|     checker.report_diagnostic(ContinueOutsideLoop, stmt.range()); | ||||
| } | ||||
|  |  | |||
|  | @ -229,6 +229,11 @@ impl SemanticSyntaxChecker { | |||
|                     Self::add_error(ctx, SemanticSyntaxErrorKind::BreakOutsideLoop, *range); | ||||
|                 } | ||||
|             } | ||||
|             Stmt::Continue(ast::StmtContinue { range, .. }) => { | ||||
|                 if !ctx.in_loop_context() { | ||||
|                     Self::add_error(ctx, SemanticSyntaxErrorKind::ContinueOutsideLoop, *range); | ||||
|                 } | ||||
|             } | ||||
|             _ => {} | ||||
|         } | ||||
| 
 | ||||
|  | @ -1131,6 +1136,7 @@ impl Display for SemanticSyntaxError { | |||
|                 write!(f, "Future feature `{name}` is not defined") | ||||
|             } | ||||
|             SemanticSyntaxErrorKind::BreakOutsideLoop => f.write_str("`break` outside loop"), | ||||
|             SemanticSyntaxErrorKind::ContinueOutsideLoop => f.write_str("`continue` outside loop"), | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | @ -1507,6 +1513,9 @@ pub enum SemanticSyntaxErrorKind { | |||
| 
 | ||||
|     /// Represents the use of a `break` statement outside of a loop.
 | ||||
|     BreakOutsideLoop, | ||||
| 
 | ||||
|     /// Represents the use of a `continue` statement outside of a loop.
 | ||||
|     ContinueOutsideLoop, | ||||
| } | ||||
| 
 | ||||
| #[derive(Debug, Clone, Copy, PartialEq, Eq, Hash, get_size2::GetSize)] | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Bhuminjay Soni
						Bhuminjay Soni