rust-lang/rust-clippy

Lint for .clone().into_boxed_str()

Open

#15,951 opened on Oct 25, 2025

View on GitHub
 (4 comments) (0 reactions) (1 assignee)Rust (1,391 forks)batch import
A-lintgood first issue

Repository metrics

Stars
 (10,406 stars)
PR merge metrics
 (Avg merge 18d 15h) (115 merged PRs in 30d)

Description

What it does

Suggest turning s.clone().into_boxed_str() into Box::from(s.as_str()).

Possibly could be grouped together with other inefficient string conversions.

Advantage

Removes a call to __rust_realloc

Drawbacks

No response

Example

fn foo(s: &String) -> Box<str> {
    s.clone().into_boxed_str()
}

Could be written as:

fn foo(s: &String) -> Box<str> {
    Box::from(s.as_str())
}

Comparison with existing lints

redundant_clone generally doesn't consider the semantics of the

Additional Context

A GitHub search shows this unoptimal pattern is actually used fairly often.

Contributor guide