about summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorbptato <nincsnevem662@gmail.com>2024-02-13 00:29:22 +0100
committerbptato <nincsnevem662@gmail.com>2024-02-13 00:29:22 +0100
commit178a5357136a225136691c78216536d7897ecba6 (patch)
treeb5573e0aab88ac57833fa4def6086ba927f1c403
parent261b0fca3e7da6328d382ae752c36d374272342a (diff)
downloadchawan-178a5357136a225136691c78216536d7897ecba6.tar.gz
container: allow dismissing loadinfo
it broke line info in console since it's never fully loaded
-rw-r--r--src/local/container.nim18
-rw-r--r--src/local/pager.nim5
2 files changed, 15 insertions, 8 deletions
diff --git a/src/local/container.nim b/src/local/container.nim
index 49b93eff..85c6d842 100644
--- a/src/local/container.nim
+++ b/src/local/container.nim
@@ -457,7 +457,6 @@ proc setNumLines(container: Container, lines: int, finish = false) =
       container.pos = container.startpos.get
       container.startpos = none(CursorPosition)
     container.updateCursor()
-    container.triggerEvent(STATUS)
 
 proc requestLines*(container: Container, w = container.lineWindow): EmptyPromise
     {.discardable.} =
@@ -474,9 +473,11 @@ proc requestLines*(container: Container, w = container.lineWindow): EmptyPromise
     container.updateCursor()
     if res.numLines != container.numLines:
       container.setNumLines(res.numLines, true)
+      container.triggerEvent(STATUS)
     let cw = container.fromy ..< container.fromy + container.height
     if w.a in cw or w.b in cw or cw.a in w or cw.b in w:
-      container.triggerEvent(UPDATE))
+      container.triggerEvent(UPDATE)
+  )
 
 proc redraw(container: Container) {.jsfunc.} =
   container.triggerEvent(ContainerEvent(t: UPDATE, force: true))
@@ -491,7 +492,8 @@ proc sendCursorPosition*(container: Container) =
     if res.link.isSome or res.title.isSome:
       container.triggerEvent(STATUS)
     if res.repaint:
-      container.needslines = true)
+      container.needslines = true
+  )
 
 proc setFromY(container: Container, y: int) {.jsfunc.} =
   if container.pos.fromy != y:
@@ -1333,7 +1335,9 @@ proc onload*(container: Container, res: LoadResult) =
     #TODO we wouldn't need the then part if we had incremental rendering of
     # HTML.
     container.iface.cancel().then(proc(lines: int) =
-      container.setNumLines(lines)
+      if lines != container.numLines:
+        container.setNumLines(lines)
+        container.triggerEvent(STATUS)
       container.needslines = true
     )
   else:
@@ -1341,9 +1345,10 @@ proc onload*(container: Container, res: LoadResult) =
       container.setLoadInfo("")
     elif not res.atend:
       container.setLoadInfo(convertSize(res.bytes) & " loaded")
-    if res.lines > container.numLines or res.atend:
+    if res.lines != container.numLines or res.atend:
       container.setNumLines(res.lines, res.atend)
-      container.triggerEvent(STATUS)
+      if res.atend:
+        container.triggerEvent(STATUS)
       container.needslines = true
     if not res.atend:
       discard container.iface.load().then(proc(res: LoadResult) =
@@ -1457,6 +1462,7 @@ proc readSuccess*(container: Container, s: string) =
 proc reshape(container: Container): EmptyPromise {.jsfunc.} =
   return container.iface.render().then(proc(lines: int): auto =
     container.setNumLines(lines)
+    container.triggerEvent(STATUS)
     return container.requestLines()
   )
 
diff --git a/src/local/pager.nim b/src/local/pager.nim
index 50591ee3..0744a151 100644
--- a/src/local/pager.nim
+++ b/src/local/pager.nim
@@ -318,8 +318,9 @@ proc refreshStatusMsg*(pager: Pager) =
   elif pager.inputBuffer != "":
     pager.writeStatusMessage(pager.inputBuffer)
   elif container.loadinfo != "":
-    pager.alerton = false
+    pager.alerton = true
     pager.writeStatusMessage(container.loadinfo)
+    container.loadinfo = ""
   elif pager.alerts.len > 0:
     pager.alerton = true
     pager.writeStatusMessage(pager.alerts[0])
@@ -1261,7 +1262,7 @@ proc handleEvent0(pager: Pager, container: Container, event: ContainerEvent): bo
   of INVALID_COMMAND: discard
   of STATUS:
     if pager.container == container:
-      pager.showAlerts()
+      pager.refreshStatusMsg()
   of TITLE:
     if pager.container == container:
       pager.showAlerts()