Skip to content
This repository has been archived by the owner on Mar 1, 2023. It is now read-only.

Commit

Permalink
style: cosmetic changes
Browse files Browse the repository at this point in the history
  • Loading branch information
pleshevskiy committed Oct 16, 2020
1 parent f750de0 commit f2f49be
Show file tree
Hide file tree
Showing 7 changed files with 61 additions and 56 deletions.
2 changes: 1 addition & 1 deletion src/channel.rs
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ macro_rules! init_commands {
if mode != Some($condition) {
return Err(Error::new(
ErrorKind::UnsupportedCommand((
stringify!($fn_name),
stringify!($fn_name),
mode,
))
));
Expand Down
2 changes: 1 addition & 1 deletion src/commands/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ pub(crate) use query::QueryCommand;
pub(crate) use suggest::SuggestCommand;

#[cfg(feature = "control")]
pub(crate) use trigger::{TriggerCommand, TriggerAction};
pub(crate) use trigger::{TriggerAction, TriggerCommand};

use crate::result::Result;

Expand Down
9 changes: 4 additions & 5 deletions src/commands/pop.rs
Original file line number Diff line number Diff line change
Expand Up @@ -24,12 +24,11 @@ impl StreamCommand for PopCommand<'_> {
fn receive(&self, message: String) -> Result<Self::Response> {
if message.starts_with("RESULT ") {
let count = message.split_whitespace().last().unwrap_or_default();
count
.parse()
.map_err(|_| Error::new(ErrorKind::QueryResponseError(
count.parse().map_err(|_| {
Error::new(ErrorKind::QueryResponseError(
"Cannot parse count of pop method response to usize",
)))

))
})
} else {
Err(Error::new(ErrorKind::WrongSonicResponse))
}
Expand Down
26 changes: 14 additions & 12 deletions src/commands/query.rs
Original file line number Diff line number Diff line change
Expand Up @@ -43,19 +43,21 @@ impl StreamCommand for QueryCommand<'_> {

dbg!(&message);

match RE.captures(&message) {
None => Err(Error::new(ErrorKind::WrongSonicResponse)),
Some(caps) => {
if caps["pending_query_id"] != caps["event_query_id"] {
Err(Error::new(ErrorKind::QueryResponseError(
"Pending id and event id don't match",
)))
} else if caps["objects"].is_empty() {
Ok(vec![])
} else {
Ok(caps["objects"].split_whitespace().map(str::to_owned).collect())
}
if let Some(caps) = RE.captures(&message) {
if caps["pending_query_id"] != caps["event_query_id"] {
Err(Error::new(ErrorKind::QueryResponseError(
"Pending id and event id don't match",
)))
} else if caps["objects"].is_empty() {
Ok(vec![])
} else {
Ok(caps["objects"]
.split_whitespace()
.map(str::to_owned)
.collect())
}
} else {
Err(Error::new(ErrorKind::WrongSonicResponse))
}
}
}
33 changes: 16 additions & 17 deletions src/commands/start.rs
Original file line number Diff line number Diff line change
Expand Up @@ -40,24 +40,23 @@ impl StreamCommand for StartCommand {

dbg!(&message);

match RE.captures(&message) {
None => Err(Error::new(ErrorKind::SwitchMode)),
Some(caps) => {
if self.mode.to_str() != &caps["mode"] {
Err(Error::new(ErrorKind::SwitchMode))
} else {
let protocol_version: usize =
caps["protocol"].parse().expect("Must be digit by regex");
let max_buffer_size: usize =
caps["buffer_size"].parse().expect("Must be digit by regex");

Ok(StartCommandResponse {
protocol_version,
max_buffer_size,
mode: self.mode,
})
}
if let Some(caps) = RE.captures(&message) {
if self.mode.to_str() != &caps["mode"] {
Err(Error::new(ErrorKind::SwitchMode))
} else {
let protocol_version: usize =
caps["protocol"].parse().expect("Must be digit by regex");
let max_buffer_size: usize =
caps["buffer_size"].parse().expect("Must be digit by regex");

Ok(StartCommandResponse {
protocol_version,
max_buffer_size,
mode: self.mode,
})
}
} else {
Err(Error::new(ErrorKind::SwitchMode))
}
}
}
5 changes: 4 additions & 1 deletion src/commands/suggest.rs
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,10 @@ impl StreamCommand for SuggestCommand<'_> {
} else if caps["words"].is_empty() {
Ok(vec![])
} else {
Ok(caps["words"].split_whitespace().map(str::to_owned).collect())
Ok(caps["words"]
.split_whitespace()
.map(str::to_owned)
.collect())
}
}
}
Expand Down
40 changes: 21 additions & 19 deletions src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,74 +1,74 @@
//! # Sonic Channel
//! Rust client for [sonic] search backend.
//!
//!
//!
//!
//! ## Example usage
//!
//!
//! ### Search channel
//!
//! Note: This example requires enabling the `search` feature, enabled by default.
//!
//!
//! ```rust,no_run
//! use sonic_channel::*;
//!
//!
//! fn main() -> result::Result<()> {
//! let channel = SonicChannel::connect_with_start(
//! ChannelMode::Search,
//! "localhost:1491",
//! "SecretPassword",
//! )?;
//!
//!
//! let objects = channel.query("collection", "bucket", "recipe")?;
//! dbg!(objects);
//!
//!
//! Ok(())
//! }
//! ```
//!
//!
//! ### Ingest channel
//!
//!
//! Note: This example requires enabling the `ingest` feature.
//!
//! ```rust,no_run
//! use sonic_channel::*;
//!
//!
//! fn main() -> result::Result<()> {
//! let mut channel = SonicChannel::connect_with_start(
//! ChannelMode::Ingest,
//! "localhost:1491",
//! "SecretPassword",
//! )?;
//!
//!
//! let pushed = channel.push("collection", "bucket", "object:1", "my best recipe")?;
//! // or
//! // let pushed = channel.push_with_locale("collection", "bucket", "object:1", "Мой лучший рецепт", "rus")?;
//! dbg!(pushed);
//!
//!
//! Ok(())
//! }
//! ```
//!
//!
//! ### Control channel
//!
//!
//! Note: This example requires enabling the `control` feature.
//!
//! ```rust,no_run
//! use sonic_channel::*;
//!
//!
//! fn main() -> result::Result<()> {
//! let mut channel = SonicChannel::connect_with_start(
//! ChannelMode::Control,
//! "localhost:1491",
//! "SecretPassword",
//! )?;
//!
//!
//! let result = channel.consolidate()?;
//! assert_eq!(result, true);
//!
//!
//! Ok(())
//! }
//! ```
//!
//!
//! [sonic]: https://github.com/valeriansaliou/sonic
// Rustc lints.
Expand All @@ -84,7 +84,9 @@
#![deny(clippy::all)]

#[cfg(not(any(feature = "ingest", feature = "search", feature = "control")))]
compile_error!(r#"Either features "ingest" or "search" or "control" must be enabled for "sonic-channel" crate"#);
compile_error!(
r#"Either features "ingest" or "search" or "control" must be enabled for "sonic-channel" crate"#
);

mod channel;
mod commands;
Expand Down

0 comments on commit f2f49be

Please sign in to comment.