64 lines
No EOL
1.5 KiB
Rust
64 lines
No EOL
1.5 KiB
Rust
use crate::io::vga::colors::ColorCode;
|
|
|
|
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
|
#[repr(C)]
|
|
struct ScreenChar {
|
|
ascii_character: u8,
|
|
color_code: ColorCode,
|
|
}
|
|
|
|
const BUFFER_HEIGHT: usize = 25;
|
|
const BUFFER_WIDTH: usize = 80;
|
|
|
|
#[repr(transparent)]
|
|
pub struct Buffer {
|
|
chars: [[ScreenChar; BUFFER_WIDTH]; BUFFER_HEIGHT],
|
|
}
|
|
|
|
pub struct Writer {
|
|
pub(crate) column_position: usize,
|
|
pub(crate) color_code: ColorCode,
|
|
pub(crate) buffer: &'static mut Buffer,
|
|
}
|
|
|
|
impl Writer {
|
|
pub fn write_byte(&mut self, byte: u8) {
|
|
match byte {
|
|
b'\n' => self.new_line(),
|
|
byte => {
|
|
if self.column_position >= BUFFER_WIDTH {
|
|
self.new_line();
|
|
}
|
|
|
|
let row = BUFFER_HEIGHT - 1;
|
|
let col = self.column_position;
|
|
|
|
let color_code = self.color_code;
|
|
self.buffer.chars[row][col] = ScreenChar {
|
|
ascii_character: byte,
|
|
color_code,
|
|
};
|
|
self.column_position += 1;
|
|
}
|
|
}
|
|
}
|
|
|
|
fn new_line(&mut self) {
|
|
unimplemented!();
|
|
}
|
|
}
|
|
|
|
|
|
impl Writer {
|
|
pub fn write_string(&mut self, s: &str) {
|
|
for byte in s.bytes() {
|
|
match byte {
|
|
// printable ASCII byte or newline
|
|
0x20..=0x7e | b'\n' => self.write_byte(byte),
|
|
// not part of printable ASCII range
|
|
_ => self.write_byte(0xfe),
|
|
}
|
|
|
|
}
|
|
}
|
|
} |