Correct locking in thread poll watcher

This commit is contained in:
Leo Vasanko 2023-11-12 20:30:35 +00:00
parent 2978e0c968
commit c31fb24752
3 changed files with 13 additions and 14 deletions

View File

@ -1,7 +1,6 @@
import asyncio
import shutil
import stat
import sys
import threading
import time
from os import stat_result
@ -190,10 +189,10 @@ def watcher_thread_poll(loop):
while not quit:
rootpath = config.config.path
old = state.root
new = walk()
if old != new:
with state.lock:
old = state.root
if old != new:
state.root = new
broadcast(format_update(old, new), loop)
@ -333,8 +332,9 @@ async def abroadcast(msg):
async def start(app, loop):
config.load_config()
use_inotify = False # sys.platform == "linux"
app.ctx.watcher = threading.Thread(
target=watcher_thread if sys.platform == "linux" else watcher_thread_poll,
target=watcher_thread if use_inotify else watcher_thread_poll,
args=[loop],
)
app.ctx.watcher.start()

View File

@ -135,7 +135,7 @@ function handleUpdateMessage(updateData: { update: UpdateEntry[] }) {
else console.log("Unknown update action", action, arg)
}
if (oidx != tree.length)
throw Error(`Tree update out of sync, number of entries mismatch: got ${oidx}, expected ${tree.length}`)
throw Error(`Tree update out of sync, number of entries mismatch: got ${oidx}, expected ${tree.length}, new tree ${newtree.length}`)
store.updateRoot(newtree)
tree = newtree
saveSession()

View File

@ -4,7 +4,6 @@ import { defineStore } from 'pinia'
import { collator } from '@/utils'
import { logoutUser } from '@/repositories/User'
import { watchConnect } from '@/repositories/WS'
import { format } from 'path'
type FileData = { id: string; mtime: number; size: number; dir: DirectoryData }
type DirectoryData = {