about summary refs log tree commit diff
path: root/tests
diff options
context:
space:
mode:
authorfee1-dead <ent3rm4n@gmail.com>2023-07-06 09:20:34 +0800
committerGitHub <noreply@github.com>2023-07-06 09:20:34 +0800
commit2bc0ae3f33f014f043efecd5b91bb574ea4a855d (patch)
treeebc903e34bb804bb88829245425836b6d8c95add /tests
parent1830b80c2daf5b03d45ec69289e15b25cee97c7f (diff)
parentf25463e8483d8dcfb64cda4e96d5b4fbd11a19c8 (diff)
downloadrust-2bc0ae3f33f014f043efecd5b91bb574ea4a855d.tar.gz
rust-2bc0ae3f33f014f043efecd5b91bb574ea4a855d.zip
Rollup merge of #113350 - chenyukang:yukang-fix-113342-parser, r=compiler-errors
Fix the issue of wrong diagnosis for extern pub fn

Fixes #113342
Diffstat (limited to 'tests')
-rw-r--r--tests/ui/parser/issue-113342.rs9
-rw-r--r--tests/ui/parser/issue-113342.stderr11
2 files changed, 20 insertions, 0 deletions
diff --git a/tests/ui/parser/issue-113342.rs b/tests/ui/parser/issue-113342.rs
new file mode 100644
index 00000000000..18b502736f7
--- /dev/null
+++ b/tests/ui/parser/issue-113342.rs
@@ -0,0 +1,9 @@
+#[link(name = "my_c_library")]
+extern "C" {
+    fn my_c_function(x: i32) -> bool;
+}
+
+#[no_mangle]
+extern "C" pub fn id(x: i32) -> i32 { x } //~ ERROR expected `fn`, found keyword `pub`
+
+fn main() {}
diff --git a/tests/ui/parser/issue-113342.stderr b/tests/ui/parser/issue-113342.stderr
new file mode 100644
index 00000000000..a0c5e665ff8
--- /dev/null
+++ b/tests/ui/parser/issue-113342.stderr
@@ -0,0 +1,11 @@
+error: expected `fn`, found keyword `pub`
+  --> $DIR/issue-113342.rs:7:12
+   |
+LL | extern "C" pub fn id(x: i32) -> i32 { x }
+   | -----------^^^
+   | |          |
+   | |          expected `fn`
+   | help: visibility `pub` must come before `extern "C"`: `pub extern "C"`
+
+error: aborting due to previous error
+