mirror of
https://github.com/fafhrd91/actix-net
synced 2024-11-27 20:12:58 +01:00
add string crate
This commit is contained in:
parent
cbdbc05dbd
commit
6c00ab8296
@ -22,8 +22,7 @@ default = ["http"]
|
|||||||
[dependencies]
|
[dependencies]
|
||||||
regex = "1.3.1"
|
regex = "1.3.1"
|
||||||
serde = "1.0.80"
|
serde = "1.0.80"
|
||||||
# string = "0.2.1"
|
bytestring = "0.1.0"
|
||||||
string = { git = "https://github.com/carllerche/string.git" }
|
|
||||||
log = "0.4.8"
|
log = "0.4.8"
|
||||||
http = { version="0.2.0", optional=true }
|
http = { version="0.2.0", optional=true }
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@ impl<'a> ResourcePath for &'a str {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<T: AsRef<[u8]>> ResourcePath for string::String<T> {
|
impl ResourcePath for bytesrting::ByteString {
|
||||||
fn path(&self) -> &str {
|
fn path(&self) -> &str {
|
||||||
&*self
|
&*self
|
||||||
}
|
}
|
||||||
|
5
string/CHANGES.md
Normal file
5
string/CHANGES.md
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# Changes
|
||||||
|
|
||||||
|
[0.1.0] - 2019-12-07
|
||||||
|
|
||||||
|
* Initial release
|
19
string/Cargo.toml
Normal file
19
string/Cargo.toml
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
[package]
|
||||||
|
name = "bytestring"
|
||||||
|
version = "0.1.0"
|
||||||
|
authors = ["Nikolay Kim <fafhrd91@gmail.com>"]
|
||||||
|
description = "A UTF-8 encoded string with Bytes as a storage"
|
||||||
|
keywords = ["actix"]
|
||||||
|
homepage = "https://actix.rs"
|
||||||
|
repository = "https://github.com/actix/actix-net.git"
|
||||||
|
documentation = "https://docs.rs/bytestring/"
|
||||||
|
license = "MIT/Apache-2.0"
|
||||||
|
edition = "2018"
|
||||||
|
workspace = ".."
|
||||||
|
|
||||||
|
[lib]
|
||||||
|
name = "bytesrting"
|
||||||
|
path = "src/lib.rs"
|
||||||
|
|
||||||
|
[dependencies]
|
||||||
|
bytes = "0.5.2"
|
1
string/LICENSE-APACHE
Symbolic link
1
string/LICENSE-APACHE
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../LICENSE-APACHE
|
1
string/LICENSE-MIT
Symbolic link
1
string/LICENSE-MIT
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../LICENSE-MIT
|
145
string/src/lib.rs
Normal file
145
string/src/lib.rs
Normal file
@ -0,0 +1,145 @@
|
|||||||
|
//! A utl-8 encoded read-only string with Bytes as a storage.
|
||||||
|
use std::convert::TryFrom;
|
||||||
|
use std::{borrow, fmt, hash, ops, str};
|
||||||
|
|
||||||
|
use bytes::Bytes;
|
||||||
|
|
||||||
|
/// A utf-8 encoded string with [`Bytes`] as a storage.
|
||||||
|
///
|
||||||
|
/// [`Bytes`]: https://docs.rs/bytes/0.5.2/bytes/struct.Bytes.html
|
||||||
|
#[derive(Clone, Eq, PartialEq, Ord, PartialOrd, Default)]
|
||||||
|
pub struct ByteString(Bytes);
|
||||||
|
|
||||||
|
impl ByteString {
|
||||||
|
/// Creates a new `ByteString`.
|
||||||
|
pub fn new() -> String {
|
||||||
|
String::default()
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Get a reference to the underlying bytes object.
|
||||||
|
pub fn get_ref(&self) -> &Bytes {
|
||||||
|
&self.0
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Unwraps this `ByteString`, returning the underlying bytes object.
|
||||||
|
pub fn into_inner(self) -> Bytes {
|
||||||
|
self.0
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Creates a new `ByteString` from a static str.
|
||||||
|
pub fn from_static(src: &'static str) -> ByteString {
|
||||||
|
Self(Bytes::from_static(src.as_ref()))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl PartialEq<str> for ByteString {
|
||||||
|
fn eq(&self, other: &str) -> bool {
|
||||||
|
&self[..] == other
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl hash::Hash for ByteString {
|
||||||
|
fn hash<H: hash::Hasher>(&self, state: &mut H) {
|
||||||
|
self.0.hash(state);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ops::Deref for ByteString {
|
||||||
|
type Target = str;
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
fn deref(&self) -> &str {
|
||||||
|
let b = self.0.as_ref();
|
||||||
|
unsafe { str::from_utf8_unchecked(b) }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl borrow::Borrow<str> for ByteString {
|
||||||
|
fn borrow(&self) -> &str {
|
||||||
|
&*self
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<String> for ByteString {
|
||||||
|
fn from(value: String) -> Self {
|
||||||
|
Self(Bytes::from(value))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> From<&'a str> for ByteString {
|
||||||
|
fn from(value: &'a str) -> Self {
|
||||||
|
Self(Bytes::copy_from_slice(value.as_ref()))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> TryFrom<&'a [u8]> for ByteString {
|
||||||
|
type Error = str::Utf8Error;
|
||||||
|
|
||||||
|
fn try_from(value: &'a [u8]) -> Result<Self, Self::Error> {
|
||||||
|
let _ = str::from_utf8(value)?;
|
||||||
|
Ok(ByteString(Bytes::copy_from_slice(value)))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl TryFrom<Vec<u8>> for ByteString {
|
||||||
|
type Error = str::Utf8Error;
|
||||||
|
|
||||||
|
fn try_from(value: Vec<u8>) -> Result<Self, Self::Error> {
|
||||||
|
let _ = str::from_utf8(value.as_ref())?;
|
||||||
|
Ok(ByteString(Bytes::from(value)))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
macro_rules! array_impls {
|
||||||
|
($($len:expr)+) => {
|
||||||
|
$(
|
||||||
|
impl<'a> TryFrom<&'a [u8; $len]> for ByteString {
|
||||||
|
type Error = str::Utf8Error;
|
||||||
|
|
||||||
|
fn try_from(value: &'a [u8; $len]) -> Result<Self, Self::Error> {
|
||||||
|
ByteString::try_from(&value[..])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)+
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
array_impls!(0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16);
|
||||||
|
|
||||||
|
impl fmt::Debug for ByteString {
|
||||||
|
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
||||||
|
(**self).fmt(fmt)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl fmt::Display for ByteString {
|
||||||
|
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
||||||
|
(**self).fmt(fmt)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod test {
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_from_string() {
|
||||||
|
let s: ByteString = "hello".to_string().into();
|
||||||
|
assert_eq!(&s, "hello");
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_from_str() {
|
||||||
|
let _: ByteString = "str".into();
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_from_static_str() {
|
||||||
|
let _ = ByteString::from_static("str");
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_try_from_bytes() {
|
||||||
|
let _ = ByteString::try_from(b"nice bytes").unwrap();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user