Compare commits

..

2 Commits

Author SHA1 Message Date
cuddle-please
16c654a7e6 chore(release): 0.2.1
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2024-09-15 19:18:34 +00:00
4b79b6a352 feat: implement naive fuzzy matcher
All checks were successful
continuous-integration/drone/push Build is passing
2024-09-15 21:14:44 +02:00
4 changed files with 5 additions and 47 deletions

17
Cargo.lock generated
View File

@ -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"

View File

@ -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"

View File

@ -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());

View File

@ -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?;
} }
} }