Skip to content
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -767,10 +767,11 @@ module Public {
*/
class UninitializedNode extends Node {
LocalVariable v;
int indirectionIndex;
Copy link

Copilot AI Mar 11, 2026

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The class-level doc comment for UninitializedNode now understates the behavior: the implementation no longer represents only indirection level 0. Please update the doc comment to mention that the node can represent different indirection indices (and briefly what 0/1/... mean) so query authors don’t misinterpret it.

This issue also appears on line 784 of the same file.

Copilot uses AI. Check for mistakes.
Copy link
Copy Markdown
Contributor

@MathiasVP MathiasVP Mar 12, 2026

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copilot is right here. The changes here are actually a semantically breaking change (which would need a full deprecation cycle).

Instead of doing what you have here, I suggest you do what I hinted at on Slack:

  1. Keep the UninitializedNode as it currently is on main
  2. Create a new class IndirectUninitializedNode which basically the the charpred you have here (and indirectionIndex > 1 to avoid overlap with UninitializedNode)
  3. Add a new predicate LocalVariable asIndirectUninitializedNode(int indirectionIndex) on DataFlow::Node and an convenience predicate with 0 parameters LocalVariable asIndirectUninitializedNode() implemented as result = this.asIndirectUninitializedNode(_).

This avoids a breaking change to the UninitializedNode class and the asUninitializedNode predicate.

Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Addressed in d3066af.


UninitializedNode() {
exists(SsaImpl::Definition def, SsaImpl::SourceVariable sv |
def.getIndirectionIndex() = 0 and
def.getIndirectionIndex() = indirectionIndex and
def.getValue().asInstruction() instanceof UninitializedInstruction and
SsaImpl::defToNode(this, def, sv) and
v = sv.getBaseVariable().(SsaImpl::BaseIRVariable).getIRVariable().getAst()
Expand All @@ -779,6 +780,9 @@ module Public {

/** Gets the uninitialized local variable corresponding to this node. */
LocalVariable getLocalVariable() { result = v }

/** Gets the level of indirection to get to this node. */
Comment thread
jeongsoolee09 marked this conversation as resolved.
Outdated
int getIndirectionIndex() { result = indirectionIndex }
}

/**
Expand Down
Loading