diff --git a/LICENSE-APACHE b/LICENSE-APACHE index cf25572b..0496905d 100644 --- a/LICENSE-APACHE +++ b/LICENSE-APACHE @@ -186,7 +186,7 @@ same "printed page" as the copyright notice for easier identification within third-party archives. - Copyright 2020 - 2024 Tatsuya Kawano + Copyright 2020 - 2025 Tatsuya Kawano Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. diff --git a/LICENSE-MIT b/LICENSE-MIT index 8271bdb9..d9f36304 100644 --- a/LICENSE-MIT +++ b/LICENSE-MIT @@ -1,6 +1,6 @@ MIT License -Copyright (c) 2020 - 2024 Tatsuya Kawano +Copyright (c) 2020 - 2025 Tatsuya Kawano Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal diff --git a/README.md b/README.md index b25bc562..cb6cd661 100644 --- a/README.md +++ b/README.md @@ -6,7 +6,6 @@ [![dependency status][deps-rs-badge]][deps-rs] [![codecov][codecov-badge]][codecov] [![license][license-badge]](#license) -[![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2Fmoka-rs%2Fmoka.svg?type=shield)](https://app.fossa.com/projects/git%2Bgithub.com%2Fmoka-rs%2Fmoka?ref=badge_shield) > **note** > `v0.12.0` had major breaking changes on the API and internal behavior. Please read @@ -29,14 +28,12 @@ algorithm to determine which entries to evict when the capacity is exceeded. [deps-rs-badge]: https://deps.rs/repo/github/moka-rs/moka/status.svg [codecov-badge]: https://codecov.io/gh/moka-rs/moka/graph/badge.svg?token=7GYZNS7O67 [license-badge]: https://img.shields.io/crates/l/moka.svg -[fossa-badge]: https://app.fossa.com/api/projects/git%2Bgithub.com%2Fmoka-rs%2Fmoka.svg?type=shield [gh-actions]: https://github.com/moka-rs/moka/actions?query=workflow%3ACI [crate]: https://crates.io/crates/moka [docs]: https://docs.rs/moka [deps-rs]: https://deps.rs/repo/github/moka-rs/moka [codecov]: https://codecov.io/gh/moka-rs/moka -[fossa]: https://app.fossa.com/projects/git%2Bgithub.com%2Fmoka-rs%2Fmoka?ref=badge_shield [caffeine-git]: https://github.com/ben-manes/caffeine @@ -143,6 +140,8 @@ routers. Here are some highlights: - [Size Aware Eviction](#example-size-aware-eviction) - [Expiration Policies](#expiration-policies) - [Minimum Supported Rust Versions](#minimum-supported-rust-versions) +- Troubleshooting + - [Compile Errors on Some 32-bit Platforms](#compile-errors-on-some-32-bit-platforms) - [Developing Moka](#developing-moka) - [Road Map](#road-map) - [About the Name](#about-the-name) @@ -160,6 +159,8 @@ The following platforms are tested on CI: - Linux 64-bit (x86_64, arm aarch64) - Linux 32-bit (i646, armv7, armv5, mips) + - If you get compile errors on 32-bit platforms, see + [troubleshooting](#compile-errors-on-some-32-bit-platforms). The following platforms are not tested on CI but should work: @@ -479,6 +480,50 @@ In both cases, increasing MSRV is _not_ considered a semver-breaking change. - quanta v0.12.4 requires 1.70.0. --> +## Troubleshooting + +### Compile Errors on Some 32-bit Platforms + +#### Symptoms + +When using Moka v0.12.9 or earlier on some 32-bit platforms, you may get compile +errors: + +```console +error[E0432]: unresolved import `std::sync::atomic::AtomicU64` + --> ... /moka-0.5.3/src/sync.rs:10:30 + | +10 | atomic::{AtomicBool, AtomicU64, Ordering}, + | ^^^^^^^^^ + | | + | no `AtomicU64` in `sync::atomic` +``` + +or + +```console +error[E0583]: file not found for module `atomic_time` + --> ... /moka-0.12.9/src/common/concurrent.rs:23:1 + | +23 | pub(crate) mod atomic_time; + | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ + | +``` + +#### How to Fix + +You can fix these compilation errors by one of the following: + +1. (Recommended) Upgrade Moka to v0.12.10 or later. (`cargo update -p moka`) +2. Or, keep using Moka v0.12.9 or earlier but disable the default features in + `Cargo.toml`. (`default-features = false`) + - The default features include the `atomic64` feature, which need to be disabled. + +These error messages are caused by the absence of `std::sync::atomic::AtomicU64` on +some 32-bit platforms. Moka v0.12.10 and later will automatically use a fallback +implementation when `AtomicU64` is not available. With v0.12.9 and earlier, you must +manually disable the `atomic64` feature to use the fallback implementation. + ## Developing Moka **Running All Tests**