about summary refs log tree commit diff stats
path: root/linux/advent2020/5a.mu
blob: 19d342c40aa9d4b96d8f1d02d26d2655fab15591 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
# https://adventofcode.com/2020/day/5
#
# To run (on Linux):
#   $ git clone https://github.com/akkartik/mu
#   $ cd mu
#   $ ./translate advent2020/5a.mu
#   $ ./a.elf < input
#
# You'll need to register to download the 'input' file for yourself.

fn main -> _/ebx: int {
  var line-storage: (stream byte 0x10)  # 16 bytes is enough
  var line/edx: (addr stream byte) <- address line-storage
  var max-seat-id/edi: int <- copy 0
  {
    # read line from stdin
    clear-stream line
    read-line-from-real-keyboard line
    print-stream-to-real-screen line
    # if line is empty (not even a newline), quit
    var done?/eax: boolean <- stream-empty? line
    compare done?, 0/false
    break-if-!=
    # process line
    var seat-id/eax: int <- convert-from-binary line
    compare seat-id, max-seat-id
    {
      break-if-<=
      max-seat-id <- copy seat-id
    }
    loop
  }
  print-int32-decimal 0, max-seat-id
  print-string 0, "\n"
  return 0
}

fn convert-from-binary in: (addr stream byte) -> _/eax: int {
  var result/edi: int <- copy 0
  var i/ecx: int <- copy 9  # loop counter and also exponent
  {
    compare i, 0
    break-if-<
    var c/eax: byte <- read-byte in
#?     print-string 0, "char: "
#?     {
#?       var c2/eax: int <- copy c
#?       print-int32-hex 0, c2
#?     }
#?     print-string 0, "\n"
    var bit/edx: int <- copy 0
    {
      compare c, 0x42/B
      break-if-!=
      bit <- copy 1
    }
    {
      compare c, 0x52/R
      break-if-!=
      bit <- copy 1
    }
#?     print-string 0, "bit: "
#?     print-int32-decimal 0, bit
#?     print-string 0, "\n"
    var bit-value/eax: int <- repeated-shift-left bit, i
#?     print-string 0, "bit value: "
#?     print-int32-decimal 0, bit-value
#?     print-string 0, "\n"
    result <- add bit-value
#?     print-string 0, "result: "
#?     print-int32-decimal 0, result
#?     print-string 0, "\n"
    i <- decrement
    loop
  }
  print-int32-decimal 0, result
  print-string 0, "\n"
  return result
}