-
Notifications
You must be signed in to change notification settings - Fork 13.5k
Open
Labels
C-tracking-issueCategory: An issue tracking the progress of sth. like the implementation of an RFCCategory: An issue tracking the progress of sth. like the implementation of an RFCT-libs-apiRelevant to the library API team, which will review and decide on the PR/issue.Relevant to the library API team, which will review and decide on the PR/issue.
Description
Feature gate: #![feature(bstr)]
This is a tracking issue for the ByteStr/ByteString types, which represent human-readable strings that are usually, but not always, UTF-8. Unlike &str
/String
, these types permit non-UTF-8 contents, making them suitable for user input, non-native filenames (as Path
only supports native filenames), and other applications that need to round-trip whatever data the user provides.
This was approved in ACP rust-lang/libs-team#502 .
Public API
// In core::bstr
#[repr(transparent)]
pub struct ByteStr(pub [u8]);
impl ByteStr {
pub fn new<B: ?Sized + AsRef<[u8]>>(bytes: &B) -> &Self { ... }
}
impl Debug for ByteStr { ... }
impl Display for ByteStr { ... }
impl Deref for ByteStr { type Target = [u8]; ... }
impl DerefMut for ByteStr { ... }
// Other trait impls from bstr, including From impls
// In alloc::bstr
#[repr(transparent)]
pub struct ByteString(pub Vec<u8>);
impl Debug for ByteString { ... }
impl Display for ByteString { ... }
impl Deref for ByteString { type Target = Vec<u8>; ... }
impl DerefMut for ByteString { ... }
// Other trait impls from bstr, including From impls
Steps / History
- Implementation: Implement
ByteStr
andByteString
types #135073 - Final comment period (FCP)1
- Stabilization PR
Unresolved Questions
- Should we call this
BStr
/BString
, orByteStr
/ByteString
? The former will be more familiar to users of thebstr
crate in the ecosystem. The latter is more explicit, and avoids potential naming conflicts (making it easier to, for instance, add it to the prelude). - Should the
Display
impl use the Unicode replacement character, or do escaping like theDebug
impl?
Footnotes
karolba, oxalica, Enyium and tarcierijplatte, karolba, thaliaarchi, LeoniePhiline, musjj and 14 morejieyouxu, goffrie, GrigorenkoPV, Systemcluster, karolba and 8 more
Metadata
Metadata
Assignees
Labels
C-tracking-issueCategory: An issue tracking the progress of sth. like the implementation of an RFCCategory: An issue tracking the progress of sth. like the implementation of an RFCT-libs-apiRelevant to the library API team, which will review and decide on the PR/issue.Relevant to the library API team, which will review and decide on the PR/issue.