Skip to content

Commit

Permalink
Merge pull request #17855 from hvitved/csharp/comments-mapped-locations
Browse files Browse the repository at this point in the history
C#: Take mapped locations into account in `Comments.qll`
  • Loading branch information
hvitved authored Oct 29, 2024
2 parents 733158f + 7910af1 commit 813ccb9
Show file tree
Hide file tree
Showing 8 changed files with 16 additions and 3 deletions.
11 changes: 9 additions & 2 deletions csharp/ql/lib/semmle/code/csharp/Comments.qll
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,13 @@
import Element
import Location

private Location unmapLoc(Location l) {
result.(SourceLocation).getMappedLocation() = l
or
not exists(result.(SourceLocation).getMappedLocation()) and
result = l
}

/**
* A single line of comment.
*
Expand All @@ -19,7 +26,7 @@ class CommentLine extends @commentline {
string toString() { none() }

/** Gets the location of this comment line. */
Location getLocation() { commentline_location(this, result) }
Location getLocation() { commentline_location(this, unmapLoc(result)) }

/** Gets the containing comment block. */
CommentBlock getParent() { result.getAChild() = this }
Expand Down Expand Up @@ -159,7 +166,7 @@ class CommentBlock extends @commentblock {
string toString() { result = this.getChild(0).toString() }

/** Gets the location of this comment block */
Location getLocation() { commentblock_location(this, result) }
Location getLocation() { commentblock_location(this, unmapLoc(result)) }

/** Gets the number of lines in this comment block. */
int getNumLines() { result = count(this.getAChild()) }
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
| comments1.cs:1:1:2:46 | // ... | comments1.cs:9:7:9:7 | C | Start of comment1.cs |
| comments1.cs:1:16:1:46 | // ... | comments1.cs:2:9:2:14 | ... ...; | A mapped single-line comment |
| comments1.cs:4:1:4:25 | // ... | comments1.cs:9:7:9:7 | C | 1) Basic comment types |
| comments1.cs:6:1:6:24 | // ... | comments1.cs:9:7:9:7 | C | A single-line comment |
| comments1.cs:8:1:8:18 | /// ... | comments1.cs:9:7:9:7 | C | An XML comment |
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
| comments1.cs:1:16:1:46 | // ... | comments1.cs:1:9:1:14 | ... ...; | A mapped single-line comment |
| comments1.cs:11:1:11:25 | /* ... */ | comments1.cs:9:7:9:7 | C | A multiline comment |
| comments1.cs:13:1:13:20 | // ... | comments1.cs:9:7:9:7 | C | 2) Comment blocks |
| comments1.cs:15:1:15:38 | // ... | comments1.cs:9:7:9:7 | C | A line on its own is a commentblock |
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
| comments1.cs:1:16:1:46 | // ... | trivia.cs:17:5:29:5 | {...} | A mapped single-line comment |
| comments1.cs:36:5:38:41 | /* ... */ | comments1.cs:34:7:34:9 | Foo | |
| comments1.cs:39:13:40:51 | // ... | comments1.cs:34:7:34:9 | Foo | as this line |
| comments1.cs:42:15:42:36 | // ... | comments1.cs:34:7:34:9 | Foo | These are different |
Expand Down
1 change: 1 addition & 0 deletions csharp/ql/test/library-tests/comments/Bindings.expected
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
| comments1.cs:1:16:1:46 | // ... | comments1.cs:1:9:1:14 | ... ...; | A mapped single-line comment |
| comments1.cs:8:1:8:18 | /// ... | comments1.cs:9:7:9:7 | C | An XML comment |
| comments1.cs:36:5:38:41 | /* ... */ | comments1.cs:39:9:39:9 | x | |
| comments1.cs:39:13:40:51 | // ... | comments1.cs:39:9:39:9 | x | as this line |
Expand Down
1 change: 1 addition & 0 deletions csharp/ql/test/library-tests/comments/Comments.expected
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
singlelineComment
| comments1.cs:1:1:2:46 | // ... | comments1.cs:1:1:1:23 | // ... | 2 | Start of comment1.cs | // Start of comment1.cs |
| comments1.cs:1:1:2:46 | // ... | comments1.cs:2:1:2:46 | // ... | 2 | This tests the basic types of comment block | // This tests the basic types of comment block |
| comments1.cs:1:16:1:46 | // ... | comments1.cs:1:16:1:46 | // ... | 1 | A mapped single-line comment | // A mapped single-line comment |
| comments1.cs:4:1:4:25 | // ... | comments1.cs:4:1:4:25 | // ... | 1 | 1) Basic comment types | // 1) Basic comment types |
| comments1.cs:6:1:6:24 | // ... | comments1.cs:6:1:6:24 | // ... | 1 | A single-line comment | // A single-line comment |
| comments1.cs:13:1:13:20 | // ... | comments1.cs:13:1:13:20 | // ... | 1 | 2) Comment blocks | // 2) Comment blocks |
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ mapped
| trivia.cs:19:9:19:11 | trivia.cs:19:9:19:11 | comments1.cs:1:9:1:11 | comments1.cs:1:9:1:11 |
| trivia.cs:19:9:19:14 | trivia.cs:19:9:19:14 | comments1.cs:1:9:1:14 | comments1.cs:1:9:1:14 |
| trivia.cs:19:13:19:13 | trivia.cs:19:13:19:13 | comments1.cs:1:13:1:13 | comments1.cs:1:13:1:13 |
| trivia.cs:19:16:19:46 | trivia.cs:19:16:19:46 | comments1.cs:1:16:1:46 | comments1.cs:1:16:1:46 |
| trivia.cs:20:9:20:11 | trivia.cs:20:9:20:11 | comments1.cs:2:9:2:11 | comments1.cs:2:9:2:11 |
| trivia.cs:20:9:20:14 | trivia.cs:20:9:20:14 | comments1.cs:2:9:2:14 | comments1.cs:2:9:2:14 |
| trivia.cs:20:13:20:13 | trivia.cs:20:13:20:13 | comments1.cs:2:13:2:13 | comments1.cs:2:13:2:13 |
2 changes: 1 addition & 1 deletion csharp/ql/test/library-tests/comments/trivia.cs
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ class Tr1
static void M1()
{
#line 1 "comments1.cs"
int i;
int i; // A mapped single-line comment
int j;
#line default
char c;
Expand Down

0 comments on commit 813ccb9

Please sign in to comment.