Skip to content

Commit f34c3b1

Browse files
committed
Use location of control flow root for ExitNode
1 parent baa4c50 commit f34c3b1

File tree

3 files changed

+149
-151
lines changed

3 files changed

+149
-151
lines changed

go/ql/lib/semmle/go/controlflow/ControlFlowGraphImpl.qll

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -459,9 +459,7 @@ class ExitNode extends ControlFlow::Node, MkExitNode {
459459
override predicate hasLocationInfo(
460460
string filepath, int startline, int startcolumn, int endline, int endcolumn
461461
) {
462-
root.hasLocationInfo(filepath, _, _, endline, endcolumn) and
463-
endline = startline and
464-
endcolumn = startcolumn
462+
root.hasLocationInfo(filepath, startline, startcolumn, endline, endcolumn)
465463
}
466464
}
467465

go/ql/test/extractor-tests/go1.17/CFG.expected

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,7 @@ edges
77
| conversions.go:5:6:5:8 | skip | conversions.go:5:1:5:29 | function declaration |
88
| conversions.go:5:10:5:10 | argument corresponding to _ | conversions.go:5:10:5:10 | initialization of _ |
99
| conversions.go:5:10:5:10 | initialization of _ | conversions.go:5:28:5:29 | skip |
10-
| conversions.go:5:28:5:29 | skip | conversions.go:5:29:5:29 | exit |
10+
| conversions.go:5:28:5:29 | skip | conversions.go:5:1:5:29 | exit |
1111
| conversions.go:7:1:26:1 | entry | conversions.go:8:6:8:6 | skip |
1212
| conversions.go:7:1:26:1 | function declaration | conversions.go:0:0:0:0 | exit |
1313
| conversions.go:7:6:7:9 | skip | conversions.go:7:1:26:1 | function declaration |
@@ -21,8 +21,8 @@ edges
2121
| conversions.go:10:18:10:18 | a | conversions.go:10:21:10:22 | 10 |
2222
| conversions.go:10:21:10:22 | 10 | conversions.go:10:7:10:23 | call to Add |
2323
| conversions.go:11:2:11:4 | use | conversions.go:11:6:11:6 | b |
24+
| conversions.go:11:2:11:7 | call to use | conversions.go:7:1:26:1 | exit |
2425
| conversions.go:11:2:11:7 | call to use | conversions.go:13:6:13:8 | skip |
25-
| conversions.go:11:2:11:7 | call to use | conversions.go:26:1:26:1 | exit |
2626
| conversions.go:11:6:11:6 | b | conversions.go:11:2:11:7 | call to use |
2727
| conversions.go:13:6:13:8 | assignment to arr | conversions.go:14:2:14:6 | skip |
2828
| conversions.go:13:6:13:8 | skip | conversions.go:13:6:13:8 | zero value for arr |
@@ -35,12 +35,12 @@ edges
3535
| conversions.go:14:29:14:30 | 20 | conversions.go:14:11:14:31 | call to Slice |
3636
| conversions.go:17:2:17:4 | assignment to ptr | conversions.go:18:2:18:4 | use |
3737
| conversions.go:17:2:17:4 | skip | conversions.go:17:20:17:24 | slice |
38+
| conversions.go:17:9:17:25 | type conversion | conversions.go:7:1:26:1 | exit |
3839
| conversions.go:17:9:17:25 | type conversion | conversions.go:17:2:17:4 | assignment to ptr |
39-
| conversions.go:17:9:17:25 | type conversion | conversions.go:26:1:26:1 | exit |
4040
| conversions.go:17:20:17:24 | slice | conversions.go:17:9:17:25 | type conversion |
4141
| conversions.go:18:2:18:4 | use | conversions.go:18:6:18:8 | ptr |
42+
| conversions.go:18:2:18:9 | call to use | conversions.go:7:1:26:1 | exit |
4243
| conversions.go:18:2:18:9 | call to use | conversions.go:21:2:21:4 | skip |
43-
| conversions.go:18:2:18:9 | call to use | conversions.go:26:1:26:1 | exit |
4444
| conversions.go:18:6:18:8 | ptr | conversions.go:18:2:18:9 | call to use |
4545
| conversions.go:21:2:21:4 | assignment to str | conversions.go:22:2:22:6 | skip |
4646
| conversions.go:21:2:21:4 | skip | conversions.go:21:9:21:18 | "a string" |
@@ -50,15 +50,15 @@ edges
5050
| conversions.go:22:11:22:21 | type conversion | conversions.go:22:2:22:6 | assignment to bytes |
5151
| conversions.go:22:18:22:20 | str | conversions.go:22:11:22:21 | type conversion |
5252
| conversions.go:23:2:23:4 | use | conversions.go:23:6:23:10 | bytes |
53+
| conversions.go:23:2:23:11 | call to use | conversions.go:7:1:26:1 | exit |
5354
| conversions.go:23:2:23:11 | call to use | conversions.go:24:2:24:6 | skip |
54-
| conversions.go:23:2:23:11 | call to use | conversions.go:26:1:26:1 | exit |
5555
| conversions.go:23:6:23:10 | bytes | conversions.go:23:2:23:11 | call to use |
5656
| conversions.go:24:2:24:6 | assignment to runes | conversions.go:25:2:25:4 | use |
5757
| conversions.go:24:2:24:6 | skip | conversions.go:24:18:24:20 | str |
5858
| conversions.go:24:11:24:21 | type conversion | conversions.go:24:2:24:6 | assignment to runes |
5959
| conversions.go:24:18:24:20 | str | conversions.go:24:11:24:21 | type conversion |
6060
| conversions.go:25:2:25:4 | use | conversions.go:25:6:25:10 | runes |
61-
| conversions.go:25:2:25:11 | call to use | conversions.go:26:1:26:1 | exit |
61+
| conversions.go:25:2:25:11 | call to use | conversions.go:7:1:26:1 | exit |
6262
| conversions.go:25:6:25:10 | runes | conversions.go:25:2:25:11 | call to use |
6363
#select
6464
| |

0 commit comments

Comments
 (0)