// Copyright 2016 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 or the MIT license // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. macro_rules! log { ( $ctx:expr, $( $args:expr),* ) => { if $ctx.trace { //~^ ERROR attempted access of field `trace` on type `&T`, but no field with that name println!( $( $args, )* ); } } } // Create a structure. struct Foo { trace: bool, } // Generic wrapper calls log! with a structure. fn wrap(context: &T) -> () { log!(context, "entered wrapper"); //~^ in this expansion of log! } fn main() { // Create a structure. let x = Foo { trace: true }; log!(x, "run started"); // Apply a closure which accesses internal fields. wrap(&x); log!(x, "run finished"); }