Struct gloo_file::File

source ·
pub struct File { /* private fields */ }
Expand description

A File.

Implementations§

source§

impl File

source

pub fn new<T>(name: &str, contents: T) -> Filewhere T: BlobContents,

Create a new File with the given name and contents.

contents can be &str, &[u8], or js_sys::ArrayBuffer.

source

pub fn new_with_options<T>( name: &str, contents: T, mime_type: Option<&str>, last_modified_time: Option<SystemTime> ) -> Filewhere T: BlobContents,

Like File::new, but allows customizing the MIME type (also known as content type or media type), and the last modified time.

std::time::SystemTime is a low level type, use a crate like chrono to work with a more user-friendly representation of time.

Examples
use chrono::prelude::*;
use gloo_file::File;

// Just create a dummy `gloo::file::File` for demonstration purposes.
let example_file = File::new_with_options(
    "motivation.txt",
    "live your best life",
    Some("text/plain"),
    Some(Utc::now().into())
);
assert_eq!(example_file.name(), String::from("motivation.txt"));
assert_eq!(example_file.raw_mime_type(), String::from("text/plain"));
source

pub fn name(&self) -> String

Gets the file name.

source

pub fn last_modified_time(&self) -> SystemTime

Gets the time that the file was last modified.

std::time::SystemTime is a low level type, use a crate like chrono to work with more user-friendly representations of time. For example:

use chrono::prelude::*;
use gloo_file::File;

// Just create a dummy `gloo::file::File` for demonstration purposes.
let example_file = File::new("test_file.txt", "<almost empty contents>");
let date: DateTime<Utc> = example_file.last_modified_time().into();
source

pub fn slice(&self, start: u64, end: u64) -> Self

Create a new File from a sub-part of this File.

Methods from Deref<Target = Blob>§

source

pub fn slice(&self, start: u64, end: u64) -> Self

source

pub fn size(&self) -> u64

The number of bytes in the Blob/File.

source

pub fn raw_mime_type(&self) -> String

The raw MIME type (also known as content type or media type) of the File or Blob.

Trait Implementations§

source§

impl AsRef<Blob> for File

source§

fn as_ref(&self) -> &Blob

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl AsRef<File> for File

source§

fn as_ref(&self) -> &File

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl Clone for File

source§

fn clone(&self) -> File

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for File

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Deref for File

§

type Target = Blob

The resulting type after dereferencing.
source§

fn deref(&self) -> &Self::Target

Dereferences the value.
source§

impl From<File> for Blob

source§

fn from(file: File) -> Self

Converts to this type from the input type.
source§

impl From<File> for File

source§

fn from(file: File) -> Self

Converts to this type from the input type.
source§

impl From<File> for ObjectUrl

source§

fn from(file: File) -> Self

Converts to this type from the input type.
source§

impl PartialEq<File> for File

source§

fn eq(&self, other: &File) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Eq for File

source§

impl StructuralEq for File

source§

impl StructuralPartialEq for File

Auto Trait Implementations§

§

impl RefUnwindSafe for File

§

impl !Send for File

§

impl !Sync for File

§

impl Unpin for File

§

impl UnwindSafe for File

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

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

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.