17 unstable releases (3 breaking)
new 0.4.2 | Jan 9, 2025 |
---|---|
0.4.1 | Nov 28, 2024 |
0.4.0 | Oct 6, 2024 |
0.2.9 | Oct 5, 2023 |
0.1.1 | Jun 27, 2021 |
#300 in Text processing
54 downloads per month
Used in guff_css
34KB
518 lines
Oxford Join
Join a slice of strings with Oxford Commas inserted as necessary, using the Conjunction
of your choice.
(You know, as it should be. Haha.)
The return formatting depends on the size of the set:
0: ""
1: "first"
2: "first <CONJUNCTION> last"
n: "first, second, …, <CONJUNCTION> last"
This crate is #![no_std]
-compatible.
Examples
The magic is accomplished with the OxfordJoin
trait. Import that, and most
slice-y things holding AsRef<str>
will inherit the OxfordJoin::oxford_join
method for joining.
use oxford_join::{Conjunction, OxfordJoin};
let set = ["Apples", "Oranges"];
assert_eq!(set.oxford_join(Conjunction::And), "Apples and Oranges");
let set = ["Apples", "Oranges", "Bananas"];
assert_eq!(set.oxford_join(Conjunction::And), "Apples, Oranges, and Bananas");
// There are also shorthand methods for and, or, and_or, and nor, allowing you
// to skip the Conjunction enum entirely.
assert_eq!(set.oxford_and(), "Apples, Oranges, and Bananas");
assert_eq!(set.oxford_and_or(), "Apples, Oranges, and/or Bananas");
assert_eq!(set.oxford_nor(), "Apples, Oranges, nor Bananas");
assert_eq!(set.oxford_or(), "Apples, Oranges, or Bananas");
That's all, folks!
Installation
Add oxford_join
to your dependencies
in Cargo.toml
, like:
[dependencies]
oxford_join = "0.4.*"