]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
gccrs: proc_macro: Remode function indirection
authorPierre-Emmanuel Patry <pierre-emmanuel.patry@embecosm.com>
Wed, 26 Jul 2023 15:44:50 +0000 (17:44 +0200)
committerArthur Cohen <arthur.cohen@embecosm.com>
Tue, 16 Jan 2024 17:56:01 +0000 (18:56 +0100)
There was no need to register a function when the value could be
registered directly.

gcc/rust/ChangeLog:

* expand/rust-proc-macro.cc (available): Remove function.
(load_macros_array): There was no need for an indirection here.

libgrust/ChangeLog:

* libproc_macro/proc_macro.cc (not_available): Remove
function.
* libproc_macro/proc_macro.h (not_available): Remove
function prototype.
* libproc_macro/registration.h: Change symbol type.
* libproc_macro/bridge.h: New file.

Signed-off-by: Pierre-Emmanuel Patry <pierre-emmanuel.patry@embecosm.com>
gcc/rust/expand/rust-proc-macro.cc
libgrust/libproc_macro/bridge.h [new file with mode: 0644]
libgrust/libproc_macro/proc_macro.cc
libgrust/libproc_macro/proc_macro.h
libgrust/libproc_macro/registration.h

index b6cfe2543941b6cb369632f27dc819e4a6f6028d..9fee4bb03bdaeb7ebf351b440b53faca8c3c6363 100644 (file)
@@ -56,12 +56,6 @@ static_assert (
               ProcMacro::from_str_function_t>::value,
   "Registration callback signature not synced, check proc macro internals.");
 
-static bool
-available ()
-{
-  return true;
-}
-
 template <typename Symbol, typename Callback>
 bool
 register_callback (void *handle, Symbol, std::string symbol_name,
@@ -102,7 +96,7 @@ load_macros_array (std::string path)
                          tokenstream_from_string))
     return nullptr;
   if (!REGISTER_CALLBACK (handle, __gccrs_proc_macro_is_available_fn,
-                         available))
+                         ProcMacro::BridgeState::Available))
     return nullptr;
 
   // FIXME: Add CrateStableId handling, right now all versions may be loaded,
diff --git a/libgrust/libproc_macro/bridge.h b/libgrust/libproc_macro/bridge.h
new file mode 100644 (file)
index 0000000..47eedff
--- /dev/null
@@ -0,0 +1,35 @@
+// Copyright (C) 2023 Free Software Foundation, Inc.
+//
+// This file is part of the GNU Proc Macro Library.  This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+// GNU General Public License for more details.
+
+// Under Section 7 of GPL version 3, you are granted additional
+// permissions described in the GCC Runtime Library Exception, version
+// 3.1, as published by the Free Software Foundation.
+
+// You should have received a copy of the GNU General Public License and
+// a copy of the GCC Runtime Library Exception along with this program;
+// see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
+// <http://www.gnu.org/licenses/>.
+#ifndef BRIDGE_H
+#define BRIDGE_H
+
+namespace ProcMacro {
+
+enum class BridgeState
+{
+  Available,
+  Unavailable,
+};
+
+}
+
+#endif /* ! BRIDGE_H */
index e05ec5300b7347ea2fa6f7b9b7cca45d362f6e27..b1e108e74eb17d75d97d18c22a42888082381139 100644 (file)
@@ -21,6 +21,7 @@
 // <http://www.gnu.org/licenses/>.
 
 #include "proc_macro.h"
+#include "bridge.h"
 
 namespace ProcMacro {
 
@@ -52,17 +53,12 @@ Procmacro::make_bang (const char *name, BangMacro macro)
 extern "C" bool
 bridge_is_available ()
 {
-  return __gccrs_proc_macro_is_available_fn ();
-}
-
-bool
-not_available ()
-{
-  return false;
+  return __gccrs_proc_macro_is_available_fn
+        == ProcMacro::BridgeState::Available;
 }
 
 } // namespace ProcMacro
 
 ProcMacro::from_str_function_t __gccrs_proc_macro_from_str_fn = nullptr;
-ProcMacro::is_available_function_t __gccrs_proc_macro_is_available_fn
-  = ProcMacro::not_available;
+ProcMacro::is_available_t __gccrs_proc_macro_is_available_fn
+  = ProcMacro::BridgeState::Unavailable;
index 077e1cbbb48f19c1ea4fb8bac446d272525ab639..60d9fcb75b159800574c21e4f5a2e194572017ff 100644 (file)
@@ -99,9 +99,6 @@ struct ProcmacroArray
   Procmacro *macros;
 };
 
-bool
-not_available ();
-
 extern "C" bool
 bridge_is_available ();
 
index 76688632ced2a5eb691fc63fc659dadfd692b946..0074e993488eebff6abb5b4ddf1fd081a4024fcf 100644 (file)
 
 #include <string>
 #include "tokenstream.h"
+#include "bridge.h"
 
 namespace ProcMacro {
 
 using from_str_function_t = ProcMacro::TokenStream (*) (std::string &, bool &);
-using is_available_function_t = bool (*) ();
+using is_available_t = ProcMacro::BridgeState;
 
 } // namespace ProcMacro
 
 extern "C" ProcMacro::from_str_function_t __gccrs_proc_macro_from_str_fn;
-extern "C" ProcMacro::is_available_function_t
-  __gccrs_proc_macro_is_available_fn;
+extern "C" ProcMacro::is_available_t __gccrs_proc_macro_is_available_fn;
 
 #endif /* !REGISTRATION_H */