2015-04-17 15:32:42 -07:00
|
|
|
// Copyright 2015 The Rust Project Developers. See the COPYRIGHT
|
|
|
|
// file at the top-level directory of this distribution and at
|
|
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
// except according to those terms.
|
|
|
|
|
2017-03-30 15:27:27 +02:00
|
|
|
// ignore-tidy-linelength
|
|
|
|
|
2015-04-17 15:32:42 -07:00
|
|
|
macro_rules! enum_from_u32 {
|
|
|
|
($(#[$attr:meta])* pub enum $name:ident {
|
|
|
|
$($variant:ident = $e:expr,)*
|
|
|
|
}) => {
|
|
|
|
$(#[$attr])*
|
|
|
|
pub enum $name {
|
|
|
|
$($variant = $e),*
|
|
|
|
}
|
|
|
|
|
|
|
|
impl $name {
|
|
|
|
pub fn from_u32(u: u32) -> Option<$name> {
|
|
|
|
$(if u == $name::$variant as u32 {
|
|
|
|
return Some($name::$variant)
|
|
|
|
})*
|
|
|
|
None
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
($(#[$attr:meta])* pub enum $name:ident {
|
|
|
|
$($variant:ident,)*
|
|
|
|
}) => {
|
|
|
|
$(#[$attr])*
|
|
|
|
pub enum $name {
|
|
|
|
$($variant,)*
|
|
|
|
}
|
|
|
|
|
|
|
|
impl $name {
|
|
|
|
pub fn from_u32(u: u32) -> Option<$name> {
|
|
|
|
$(if u == $name::$variant as u32 {
|
|
|
|
return Some($name::$variant)
|
|
|
|
})*
|
|
|
|
None
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-03-24 00:35:26 +01:00
|
|
|
|
|
|
|
#[macro_export]
|
|
|
|
macro_rules! bug {
|
|
|
|
() => ( bug!("impossible case reached") );
|
|
|
|
($($message:tt)*) => ({
|
|
|
|
$crate::session::bug_fmt(file!(), line!(), format_args!($($message)*))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
#[macro_export]
|
|
|
|
macro_rules! span_bug {
|
|
|
|
($span:expr, $($message:tt)*) => ({
|
|
|
|
$crate::session::span_bug_fmt(file!(), line!(), $span, format_args!($($message)*))
|
|
|
|
})
|
|
|
|
}
|
2017-03-30 15:27:27 +02:00
|
|
|
|
|
|
|
#[macro_export]
|
|
|
|
macro_rules! __impl_stable_hash_field {
|
|
|
|
(DECL IGNORED) => (_);
|
|
|
|
(DECL $name:ident) => (ref $name);
|
|
|
|
(USE IGNORED $ctx:expr, $hasher:expr) => ({});
|
|
|
|
(USE $name:ident, $ctx:expr, $hasher:expr) => ($name.hash_stable($ctx, $hasher));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[macro_export]
|
|
|
|
macro_rules! impl_stable_hash_for {
|
|
|
|
(enum $enum_name:path { $( $variant:ident $( ( $($arg:ident),* ) )* ),* }) => {
|
2017-06-02 15:45:56 +02:00
|
|
|
impl<'a, 'gcx, 'tcx> ::rustc_data_structures::stable_hasher::HashStable<$crate::ich::StableHashingContext<'a, 'gcx, 'tcx>> for $enum_name {
|
2017-03-30 15:27:27 +02:00
|
|
|
#[inline]
|
|
|
|
fn hash_stable<W: ::rustc_data_structures::stable_hasher::StableHasherResult>(&self,
|
2017-06-02 15:45:56 +02:00
|
|
|
__ctx: &mut $crate::ich::StableHashingContext<'a, 'gcx, 'tcx>,
|
2017-03-30 15:27:27 +02:00
|
|
|
__hasher: &mut ::rustc_data_structures::stable_hasher::StableHasher<W>) {
|
|
|
|
use $enum_name::*;
|
|
|
|
::std::mem::discriminant(self).hash_stable(__ctx, __hasher);
|
|
|
|
|
|
|
|
match *self {
|
|
|
|
$(
|
|
|
|
$variant $( ( $( __impl_stable_hash_field!(DECL $arg) ),* ) )* => {
|
|
|
|
$($( __impl_stable_hash_field!(USE $arg, __ctx, __hasher) );*)*
|
|
|
|
}
|
|
|
|
)*
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(struct $struct_name:path { $($field:ident),* }) => {
|
2017-06-02 15:45:56 +02:00
|
|
|
impl<'a, 'gcx, 'tcx> ::rustc_data_structures::stable_hasher::HashStable<$crate::ich::StableHashingContext<'a, 'gcx, 'tcx>> for $struct_name {
|
2017-03-30 15:27:27 +02:00
|
|
|
#[inline]
|
|
|
|
fn hash_stable<W: ::rustc_data_structures::stable_hasher::StableHasherResult>(&self,
|
2017-06-02 15:45:56 +02:00
|
|
|
__ctx: &mut $crate::ich::StableHashingContext<'a, 'gcx, 'tcx>,
|
2017-03-30 15:27:27 +02:00
|
|
|
__hasher: &mut ::rustc_data_structures::stable_hasher::StableHasher<W>) {
|
|
|
|
let $struct_name {
|
|
|
|
$(ref $field),*
|
|
|
|
} = *self;
|
|
|
|
|
|
|
|
$( $field.hash_stable(__ctx, __hasher));*
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
(tuple_struct $struct_name:path { $($field:ident),* }) => {
|
2017-06-02 15:45:56 +02:00
|
|
|
impl<'a, 'gcx, 'tcx> ::rustc_data_structures::stable_hasher::HashStable<$crate::ich::StableHashingContext<'a, 'gcx, 'tcx>> for $struct_name {
|
2017-03-30 15:27:27 +02:00
|
|
|
#[inline]
|
|
|
|
fn hash_stable<W: ::rustc_data_structures::stable_hasher::StableHasherResult>(&self,
|
2017-06-02 15:45:56 +02:00
|
|
|
__ctx: &mut $crate::ich::StableHashingContext<'a, 'gcx, 'tcx>,
|
2017-03-30 15:27:27 +02:00
|
|
|
__hasher: &mut ::rustc_data_structures::stable_hasher::StableHasher<W>) {
|
|
|
|
let $struct_name (
|
|
|
|
$(ref $field),*
|
|
|
|
) = *self;
|
|
|
|
|
|
|
|
$( $field.hash_stable(__ctx, __hasher));*
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#[macro_export]
|
|
|
|
macro_rules! impl_stable_hash_for_spanned {
|
|
|
|
($T:path) => (
|
|
|
|
|
2017-06-02 15:45:56 +02:00
|
|
|
impl<'a, 'gcx, 'tcx> HashStable<StableHashingContext<'a, 'gcx, 'tcx>> for ::syntax::codemap::Spanned<$T>
|
2017-03-30 15:27:27 +02:00
|
|
|
{
|
|
|
|
#[inline]
|
|
|
|
fn hash_stable<W: StableHasherResult>(&self,
|
2017-06-02 15:45:56 +02:00
|
|
|
hcx: &mut StableHashingContext<'a, 'gcx, 'tcx>,
|
2017-03-30 15:27:27 +02:00
|
|
|
hasher: &mut StableHasher<W>) {
|
|
|
|
self.node.hash_stable(hcx, hasher);
|
|
|
|
self.span.hash_stable(hcx, hasher);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|