about summary refs log tree commit diff
path: root/src/libstd
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2014-01-04 10:16:51 -0800
committerbors <bors@rust-lang.org>2014-01-04 10:16:51 -0800
commitb432e82515f4cc145cf41bbcb92ff9b874b23afe (patch)
treec94c4b24c628207e0522e458054b573e01fe8f64 /src/libstd
parentd86cb6a39fee0d437ab1d4642468257b1f6b11f4 (diff)
parentdcaf10f8de7be79d7ef8aa5e048bf6535108dc16 (diff)
downloadrust-b432e82515f4cc145cf41bbcb92ff9b874b23afe.tar.gz
rust-b432e82515f4cc145cf41bbcb92ff9b874b23afe.zip
auto merge of #11306 : alexcrichton/rust/native-bounds, r=pcwalton
This allows inspection of the current task's bounds regardless of what the
underlying task is.

Closes #11293
Diffstat (limited to 'src/libstd')
-rw-r--r--src/libstd/rt/mod.rs1
-rw-r--r--src/libstd/rt/task.rs7
2 files changed, 8 insertions, 0 deletions
diff --git a/src/libstd/rt/mod.rs b/src/libstd/rt/mod.rs
index 9bd804f7bab..050caef86eb 100644
--- a/src/libstd/rt/mod.rs
+++ b/src/libstd/rt/mod.rs
@@ -159,6 +159,7 @@ pub trait Runtime {
     // you're in.
     fn spawn_sibling(~self, cur_task: ~Task, opts: TaskOpts, f: proc());
     fn local_io<'a>(&'a mut self) -> Option<rtio::LocalIo<'a>>;
+    fn stack_bounds(&self) -> Option<(uint, uint)>; // (lo, hi)
 
     // XXX: This is a serious code smell and this should not exist at all.
     fn wrap(~self) -> ~Any;
diff --git a/src/libstd/rt/task.rs b/src/libstd/rt/task.rs
index ae12f944f9c..41819421be8 100644
--- a/src/libstd/rt/task.rs
+++ b/src/libstd/rt/task.rs
@@ -277,6 +277,13 @@ impl Task {
     pub fn local_io<'a>(&'a mut self) -> Option<LocalIo<'a>> {
         self.imp.get_mut_ref().local_io()
     }
+
+    /// Returns the stack bounds for this task in (lo, hi) format. The stack
+    /// bounds may not be known for all tasks, so the return value may be
+    /// `None`.
+    pub fn stack_bounds(&self) -> Option<(uint, uint)> {
+        self.imp.get_ref().stack_bounds()
+    }
 }
 
 impl Drop for Task {