forked from koniifer/ableos
Update string lib for num format - Trees
This commit is contained in:
parent
1adc381399
commit
f59776e792
|
@ -177,7 +177,9 @@ pub fn handler(vm: &mut Vm) {
|
|||
unsafe fn x86_out(address: u16, value: u32) {
|
||||
x86_64::instructions::port::Port::new(address).write(value);
|
||||
}
|
||||
vm.registers[3] = hbvm::value::Value(unsafe { x86_in(r2 as u16) } as u64);
|
||||
let x = hbvm::value::Value(unsafe { x86_in(r2 as u16) } as u64);
|
||||
info!("Read {:?} from Port {:?}", x, r2);
|
||||
vm.registers[3] = x
|
||||
}
|
||||
}
|
||||
// 5
|
||||
|
|
|
@ -6,3 +6,47 @@ length := fn(ptr: ^u8): int {
|
|||
}
|
||||
return len;
|
||||
}
|
||||
|
||||
display_int := fn(num: int): ^u8 {
|
||||
p := page;
|
||||
i := 0;
|
||||
if num == 0 {
|
||||
set(p, 48);
|
||||
return p;
|
||||
}
|
||||
loop {
|
||||
if num == 0 break;
|
||||
set(p + i, num % 10 + 48);
|
||||
num /= 10;
|
||||
i += 1;
|
||||
}
|
||||
reverse(p);
|
||||
//null terminate
|
||||
set(p + i, 0);
|
||||
return p;
|
||||
}
|
||||
|
||||
reverse := fn(s: ^u8): void {
|
||||
//reverse a string, don't remove digits
|
||||
len := 0;
|
||||
loop {
|
||||
if *(s + len) == 0 break;
|
||||
len += 1;
|
||||
}
|
||||
i := 0;
|
||||
j := len - 1;
|
||||
loop {
|
||||
if i >= j break;
|
||||
temp := *(s + i);
|
||||
*(s + i) = *(s + j);
|
||||
*(s + j) = temp;
|
||||
i += 1;
|
||||
j -= 1;
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
set := fn(change: ^int, new: int): void {
|
||||
*(change) = new;
|
||||
return;
|
||||
}
|
||||
|
|
11
sysdata/programs/time_driver/meta.toml
Normal file
11
sysdata/programs/time_driver/meta.toml
Normal file
|
@ -0,0 +1,11 @@
|
|||
[package]
|
||||
name = "time_driver"
|
||||
authors = ["SamBuckley"]
|
||||
|
||||
[dependants.libraries]
|
||||
|
||||
[dependants.binaries]
|
||||
hblang.version = "1.0.0"
|
||||
|
||||
[build]
|
||||
command = "hblang src/main.hb"
|
64
sysdata/programs/time_driver/src/main.hb
Normal file
64
sysdata/programs/time_driver/src/main.hb
Normal file
|
@ -0,0 +1,64 @@
|
|||
stn := @use("../../../libraries/stn/src/lib.hb");
|
||||
log := stn.log;
|
||||
mem := stn.memory;
|
||||
page := 0
|
||||
|
||||
main := fn(): void {
|
||||
page += mem.request_page(1);
|
||||
port_str := "\0\{46}\0";
|
||||
a := @eca(u8, 3, 3, port_str, 2);
|
||||
log.debug(&a);
|
||||
n := 5000000;
|
||||
loop {
|
||||
if n == 0 break;
|
||||
n -= 1;
|
||||
stack_reclamation_edge_case := 0;
|
||||
}
|
||||
td := display_int(100);
|
||||
log.debug(td);
|
||||
return;
|
||||
}
|
||||
|
||||
display_int := fn(num: int): ^u8 {
|
||||
p := page;
|
||||
i := 0;
|
||||
if num == 0 {
|
||||
set(p, 48);
|
||||
return p;
|
||||
}
|
||||
loop {
|
||||
if num == 0 break;
|
||||
set(p + i, num % 10 + 48);
|
||||
num /= 10;
|
||||
i += 1;
|
||||
}
|
||||
reverse(p);
|
||||
//null terminate
|
||||
set(p + i, 0);
|
||||
return p;
|
||||
}
|
||||
|
||||
reverse := fn(s: ^u8): void {
|
||||
//reverse a string, don't remove digits
|
||||
len := 0;
|
||||
loop {
|
||||
if *(s + len) == 0 break;
|
||||
len += 1;
|
||||
}
|
||||
i := 0;
|
||||
j := len - 1;
|
||||
loop {
|
||||
if i >= j break;
|
||||
temp := *(s + i);
|
||||
*(s + i) = *(s + j);
|
||||
*(s + j) = temp;
|
||||
i += 1;
|
||||
j -= 1;
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
set := fn(change: ^int, new: int): void {
|
||||
*(change) = new;
|
||||
return;
|
||||
}
|
|
@ -24,5 +24,8 @@ path = "boot:///tests.hbf"
|
|||
# [boot.limine.ableos.modules.diskio_driver]
|
||||
# path = "boot:///diskio_driver.hbf"
|
||||
|
||||
[boot.limine.ableos.modules.fb_driver]
|
||||
path = "boot:///fb_driver.hbf"
|
||||
# [boot.limine.ableos.modules.fb_driver]
|
||||
# path = "boot:///fb_driver.hbf"
|
||||
|
||||
[boot.limine.ableos.modules.time_driver]
|
||||
path = "boot:///time_driver.hbf"
|
Loading…
Reference in a new issue