Skip to content

Commit 6df5a1e

Browse files
committed
Rust: Extract SelfParams from crate graph
1 parent c11ed6d commit 6df5a1e

File tree

4 files changed

+70
-9
lines changed

4 files changed

+70
-9
lines changed

rust/extractor/src/crate_graph.rs

+37-8
Original file line numberDiff line numberDiff line change
@@ -383,25 +383,54 @@ fn emit_function(
383383
assert_eq!(sig.binders.len(Interner), parameters.len());
384384
let sig = sig.skip_binders();
385385
let ty_vars = &[parameters];
386+
let function_data = db.function_data(function);
387+
let mut self_param = None;
386388
let params = sig
387389
.params()
388390
.iter()
389-
.map(|p| {
391+
.enumerate()
392+
.filter_map(|(idx, p)| {
390393
let type_repr = emit_hir_ty(trap, db, ty_vars, p);
391-
trap.emit(generated::Param {
392-
id: trap::TrapId::Star,
393-
attrs: vec![],
394-
type_repr,
395-
pat: None,
396-
})
394+
395+
if idx == 0 && function_data.has_self_param() {
396+
// Check if the self parameter is a reference
397+
let (is_ref, is_mut) = match p.kind(Interner) {
398+
chalk_ir::TyKind::Ref(mutability, _, _) => {
399+
(true, matches!(mutability, chalk_ir::Mutability::Mut))
400+
}
401+
chalk_ir::TyKind::Raw(mutability, _) => {
402+
(false, matches!(mutability, chalk_ir::Mutability::Mut))
403+
}
404+
_ => (false, false),
405+
};
406+
407+
self_param = Some(trap.emit(generated::SelfParam {
408+
id: trap::TrapId::Star,
409+
attrs: vec![],
410+
type_repr,
411+
is_ref,
412+
is_mut,
413+
lifetime: None,
414+
name: None,
415+
}));
416+
None
417+
} else {
418+
Some(trap.emit(generated::Param {
419+
id: trap::TrapId::Star,
420+
attrs: vec![],
421+
type_repr,
422+
pat: None,
423+
}))
424+
}
397425
})
398426
.collect();
399427

400428
let ret_type = emit_hir_ty(trap, db, ty_vars, sig.ret());
429+
401430
let param_list = trap.emit(generated::ParamList {
402431
id: trap::TrapId::Star,
403432
params,
404-
self_param: None,
433+
self_param,
405434
});
406435
let ret_type = ret_type.map(|ret_type| {
407436
trap.emit(generated::RetTypeRepr {

rust/ql/test/library-tests/dataflow/modeled/inline-flow.expected

+18
Original file line numberDiff line numberDiff line change
@@ -8,19 +8,29 @@ models
88
| 7 | Summary: lang:core; crate::ptr::write; Argument[1]; Argument[0].Reference; value |
99
edges
1010
| main.rs:12:9:12:9 | a [Some] | main.rs:13:10:13:19 | a.unwrap() | provenance | MaD:2 |
11+
| main.rs:12:9:12:9 | a [Some] | main.rs:14:13:14:13 | a [Some] | provenance | |
1112
| main.rs:12:9:12:9 | a [Some] | main.rs:14:13:14:21 | a.clone() [Some] | provenance | MaD:1 |
1213
| main.rs:12:9:12:9 | a [Some] | main.rs:14:13:14:21 | a.clone() [Some] | provenance | generated |
1314
| main.rs:12:13:12:28 | Some(...) [Some] | main.rs:12:9:12:9 | a [Some] | provenance | |
1415
| main.rs:12:18:12:27 | source(...) | main.rs:12:13:12:28 | Some(...) [Some] | provenance | |
16+
| main.rs:14:9:14:9 | b [&ref, Some] | main.rs:15:10:15:10 | b [&ref, Some] | provenance | |
1517
| main.rs:14:9:14:9 | b [Some] | main.rs:15:10:15:19 | b.unwrap() | provenance | MaD:2 |
18+
| main.rs:14:13:14:13 | a [Some] | main.rs:14:13:14:21 | a.clone() [&ref, Some] | provenance | generated |
19+
| main.rs:14:13:14:21 | a.clone() [&ref, Some] | main.rs:14:9:14:9 | b [&ref, Some] | provenance | |
1620
| main.rs:14:13:14:21 | a.clone() [Some] | main.rs:14:9:14:9 | b [Some] | provenance | |
21+
| main.rs:15:10:15:10 | b [&ref, Some] | main.rs:15:10:15:19 | b.unwrap() | provenance | MaD:2 |
1722
| main.rs:19:9:19:9 | a [Ok] | main.rs:20:10:20:19 | a.unwrap() | provenance | MaD:5 |
23+
| main.rs:19:9:19:9 | a [Ok] | main.rs:21:13:21:13 | a [Ok] | provenance | |
1824
| main.rs:19:9:19:9 | a [Ok] | main.rs:21:13:21:21 | a.clone() [Ok] | provenance | MaD:4 |
1925
| main.rs:19:9:19:9 | a [Ok] | main.rs:21:13:21:21 | a.clone() [Ok] | provenance | generated |
2026
| main.rs:19:31:19:44 | Ok(...) [Ok] | main.rs:19:9:19:9 | a [Ok] | provenance | |
2127
| main.rs:19:34:19:43 | source(...) | main.rs:19:31:19:44 | Ok(...) [Ok] | provenance | |
28+
| main.rs:21:9:21:9 | b [&ref, Ok] | main.rs:22:10:22:10 | b [&ref, Ok] | provenance | |
2229
| main.rs:21:9:21:9 | b [Ok] | main.rs:22:10:22:19 | b.unwrap() | provenance | MaD:5 |
30+
| main.rs:21:13:21:13 | a [Ok] | main.rs:21:13:21:21 | a.clone() [&ref, Ok] | provenance | generated |
31+
| main.rs:21:13:21:21 | a.clone() [&ref, Ok] | main.rs:21:9:21:9 | b [&ref, Ok] | provenance | |
2332
| main.rs:21:13:21:21 | a.clone() [Ok] | main.rs:21:9:21:9 | b [Ok] | provenance | |
33+
| main.rs:22:10:22:10 | b [&ref, Ok] | main.rs:22:10:22:19 | b.unwrap() | provenance | MaD:5 |
2434
| main.rs:26:9:26:9 | a | main.rs:27:10:27:10 | a | provenance | |
2535
| main.rs:26:9:26:9 | a | main.rs:28:13:28:21 | a.clone() | provenance | generated |
2636
| main.rs:26:13:26:22 | source(...) | main.rs:26:9:26:9 | a | provenance | |
@@ -56,15 +66,23 @@ nodes
5666
| main.rs:12:13:12:28 | Some(...) [Some] | semmle.label | Some(...) [Some] |
5767
| main.rs:12:18:12:27 | source(...) | semmle.label | source(...) |
5868
| main.rs:13:10:13:19 | a.unwrap() | semmle.label | a.unwrap() |
69+
| main.rs:14:9:14:9 | b [&ref, Some] | semmle.label | b [&ref, Some] |
5970
| main.rs:14:9:14:9 | b [Some] | semmle.label | b [Some] |
71+
| main.rs:14:13:14:13 | a [Some] | semmle.label | a [Some] |
72+
| main.rs:14:13:14:21 | a.clone() [&ref, Some] | semmle.label | a.clone() [&ref, Some] |
6073
| main.rs:14:13:14:21 | a.clone() [Some] | semmle.label | a.clone() [Some] |
74+
| main.rs:15:10:15:10 | b [&ref, Some] | semmle.label | b [&ref, Some] |
6175
| main.rs:15:10:15:19 | b.unwrap() | semmle.label | b.unwrap() |
6276
| main.rs:19:9:19:9 | a [Ok] | semmle.label | a [Ok] |
6377
| main.rs:19:31:19:44 | Ok(...) [Ok] | semmle.label | Ok(...) [Ok] |
6478
| main.rs:19:34:19:43 | source(...) | semmle.label | source(...) |
6579
| main.rs:20:10:20:19 | a.unwrap() | semmle.label | a.unwrap() |
80+
| main.rs:21:9:21:9 | b [&ref, Ok] | semmle.label | b [&ref, Ok] |
6681
| main.rs:21:9:21:9 | b [Ok] | semmle.label | b [Ok] |
82+
| main.rs:21:13:21:13 | a [Ok] | semmle.label | a [Ok] |
83+
| main.rs:21:13:21:21 | a.clone() [&ref, Ok] | semmle.label | a.clone() [&ref, Ok] |
6784
| main.rs:21:13:21:21 | a.clone() [Ok] | semmle.label | a.clone() [Ok] |
85+
| main.rs:22:10:22:10 | b [&ref, Ok] | semmle.label | b [&ref, Ok] |
6886
| main.rs:22:10:22:19 | b.unwrap() | semmle.label | b.unwrap() |
6987
| main.rs:26:9:26:9 | a | semmle.label | a |
7088
| main.rs:26:13:26:22 | source(...) | semmle.label | source(...) |

rust/ql/test/library-tests/type-inference/type-inference.ql

+2-1
Original file line numberDiff line numberDiff line change
@@ -4,7 +4,8 @@ import codeql.rust.internal.TypeInference as TypeInference
44
import TypeInference
55

66
query predicate inferType(AstNode n, TypePath path, Type t) {
7-
t = TypeInference::inferType(n, path)
7+
t = TypeInference::inferType(n, path) and
8+
n.fromSource()
89
}
910

1011
module ResolveTest implements TestSig {
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
multipleMethodCallTargets
2+
| sqlx.rs:65:30:65:52 | unsafe_query_2.as_str() | file://:0:0:0:0 | fn as_str |
3+
| sqlx.rs:65:30:65:52 | unsafe_query_2.as_str() | file://:0:0:0:0 | fn as_str |
4+
| sqlx.rs:65:30:65:52 | unsafe_query_2.as_str() | file://:0:0:0:0 | fn as_str |
5+
| sqlx.rs:65:30:65:52 | unsafe_query_2.as_str() | file://:0:0:0:0 | fn as_str |
6+
| sqlx.rs:65:30:65:52 | unsafe_query_2.as_str() | file://:0:0:0:0 | fn as_str |
7+
| sqlx.rs:65:30:65:52 | unsafe_query_2.as_str() | file://:0:0:0:0 | fn as_str |
8+
| sqlx.rs:76:29:76:51 | unsafe_query_2.as_str() | file://:0:0:0:0 | fn as_str |
9+
| sqlx.rs:76:29:76:51 | unsafe_query_2.as_str() | file://:0:0:0:0 | fn as_str |
10+
| sqlx.rs:76:29:76:51 | unsafe_query_2.as_str() | file://:0:0:0:0 | fn as_str |
11+
| sqlx.rs:76:29:76:51 | unsafe_query_2.as_str() | file://:0:0:0:0 | fn as_str |
12+
| sqlx.rs:76:29:76:51 | unsafe_query_2.as_str() | file://:0:0:0:0 | fn as_str |
13+
| sqlx.rs:76:29:76:51 | unsafe_query_2.as_str() | file://:0:0:0:0 | fn as_str |

0 commit comments

Comments
 (0)