JsString

Struct JsString 

Source
pub struct JsString { /* private fields */ }
Expand description

A Latin1 or UTF-16–encoded, reference counted, immutable string.

This is pretty similar to a Rc<[u16]>, but without the length metadata associated with the Rc fat pointer. Instead, the length of every string is stored on the heap, along with its reference counter and its data.

The string can be latin1 (stored as a byte for space efficiency) or U16 encoding.

We define some commonly used string constants in an interner. For these strings, we don’t allocate memory on the heap to reduce the overhead of memory allocation and reference counting.

Implementations§

Source§

impl JsString

Source

pub const fn from_static_js_string(src: &'static StaticJsString) -> Self

Create a JsString from a static js string.

Source

pub fn iter(&self) -> Iter<'_>

Create an iterator over the JsString.

Source

pub fn windows(&self, size: usize) -> Windows<'_>

Create an iterator over overlapping subslices of length size.

Source

pub fn as_str(&self) -> JsStr<'_>

Obtains the underlying &[u16] slice of a JsString

Source

pub fn concat(x: JsStr<'_>, y: JsStr<'_>) -> Self

Creates a new JsString from the concatenation of x and y.

Source

pub fn concat_array(strings: &[JsStr<'_>]) -> Self

Creates a new JsString from the concatenation of every element of strings.

Source

pub fn to_std_string_escaped(&self) -> String

Decodes a JsString into a String, replacing invalid data with its escaped representation in 4 digit hexadecimal.

Source

pub fn to_std_string_lossy(&self) -> String

Decodes a JsString into a String, replacing invalid data with the replacement character U+FFFD.

Source

pub fn to_std_string(&self) -> Result<String, FromUtf16Error>

Decodes a JsString into a String, returning

§Errors

FromUtf16Error if it contains any invalid data.

Source

pub fn to_std_string_with_surrogates( &self, ) -> impl Iterator<Item = Result<String, u16>> + '_

Decodes a JsString into an iterator of Result<String, u16>, returning surrogates as errors.

Source

pub fn map_valid_segments<F>(&self, f: F) -> Self
where F: FnMut(String) -> String,

Maps the valid segments of an UTF16 string and leaves the unpaired surrogates unchanged.

Source

pub fn code_points(&self) -> impl Iterator<Item = CodePoint> + Clone + '_

Gets an iterator of all the Unicode codepoints of a JsString.

Source

pub fn index_of( &self, search_value: JsStr<'_>, from_index: usize, ) -> Option<usize>

Abstract operation StringIndexOf ( string, searchValue, fromIndex )

Note: Instead of returning an isize with -1 as the “not found” value, we make use of the type system and return Option<usize> with None as the “not found” value.

More information:

Source

pub fn code_point_at(&self, position: usize) -> CodePoint

Abstract operation CodePointAt( string, position ).

The abstract operation CodePointAt takes arguments string (a String) and position (a non-negative integer) and returns a Record with fields [[CodePoint]] (a code point), [[CodeUnitCount]] (a positive integer), and [[IsUnpairedSurrogate]] (a Boolean). It interprets string as a sequence of UTF-16 encoded code points, as described in 6.1.4, and reads from it a single code point starting with the code unit at index position.

More information:

§Panics

If position is smaller than size of string.

Source

pub fn to_number(&self) -> f64

Abstract operation StringToNumber ( str )

More information:

Source

pub fn len(&self) -> usize

Get the length of the JsString.

Source

pub fn is_empty(&self) -> bool

Return true if the JsString is emtpy.

Source

pub fn to_vec(&self) -> Vec<u16>

Convert the JsString into a Vec<U16>.

Source

pub fn contains(&self, element: u8) -> bool

Check if the JsString contains a byte.

Source

pub fn trim(&self) -> JsStr<'_>

Trim whitespace from the start and end of the JsString.

Source

pub fn trim_start(&self) -> JsStr<'_>

Trim whitespace from the start of the JsString.

Source

pub fn trim_end(&self) -> JsStr<'_>

Trim whitespace from the end of the JsString.

Source

pub fn is_static(&self) -> bool

Check if the JsString is static.

Source

pub fn get<'a, I>(&'a self, index: I) -> Option<I::Value>
where I: JsSliceIndex<'a>,

Get the element a the given index, None otherwise.

Source

pub unsafe fn get_unchecked<'a, I>(&'a self, index: I) -> I::Value
where I: JsSliceIndex<'a>,

Returns an element or subslice depending on the type of index, without doing bounds check.

§Safety

Caller must ensure the index is not out of bounds

Source

pub fn get_expect<'a, I>(&'a self, index: I) -> I::Value
where I: JsSliceIndex<'a>,

Get the element a the given index.

§Panics

If the index is out of bounds.

Source

pub fn refcount(&self) -> Option<usize>

Gets the number of JsStrings which point to this allocation.

Source

pub fn display_escaped(&self) -> JsStrDisplayEscaped<'_>

Gets a displayable escaped string. This may be faster and has fewer allocations than format!("{}", str.to_string_escaped()) when displaying.

Source

pub fn display_lossy(&self) -> JsStrDisplayLossy<'_>

Gets a displayable lossy string. This may be faster and has fewer allocations than format!("{}", str.to_string_lossy()) when displaying.

Trait Implementations§

Source§

impl Clone for JsString

Source§

fn clone(&self) -> Self

Returns a duplicate 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 JsString

Source§

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

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

impl Default for JsString

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl Drop for JsString

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl From<&[JsString]> for JsString

Source§

fn from(value: &[JsString]) -> Self

Converts to this type from the input type.
Source§

impl From<&[u16]> for JsString

Source§

fn from(s: &[u16]) -> Self

Converts to this type from the input type.
Source§

impl<const N: usize> From<&[u16; N]> for JsString

Source§

fn from(s: &[u16; N]) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<&'a JsString> for JsStr<'a>

Source§

fn from(value: &'a JsString) -> Self

Converts to this type from the input type.
Source§

impl From<&str> for JsString

Source§

fn from(s: &str) -> Self

Converts to this type from the input type.
Source§

impl From<JsStr<'_>> for JsString

Source§

fn from(value: JsStr<'_>) -> Self

Converts to this type from the input type.
Source§

impl From<String> for JsString

Source§

fn from(s: String) -> Self

Converts to this type from the input type.
Source§

impl FromStr for JsString

Source§

type Err = Infallible

The associated error which can be returned from parsing.
Source§

fn from_str(s: &str) -> Result<Self, Self::Err>

Parses a string s to return a value of this type. Read more
Source§

impl Hash for JsString

Source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl<'a> IntoIterator for &'a JsString

Source§

type IntoIter = Iter<'a>

Which kind of iterator are we turning this into?
Source§

type Item = u16

The type of the elements being iterated over.
Source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more
Source§

impl Ord for JsString

Source§

fn cmp(&self, other: &Self) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl PartialEq<&str> for JsString

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialEq<[u16]> for JsString

Source§

fn eq(&self, other: &[u16]) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<const N: usize> PartialEq<[u16; N]> for JsString

Source§

fn eq(&self, other: &[u16; N]) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialEq<JsStr<'_>> for JsString

Source§

fn eq(&self, other: &JsStr<'_>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialEq<JsString> for [u16]

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<const N: usize> PartialEq<JsString> for [u16; N]

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialEq<JsString> for JsStr<'_>

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialEq<JsString> for str

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialEq<str> for JsString

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialEq for JsString

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialOrd for JsString

Source§

fn partial_cmp(&self, other: &Self) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

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

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

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

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

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

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

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

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl Eq for JsString

Auto Trait Implementations§

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

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

Source§

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

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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 T
where 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 T
where T: Clone,

Source§

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 T
where U: Into<T>,

Source§

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 T
where U: TryFrom<T>,

Source§

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.