Struct otter_nodejs_tests::tempfile::Builder
source · [−]pub struct Builder<'a, 'b> { /* private fields */ }Expand description
Create a new temporary file or directory with custom parameters.
Implementations
sourceimpl<'a, 'b> Builder<'a, 'b>
impl<'a, 'b> Builder<'a, 'b>
sourcepub fn new() -> Builder<'a, 'b>
pub fn new() -> Builder<'a, 'b>
Create a new Builder.
Examples
Create a named temporary file and write some data into it:
use tempfile::Builder;
let named_tempfile = Builder::new()
.prefix("my-temporary-note")
.suffix(".txt")
.rand_bytes(5)
.tempfile()?;
let name = named_tempfile
.path()
.file_name().and_then(OsStr::to_str);
if let Some(name) = name {
assert!(name.starts_with("my-temporary-note"));
assert!(name.ends_with(".txt"));
assert_eq!(name.len(), "my-temporary-note.txt".len() + 5);
}Create a temporary directory and add a file to it:
use tempfile::Builder;
let dir = Builder::new()
.prefix("my-temporary-dir")
.rand_bytes(5)
.tempdir()?;
let file_path = dir.path().join("my-temporary-note.txt");
let mut file = File::create(file_path)?;
writeln!(file, "Brian was here. Briefly.")?;
// By closing the `TempDir` explicitly, we can check that it has
// been deleted successfully. If we don't close it explicitly,
// the directory will still be deleted when `dir` goes out
// of scope, but we won't know whether deleting the directory
// succeeded.
drop(file);
dir.close()?;sourcepub fn prefix<S>(&mut self, prefix: &'a S) -> &mut Builder<'a, 'b> where
S: AsRef<OsStr> + ?Sized,
pub fn prefix<S>(&mut self, prefix: &'a S) -> &mut Builder<'a, 'b> where
S: AsRef<OsStr> + ?Sized,
Set a custom filename prefix.
Path separators are legal but not advisable.
Default: .tmp.
Examples
let named_tempfile = Builder::new()
.prefix("my-temporary-note")
.tempfile()?;sourcepub fn suffix<S>(&mut self, suffix: &'b S) -> &mut Builder<'a, 'b> where
S: AsRef<OsStr> + ?Sized,
pub fn suffix<S>(&mut self, suffix: &'b S) -> &mut Builder<'a, 'b> where
S: AsRef<OsStr> + ?Sized,
Set a custom filename suffix.
Path separators are legal but not advisable. Default: empty.
Examples
let named_tempfile = Builder::new()
.suffix(".txt")
.tempfile()?;sourcepub fn rand_bytes(&mut self, rand: usize) -> &mut Builder<'a, 'b>
pub fn rand_bytes(&mut self, rand: usize) -> &mut Builder<'a, 'b>
Set the number of random bytes.
Default: 6.
Examples
let named_tempfile = Builder::new()
.rand_bytes(5)
.tempfile()?;sourcepub fn append(&mut self, append: bool) -> &mut Builder<'a, 'b>
pub fn append(&mut self, append: bool) -> &mut Builder<'a, 'b>
Set the file to be opened in append mode.
Default: false.
Examples
let named_tempfile = Builder::new()
.append(true)
.tempfile()?;sourcepub fn tempfile(&self) -> Result<NamedTempFile, Error>
pub fn tempfile(&self) -> Result<NamedTempFile, Error>
Create the named temporary file.
Security
See the security docs on NamedTempFile.
Resource leaking
See the resource leaking docs on NamedTempFile.
Errors
If the file cannot be created, Err is returned.
Examples
let tempfile = Builder::new().tempfile()?;sourcepub fn tempfile_in<P>(&self, dir: P) -> Result<NamedTempFile, Error> where
P: AsRef<Path>,
pub fn tempfile_in<P>(&self, dir: P) -> Result<NamedTempFile, Error> where
P: AsRef<Path>,
Create the named temporary file in the specified directory.
Security
See the security docs on NamedTempFile.
Resource leaking
See the resource leaking docs on NamedTempFile.
Errors
If the file cannot be created, Err is returned.
Examples
let tempfile = Builder::new().tempfile_in("./")?;sourcepub fn tempdir(&self) -> Result<TempDir, Error>
pub fn tempdir(&self) -> Result<TempDir, Error>
Attempts to make a temporary directory inside of env::temp_dir() whose
name will have the prefix, prefix. The directory and
everything inside it will be automatically deleted once the
returned TempDir is destroyed.
Resource leaking
See the resource leaking docs on TempDir.
Errors
If the directory can not be created, Err is returned.
Examples
use std::fs::File;
use std::io::Write;
use tempfile::Builder;
let tmp_dir = Builder::new().tempdir()?;sourcepub fn tempdir_in<P>(&self, dir: P) -> Result<TempDir, Error> where
P: AsRef<Path>,
pub fn tempdir_in<P>(&self, dir: P) -> Result<TempDir, Error> where
P: AsRef<Path>,
Attempts to make a temporary directory inside of dir.
The directory and everything inside it will be automatically
deleted once the returned TempDir is destroyed.
Resource leaking
See the resource leaking docs on TempDir.
Errors
If the directory can not be created, Err is returned.
Examples
use std::fs::{self, File};
use std::io::Write;
use tempfile::Builder;
let tmp_dir = Builder::new().tempdir_in("./")?;Trait Implementations
impl<'a, 'b> Eq for Builder<'a, 'b>
impl<'a, 'b> StructuralEq for Builder<'a, 'b>
impl<'a, 'b> StructuralPartialEq for Builder<'a, 'b>
Auto Trait Implementations
impl<'a, 'b> RefUnwindSafe for Builder<'a, 'b>
impl<'a, 'b> Send for Builder<'a, 'b>
impl<'a, 'b> Sync for Builder<'a, 'b>
impl<'a, 'b> Unpin for Builder<'a, 'b>
impl<'a, 'b> UnwindSafe for Builder<'a, 'b>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
impl<T> Downcast for T where
T: Any,
impl<T> Downcast for T where
T: Any,
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>ⓘNotable traits for Box<R, Global>impl<R> Read for Box<R, Global> where
R: Read + ?Sized, impl<W> Write for Box<W, Global> where
W: Write + ?Sized, impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>ⓘNotable traits for Box<R, Global>impl<R> Read for Box<R, Global> where
R: Read + ?Sized, impl<W> Write for Box<W, Global> where
W: Write + ?Sized, impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;
R: Read + ?Sized, impl<W> Write for Box<W, Global> where
W: Write + ?Sized, impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;
Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait. Read more
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait. Read more
fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s. Read more
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s. Read more
impl<A> DynCastExt for A
impl<A> DynCastExt for A
fn dyn_cast<T>(
self
) -> Result<<A as DynCastExtHelper<T>>::Target, <A as DynCastExtHelper<T>>::Source> where
A: DynCastExtHelper<T>,
T: ?Sized,
fn dyn_cast<T>(
self
) -> Result<<A as DynCastExtHelper<T>>::Target, <A as DynCastExtHelper<T>>::Source> where
A: DynCastExtHelper<T>,
T: ?Sized,
Use this to cast from one trait object type to another. Read more
fn dyn_upcast<T>(self) -> <A as DynCastExtAdvHelper<T, T>>::Target where
A: DynCastExtAdvHelper<T, T, Source = <A as DynCastExtAdvHelper<T, T>>::Target>,
T: ?Sized,
fn dyn_upcast<T>(self) -> <A as DynCastExtAdvHelper<T, T>>::Target where
A: DynCastExtAdvHelper<T, T, Source = <A as DynCastExtAdvHelper<T, T>>::Target>,
T: ?Sized,
Use this to upcast a trait to one of its supertraits. Read more
fn dyn_cast_adv<F, T>(
self
) -> Result<<A as DynCastExtAdvHelper<F, T>>::Target, <A as DynCastExtAdvHelper<F, T>>::Source> where
A: DynCastExtAdvHelper<F, T>,
F: ?Sized,
T: ?Sized,
fn dyn_cast_adv<F, T>(
self
) -> Result<<A as DynCastExtAdvHelper<F, T>>::Target, <A as DynCastExtAdvHelper<F, T>>::Source> where
A: DynCastExtAdvHelper<F, T>,
F: ?Sized,
T: ?Sized,
fn dyn_cast_with_config<C>(
self
) -> Result<<A as DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>>::Target, <A as DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>>::Source> where
C: DynCastConfig,
A: DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>,
fn dyn_cast_with_config<C>(
self
) -> Result<<A as DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>>::Target, <A as DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>>::Source> where
C: DynCastConfig,
A: DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>,
Use this to cast from one trait object type to another. With this method the type parameter is a config type that uniquely specifies which cast should be preformed. Read more
sourceimpl<Q, K> Equivalent<K> for Q where
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Q where
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
sourcefn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to key and return true if they are equal.
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>ⓘNotable traits for Instrumented<T>impl<T> Future for Instrumented<T> where
T: Future, type Output = <T as Future>::Output;
fn instrument(self, span: Span) -> Instrumented<Self>ⓘNotable traits for Instrumented<T>impl<T> Future for Instrumented<T> where
T: Future, type Output = <T as Future>::Output;
T: Future, type Output = <T as Future>::Output;
sourcefn in_current_span(self) -> Instrumented<Self>ⓘNotable traits for Instrumented<T>impl<T> Future for Instrumented<T> where
T: Future, type Output = <T as Future>::Output;
fn in_current_span(self) -> Instrumented<Self>ⓘNotable traits for Instrumented<T>impl<T> Future for Instrumented<T> where
T: Future, type Output = <T as Future>::Output;
T: Future, type Output = <T as Future>::Output;
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into)Uses borrowed data to replace owned data, usually by cloning. Read more
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
fn vzip(self) -> V
sourceimpl<T> WithSubscriber for T
impl<T> WithSubscriber for T
sourcefn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>ⓘNotable traits for WithDispatch<T>impl<T> Future for WithDispatch<T> where
T: Future, type Output = <T as Future>::Output; where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>ⓘNotable traits for WithDispatch<T>impl<T> Future for WithDispatch<T> where
T: Future, type Output = <T as Future>::Output; where
S: Into<Dispatch>,
T: Future, type Output = <T as Future>::Output;
Attaches the provided Subscriber to this type, returning a
WithDispatch wrapper. Read more
sourcefn with_current_subscriber(self) -> WithDispatch<Self>ⓘNotable traits for WithDispatch<T>impl<T> Future for WithDispatch<T> where
T: Future, type Output = <T as Future>::Output;
fn with_current_subscriber(self) -> WithDispatch<Self>ⓘNotable traits for WithDispatch<T>impl<T> Future for WithDispatch<T> where
T: Future, type Output = <T as Future>::Output;
T: Future, type Output = <T as Future>::Output;
Attaches the current default Subscriber to this type, returning a
WithDispatch wrapper. Read more