about summary refs log tree commit diff stats
path: root/apps/browse
diff options
context:
space:
mode:
authorKartik Agaram <vc@akkartik.com>2020-09-07 21:21:31 -0700
committerKartik Agaram <vc@akkartik.com>2020-09-07 21:21:31 -0700
commit137cde5bfae7104c97b0f48277480eb78ced4ff1 (patch)
tree1d2ceb7ab07a0dde2e8c4a3e081f5eb09d9b6319 /apps/browse
parentdce4efd268b9080d4e29b34699b83a124dfcfb0e (diff)
downloadmu-137cde5bfae7104c97b0f48277480eb78ced4ff1.tar.gz
6750
Diffstat (limited to 'apps/browse')
-rw-r--r--apps/browse/file-state.mu45
-rw-r--r--apps/browse/main.mu28
2 files changed, 15 insertions, 58 deletions
diff --git a/apps/browse/file-state.mu b/apps/browse/file-state.mu
deleted file mode 100644
index d42bf8bf..00000000
--- a/apps/browse/file-state.mu
+++ /dev/null
@@ -1,45 +0,0 @@
-type file-state {
-  source: (handle buffered-file)
-  eof?: boolean
-}
-
-fn init-file-state _self: (addr file-state), filename: (addr array byte) {
-  var self/eax: (addr file-state) <- copy _self
-  load-file self, filename
-  var eof/eax: (addr boolean) <- get self, eof?
-  copy-to *eof, 0  # false
-}
-
-fn load-file _self: (addr file-state), filename: (addr array byte) {
-  var self/eax: (addr file-state) <- copy _self
-  var out/esi: (addr handle buffered-file) <- get self, source
-  open filename, 0, out  # 0 = read mode
-}
-
-fn next-char _self: (addr file-state) -> result/eax: byte {
-  var self/ecx: (addr file-state) <- copy _self
-  var source/eax: (addr handle buffered-file) <- get self, source
-  var in/eax: (addr buffered-file) <- lookup *source
-  result <- read-byte-buffered in
-  # if result == EOF, set eof?
-  compare result, 0xffffffff  # EOF marker
-  {
-    var eof/ecx: (addr boolean) <- get self, eof?
-    copy-to *eof, 1  # true
-  }
-}
-
-fn done-reading? _self: (addr file-state) -> result/eax: boolean {
-  var self/eax: (addr file-state) <- copy _self
-  var eof/eax: (addr boolean) <- get self, eof?
-  result <- copy *eof
-}
-
-fn dump in: (addr buffered-file) {
-  var c/eax: byte <- read-byte-buffered in
-  compare c, 0xffffffff  # EOF marker
-  break-if-=
-  var g/eax: grapheme <- copy c
-  print-grapheme 0, g
-  loop
-}
diff --git a/apps/browse/main.mu b/apps/browse/main.mu
index 1a1eb09d..d710c1a6 100644
--- a/apps/browse/main.mu
+++ b/apps/browse/main.mu
@@ -1,9 +1,11 @@
 fn main args: (addr array addr array byte) -> exit-status/ebx: int {
   # initialize fs from args[1]
   var filename/eax: (addr array byte) <- first-arg args
-  var file-state-storage: file-state
-  var fs/esi: (addr file-state) <- address file-state-storage
-  init-file-state fs, filename
+  var file-storage: (handle buffered-file)
+  var file-storage-addr/esi: (addr handle buffered-file) <- address file-storage
+  open filename, 0, file-storage-addr
+  var _fs/eax: (addr buffered-file) <- lookup file-storage
+  var fs/esi: (addr buffered-file) <- copy _fs
   #
   enable-screen-grid-mode
   enable-keyboard-immediate-mode
@@ -23,12 +25,12 @@ fn main args: (addr array addr array byte) -> exit-status/ebx: int {
   exit-status <- copy 0
 }
 
-fn render screen: (addr screen), fs: (addr file-state), state: (addr screen-position-state) {
+fn render screen: (addr screen), fs: (addr buffered-file), state: (addr screen-position-state) {
   start-drawing state
   render-normal screen, fs, state
 }
 
-fn render-normal screen: (addr screen), fs: (addr file-state), state: (addr screen-position-state) {
+fn render-normal screen: (addr screen), fs: (addr buffered-file), state: (addr screen-position-state) {
   var newline-seen?/esi: boolean <- copy 0  # false
   var start-of-paragraph?/edi: boolean <- copy 1  # true
   var previous-char/ebx: byte <- copy 0
@@ -37,7 +39,7 @@ $render-normal:loop: {
     var done?/eax: boolean <- done-drawing? state
     compare done?, 0  # false
     break-if-!=
-    var c/eax: byte <- next-char fs
+    var c/eax: byte <- read-byte-buffered fs
 $render-normal:loop-body: {
       # if (c == EOF) break
       compare c, 0xffffffff  # EOF marker
@@ -138,7 +140,7 @@ $render-normal:whitespace-separated-regions: {
   }  # $render-normal:loop
 }
 
-fn render-header-line screen: (addr screen), fs: (addr file-state), state: (addr screen-position-state) {
+fn render-header-line screen: (addr screen), fs: (addr buffered-file), state: (addr screen-position-state) {
 $render-header-line:body: {
   # compute color based on number of '#'s
   var header-level/esi: int <- copy 1  # caller already grabbed one
@@ -151,7 +153,7 @@ $render-header-line:body: {
       break-if-!= $render-header-line:body
     }
     #
-    c <- next-char fs
+    c <- read-byte-buffered fs
     # if (c != '#') break
     compare c, 0x23  # '#'
     break-if-!=
@@ -169,7 +171,7 @@ $render-header-line:body: {
       break-if-!=
     }
     #
-    c <- next-char fs
+    c <- read-byte-buffered fs
     # if (c == EOF) break
     compare c, 0xffffffff  # EOF marker
     break-if-=
@@ -217,14 +219,14 @@ $start-heading:body: {
 }
 }
 
-fn render-until-asterisk fs: (addr file-state), state: (addr screen-position-state) {
+fn render-until-asterisk fs: (addr buffered-file), state: (addr screen-position-state) {
   {
     # if done-drawing?(state) break
     var done?/eax: boolean <- done-drawing? state
     compare done?, 0  # false
     break-if-!=
     #
-    var c/eax: byte <- next-char fs
+    var c/eax: byte <- read-byte-buffered fs
     # if (c == EOF) break
     compare c, 0xffffffff  # EOF marker
     break-if-=
@@ -238,14 +240,14 @@ fn render-until-asterisk fs: (addr file-state), state: (addr screen-position-sta
   }
 }
 
-fn render-until-underscore fs: (addr file-state), state: (addr screen-position-state) {
+fn render-until-underscore fs: (addr buffered-file), state: (addr screen-position-state) {
   {
     # if done-drawing?(state) break
     var done?/eax: boolean <- done-drawing? state
     compare done?, 0  # false
     break-if-!=
     #
-    var c/eax: byte <- next-char fs
+    var c/eax: byte <- read-byte-buffered fs
     # if (c == EOF) break
     compare c, 0xffffffff  # EOF marker
     break-if-=