[doc]
This commit is contained in:
parent
9bd45d5a07
commit
d8c89ec727
3 changed files with 9 additions and 4 deletions
|
@ -18,7 +18,8 @@
|
||||||
//!
|
//!
|
||||||
//! ## Examples
|
//! ## Examples
|
||||||
//!
|
//!
|
||||||
//! See example usage in the `examples/` folder, that you can run using `cargo run --example <example-name>`
|
//! See example usage in the `examples/` folder, that you can run using `cargo run --example <example-name>`. \
|
||||||
|
//! You can also have a look at `tasklist`, a GUI app that uses `kitchen-fridge` under the hood.
|
||||||
|
|
||||||
pub mod traits;
|
pub mod traits;
|
||||||
|
|
||||||
|
|
|
@ -68,10 +68,11 @@ where
|
||||||
/// Performs a synchronisation between `local` and `remote`, and provide feeedback to the user about the progress.
|
/// Performs a synchronisation between `local` and `remote`, and provide feeedback to the user about the progress.
|
||||||
///
|
///
|
||||||
/// This bidirectional sync applies additions/deletions made on a source to the other source.
|
/// This bidirectional sync applies additions/deletions made on a source to the other source.
|
||||||
/// In case of conflicts (the same item has been modified on both ends since the last sync, `remote` always wins)
|
/// In case of conflicts (the same item has been modified on both ends since the last sync, `remote` always wins).
|
||||||
///
|
///
|
||||||
/// It returns whether the sync was totally successful (details about errors are logged using the `log::*` macros).
|
/// It returns whether the sync was totally successful (details about errors are logged using the `log::*` macros).
|
||||||
/// In case errors happened, the sync might have been partially executed, and you can safely run this function again, since it has been designed to gracefully recover from errors.
|
/// In case errors happened, the sync might have been partially executed but your data will never be correupted (either locally nor in the server).
|
||||||
|
/// Simply run this function again, it will re-start a sync, picking up where it failed.
|
||||||
pub async fn sync_with_feedback(&mut self, feedback_sender: FeedbackSender) -> bool {
|
pub async fn sync_with_feedback(&mut self, feedback_sender: FeedbackSender) -> bool {
|
||||||
let mut progress = SyncProgress::new_with_feedback_channel(feedback_sender);
|
let mut progress = SyncProgress::new_with_feedback_channel(feedback_sender);
|
||||||
self.run_sync(&mut progress).await
|
self.run_sync(&mut progress).await
|
||||||
|
@ -79,7 +80,7 @@ where
|
||||||
|
|
||||||
/// Performs a synchronisation between `local` and `remote`, without giving any feedback.
|
/// Performs a synchronisation between `local` and `remote`, without giving any feedback.
|
||||||
///
|
///
|
||||||
/// See [sync_with_feedback]
|
/// See [`Self::sync_with_feedback`]
|
||||||
pub async fn sync(&mut self) -> bool {
|
pub async fn sync(&mut self) -> bool {
|
||||||
let mut progress = SyncProgress::new();
|
let mut progress = SyncProgress::new();
|
||||||
self.run_sync(&mut progress).await
|
self.run_sync(&mut progress).await
|
||||||
|
|
|
@ -36,9 +36,12 @@ impl Default for SyncEvent {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/// See [`feedback_channel`]
|
||||||
pub type FeedbackSender = tokio::sync::watch::Sender<SyncEvent>;
|
pub type FeedbackSender = tokio::sync::watch::Sender<SyncEvent>;
|
||||||
|
/// See [`feedback_channel`]
|
||||||
pub type FeedbackReceiver = tokio::sync::watch::Receiver<SyncEvent>;
|
pub type FeedbackReceiver = tokio::sync::watch::Receiver<SyncEvent>;
|
||||||
|
|
||||||
|
/// Create a feeback channel, that can be used to retrieve the current progress of a sync operation
|
||||||
pub fn feedback_channel() -> (FeedbackSender, FeedbackReceiver) {
|
pub fn feedback_channel() -> (FeedbackSender, FeedbackReceiver) {
|
||||||
tokio::sync::watch::channel(SyncEvent::default())
|
tokio::sync::watch::channel(SyncEvent::default())
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue