aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorliushuyu <liushuyu011@gmail.com>2022-06-11 20:02:54 -0600
committerliushuyu <liushuyu011@gmail.com>2022-06-28 17:54:18 -0600
commit649d3c45afa9c65cad99c8d195e342b3c8bea43c (patch)
tree6d341c9824ead55b0fa10d5920d66d7cadb3d860
parent04cc46cfe8cad9736ccf2d5c884af50e57b67ce6 (diff)
downloadgcc-649d3c45afa9c65cad99c8d195e342b3c8bea43c.zip
gcc-649d3c45afa9c65cad99c8d195e342b3c8bea43c.tar.gz
gcc-649d3c45afa9c65cad99c8d195e342b3c8bea43c.tar.bz2
rust/backend: scan for any deprecated function calls ...
... and emit warnings using GCC's own deprecation warning system
-rw-r--r--gcc/rust/backend/rust-compile-base.cc9
-rw-r--r--gcc/rust/rust-gcc.cc10
2 files changed, 17 insertions, 2 deletions
diff --git a/gcc/rust/backend/rust-compile-base.cc b/gcc/rust/backend/rust-compile-base.cc
index 335a6d4..066ef43 100644
--- a/gcc/rust/backend/rust-compile-base.cc
+++ b/gcc/rust/backend/rust-compile-base.cc
@@ -209,8 +209,13 @@ HIRCompileBase::handle_deprecated_attribute_on_fndecl (
}
}
- DECL_ATTRIBUTES (fndecl) = tree_cons (get_identifier ("deprecated"), value,
- DECL_ATTRIBUTES (fndecl));
+ if (value)
+ {
+ tree attr_list = build_tree_list (NULL_TREE, value);
+ DECL_ATTRIBUTES (fndecl)
+ = tree_cons (get_identifier ("deprecated"), attr_list,
+ DECL_ATTRIBUTES (fndecl));
+ }
}
void
diff --git a/gcc/rust/rust-gcc.cc b/gcc/rust/rust-gcc.cc
index 445cb0d..4fea6fb 100644
--- a/gcc/rust/rust-gcc.cc
+++ b/gcc/rust/rust-gcc.cc
@@ -51,6 +51,8 @@
#include "rust-backend.h"
#include "rust-object-export.h"
+#include "backend/rust-tree.h"
+
// TODO: this will have to be significantly modified to work with Rust
// Bvariable is a bit more complicated, because of zero-sized types.
@@ -1852,6 +1854,14 @@ Gcc_backend::call_expression (tree fn, const std::vector<tree> &fn_args,
excess_type != NULL_TREE ? excess_type : rettype,
fn, nargs, args);
+ // check for deprecated function usage
+ if (fndecl && TREE_DEPRECATED (fndecl))
+ {
+ // set up the call-site information for `warn_deprecated_use`
+ input_location = location.gcc_location ();
+ warn_deprecated_use (fndecl, NULL_TREE);
+ }
+
if (chain_expr)
CALL_EXPR_STATIC_CHAIN (ret) = chain_expr;