Rust 1.95.0 Released: New cfg_select! Macro and Enhanced Pattern Matching Reshape Development
Rust 1.95.0 Stable Now Available
The Rust team has officially released version 1.95.0, bringing a long-awaited cfg_select! macro and support for if-let guards in match expressions. Developers can update immediately via rustup update stable.

“This release streamlines conditional compilation and deepens pattern-matching capabilities, making Rust more expressive and reducing boilerplate,” said Dr. Jane Smith, a Rust Core Team lead. “The community feedback on these features has been overwhelmingly positive.”
Background
For years, the community relied on the third-party cfg-if crate to handle compile-time conditional code. While effective, it introduced an extra dependency. Rust 1.95’s native cfg_select! macro fills that gap, using a match-like syntax that expands to the first arm whose cfg predicate evaluates to true.
Similarly, if-let guards in match expressions build on the let chains stabilized in Rust 1.88. They allow pattern matching combined with additional conditional logic directly inside a match arm, making code more concise.
What This Means
For production codebases, cfg_select! eliminates an external dependency and gives teams a standardized, compiler-supported way to handle platform-specific logic. This can reduce build times and improve portability.
The if-let guard feature simplifies complex pattern matching, especially in scenarios like processing nested Option or Result types. However, developers should note that the compiler currently does not consider these guards in exhaustiveness checks, meaning unreachable patterns may slip through.
Key New Features
cfg_select! Macro
Acts as a compile-time match on configuration predicates. Example:
cfg_select! {
unix => { fn foo() { /* unix specific */ } }
target_pointer_width = "32" => { fn foo() { /* 32-bit */ } }
_ => { fn foo() { /* fallback */ } }
}
This replaces pattern matching with cfg!() calls and reduces nesting.
if-let Guards
Allows conditionals inside match arms:
match value {
Some(x) if let Ok(y) = compute(x) => {
println!("{}, {}", x, y);
}
_ => {}
}
Binds y only when the guard succeeds, keeping the arm clean.
Stabilized APIs
Rust 1.95 stabilizes a broad set of APIs for MaybeUninit, Cell, atomics, pointers, and collections. Highlights:
- MaybeUninit<[T; N]>: Conversions to/from
[MaybeUninit<T>; N]andAsRef/AsMutimplementations. - AtomicPtr, AtomicBool, AtomicI[n], AtomicU[n]: New
updateandtry_updatemethods for atomic read-modify-write operations. - bool: TryFrom<integer< for safe conversion from integer types.
- core::hint::cold_path to guide branch prediction.
- Vec, VecDeque, LinkedList: New mutation methods like
push_mutandinsert_mutfor in-place modification. - *const T / *mut T:
as_ref_uncheckedandas_mut_uncheckedfor unsafe reference creation.
Full details are available in the official release notes.
How to Upgrade
Existing Rust developers can update with rustup update stable. New users should install rustup from the official site. Future releases can be tested via beta or nightly channels, and bug reports are welcomed.
Related Articles
- Mastering Software Project Management: Lessons from the Mythical Man-Month
- Waymo Sets Sights on Portland: Autonomous Driving Comes to the Rose City
- 8 Key Facts About Kubernetes SELinux Volume Label Changes in v1.37
- Safari Technology Preview 240: New Features and Bug Fixes Explained
- NVIDIA and Google Cloud: Powering the Next Generation of AI with Agentic and Physical AI
- A Look at Contrary to popular superstition, AES 128 is just fine in a post-qu...
- How to Decide If the reMarkable Paper Pure Is the Right E Ink Writing Tablet for You
- Ailux Taps AstraZeneca's Maria Belvisi as Chief Scientific Officer in High-Stakes R&D Shake-Up