Module std::string
The
stringString- Struct String
- Constants
- Function utf8
- Function from_ascii
- Function to_ascii
- Function try_utf8
- Function as_bytes
- Function into_bytes
- Function is_empty
- Function length
- Function append
- Function append_utf8
- Function insert
- Function substring
- Function index_of
- Function internal_check_utf8
- Function internal_is_char_boundary
- Function internal_sub_string
- Function internal_index_of
- Function bytes
- Function sub_string
use std::ascii;
use std::option;
use std::vector;
Struct String
A
Stringpublic struct String has copy, drop, store
Constants
An invalid UTF8 encoding.
const EInvalidUTF8: u64 = 1;
Index out of range.
const EInvalidIndex: u64 = 2;
Function utf8
Creates a new string from a sequence of bytes. Aborts if the bytes do not represent valid utf8.
public fun utf8(bytes: vector<u8>): std::string::String
Implementation
public fun utf8(bytes: vector<u8>): String {
    assert!(internal_check_utf8(&bytes), EInvalidUTF8);
    String { bytes }
}
Function from_ascii
Convert an ASCII string to a UTF8 string
public fun from_ascii(s: std::ascii::String): std::string::String
Implementation
public fun from_ascii(s: ascii::String): String {
    String { bytes: s.into_bytes() }
}
Function to_ascii
Convert an UTF8 string to an ASCII string.
Aborts if s is not valid ASCII
public fun to_ascii(s: std::string::String): std::ascii::String
Function try_utf8
Tries to create a new string from a sequence of bytes.
public fun try_utf8(bytes: vector<u8>): std::option::Option<std::string::String>
Implementation
public fun try_utf8(bytes: vector<u8>): Option<String> {
    if (internal_check_utf8(&bytes)) option::some(String { bytes }) else option::none()
}
Function as_bytes
Returns a reference to the underlying byte vector.
public fun as_bytes(s: &std::string::String): &vector<u8>
Function into_bytes
Unpack the
stringpublic fun into_bytes(s: std::string::String): vector<u8>
Function is_empty
Checks whether this string is empty.
public fun is_empty(s: &std::string::String): bool
Function length
Returns the length of this string, in bytes.
public fun length(s: &std::string::String): u64
Function append
Appends a string.
public fun append(s: &mut std::string::String, r: std::string::String)
Function append_utf8
Appends bytes which must be in valid utf8 format.
public fun append_utf8(s: &mut std::string::String, bytes: vector<u8>)
Function insert
Insert the other string at the byte index in given string. The index must be at a valid utf8 char boundary.
public fun insert(s: &mut std::string::String, at: u64, o: std::string::String)
Implementation
Function substring
Returns a sub-string using the given byte indices, where i is the first
byte position and j is the start of the first byte not included (or the
length of the string). The indices must be at valid utf8 char boundaries,
guaranteeing that the result is valid utf8.
public fun substring(s: &std::string::String, i: u64, j: u64): std::string::String
Implementation
public fun substring(s: &String, i: u64, j: u64): String {
    let bytes = &s.bytes;
    let l = bytes.length();
    assert!(
        j <= l &&
            i <= j &&
            internal_is_char_boundary(bytes, i) &&
            internal_is_char_boundary(bytes, j),
        EInvalidIndex,
    );
    String { bytes: internal_sub_string(bytes, i, j) }
}
Function index_of
Computes the index of the first occurrence of a string. Returns
s.length()public fun index_of(s: &std::string::String, r: &std::string::String): u64
Function internal_check_utf8
fun internal_check_utf8(v: &vector<u8>): bool
Implementation
native fun internal_check_utf8(v: &vector<u8>): bool;
Function internal_is_char_boundary
fun internal_is_char_boundary(v: &vector<u8>, i: u64): bool
Implementation
native fun internal_is_char_boundary(v: &vector<u8>, i: u64): bool;
Function internal_sub_string
fun internal_sub_string(v: &vector<u8>, i: u64, j: u64): vector<u8>
Function internal_index_of
fun internal_index_of(v: &vector<u8>, r: &vector<u8>): u64
Function bytes
public fun bytes(s: &std::string::String): &vector<u8>
Function sub_string
public fun sub_string(s: &std::string::String, i: u64, j: u64): std::string::String