Merge remote-tracking branch 'origin/dev' into dev

This commit is contained in:
Vanessa 2023-12-09 22:58:47 +08:00
commit db2a3a5e20
4 changed files with 27 additions and 7 deletions

View file

@ -586,15 +586,13 @@ func NewLute() (ret *lute.Lute) {
return
}
var confSaveLock = sync.Mutex{}
func (conf *AppConf) Save() {
if util.ReadOnly {
return
}
confSaveLock.Lock()
defer confSaveLock.Unlock()
Conf.m.Lock()
defer Conf.m.Unlock()
newData, _ := gulu.JSON.MarshalIndentJSON(Conf, "", " ")
confPath := filepath.Join(util.ConfDir, "conf.json")
@ -949,6 +947,7 @@ func upgradeUserGuide() {
continue
}
logging.LogInfof("upgrading user guide box [%s]", boxID)
unindex(boxID)
if err = filelock.Remove(boxDirPath); nil != err {
@ -960,6 +959,7 @@ func upgradeUserGuide() {
}
index(boxID)
logging.LogInfof("upgraded user guide box [%s]", boxID)
}
}

View file

@ -12,6 +12,7 @@ import (
"github.com/siyuan-note/filelock"
"github.com/siyuan-note/logging"
"github.com/siyuan-note/siyuan/kernel/cache"
"github.com/siyuan-note/siyuan/kernel/sql"
"github.com/siyuan-note/siyuan/kernel/task"
"github.com/siyuan-note/siyuan/kernel/util"
)
@ -53,6 +54,14 @@ func autoOCRAssets() {
}
cleanNotExistAssetsTexts()
// 刷新 OCR 结果到数据库
util.NodeOCRQueueLock.Lock()
defer util.NodeOCRQueueLock.Unlock()
for _, id := range util.NodeOCRQueue {
sql.IndexNodeQueue(id)
}
util.NodeOCRQueue = nil
}
func cleanNotExistAssetsTexts() {

View file

@ -800,13 +800,13 @@ func buildBlockFromNode(n *ast.Node, tree *parse.Tree) (block *Block, attributes
markdown = treenode.ExportNodeStdMd(n, luteEngine)
if !treenode.IsNodeOCRed(n) {
IndexNodeQueue(n.ID)
util.PushNodeOCRQueue(n.ID)
}
content = treenode.NodeStaticContent(n, nil, true, indexAssetPath)
fc := treenode.FirstLeafBlock(n)
if !treenode.IsNodeOCRed(fc) {
IndexNodeQueue(fc.ID)
util.PushNodeOCRQueue(fc.ID)
}
fcontent = treenode.NodeStaticContent(fc, nil, true, false)
@ -820,7 +820,7 @@ func buildBlockFromNode(n *ast.Node, tree *parse.Tree) (block *Block, attributes
markdown = treenode.ExportNodeStdMd(n, luteEngine)
if !treenode.IsNodeOCRed(n) {
IndexNodeQueue(n.ID)
util.PushNodeOCRQueue(n.ID)
}
content = treenode.NodeStaticContent(n, nil, true, indexAssetPath)

View file

@ -273,3 +273,14 @@ func getTesseractLangs() (ret []string) {
}
return
}
var (
NodeOCRQueue []string
NodeOCRQueueLock = sync.Mutex{}
)
func PushNodeOCRQueue(id string) {
NodeOCRQueueLock.Lock()
defer NodeOCRQueueLock.Unlock()
NodeOCRQueue = append(NodeOCRQueue, id)
}