2017-08-29 65 views
2
#![feature(rustc_private)] 
#![feature(box_syntax)] 
extern crate rustc; 
extern crate rustc_driver; 

use rustc::hir::intravisit as hir_visit; 
use rustc::hir; 
use rustc_driver::driver::{CompileController, CompileState}; 

pub struct SomeVisitor<'a, 'tcx: 'a> { 
    pub map: &'a hir::map::Map<'tcx>, 
} 

impl<'v, 'tcx: 'v> rustc::hir::intravisit::Visitor<'tcx> for SomeVisitor<'v, 'tcx> { 
    fn nested_visit_map<'this>(&'this mut self) -> hir_visit::NestedVisitorMap<'this, 'tcx> { 
     hir_visit::NestedVisitorMap::All(self.map) 
    } 
} 

fn hir(s: &mut CompileState) { 
    let krate = s.hir_crate.unwrap(); 
    let map = s.hir_map.unwrap(); 
    let mut visitor = SomeVisitor { map }; 
    hir_visit::walk_crate(&mut visitor, krate); 
} 

fn main() { 
    { 
     let mut controller = CompileController::basic(); 
     controller.after_hir_lowering.callback = box hir; 
    } 
} 

playground明確的壽命變函數簽名,併爲所需要的類型簽名

我明白爲什麼我得到了一生的錯誤功能不兼容,這是很容易通過添加明確的壽命來解決它功能hir

pub fn walk_crate<'v, V: hir_visit::Visitor<'v>>(visitor: &mut V, krate: &'v Crate) {} 

由於這一定義的壽命爲參考需要住'tcx

fn hir<'v, 'tcx>(s: &'tcx mut CompileState<'v, 'tcx>) { 
    let krate = s.hir_crate.unwrap(); 
    let map = s.hir_map.unwrap(); 
    let mut visitor = SomeVisitor { map }; 
    hir_visit::walk_crate(&mut visitor, krate); 
} 

但是功能hir變得不兼容的回調。 playground

我想我可能需要在這裏使用HRTB

更新:

我目前的解決辦法是使用蛻變。 (playground)。當然必須有更好的方法?

回答

1
hir_visit::walk_crate(&mut visitor, visitor.map.krate()); 

解決方案是要認識到,地圖還包含一個作爲參考,但具有正確的使用壽命。這意味着我不必介紹明確的生命週期。

playground

相關問題