move examples into subfolder, added wasm4 skip_ahead

This commit is contained in:
2021-11-10 22:37:26 +01:00
parent e9f115ee95
commit 911c2e43ad
11 changed files with 112 additions and 77 deletions

View File

@@ -0,0 +1,35 @@
import "env.memory" memory(4);
global mut randomState: i64 = 37i64;
fn random() -> i32 {
(random64() >> 32i64) as i32
}
fn random64() -> i64 {
let state: i64;
randomState = (state := (
state := randomState ^ (randomState >> 12i64)
) ^ (state << 25i64)
) ^ (state >> 27i64);
randomState * 2685821657736338717i64
}
fn randomf() -> f32 {
f32.reinterpret_i32(1065353216 | (random() >> 9)) - 1 as f32
}
fn seed(s: i32) {
randomState = (s as i64 << 32i64) ^ ((63 - s) as i64);
randomState = random64();
randomState = random64();
}
export fn tic(time: i32) {
let i: i32;
loop pixels {
seed(i + (time / 100) * 320);
i?120 = (randomf() * 256 as f32 + time as f32 / 10 as f32) as i32;
branch_if (i := i + 1) < 320*256: pixels
}
}

View File

@@ -0,0 +1,14 @@
import "env.memory" memory(4);
import "env.atan2" fn atan2(f32, f32) -> f32;
export fn tic(time: i32) {
let i: i32;
loop screen {
let defer t = time as f32 / 10 as f32;
let defer x = (i % 320) as f32 - 160.1;
let defer y = (i / 320 - 128) as f32;
i?120 = ((20000 as f32 / sqrt(x * x + y * y) + t) as i32 ^ (atan2(x, y) * 512 as f32 / 3.141 + t) as i32);
branch_if (i := i + 1) < 320*256: screen
}
}

View File

@@ -0,0 +1,62 @@
import "env.memory" memory(1);
import "env.rect" fn rect(i32, i32, i32, i32);
import "env.oval" fn oval(i32, i32, i32, i32);
global mut pz: f32 = 0.0;
global mut px: f32 = 2.0;
global mut py: f32 = 0.0;
global mut s: f32 = 0.0;
global mut f: f32 = 0.0;
fn xorshift(state: i32) -> i32 {
100902443 * (
(state :=
(state := state ^ (state << 13))
^ (state >> 17))
^ (state << 5)
)
}
export fn update() {
let y: i32;
loop lines {
let z = (200 as f32 / (y := y + 1) as f32 + pz) as i32;
let x = (xorshift(xorshift(xorshift(z))) & 3) as f32 / 2 as f32 - px;
let w = 6 as f32 / sqrt(z as f32);
let rx = 80 + (y as f32 * x) as i32;
let rw = (y as f32 * w) as i32;
let defer c = ((z & 1) + 2) * 17;
?20 = c;
rect(rx, y, rw, y / 9);
?20 = c + 17;
rect(rx, y + 1, rw, y / 9);
if y == 120 & py > 0.0 {
if x+w < 0.0 | x > 0.0 {
return;
}
py = 0.0;
s = 0.0;
f = 0.8;
}
branch_if y < 160: lines;
};
?20 = 50;
oval(80 - 11, 114 - 11 + py as i32, 22, 22);
?20 = 17;
oval(80 - 6, 114 - 6 + py as i32, 6, 6);
let defer pad = ?22;
let defer control_speed = 0.03;
px = px + (((pad >> 5) & 1) - ((pad >> 4) & 1)) as f32 * control_speed;
if pad & 1 {
s = s - f - control_speed;
}
s = s + 0.1;
py = py + s;
pz = pz + 0.05;
f = f * 0.7;
}

View File

@@ -1,12 +0,0 @@
import "env.memory" memory(4);
import "env.random" fn random() -> i32;
import "env.randomSeed" fn seed(i32);
export fn tic(time: i32) {
let i: i32;
loop pixels {
seed(i + (time / 100) * 320);
i?120 = random();
branch_if (i := i + 1) < 320*256: pixels
}
}

View File

@@ -619,8 +619,8 @@ fn emit_expression<'a>(ctx: &mut FunctionContext<'a>, expr: &'a ast::Expression)
ast::Expr::Return { value } => { ast::Expr::Return { value } => {
if let Some(value) = value { if let Some(value) = value {
emit_expression(ctx, value); emit_expression(ctx, value);
ctx.function.instruction(&Instruction::Return);
} }
ctx.function.instruction(&Instruction::Return);
} }
ast::Expr::Error => unreachable!(), ast::Expr::Error => unreachable!(),
} }

View File

@@ -1,64 +0,0 @@
import "env.memory" memory(8);
export fn load_uw8(module_start: i32, module_end: i32, base_start: i32, base_end: i32) -> i32 {
if ?module_start == 0 {
let defer length = module_end - module_start;
copy(base_end, module_start, length);
return base_end + length;
}
copy(base_end, base_start, 8);
base_start = base_start + 8;
let dest = base_end + 8;
let src = module_start + 1;
loop sections {
if src < module_end & (base_start >= base_end | ?src <= ?base_start) {
let defer length2 = copy_section(dest, src);
dest = dest + length2;
if base_start < base_end & ?src == ?base_start {
base_start = base_start + section_size(base_start);
}
src = src + length2;
branch sections;
}
if base_start < base_end {
let defer length3 = copy_section(dest, base_start);
dest = dest + length3;
base_start = base_start + length3;
branch sections;
}
}
dest
}
fn section_size(ptr: i32) -> i32 {
let p = ptr + 1;
let l = 0;
let shift = 0;
loop size {
let defer b = ?p;
l = l | ((b & 127) << shift);
shift = shift + 7;
p = p + 1;
branch_if b & 128: size;
}
p - ptr + l
}
fn copy_section(dest: i32, src: i32) -> i32 {
let defer length = section_size(src);
copy(dest, src, length);
length
}
fn copy(dest: i32, src: i32, len: i32) {
if len > 0 {
loop bytes {
?(dest + (len := len - 1)) = ?(src + len);
branch_if len: bytes
}
}
}