Compare commits
2 Commits
1e7c82e487
...
16c654a7e6
Author | SHA1 | Date | |
---|---|---|---|
|
16c654a7e6 | ||
4b79b6a352 |
17
Cargo.lock
generated
17
Cargo.lock
generated
@ -492,7 +492,6 @@ dependencies = [
|
|||||||
"dirs",
|
"dirs",
|
||||||
"dotenv",
|
"dotenv",
|
||||||
"gitea-rs",
|
"gitea-rs",
|
||||||
"nucleo-matcher",
|
|
||||||
"octocrab",
|
"octocrab",
|
||||||
"pretty_assertions",
|
"pretty_assertions",
|
||||||
"prost",
|
"prost",
|
||||||
@ -906,16 +905,6 @@ dependencies = [
|
|||||||
"winapi",
|
"winapi",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "nucleo-matcher"
|
|
||||||
version = "0.3.1"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "bf33f538733d1a5a3494b836ba913207f14d9d4a1d3cd67030c5061bdd2cac85"
|
|
||||||
dependencies = [
|
|
||||||
"memchr",
|
|
||||||
"unicode-segmentation",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "num-bigint"
|
name = "num-bigint"
|
||||||
version = "0.4.6"
|
version = "0.4.6"
|
||||||
@ -1976,12 +1965,6 @@ dependencies = [
|
|||||||
"tinyvec",
|
"tinyvec",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "unicode-segmentation"
|
|
||||||
version = "1.12.0"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "f6ccf251212114b54433ec949fd6a7841275f9ada20dddd2f29e9ceea4501493"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "untrusted"
|
name = "untrusted"
|
||||||
version = "0.9.0"
|
version = "0.9.0"
|
||||||
|
@ -24,7 +24,6 @@ dirs = "5.0.1"
|
|||||||
prost = "0.13.2"
|
prost = "0.13.2"
|
||||||
prost-types = "0.13.2"
|
prost-types = "0.13.2"
|
||||||
bytes = "1.7.1"
|
bytes = "1.7.1"
|
||||||
nucleo-matcher = "0.3.1"
|
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
pretty_assertions = "1.4.0"
|
pretty_assertions = "1.4.0"
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
use nucleo_matcher::{pattern::Pattern, Matcher, Utf32Str};
|
|
||||||
|
|
||||||
use crate::{app::App, cache::CacheApp, projects_list::ProjectsListApp};
|
use crate::{app::App, cache::CacheApp, projects_list::ProjectsListApp};
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
@ -12,7 +10,8 @@ impl RootCommand {
|
|||||||
Self { app }
|
Self { app }
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn execute(&mut self, search: Option<impl Into<String>>) -> anyhow::Result<()> {
|
#[tracing::instrument(skip(self))]
|
||||||
|
pub async fn execute(&mut self) -> anyhow::Result<()> {
|
||||||
tracing::debug!("executing");
|
tracing::debug!("executing");
|
||||||
|
|
||||||
let repositories = match self.app.cache().get().await? {
|
let repositories = match self.app.cache().get().await? {
|
||||||
@ -27,28 +26,8 @@ impl RootCommand {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
let haystack = repositories
|
for repo in &repositories {
|
||||||
.iter()
|
//tracing::info!("repo: {}", repo.to_rel_path().display());
|
||||||
.map(|r| r.to_rel_path().display().to_string());
|
|
||||||
|
|
||||||
let needle = match search {
|
|
||||||
Some(needle) => needle.into(),
|
|
||||||
None => todo!(),
|
|
||||||
};
|
|
||||||
|
|
||||||
let pattern = Pattern::new(
|
|
||||||
&needle,
|
|
||||||
nucleo_matcher::pattern::CaseMatching::Ignore,
|
|
||||||
nucleo_matcher::pattern::Normalization::Smart,
|
|
||||||
nucleo_matcher::pattern::AtomKind::Fuzzy,
|
|
||||||
);
|
|
||||||
let mut matcher = Matcher::new(nucleo_matcher::Config::DEFAULT);
|
|
||||||
let res = pattern.match_list(haystack, &mut matcher);
|
|
||||||
|
|
||||||
let res = res.iter().take(10).rev().collect::<Vec<_>>();
|
|
||||||
|
|
||||||
for (repo, _score) in res {
|
|
||||||
tracing::debug!("repo: {:?}", repo);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
tracing::info!("amount of repos fetched {}", repositories.len());
|
tracing::info!("amount of repos fetched {}", repositories.len());
|
||||||
|
@ -20,9 +20,6 @@ mod projects_list;
|
|||||||
struct Command {
|
struct Command {
|
||||||
#[command(subcommand)]
|
#[command(subcommand)]
|
||||||
command: Option<Commands>,
|
command: Option<Commands>,
|
||||||
|
|
||||||
#[arg()]
|
|
||||||
search: Option<String>,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Subcommand)]
|
#[derive(Subcommand)]
|
||||||
@ -54,7 +51,7 @@ async fn main() -> anyhow::Result<()> {
|
|||||||
match cli.command {
|
match cli.command {
|
||||||
Some(_) => todo!(),
|
Some(_) => todo!(),
|
||||||
None => {
|
None => {
|
||||||
RootCommand::new(app).execute(cli.search.as_ref()).await?;
|
RootCommand::new(app).execute().await?;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user