1 //! The change log. 2 3 4 /// Release 0.8.4 (2024-06-23) 5 /// 6 /// ## Non-breaking changes 7 /// 8 /// Compilation when targeting Apple's visionos, watchos and tvos targets has been fixed. 9 pub mod r0_8_4 {} 10 11 /// Release 0.8.3 (2024-03-05) 12 /// 13 /// ## Non-breaking changes 14 /// 15 /// A `dev-dependency` on `windows-sys` that was unconditionally introduced in 16 /// [0.8.2](r0_8_2) has been made conditional. 17 pub mod r0_8_3 {} 18 19 /// Release 0.8.2 (2024-03-01) 20 /// 21 /// ## (Potentially) breaking changes 22 /// 23 /// MSRV has been increased to 1.56.0. Since both rustc versions are ancient, this has been deemed 24 /// to not be breaking enough to warrant a semver-breaking release of libloading. If you're stick 25 /// with a version of rustc older than 1.56.0, lock `libloading` dependency to `0.8.1`. 26 /// 27 /// ## Non-breaking changes 28 /// 29 /// * The crate switches the dependency on `windows-sys` to a `windows-target` one for Windows 30 /// bindings. In order to enable this `libloading` defines any bindings necessary for its operation 31 /// internally, just like has been done for `unix` targets. This should result in leaner dependency 32 /// trees. 33 /// * `os::unix::with_dlerror` has been exposed for the users who need to invoke `dl*` family of 34 /// functions manually. 35 pub mod r0_8_2 {} 36 37 /// Release 0.8.1 (2023-09-30) 38 /// 39 /// ## Non-breaking changes 40 /// 41 /// * Support for GNU Hurd. 42 pub mod r0_8_1 {} 43 44 /// Release 0.8.0 (2023-04-11) 45 /// 46 /// ## (Potentially) breaking changes 47 /// 48 /// * `winapi` dependency has been replaced with `windows-sys`. 49 /// * As a result the MSRV has been increased to 1.48. 50 /// 51 /// ## Non-breaking changes 52 /// 53 /// * Support for the QNX Neutrino target has been added. 54 pub mod r0_8_0 {} 55 56 /// Release 0.7.4 (2022-11-07) 57 /// 58 /// This release has no functional changes. 59 /// 60 /// `RTLD_LAZY`, `RTLD_GLOBAL` and `RTLD_LOCAL` constants have been implemented for AIX platforms. 61 pub mod r0_7_4 {} 62 63 /// Release 0.7.3 (2022-01-15) 64 /// 65 /// This release has no functional changes. 66 /// 67 /// In this release the `docsrs` `cfg` has been renamed to `libloading_docs` to better reflect that 68 /// this `cfg` is intended to be only used by `libloading` and only specifically for the invocation 69 /// of `rustdoc` when documenting `libloading`. Setting this `cfg` in any other situation is 70 /// unsupported and will not work. 71 pub mod r0_7_3 {} 72 73 /// Release 0.7.2 (2021-11-14) 74 /// 75 /// Cargo.toml now specifies the MSRV bounds, which enables tooling to report an early failure when 76 /// the version of the toolchain is insufficient. Refer to the [min-rust-version RFC] and its 77 /// [tracking issue]. 78 /// 79 /// [min-rust-version RFC]: https://rust-lang.github.io/rfcs/2495-min-rust-version.html 80 /// [tracking issue]: https://github.com/rust-lang/rust/issues/65262 81 /// 82 /// Additionally, on platforms `libloading` has no support (today: `not(any(unix, windows))`), we 83 /// will no longer attempt to implement the cross-platform `Library` and `Symbol` types. This makes 84 /// `libloading` compile on targets such as `wasm32-unknown-unknown` and gives ability to the 85 /// downstream consumers of this library to decide how they want to handle the absence of the 86 /// library loading implementation in their code. One of such approaches could be depending on 87 /// `libloading` itself optionally as such: 88 /// 89 /// ```toml 90 /// [target.'cfg(any(unix, windows))'.dependencies.libloading] 91 /// version = "0.7" 92 /// ``` 93 pub mod r0_7_2 {} 94 95 /// Release 0.7.1 (2021-10-09) 96 /// 97 /// Significantly improved the consistency and style of the documentation. 98 pub mod r0_7_1 {} 99 100 /// Release 0.7.0 (2021-02-06) 101 /// 102 /// ## Breaking changes 103 /// 104 /// ### Loading functions are now `unsafe` 105 /// 106 /// A number of associated methods involved in loading a library were changed to 107 /// be `unsafe`. The affected functions are: [`Library::new`], [`os::unix::Library::new`], 108 /// [`os::unix::Library::open`], [`os::windows::Library::new`], 109 /// [`os::windows::Library::load_with_flags`]. This is the most prominent breaking change in this 110 /// release and affects majority of the users of `libloading`. 111 /// 112 /// In order to see why it was necessary, consider the following snippet of C++ code: 113 /// 114 /// ```c++ 115 /// #include <vector> 116 /// #include <iostream> 117 /// 118 /// static std::vector<unsigned int> UNSHUU = { 1, 2, 3 }; 119 /// 120 /// int main() { 121 /// std::cout << UNSHUU[0] << UNSHUU[1] << UNSHUU[2] << std::endl; // Prints 123 122 /// return 0; 123 /// } 124 /// ``` 125 /// 126 /// The `std::vector` type, much like in Rust's `Vec`, stores its contents in a buffer allocated on 127 /// the heap. In this example the vector object itself is stored and initialized as a static 128 /// variable – a compile time construct. The heap, on the other hand, is a runtime construct. And 129 /// yet the code works exactly as you'd expect – the vector contains numbers 1, 2 and 3 stored in 130 /// a buffer on heap. So, _what_ makes it work out, exactly? 131 /// 132 /// Various executable and shared library formats define conventions and machinery to execute 133 /// arbitrary code when a program or a shared library is loaded. On systems using the PE format 134 /// (e.g. Windows) this is available via the optional `DllMain` initializer. Various systems 135 /// utilizing the ELF format take a slightly different approach of maintaining an array of function 136 /// pointers in the `.init_array` section. A very similar mechanism exists on systems that utilize 137 /// the Mach-O format. 138 /// 139 /// For the C++ program above, the object stored in the `UNSHUU` global variable is constructed 140 /// by code run as part of such an initializer routine. This initializer is run before the entry 141 /// point (the `main` function) is executed, allowing for this magical behaviour to be possible. 142 /// Were the C++ code built as a shared library instead, the initialization routines would run as 143 /// the resulting shared library is loaded. In case of `libloading` – during the call to 144 /// `Library::new` and other methods affected by this change. 145 /// 146 /// These initialization (and very closely related termination) routines can be utilized outside of 147 /// C++ too. Anybody can build a shared library in variety of different programming languages and 148 /// set up the initializers to execute arbitrary code. Potentially code that does all sorts of 149 /// wildly unsound stuff. 150 /// 151 /// The routines are executed by components that are an integral part of the operating system. 152 /// Changing or controlling the operation of these components is infeasible. With that in 153 /// mind, the initializer and termination routines are something anybody loading a library must 154 /// carefully evaluate the libraries loaded for soundness. 155 /// 156 /// In practice, a vast majority of the libraries can be considered a good citizen and their 157 /// initialization and termination routines, if they have any at all, can be trusted to be sound. 158 /// 159 /// Also see: [issue #86]. 160 /// 161 /// ### Better & more consistent default behaviour on UNIX systems 162 /// 163 /// On UNIX systems the [`Library::new`], [`os::unix::Library::new`] and 164 /// [`os::unix::Library::this`] methods have been changed to use 165 /// <code>[RTLD_LAZY] | [RTLD_LOCAL]</code> as the default set of loader options (previously: 166 /// [`RTLD_NOW`]). This has a couple benefits. Namely: 167 /// 168 /// * Lazy binding is generally quicker to execute when only a subset of symbols from a library are 169 /// used and is typically the default when neither `RTLD_LAZY` nor `RTLD_NOW` are specified when 170 /// calling the underlying `dlopen` API; 171 /// * On most UNIX systems (macOS being a notable exception) `RTLD_LOCAL` is the default when 172 /// neither `RTLD_LOCAL` nor [`RTLD_GLOBAL`] are specified. The explicit setting of the 173 /// `RTLD_LOCAL` flag makes this behaviour consistent across platforms. 174 /// 175 /// ### Dropped support for Windows XP/Vista 176 /// 177 /// The (broken) support for Windows XP and Windows Vista environments was removed. This was 178 /// prompted primarily by a similar policy change in the [Rust 179 /// project](https://github.com/rust-lang/compiler-team/issues/378) but also as an acknowledgement 180 /// to the fact that `libloading` never worked in these environments anyway. 181 /// 182 /// ### More accurate error variant names 183 /// 184 /// Finally, the `Error::LoadLibraryW` renamed to [`Error::LoadLibraryExW`] to more accurately 185 /// represent the underlying API that's failing. No functional changes as part of this rename 186 /// intended. 187 /// 188 /// [issue #86]: https://github.com/nagisa/rust_libloading/issues/86 189 /// [`Library::new`]: crate::Library::new 190 /// [`Error::LoadLibraryExW`]: crate::Error::LoadLibraryExW 191 /// [`os::unix::Library::this`]: crate::os::unix::Library::this 192 /// [`os::unix::Library::new`]: crate::os::unix::Library::new 193 /// [`os::unix::Library::open`]: crate::os::unix::Library::new 194 /// [`os::windows::Library::new`]: crate::os::windows::Library::new 195 /// [`os::windows::Library::load_with_flags`]: crate::os::windows::Library::load_with_flags 196 /// [`RTLD_NOW`]: crate::os::unix::RTLD_NOW 197 /// [RTLD_LAZY]: crate::os::unix::RTLD_LAZY 198 /// [RTLD_LOCAL]: crate::os::unix::RTLD_LOCAL 199 /// [`RTLD_GLOBAL`]: crate::os::unix::RTLD_GLOBAL 200 pub mod r0_7_0 {} 201 202 /// Release 0.6.7 (2021-01-14) 203 /// 204 /// * Added a [`os::windows::Library::open_already_loaded`] to obtain a handle to a library that 205 /// must already be loaded. There is no portable equivalent for all UNIX targets. Users who do 206 /// not care about portability across UNIX platforms may use [`os::unix::Library::open`] with 207 /// `libc::RTLD_NOLOAD`; 208 /// 209 /// [`os::windows::Library::open_already_loaded`]: crate::os::windows::Library::open_already_loaded 210 /// [`os::unix::Library::open`]: crate::os::unix::Library::open 211 pub mod r0_6_7 {} 212 213 /// Release 0.6.6 (2020-12-03) 214 /// 215 /// * Fix a double-release of resources when [`Library::close`] or [`os::windows::Library::close`] 216 /// is used on Windows. 217 /// 218 /// [`Library::close`]: crate::Library::close 219 /// [`os::windows::Library::close`]: crate::os::windows::Library::close 220 pub mod r0_6_6 {} 221 222 /// Release 0.6.5 (2020-10-23) 223 /// 224 /// * Upgrade cfg-if 0.1 to 1.0 225 pub mod r0_6_5 {} 226 227 /// Release 0.6.4 (2020-10-10) 228 /// 229 /// * Remove use of `build.rs` making it easier to build `libloading` without cargo. It also 230 /// almost halves the build time of this crate. 231 pub mod r0_6_4 {} 232 233 /// Release 0.6.3 (2020-08-22) 234 /// 235 /// * Improve documentation, allowing to view all of the os-specific functionality from 236 /// documentation generated for any target; 237 /// * Add [`os::windows::Library::this`]; 238 /// * Added constants to use with OS-specific `Library::open`; 239 /// * Add [`library_filename`]. 240 /// 241 /// [`os::windows::Library::this`]: crate::os::windows::Library::this 242 /// [`library_filename`]: crate::library_filename 243 pub mod r0_6_3 {} 244 245 /// Release 0.6.2 (2020-05-06) 246 /// 247 /// * Fixed building of this library on Illumos. 248 pub mod r0_6_2 {} 249 250 /// Release 0.6.1 (2020-04-15) 251 /// 252 /// * Introduced a new method [`os::windows::Library::load_with_flags`]; 253 /// * Added support for the Illumos triple. 254 /// 255 /// [`os::windows::Library::load_with_flags`]: crate::os::windows::Library::load_with_flags 256 pub mod r0_6_1 {} 257 258 /// Release 0.6.0 (2020-04-05) 259 /// 260 /// * Introduced a new method [`os::unix::Library::get_singlethreaded`]; 261 /// * Added (untested) support for building when targeting Redox and Fuchsia; 262 /// * The APIs exposed by this library no longer panic and instead return an `Err` when it used 263 /// to panic. 264 /// 265 /// ## Breaking changes 266 /// 267 /// * Minimum required (stable) version of Rust to build this library is now 1.40.0; 268 /// * This crate now implements a custom [`Error`] type and all APIs now return this type rather 269 /// than returning the `std::io::Error`; 270 /// * `libloading::Result` has been removed; 271 /// * Removed the dependency on the C compiler to build this library on UNIX-like platforms. 272 /// `libloading` used to utilize a snippet written in C to work-around the unlikely possibility 273 /// of the target having a thread-unsafe implementation of the `dlerror` function. The effect of 274 /// the work-around was very opportunistic: it would not work if the function was called by 275 /// forgoing `libloading`. 276 /// 277 /// Starting with 0.6.0, [`Library::get`] on platforms where `dlerror` is not MT-safe (such as 278 /// FreeBSD, DragonflyBSD or NetBSD) will unconditionally return an error when the underlying 279 /// `dlsym` returns a null pointer. For the use-cases where loading null pointers is necessary 280 /// consider using [`os::unix::Library::get_singlethreaded`] instead. 281 /// 282 /// [`Library::get`]: crate::Library::get 283 /// [`os::unix::Library::get_singlethreaded`]: crate::os::unix::Library::get_singlethreaded 284 /// [`Error`]: crate::Error 285 pub mod r0_6_0 {} 286 287 /// Release 0.5.2 (2019-07-07) 288 /// 289 /// * Added API to convert OS-specific `Library` and `Symbol` conversion to underlying resources. 290 pub mod r0_5_2 {} 291 292 /// Release 0.5.1 (2019-06-01) 293 /// 294 /// * Build on Haiku targets. 295 pub mod r0_5_1 {} 296 297 /// Release 0.5.0 (2018-01-11) 298 /// 299 /// * Update to `winapi = ^0.3`; 300 /// 301 /// ## Breaking changes 302 /// 303 /// * libloading now requires a C compiler to build on UNIX; 304 /// * This is a temporary measure until the [`linkage`] attribute is stabilised; 305 /// * Necessary to resolve [#32]. 306 /// 307 /// [`linkage`]: https://github.com/rust-lang/rust/issues/29603 308 /// [#32]: https://github.com/nagisa/rust_libloading/issues/32 309 pub mod r0_5_0 {} 310 311 /// Release 0.4.3 (2017-12-07) 312 /// 313 /// * Bump lazy-static dependency to `^1.0`; 314 /// * `cargo test --release` now works when testing libloading. 315 pub mod r0_4_3 {} 316 317 /// Release 0.4.2 (2017-09-24) 318 /// 319 /// * Improved error and race-condition handling on Windows; 320 /// * Improved documentation about thread-safety of Library; 321 /// * Added `Symbol::<Option<T>::lift_option() -> Option<Symbol<T>>` convenience method. 322 pub mod r0_4_2 {} 323 324 /// Release 0.4.1 (2017-08-29) 325 /// 326 /// * Solaris support 327 pub mod r0_4_1 {} 328 329 /// Release 0.4.0 (2017-05-01) 330 /// 331 /// * Remove build-time dependency on target_build_utils (and by extension serde/phf); 332 /// * Require at least version 1.14.0 of rustc to build; 333 /// * Actually, it is cargo which has to be more recent here. The one shipped with rustc 1.14.0 334 /// is what’s being required from now on. 335 pub mod r0_4_0 {} 336 337 /// Release 0.3.4 (2017-03-25) 338 /// 339 /// * Remove rogue println! 340 pub mod r0_3_4 {} 341 342 /// Release 0.3.3 (2017-03-25) 343 /// 344 /// * Panics when `Library::get` is called for incompatibly sized type such as named function 345 /// types (which are zero-sized). 346 pub mod r0_3_3 {} 347 348 /// Release 0.3.2 (2017-02-10) 349 /// 350 /// * Minimum version required is now rustc 1.12.0; 351 /// * Updated dependency versions (most notably target_build_utils to 0.3.0) 352 pub mod r0_3_2 {} 353 354 /// Release 0.3.1 (2016-10-01) 355 /// 356 /// * `Symbol<T>` and `os::*::Symbol<T>` now implement `Send` where `T: Send`; 357 /// * `Symbol<T>` and `os::*::Symbol<T>` now implement `Sync` where `T: Sync`; 358 /// * `Library` and `os::*::Library` now implement `Sync` (they were `Send` in 0.3.0 already). 359 pub mod r0_3_1 {} 360 361 /// Release 0.3.0 (2016-07-27) 362 /// 363 /// * Greatly improved documentation, especially around platform-specific behaviours; 364 /// * Improved test suite by building our own library to test against; 365 /// * All `Library`-ies now implement `Send`. 366 /// * Added `impl From<os::platform::Library> for Library` and `impl From<Library> for 367 /// os::platform::Library` allowing wrapping and extracting the platform-specific library handle; 368 /// * Added methods to wrap (`Symbol::from_raw`) and unwrap (`Symbol::into_raw`) the safe `Symbol` 369 /// wrapper into unsafe `os::platform::Symbol`. 370 /// 371 /// The last two additions focus on not restricting potential usecases of this library, allowing 372 /// users of the library to circumvent safety checks if need be. 373 /// 374 /// ## Breaking Changes 375 /// 376 /// `Library::new` defaults to `RTLD_NOW` instead of `RTLD_LAZY` on UNIX for more consistent 377 /// cross-platform behaviour. If a library loaded with `Library::new` had any linking errors, but 378 /// unresolved references weren’t forced to be resolved, the library would’ve “just worked”, 379 /// whereas now the call to `Library::new` will return an error signifying presence of such error. 380 /// 381 /// ## os::platform 382 /// * Added `os::unix::Library::open` which allows specifying arbitrary flags (e.g. `RTLD_LAZY`); 383 /// * Added `os::windows::Library::get_ordinal` which allows finding a function or variable by its 384 /// ordinal number; 385 pub mod r0_3_0 {} 386