mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-22 23:04:33 +00:00
Rollup merge of #82607 - bjorn3:frame_loc_getter, r=RalfJung
Add a getter for Frame.loc This is necessary for Priroda. For context see https://rust-lang.zulipchat.com/#narrow/stream/146212-t-compiler.2Fconst-eval/topic/Frame.3A.3Aloc.20no.20longer.20public/near/228070266 and oli-obk/priroda#27. cc `@DJMcNab` r? `@RalfJung`
This commit is contained in:
commit
7847f690fd
@ -226,6 +226,16 @@ impl<'mir, 'tcx, Tag> Frame<'mir, 'tcx, Tag> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl<'mir, 'tcx, Tag, Extra> Frame<'mir, 'tcx, Tag, Extra> {
|
impl<'mir, 'tcx, Tag, Extra> Frame<'mir, 'tcx, Tag, Extra> {
|
||||||
|
/// Get the current location within the Frame.
|
||||||
|
///
|
||||||
|
/// If this is `Err`, we are not currently executing any particular statement in
|
||||||
|
/// this frame (can happen e.g. during frame initialization, and during unwinding on
|
||||||
|
/// frames without cleanup code).
|
||||||
|
/// We basically abuse `Result` as `Either`.
|
||||||
|
pub fn current_loc(&self) -> Result<mir::Location, Span> {
|
||||||
|
self.loc
|
||||||
|
}
|
||||||
|
|
||||||
/// Return the `SourceInfo` of the current instruction.
|
/// Return the `SourceInfo` of the current instruction.
|
||||||
pub fn current_source_info(&self) -> Option<&mir::SourceInfo> {
|
pub fn current_source_info(&self) -> Option<&mir::SourceInfo> {
|
||||||
self.loc.ok().map(|loc| self.body.source_info(loc))
|
self.loc.ok().map(|loc| self.body.source_info(loc))
|
||||||
|
Loading…
Reference in New Issue
Block a user