grid_editor_task.rs 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. use crate::manager::GridTaskSchedulerRwLock;
  2. use crate::services::grid_editor::GridRevisionEditor;
  3. use crate::services::tasks::{GridTaskHandler, Task, TaskContent, TaskHandlerId, TaskId};
  4. use flowy_error::FlowyError;
  5. use futures::future::BoxFuture;
  6. use lib_infra::future::BoxResultFuture;
  7. pub(crate) trait GridServiceTaskScheduler: Send + Sync + 'static {
  8. fn gen_task_id(&self) -> BoxFuture<TaskId>;
  9. fn register_task(&self, task: Task) -> BoxFuture<()>;
  10. }
  11. impl GridTaskHandler for GridRevisionEditor {
  12. fn handler_id(&self) -> &TaskHandlerId {
  13. &self.grid_id
  14. }
  15. fn process_task(&self, task: Task) -> BoxResultFuture<(), FlowyError> {
  16. Box::pin(async move {
  17. match task.content {
  18. TaskContent::Snapshot => {}
  19. TaskContent::Filter(context) => self.filter_service.process(context).await?,
  20. }
  21. Ok(())
  22. })
  23. }
  24. }
  25. impl GridServiceTaskScheduler for GridTaskSchedulerRwLock {
  26. fn gen_task_id(&self) -> BoxFuture<TaskId> {
  27. let this = self.clone();
  28. Box::pin(async move { this.read().await.next_task_id() })
  29. }
  30. fn register_task(&self, task: Task) -> BoxFuture<()> {
  31. let this = self.clone();
  32. Box::pin(async move {
  33. this.write().await.register_task(task);
  34. })
  35. }
  36. }