Skip to content
Navigation Menu
Toggle navigation
Sign in
Appearance settings
Platform
AI CODE CREATION
GitHub Copilot
Write better code with AI
GitHub Copilot app
Direct agents from issue to merge
MCP Registry
New
Integrate external tools
DEVELOPER WORKFLOWS
Actions
Automate any workflow
Codespaces
Instant dev environments
Issues
Plan and track work
Code Review
Manage code changes
APPLICATION SECURITY
GitHub Advanced Security
Find and fix vulnerabilities
Code security
Secure your code as you build
Secret protection
Stop leaks before they start
EXPLORE
Why GitHub
Documentation
Blog
Changelog
Marketplace
View all features
Solutions
BY COMPANY SIZE
Enterprises
Small and medium teams
Startups
Nonprofits
BY USE CASE
App Modernization
DevSecOps
DevOps
CI/CD
View all use cases
BY INDUSTRY
Healthcare
Financial services
Manufacturing
Government
View all industries
View all solutions
Resources
EXPLORE BY TOPIC
AI
Software Development
DevOps
Security
View all topics
EXPLORE BY TYPE
Customer stories
Events & webinars
Ebooks & reports
Business insights
GitHub Skills
SUPPORT & SERVICES
Documentation
Customer support
Community forum
Trust center
Partners
View all resources
Open Source
COMMUNITY
GitHub Sponsors
Fund open source developers
PROGRAMS
Security Lab
Maintainer Community
Accelerator
GitHub Stars
Archive Program
REPOSITORIES
Topics
Trending
Collections
Enterprise
ENTERPRISE SOLUTIONS
Enterprise platform
AI-powered developer platform
AVAILABLE ADD-ONS
GitHub Advanced Security
Enterprise-grade security features
Copilot for Business
Enterprise-grade AI features
Premium Support
Enterprise-grade 24/7 support
Pricing
Search or jump to...
Search code, repositories, users, issues, pull requests...
Search syntax tips
Provide feedback
Saved searches
Use saved searches to filter your results more quickly
Sign in
Sign up
Appearance settings
Resetting focus
You signed in with another tab or window.
Reload
to refresh your session.
You signed out in another tab or window.
Reload
to refresh your session.
You switched accounts on another tab or window.
Reload
to refresh your session.
Dismiss alert
{{ message }}
Uh oh!
There was an error while loading.
Please reload this page
.
github
/
codeql
Public
Notifications
You must be signed in to change notification settings
Fork
2k
Star
9.8k
Code
Issues
985
Pull requests
417
Discussions
Actions
Projects
Models
Security and quality
0
Insights
Additional navigation options
Code
Issues
Pull requests
Discussions
Actions
Projects
Models
Security and quality
Insights
Files
Expand file tree
main
Breadcrumbs
codeql
/
python
/
ql
/
src
/
Statements
/
NestedLoopsSameVariable.ql
Copy path
Blame
More file actions
Blame
More file actions
Latest commit
History
History
History
31 lines (27 loc) · 1.11 KB
main
Breadcrumbs
codeql
/
python
/
ql
/
src
/
Statements
/
NestedLoopsSameVariable.ql
Copy path
Top
File metadata and controls
Code
Blame
31 lines (27 loc) · 1.11 KB
Raw
Copy raw file
Download raw file
Open symbols panel
Edit and raw actions
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
/**
* @name Nested loops with same variable
* @description Nested loops in which the target variable is the same for each loop make
* the behavior of the loops difficult to understand.
* @kind problem
* @tags quality
* maintainability
* readability
* @problem.severity recommendation
* @sub-severity high
* @precision very-high
* @id py/nested-loops-with-same-variable
*/
import
python
predicate
loop_variable
(
For
f
,
Variable
v
)
{
f
.
getTarget
(
)
.
defines
(
v
)
}
predicate
variableUsedInNestedLoops
(
For
inner
,
For
outer
,
Variable
v
)
{
/* Only treat loops in body as inner loops. Loops in the else clause are ignored. */
outer
.
getBody
(
)
.
contains
(
inner
)
and
loop_variable
(
inner
,
v
)
and
loop_variable
(
outer
,
v
)
and
/* Ignore cases where there is no use of the variable or the only use is in the inner loop */
exists
(
Name
n
|
n
.
uses
(
v
)
and
outer
.
contains
(
n
)
and
not
inner
.
contains
(
n
)
)
}
from
For
inner
,
For
outer
,
Variable
v
where
variableUsedInNestedLoops
(
inner
,
outer
,
v
)
select
inner
,
"Nested for statement uses loop variable '"
+
v
.
getId
(
)
+
"' of enclosing $@."
,
outer
,
"for statement"
You can’t perform that action at this time.