[][src]Struct cannyls::device::Device

#[must_use]
pub struct Device { /* fields omitted */ }

Lump群を格納するためのデバイス.

モジュールドキュメントも参照のこと.

Future実装

DeviceFutureを実装している.

実際の処理は、別スレッドで実行されるためFuture::pollを呼び出さなくても進行上は支障はないが、 このメソッドによりデバイス(スレッド)の終了(正常ないし異常)を検知することが可能となる.

なおDeviceインスタンスが破棄されると、裏で動いているデバイス用のOSスレッドも停止させられるので、 Future::pollを呼び出さない場合でも、インスタンス自体は保持しておく必要がある.

デバイスを安全に停止する方法

Device::spawn関数を呼び出すとDeviceインスタンスが結果として返されるが、 同時に引数で指定されたストレージを管理するためのOSスレッドも起動される。

Deviceインスタンスのドロップ時には、そのデストラクタ内でDevice::stopメソッドが呼び出され、 対応する管理スレッドに停止リクエストが発行される。 注意すべきは、デストラクタ内ではリクエストを発行するのみであり、停止完了を待機することはないという点である。 これは、デストラクタの呼び出し元スレッドが長時間ブロックすることを避けるための挙動である

通常はこの挙動で問題が発生することはないが、もし対象Deviceでジャーナルメモリバッファが有効になっており、 かつ、Deviceのドロップ直後にプログラムが終了する場合には、ジャーナルメモリバッファの内容が ディスクに反映される前に、管理スレッドが強制終了されてしまう可能性がある(i.e., 直近の操作内容が失われる)。

これを防ぐためには、以下のように明示的にDevice::stopを呼び出し上で、Deviceの終了を待機すれば良い:

use cannyls::deadline::Deadline;
use cannyls::device::Device;
use cannyls::nvm::MemoryNvm;
use cannyls::storage::Storage;
use futures::Future;

let nvm = MemoryNvm::new(vec![0; 1024 * 1024]);
let storage = Storage::create(nvm)?;
let mut device = Device::spawn(|| Ok(storage));

// ...デバイスに対する何らかの操作...

device.stop(Deadline::Immediate);    // 管理スレッドの停止を指示
while !device.poll()?.is_ready() {}  // 停止完了を待機

Methods

impl Device
[src]

pub fn spawn<F, N>(init_storage: F) -> Device where
    F: FnOnce() -> Result<Storage<N>> + Send + 'static,
    N: NonVolatileMemory + Send + 'static, 
[src]

デフォルト設定でデバイスを起動する.

設定を変更したい場合にはDeviceBuilderを使用すること.

pub fn handle(&self) -> DeviceHandle
[src]

デバイスを操作するためのハンドルを返す.

pub fn stop(&self, deadline: Deadline)
[src]

デバイスに停止リクエストを発行する.

このメソッドが返った時点でデバイスが停止している保証はないので、 確実に終了を検知したい場合にはFuture::pollメソッド経由で知る必要がある.

なおDeviceインスタンスのドロップ時点で、そのデバイスがまだ稼働中の場合には stop(Deadline::Immediate)が自動で呼び出される. ただし、その後にデバイスの終了を待機したりはしないので注意は必要. 例えば「Deviceインスタンスをドロップして、直後に同じ設定でデバイスを起動」といったことを 行った場合には、停止中の旧インスタンスと起動した新インスタンスでリソース(e.g., ファイル)が 衝突し、エラーが発生するかもしれない. 確実な終了検知が必要なら、アプリケーションが明示的にDevice::stopを呼び出す必要がある.

pub fn wait_for_running(
    self
) -> impl Future<Item = Self, Error = Error>
[src]

デバイスの起動を待機するためのFutureを返す.

Trait Implementations

impl Drop for Device
[src]

impl Debug for Device
[src]

impl Future for Device
[src]

type Item = ()

The type of value that this future will resolved with if it is successful. Read more

type Error = Error

The type of error that this future will resolve with if it fails in a normal fashion. Read more

fn wait(self) -> Result<Self::Item, Self::Error>
[src]

Block the current thread until this future is resolved. Read more

fn map<F, U>(self, f: F) -> Map<Self, F> where
    F: FnOnce(Self::Item) -> U, 
[src]

Map this future's result to a different type, returning a new future of the resulting type. Read more

fn map_err<F, E>(self, f: F) -> MapErr<Self, F> where
    F: FnOnce(Self::Error) -> E, 
[src]

Map this future's error to a different error, returning a new future. Read more

fn from_err<E>(self) -> FromErr<Self, E> where
    E: From<Self::Error>, 
[src]

Map this future's error to any error implementing From for this future's Error, returning a new future. Read more

fn then<F, B>(self, f: F) -> Then<Self, B, F> where
    B: IntoFuture,
    F: FnOnce(Result<Self::Item, Self::Error>) -> B, 
