KEMBAR78
Release 0.62.0 by kennykerr · Pull Request #3502 · microsoft/windows-rs · GitHub
Skip to content

Conversation

@kennykerr
Copy link
Collaborator

@kennykerr kennykerr commented Feb 21, 2025

This release includes the following brand new crates:

  • The windows-collections crate defines the Windows collection types like IIterable<T>, IVector<T>, IMap<K, V>, and so on (Introducing the dedicated windows-collections crate #3483). It also includes all of the stock implementations for creating such collections (Stock collection support for IIterable #2346, Stock collection support for IVectorView #2350, Stock collection support for IMapView #2353). This allows these collections to be used without requiring a dependency on the larger windows crate. This crate also provides an optimized implementation of the standard Iterator trait for the Windows IIterator<T> interface (Optimize Iterator for IIterator<T> #3476).

  • The windows-future crate defines the Windows async types like IAsyncAction, IAsyncOperation<T>, and so on (Introducing the dedicated windows-future crate #3490). It also includes all of the stock implementations for creating such async types (Add async ready support #3221, Add async spawn support #3235). This allows these async types to be used without requiring a dependency on the larger windows crate.

  • The windows-link crate provides linker support for Windows (Introducing the windows-link crate #3450). This is the evolution of the older windows-targets crate but is substantially simpler and more versatile thanks to advances in the Rust compiler since the windows-targets crate was unveiled. Notably, it does not depend on or insert any import libs and can be used with custom libraries, not only those provided by the Windows operating system. All of the crates, with the exception of windows-sys, now depend on the new windows-link crate instead of the older windows-targets crate. This greatly simplifies compilation and also greatly reduces the size of dependencies as the windows-link crate is tiny. The windows-bindgen crate defaults to windows-link but also adds the --link option to override this as needed. You may for example want to use --link windows_targets if you need to stick with the windows-targets crate if you cannot change your MSRV to Rust 1.71 or later as that was the first version to stabilize raw-dylib for all Windows targets. This then lets you continue to use windows-bindgen until you are ready to move to a newer version of Rust.

  • The windows-numerics crate defines the Windows numeric types to support graphics-oriented math APIs and calculations (Introducing the dedicated windows-numerics crate #3488). It also also includes all of the stock implementations for overloaded operators and other transformations. This allows these numeric types to be used without requiring a dependency on the larger windows crate.

In addition to these new crates, this release includes major updates to the following existing crates:

In addition, this release also includes minor updates to the following existing crates:

  • The windows-result now includes the BOOL type (Make BOOL a core type #3441) as a core type. This allows this ubiquitous type to be used without requiring a dependency on the larger windows crate.

  • The windows-strings crate now depends on the new windows-link crate instead of the older windows-targets crate.

  • The windows-version crate now depends on the new windows-link crate instead of the older windows-targets crate.

  • The cppwinrt crate includes minor improvements to improve build reliability.

@kennykerr kennykerr merged commit 50e85cb into master Feb 21, 2025
84 checks passed
@kennykerr kennykerr deleted the 0.62.0 branch February 21, 2025 16:22
@ratijas
Copy link

ratijas commented May 2, 2025

Sorry, I can't find v0.62 on crates.io, and official documentation shows v0.60 — what is happening?

@kennykerr
Copy link
Collaborator Author

See the release notes for the latest release. The windows-rs project now encompasses a wide range of crates and it doesn't make sense to release a new version of each crate with every release.

@ratijas
Copy link

ratijas commented May 5, 2025

I see.

Well, on some level it does make sense to release all crates with the same version -- even if some of them didn't have any commits since the last release -- just to avoid the confusion. For example, KDE does that for their Frameworks and Plasma releases. They have automated tooling to bump versions simultaneously across all their repos. To be honest it kinda helps stay sane with their amount of repos to manage.

@kennykerr
Copy link
Collaborator Author

Sure, I did that for a while as it made a lot of sense to me at the time but it upset a lot of consumers who didn't appreciate the version churn. 🤷

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants