summaryrefslogtreecommitdiffstats
path: root/tests/rustdoc-json/fns/qualifiers.rs
blob: 7ff542900423bd6fe486becb8854206ccaed9abb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
// edition:2018

// @is "$.index[*][?(@.name=='nothing_fn')].inner.header.async" false
// @is "$.index[*][?(@.name=='nothing_fn')].inner.header.const"  false
// @is "$.index[*][?(@.name=='nothing_fn')].inner.header.unsafe" false
pub fn nothing_fn() {}

// @is "$.index[*][?(@.name=='unsafe_fn')].inner.header.async"  false
// @is "$.index[*][?(@.name=='unsafe_fn')].inner.header.const"  false
// @is "$.index[*][?(@.name=='unsafe_fn')].inner.header.unsafe" true
pub unsafe fn unsafe_fn() {}

// @is "$.index[*][?(@.name=='const_fn')].inner.header.async"  false
// @is "$.index[*][?(@.name=='const_fn')].inner.header.const"  true
// @is "$.index[*][?(@.name=='const_fn')].inner.header.unsafe" false
pub const fn const_fn() {}

// @is "$.index[*][?(@.name=='async_fn')].inner.header.async"  true
// @is "$.index[*][?(@.name=='async_fn')].inner.header.const"  false
// @is "$.index[*][?(@.name=='async_fn')].inner.header.unsafe" false
pub async fn async_fn() {}

// @is "$.index[*][?(@.name=='async_unsafe_fn')].inner.header.async"  true
// @is "$.index[*][?(@.name=='async_unsafe_fn')].inner.header.const"  false
// @is "$.index[*][?(@.name=='async_unsafe_fn')].inner.header.unsafe" true
pub async unsafe fn async_unsafe_fn() {}

// @is "$.index[*][?(@.name=='const_unsafe_fn')].inner.header.async"  false
// @is "$.index[*][?(@.name=='const_unsafe_fn')].inner.header.const"  true
// @is "$.index[*][?(@.name=='const_unsafe_fn')].inner.header.unsafe" true
pub const unsafe fn const_unsafe_fn() {}

// It's impossible for a function to be both const and async, so no test for that