fix end of file bug
This commit is contained in:
73
test.jai
73
test.jai
@@ -1,10 +1,22 @@
|
||||
main :: () {
|
||||
print("\nBeginning tests...\n");
|
||||
// test_handle_arrow_empty_lines();
|
||||
// test_handle_arrow_one_line();
|
||||
x := 1;
|
||||
y := 2;
|
||||
assert_test(x == y);
|
||||
//test_get_visible_lines();
|
||||
//test_handle_arrow_empty_lines();
|
||||
test_handle_arrow_one_line();
|
||||
print("Tests completed successfully\n");
|
||||
}
|
||||
|
||||
test_get_visible_lines :: () {
|
||||
state: State;
|
||||
state.line_height = 10;
|
||||
state.window_height = 100;
|
||||
assert_test(get_visible_lines(state).count == 0);
|
||||
|
||||
line: [..]u8;
|
||||
array_add(*line, array_view("foo"));
|
||||
array_add(*state.lines, line);
|
||||
assert_test(get_visible_lines(state).count == 1);
|
||||
print("test_get_visible_lines completed successfully\n");
|
||||
}
|
||||
|
||||
test_handle_arrow_empty_lines :: () {
|
||||
@@ -23,14 +35,13 @@ test_handle_arrow_empty_lines :: () {
|
||||
|
||||
test_handle_arrow_one_line :: () {
|
||||
state: State;
|
||||
state.first_line = 0;
|
||||
state.cursor_y = 0;
|
||||
state.cursor_x = 0;
|
||||
state.line_height = 10;
|
||||
state.window_height = 100;
|
||||
|
||||
line: [..]u8;
|
||||
line_str := "foo bar";
|
||||
|
||||
array_add(*line, .{data=line_str.data, count=line_str.count});
|
||||
array_add(*state.lines, line);
|
||||
add_line(*state, "foo bar");
|
||||
|
||||
codes := Input.Key_Code.[.ARROW_DOWN, .ARROW_UP, .ARROW_LEFT];
|
||||
for codes {
|
||||
@@ -38,33 +49,33 @@ test_handle_arrow_one_line :: () {
|
||||
assert(state.cursor_x == 0 && state.cursor_y == 0);
|
||||
}
|
||||
|
||||
handle_arrow(*state, .{key_code=.ARROW_RIGHT});
|
||||
assert(state.cursor_x == 1 && state.cursor_y == 0);
|
||||
|
||||
print("lines: %\n", state.lines);
|
||||
print("visible_lines: %\n", get_visible_lines(state));
|
||||
handle_arrow(*state, .ARROW_RIGHT);
|
||||
assert_test(state.cursor_x == 1 && state.cursor_y == 0);
|
||||
|
||||
print("test_handle_arrow_one_line completed successfully\n");
|
||||
}
|
||||
|
||||
assert_test :: (value: bool, $code := #caller_code) {
|
||||
builder: String_Builder;
|
||||
root, expressions := compiler_get_nodes(code);
|
||||
loc := #location(code);
|
||||
assert_test :: (value: bool, $call := #caller_code, loc := #caller_location) {
|
||||
if value == true return;
|
||||
assert(false, "%\nValue is false.", #run get_expression(call), value, loc = loc);
|
||||
}
|
||||
|
||||
print_to_builder(*builder, "%:%: Test: ", loc.fully_pathed_filename, loc.line_number);
|
||||
get_expression :: (call := #caller_code) -> string {
|
||||
root := compiler_get_nodes(call);
|
||||
builder: String_Builder;
|
||||
print_expression(*builder, root);
|
||||
append(*builder, "\n");
|
||||
`result := #insert code;
|
||||
if !result {
|
||||
for expressions {
|
||||
if it == root continue;
|
||||
print_expression(*builder, it);
|
||||
append(*builder, "\n");
|
||||
}
|
||||
append(*builder, "\n");
|
||||
`expression := builder_to_string(*builder);
|
||||
`print("%\n", expression);
|
||||
} else {
|
||||
`print("Passed!\n");
|
||||
}
|
||||
return builder_to_string(*builder);
|
||||
};
|
||||
|
||||
#scope_file
|
||||
|
||||
add_line :: (using state: *State, line: string) {
|
||||
line_dyn: [..]u8;
|
||||
array_add(*line_dyn, array_view(line));
|
||||
array_add(*state.lines, line_dyn);
|
||||
}
|
||||
|
||||
#import,file "edit.jai";
|
||||
|
||||
Reference in New Issue
Block a user