[src]

Chain on a computation for when a future finished, passing the result of the future to the provided closure f. Read more

fn and_then<F, B>(self, f: F) -> AndThen<Self, B, F> where
    B: IntoFuture<Error = Self::Error>,
    F: FnOnce(Self::Item) -> B, 
[src]

Execute another future after this one has resolved successfully. Read more

fn or_else<F, B>(self, f: F) -> OrElse<Self, B, F> where
    B: IntoFuture<Item = Self::Item>,
    F: FnOnce(Self::Error) -> B, 
[src]

Execute another future if this one resolves with an error. Read more

fn select<B>(self, other: B) -> Select<Self, <B as IntoFuture>::Future> where
    B: IntoFuture<Item = Self::Item, Error = Self::Error>, 
[src]

Waits for either one of two futures to complete. Read more

fn select2<B>(self, other: B) -> Select2<Self, <B as IntoFuture>::Future> where
    B: IntoFuture
[src]

Waits for either one of two differently-typed futures to complete. Read more

fn join<B>(self, other: B) -> Join<Self, <B as IntoFuture>::Future> where
    B: IntoFuture<Error = Self::Error>, 
[src]

Joins the result of two futures, waiting for them both to complete. Read more

fn join3<B, C>(
    self,
    b: B,
    c: C
) -> Join3<Self, <B as IntoFuture>::Future, <C as IntoFuture>::Future> where
    B: IntoFuture<Error = Self::Error>,
    C: IntoFuture<Error = Self::Error>, 
[src]

Same as join, but with more futures.

fn join4<B, C, D>(
    self,
    b: B,
    c: C,
    d: D
) -> Join4<Self, <B as IntoFuture>::Future, <C as IntoFuture>::Future, <D as IntoFuture>::Future> where
    B: IntoFuture<Error = Self::Error>,
    C: IntoFuture<Error = Self::Error>,
    D: IntoFuture<Error = Self::Error>, 
[src]

Same as join, but with more futures.

fn join5<B, C, D, E>(
    self,
    b: B,
    c: C,
    d: D,
    e: E
) -> Join5<Self, <B as IntoFuture>::Future, <C as IntoFuture>::Future, <D as IntoFuture>::Future, <E as IntoFuture>::Future> where
    B: IntoFuture<Error = Self::Error>,
    C: IntoFuture<Error = Self::Error>,
    D: IntoFuture<Error = Self::Error>,
    E: IntoFuture<Error = Self::Error>, 
[src]

Same as join, but with more futures.

fn into_stream(self) -> IntoStream<Self>
[src]

Convert this future into a single element stream. Read more

fn flatten(self) -> Flatten<Self> where
    Self::Item: IntoFuture,
    <Self::Item as IntoFuture>::Error: From<Self::Error>, 
[src]

Flatten the execution of this future when the successful result of this future is itself another future. Read more

fn flatten_stream(self) -> FlattenStream<Self> where
    Self::Item: Stream,
    <Self::Item as Stream>::Error == Self::Error
[src]

Flatten the execution of this future when the successful result of this future is a stream. Read more

fn fuse(self) -> Fuse<Self>
[src]

Fuse a future such that poll will never again be called once it has completed. Read more

fn inspect<F>(self, f: F) -> Inspect<Self, F> where
    F: FnOnce(&Self::Item), 
[src]

Do something with the item of a future, passing it on. Read more

fn catch_unwind(self) -> CatchUnwind<Self> where
    Self: UnwindSafe
[src]

Catches unwinding panics while polling the future. Read more

fn shared(self) -> Shared<Self>
[src]

Create a cloneable handle to this future where all handles will resolve to the same result. Read more

Auto Trait Implementations

impl Send for Device

impl !Sync for Device

Blanket Implementations

impl<T> From for T
[src]

impl<T, U> Into for T where
    U: From<T>, 
[src]

impl<T, U> TryFrom for T where
    T: From<U>, 
[src]

type Error = !

🔬 This is a nightly-only experimental API. (try_from)

The type returned in the event of a conversion error.

impl<T> Borrow for T where
    T: ?Sized
[src]

impl<T, U> TryInto for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

🔬 This is a nightly-only experimental API. (try_from)

The type returned in the event of a conversion error.

impl<T> BorrowMut for T where
    T: ?Sized
[src]

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<F> IntoFuture for F where
    F: Future
[src]

type Future = F

The future that this type can be converted into.

type Item = <F as Future>::Item

The item that the future may resolve with.

type Error = <F as Future>::Error

The error that the future may resolve with.

impl<T> TimerExt for T where
    T: Future
[src]

fn timeout_after(self, duration: Duration) -> TimeoutAfter<Self>
[src]

Adds the specified timeout to this future.