Commit 82756a8
authored
Use async tasks instead of blocking sync for store operations (#338)
The widget message handler was using zarr's `_sync()` to block the
Jupyter kernel event loop while waiting on store reads. This freezes the
kernel during slow operations like remote store access.
Since Jupyter already runs an asyncio event loop and zarr v3 stores
expose a native async API, we can schedule store operations as async
tasks directly via `asyncio.create_task()` rather than blocking. A
`_pending_tasks` set prevents in-flight tasks from being garbage
collected, following the same pattern used by lonboard.1 parent 91fef61 commit 82756a8
1 file changed
Lines changed: 9 additions & 3 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
| 3 | + | |
3 | 4 | | |
4 | 5 | | |
5 | 6 | | |
| |||
11 | 12 | | |
12 | 13 | | |
13 | 14 | | |
14 | | - | |
15 | 15 | | |
16 | 16 | | |
17 | 17 | | |
| |||
86 | 86 | | |
87 | 87 | | |
88 | 88 | | |
| 89 | + | |
89 | 90 | | |
90 | 91 | | |
91 | 92 | | |
| |||
94 | 95 | | |
95 | 96 | | |
96 | 97 | | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
97 | 103 | | |
98 | 104 | | |
99 | 105 | | |
100 | 106 | | |
101 | 107 | | |
102 | 108 | | |
103 | | - | |
| 109 | + | |
104 | 110 | | |
105 | 111 | | |
106 | 112 | | |
107 | 113 | | |
108 | 114 | | |
109 | | - | |
| 115 | + | |
110 | 116 | | |
111 | 117 | | |
112 | 118 | | |
| |||
0 commit comments