From 2581c4fe50a8f25d249d620d8a5b1100ac046e5d Mon Sep 17 00:00:00 2001 From: HeroicKatora Date: Thu, 25 Jul 2019 12:12:26 +0200 Subject: [PATCH] Address review comments on documentation --- src/lib.rs | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index 544ea4e..bd3a9ed 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -79,7 +79,13 @@ pub unsafe fn concat<'a>(a: &'a str, b: &'a str) -> Result<&'a str, Error> { /// than `isize::MAX`). /// /// When T is a ZST then returns `Err(TooLong)` if the total length would overflow -/// `usize` and `Err(NotAdjacent)` otherwise. +/// `usize` and `Err(NotAdjacent)` otherwise. This is because ZST-slices are [extra +/// weird][zst-str-concat] and [their safety][zst-unsafe-wg1] is not yet [fully +/// determined][zst-unsafe-wg2]. +/// +/// [zst-str-concat]: https://github.com/oberien/str-concat/issues/5 +/// [zst-unsafe-wg1]: https://github.com/rust-lang/unsafe-code-guidelines/issues/93 +/// [zst-unsafe-wg2]: https://github.com/rust-lang/unsafe-code-guidelines/issues/168 /// /// # Safety /// @@ -126,6 +132,10 @@ pub unsafe fn concat_slice<'a, T>(a: &'a [T], b: &'a [T]) -> Result<&'a [T], Err // Never consider ZST slices adjacent. You could otherwise infinitely // duplicate a non-zero length slice by concatenating it to itself. + // See: https://github.com/rust-lang/unsafe-code-guidelines/issues/93 + // and https://github.com/rust-lang/unsafe-code-guidelines/issues/168 + // where the second link makes it sound like it would be possible but + // not necessarily easy. return Err(Error::NotAdjacent) } @@ -220,7 +230,7 @@ pub unsafe fn concat_unordered<'a>(a: &'a str, b: &'a str) -> Result<&'a str, Er /// /// This is the same as [`concat_slice`] except that it also concatenates `b` to /// `a` if `b` is in front of `a` (in which case of [`concat_slice`] errors). -/// Keep in mind that slices of ZSTs will still not be concatenated. +/// Keep in mind that slices of zero-sized types (ZST) will still not be concatenated. /// /// # Safety /// @@ -234,7 +244,7 @@ pub unsafe fn concat_unordered<'a>(a: &'a str, b: &'a str) -> Result<&'a str, Er /// /// ```rust /// # use str_concat::concat_slice_unordered; -/// let s = b"0123456789"; +/// let s = [0, 1, 2, 3, 4, 5, 6]; /// unsafe { /// // SAFETY: slices from the same bytes originally. /// assert_eq!(b"0123456", concat_slice_unordered(&s[5..7], &s[..5]).unwrap()); @@ -245,7 +255,7 @@ pub unsafe fn concat_unordered<'a>(a: &'a str, b: &'a str) -> Result<&'a str, Er /// /// ```rust /// # use str_concat::{concat_slice_unordered, Error}; -/// let s = b"0123456789"; +/// let s = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]; /// unsafe { /// // SAFETY: slices from the same bytes originally. /// assert_eq!(b"0123456", concat_slice_unordered(&s[..5], &s[5..7]).unwrap())