]> git.lizzy.rs Git - rust.git/commitdiff
use :vis in thread_local!
authorAlex Burka <alex@alexburka.com>
Wed, 19 Apr 2017 02:29:40 +0000 (02:29 +0000)
committerAlex Burka <alex@alexburka.com>
Tue, 11 Jul 2017 20:27:55 +0000 (20:27 +0000)
src/libstd/lib.rs
src/libstd/thread/local.rs

index 2fc107c663bb41e9557a25545f614dd293900ad5..dda069324b08d0e78f990f075a9d8fb833a38503 100644 (file)
 #![feature(link_args)]
 #![feature(linkage)]
 #![feature(macro_reexport)]
+#![feature(macro_vis_matcher)]
 #![feature(needs_panic_runtime)]
 #![feature(needs_drop)]
 #![feature(never_type)]
index 49ceaff8d3efebcd4167065eda58530850eff038..c3aa3ff79c6161e5efc4e8efb40e2ca2f3928876 100644 (file)
@@ -139,37 +139,15 @@ macro_rules! thread_local {
     // empty (base case for the recursion)
     () => {};
 
-    // process multiple declarations where the first one is private
-    ($(#[$attr:meta])* static $name:ident: $t:ty = $init:expr; $($rest:tt)*) => (
-        __thread_local_inner!($(#[$attr])* [] $name, $t, $init);
+    // process multiple declarations
+    ($(#[$attr:meta])* $vis:vis static $name:ident: $t:ty = $init:expr; $($rest:tt)*) => (
+        __thread_local_inner!($(#[$attr])* $vis $name, $t, $init);
         thread_local!($($rest)*);
     );
 
-    // handle a single private declaration
-    ($(#[$attr:meta])* static $name:ident: $t:ty = $init:expr) => (
-        __thread_local_inner!($(#[$attr])* [] $name, $t, $init);
-    );
-
-    // handle multiple declarations where the first one is public
-    ($(#[$attr:meta])* pub static $name:ident: $t:ty = $init:expr; $($rest:tt)*) => (
-        __thread_local_inner!($(#[$attr])* [pub] $name, $t, $init);
-        thread_local!($($rest)*);
-    );
-
-    // handle a single public declaration
-    ($(#[$attr:meta])* pub static $name:ident: $t:ty = $init:expr) => (
-        __thread_local_inner!($(#[$attr])* [pub] $name, $t, $init);
-    );
-
-    // handle multiple declarations where the first one is restricted public
-    ($(#[$attr:meta])* pub $vis:tt static $name:ident: $t:ty = $init:expr; $($rest:tt)*) => (
-        __thread_local_inner!($(#[$attr])* [pub $vis] $name, $t, $init);
-        thread_local!($($rest)*);
-    );
-
-    // handle a single restricted public declaration
-    ($(#[$attr:meta])* pub $vis:tt static $name:ident: $t:ty = $init:expr) => (
-        __thread_local_inner!($(#[$attr])* [pub $vis] $name, $t, $init);
+    // handle a single declaration
+    ($(#[$attr:meta])* $vis:vis static $name:ident: $t:ty = $init:expr) => (
+        __thread_local_inner!($(#[$attr])* $vis $name, $t, $init);
     );
 }
 
@@ -180,8 +158,8 @@ macro_rules! thread_local {
 #[macro_export]
 #[allow_internal_unstable]
 macro_rules! __thread_local_inner {
-    ($(#[$attr:meta])* [$($vis:tt)*] $name:ident, $t:ty, $init:expr) => {
-        $(#[$attr])* $($vis)* static $name: $crate::thread::LocalKey<$t> = {
+    ($(#[$attr:meta])* $vis:vis $name:ident, $t:ty, $init:expr) => {
+        $(#[$attr])* $vis static $name: $crate::thread::LocalKey<$t> = {
             fn __init() -> $t { $init }
 
             fn __getit() -> $crate::option::Option<