fn draw-box screen: (addr screen), row1: int, col1: int, row2: int, col2: int { draw-horizontal-line screen, row1, col1, col2 draw-vertical-line screen, row1, row2, col1 draw-horizontal-line screen, row2, col1, col2 draw-vertical-line screen, row1, row2, col2 draw-top-left-corner screen, row1, col1 draw-top-right-corner screen, row1, col2 draw-bottom-left-corner screen, row2, col1 draw-bottom-right-corner screen, row2, col2 } fn draw-hatching screen: (addr screen), row1: int, col1: int, row2: int, col2: int { var c/eax: int <- copy col1 var r1/ecx: int <- copy row1 r1 <- increment c <- add 2 { compare c, col2 break-if->= draw-vertical-line screen, r1, row2, c c <- add 2 loop } } fn draw-horizontal-line screen: (addr screen), row: int, col1: int, col2: int { var col/eax: int <- copy col1 move-cursor screen, row, col { compare col, col2 break-if->= print-code-point screen, 0x2500 col <- increment loop } } fn draw-vertical-line screen: (addr screen), row1: int, row2: int, col: int { var row/eax: int <- copy row1 { compare row, row2 break-if->= move-cursor screen, row, col print-code-point screen, 0x2502 row <- increment loop } } fn draw-top-left-corner screen: (addr screen), row: int, col: int { move-cursor screen, row, col print-code-point screen, 0x250c } fn draw-top-right-corner screen: (addr screen), row: int, col: int { move-cursor screen, row, col print-code-point screen, 0x2510 } fn draw-bottom-left-corner screen: (addr screen), row: int, col: int { move-cursor screen, row, col print-code-point screen, 0x2514 } fn draw-bottom-right-corner screen: (addr screen), row: int, col: int { move-cursor screen, row, col print-code-point screen, 0x2518 } # erase parts of screen the slow way fn clear-rect screen: (addr screen), row1: int, col1: int, row2: int, col2: int { var i/eax: int <- copy row1 { compare i, row2 break-if-> var j/ecx: int <- copy col1 move-cursor screen, i, j { compare j, col2 break-if-> print-code-point-utf8 screen 0x20/space j <- increment loop } i <- increment loop } } fn clear-rect2 screen: (addr screen), row1: int, col1: int, w: int, h: int { var i/eax: int <- copy 0 var curr-row/esi: int <- copy row1 { compare i, w break-if->= move-cursor screen, curr-row, col1 var j/ecx: int <- copy 0 { compare j, h break-if->= print-code-point-utf8 screen 0x20/space j <- increment loop } i <- increment curr-row <- increment loop } }