refactor: prefer Arc<str> to String
This commit is contained in:
@@ -1,11 +1,10 @@
|
||||
use futures::{FutureExt, TryFutureExt};
|
||||
use std::sync::Arc;
|
||||
|
||||
use reqwest::Method;
|
||||
use serde::Deserialize;
|
||||
use tokio::sync::OwnedRwLockReadGuard;
|
||||
|
||||
use crate::{
|
||||
api,
|
||||
query::{self, Query, fetch_query},
|
||||
api, query,
|
||||
util::{self, file},
|
||||
};
|
||||
|
||||
@@ -31,9 +30,9 @@ pub struct Owner {
|
||||
|
||||
#[derive(Debug, Clone)]
|
||||
pub struct FileRef {
|
||||
pub repo_slug: String,
|
||||
pub path: String,
|
||||
pub reff: Option<String>,
|
||||
pub repo_slug: Arc<str>,
|
||||
pub path: Arc<str>,
|
||||
pub reff: Option<Arc<str>>,
|
||||
}
|
||||
|
||||
#[derive(Clone)]
|
||||
@@ -67,9 +66,9 @@ impl query::QueryFn for List {
|
||||
|
||||
#[derive(Clone)]
|
||||
pub struct FetchFileContent {
|
||||
pub repo_slug: String,
|
||||
pub path: String,
|
||||
pub reff: Option<String>,
|
||||
pub repo_slug: Arc<str>,
|
||||
pub path: Arc<str>,
|
||||
pub reff: Option<Arc<str>>,
|
||||
}
|
||||
|
||||
impl query::QueryFn for FetchFileContent {
|
||||
@@ -79,8 +78,8 @@ impl query::QueryFn for FetchFileContent {
|
||||
|
||||
fn key(&self) -> query::Key {
|
||||
match &self.reff {
|
||||
| Some(reff) => format!("repo/fetch/{}/{}/{}", self.repo_slug, self.path, reff).into(),
|
||||
| None => format!("repo/fetch/{}/{}", self.repo_slug, self.path).into(),
|
||||
| Some(reff) => format!("repo/fetch/{}/{}/{}", self.repo_slug, self.path, reff).into(),
|
||||
| None => format!("repo/fetch/{}/{}", self.repo_slug, self.path).into(),
|
||||
}
|
||||
}
|
||||
|
||||
@@ -95,11 +94,11 @@ impl query::QueryFn for FetchFileContent {
|
||||
}
|
||||
|
||||
let path = match &self.reff {
|
||||
| Some(reff) => format!(
|
||||
"/repos/{}/contents/{}?ref={}",
|
||||
self.repo_slug, self.path, reff
|
||||
),
|
||||
| None => format!("/repos/{}/contents/{}", self.repo_slug, self.path),
|
||||
| Some(reff) => format!(
|
||||
"/repos/{}/contents/{}?ref={}",
|
||||
self.repo_slug, self.path, reff
|
||||
),
|
||||
| None => format!("/repos/{}/contents/{}", self.repo_slug, self.path),
|
||||
};
|
||||
|
||||
let res = c
|
||||
@@ -137,8 +136,8 @@ impl query::QueryFn for FetchFileDiff {
|
||||
c: &<FetchFileDiff as query::QueryFn>::Context,
|
||||
) -> Result<Option<bytes::Bytes>, api::Error> {
|
||||
let path = match &r.reff {
|
||||
| Some(reff) => format!("/repos/{}/contents/{}?ref={}", r.repo_slug, r.path, reff),
|
||||
| None => format!("/repos/{}/contents/{}", r.repo_slug, r.path),
|
||||
| Some(reff) => format!("/repos/{}/contents/{}?ref={}", r.repo_slug, r.path, reff),
|
||||
| None => format!("/repos/{}/contents/{}", r.repo_slug, r.path),
|
||||
};
|
||||
|
||||
let res = c
|
||||
@@ -160,10 +159,10 @@ impl query::QueryFn for FetchFileDiff {
|
||||
let (old, new) = tokio::join!(fetch_content(&self.base, c), fetch_content(&self.head, c),);
|
||||
|
||||
match (old, new) {
|
||||
| (Ok(Some(old)), Ok(Some(new))) => Ok(util::diff::diff_content(old, new)),
|
||||
| _ => Err(api::Error::MalformedResponse(
|
||||
"failed to fetch content".to_string(),
|
||||
)),
|
||||
| (Ok(Some(old)), Ok(Some(new))) => Ok(util::diff::diff_content(old, new)),
|
||||
| _ => Err(api::Error::MalformedResponse(
|
||||
"failed to fetch content".to_string(),
|
||||
)),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user