-
Notifications
You must be signed in to change notification settings - Fork 13.6k
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 RFCF-cstr_display`#![feature(cstr_display)]``#![feature(cstr_display)]`S-tracking-needs-to-bakeStatus: The implementation is "complete" but it needs time to bake.Status: The implementation is "complete" but it needs time to bake.T-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(cstr_display)]
This is a tracking issue for the CStr::display
API.
Implement Display
for CStr
and CString
. The implementation would be the same as for the ByteStr and ByteString types.
Public API
I'm abusing the API section here to include the whole implementation, as it is very simple.
impl CStr {
pub fn display(&self) -> impl fmt::Display {
crate::bstr::ByteStr::from_bytes(self.to_bytes())
}
}
Steps / History
Motivation and discussion is elaborated in the ACP.
2025-02-27: ACP created by @Darksonn.
2025-04-17: ACP accepted by @BurntSushi.
2025-04-17: tracking issue created.
2025-04-29: @rust-lang/libs-api team decided against implementing Display
for CStr
in favor of adding a display
method like on OsStr
and Path
.
2025-05-24: implementation updated to add CStr::display
.
(Remember to update the S-tracking-*
label when checking boxes.)
- Implementation: add
CStr::display
#139994 - Final comment period (FCP)1
- Stabilization PR
Unresolved Questions
- None yet.
Footnotes
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 RFCF-cstr_display`#![feature(cstr_display)]``#![feature(cstr_display)]`S-tracking-needs-to-bakeStatus: The implementation is "complete" but it needs time to bake.Status: The implementation is "complete" but it needs time to bake.T-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.