Commit 78f3373
fix(analyzer): correct tree-sitter resolver name→def pairing
The per-module symbol table in `_index_file` was built by zipping two
independently-grouped `QueryCursor.captures()` lists (`@name` and `@def`).
When `@def` positions shift relative to `@name` (e.g. decorated defs), the
zip mis-pairs names with definitions, so imported-call resolution attaches
CALLS edges to the wrong target — producing phantom edges to functions whose
token never appears at the call site.
Fix: iterate per-match via a `_matches()` helper wrapping
`QueryCursor.matches()`, which guarantees each match's `@name`/`@def`
captures belong together. Applied across all four indexing loops
(top-level funcs, classes, assigns, class methods).
Impact (deterministic graph-vs-jedi-oracle caller bench, n=40, paired,
identical harness — only the resolver differs):
uxarray CALLS macro-F1 0.178 → 0.713 (median 0.0 → 0.94)
arkouda CALLS macro-F1 0.031 → 0.262
Adds two regression tests asserting each imported call resolves to the def
whose name matches exactly (10 top-level functions, 8 classes).
Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>1 parent 7d12be1 commit 78f3373
2 files changed
Lines changed: 97 additions & 26 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
167 | 167 | | |
168 | 168 | | |
169 | 169 | | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
170 | 185 | | |
171 | 186 | | |
172 | 187 | | |
| |||
217 | 232 | | |
218 | 233 | | |
219 | 234 | | |
220 | | - | |
221 | | - | |
222 | | - | |
223 | | - | |
224 | | - | |
225 | | - | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
226 | 242 | | |
227 | 243 | | |
228 | 244 | | |
229 | 245 | | |
230 | | - | |
231 | | - | |
232 | | - | |
233 | | - | |
234 | | - | |
235 | | - | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
236 | 253 | | |
237 | 254 | | |
238 | 255 | | |
239 | 256 | | |
240 | | - | |
241 | | - | |
242 | | - | |
243 | | - | |
244 | | - | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
245 | 263 | | |
246 | 264 | | |
247 | | - | |
| 265 | + | |
248 | 266 | | |
249 | 267 | | |
250 | 268 | | |
251 | 269 | | |
252 | | - | |
253 | | - | |
254 | | - | |
255 | | - | |
256 | | - | |
257 | | - | |
258 | | - | |
259 | | - | |
| 270 | + | |
| 271 | + | |
| 272 | + | |
| 273 | + | |
| 274 | + | |
| 275 | + | |
| 276 | + | |
| 277 | + | |
| 278 | + | |
260 | 279 | | |
261 | 280 | | |
262 | 281 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
227 | 227 | | |
228 | 228 | | |
229 | 229 | | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
| 269 | + | |
| 270 | + | |
| 271 | + | |
| 272 | + | |
| 273 | + | |
| 274 | + | |
| 275 | + | |
| 276 | + | |
| 277 | + | |
| 278 | + | |
| 279 | + | |
| 280 | + | |
| 281 | + | |
230 | 282 | | |
231 | 283 | | |
232 | 284 | | |
| |||
0 commit comments