- 
                Notifications
    You must be signed in to change notification settings 
- Fork 13.9k
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
bjoernagerbjoernager
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.