Skip to content

Commit

Permalink
Merge pull request #16603 from aschackmull/dataflow/location
Browse files Browse the repository at this point in the history
Dataflow/Go: Add getLocation to DataFlowCall and DataFlowCallable for easier debugging.
  • Loading branch information
aschackmull authored May 29, 2024
2 parents 06fd16b + 3b12f69 commit 2f95851
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 0 deletions.
17 changes: 17 additions & 0 deletions go/ql/lib/semmle/go/dataflow/internal/DataFlowPrivate.qll
Original file line number Diff line number Diff line change
Expand Up @@ -311,6 +311,13 @@ class DataFlowCallable extends TDataFlowCallable {
.hasLocationInfo(filepath, startline, startcolumn, endline, endcolumn)
}

/** Gets the location of this callable. */
Location getLocation() {
result = getCallableLocation(this.asCallable()) or
result = this.asFileScope().getLocation() or
result = getCallableLocation(this.asSummarizedCallable())
}

/** Gets a best-effort total ordering. */
int totalorder() {
this =
Expand All @@ -322,6 +329,13 @@ class DataFlowCallable extends TDataFlowCallable {
}
}

private Location getCallableLocation(Callable c) {
exists(string filepath, int startline, int startcolumn, int endline, int endcolumn |
c.hasLocationInfo(filepath, startline, startcolumn, endline, endcolumn) and
result.hasLocationInfo(filepath, startline, startcolumn, endline, endcolumn)
)
}

/** A function call relevant for data flow. */
class DataFlowCall extends Expr {
DataFlow::CallNode call;
Expand All @@ -344,6 +358,9 @@ class DataFlowCall extends Expr {
not exists(this.getEnclosingFunction()) and result.asFileScope() = this.getFile()
}

/** Gets the location of this call. */
Location getLocation() { result = super.getLocation() }

/** Gets a best-effort total ordering. */
int totalorder() {
this =
Expand Down
6 changes: 6 additions & 0 deletions shared/dataflow/codeql/dataflow/DataFlow.qll
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,9 @@ signature module InputSig<LocationSig Location> {
/** Gets a textual representation of this element. */
string toString();

/** Gets the location of this call. */
Location getLocation();

DataFlowCallable getEnclosingCallable();

/** Gets a best-effort total ordering. */
Expand All @@ -82,6 +85,9 @@ signature module InputSig<LocationSig Location> {
/** Gets a textual representation of this element. */
string toString();

/** Gets the location of this callable. */
Location getLocation();

/** Gets a best-effort total ordering. */
int totalorder();
}
Expand Down

0 comments on commit 2f95851

Please sign in to comment.