std: fix parse_u64 implementation and add test

also codegen implement comparision with pure errors
master
Andrew Kelley 2016-02-09 09:51:25 -07:00
parent 1d92700d08
commit 207862647c
4 changed files with 16 additions and 1 deletions

View File

@ -1269,6 +1269,9 @@ static LLVMValueRef gen_cmp_expr(CodeGen *g, AstNode *node) {
} else {
zig_unreachable();
}
} else if (op1_type->id == TypeTableEntryIdPureError) {
LLVMIntPredicate pred = cmp_op_to_int_predicate(node->data.bin_op_expr.bin_op, false);
return LLVMBuildICmp(g->builder, pred, val1, val2, "");
} else {
zig_unreachable();
}

View File

@ -158,7 +158,7 @@ pub fn parse_u64(buf: []u8, radix: u8) -> %u64 {
for (buf) |c| {
const digit = char_to_digit(c);
if (digit > radix) {
if (digit >= radix) {
return error.InvalidChar;
}
@ -342,3 +342,12 @@ pub fn buf_print_f64(out_buf: []u8, x: f64, decimals: isize) -> isize {
len
}
#attribute("test")
fn parse_u64_digit_too_big() {
parse_u64("123a", 10) %% |err| {
if (err == error.InvalidChar) return;
unreachable{};
};
unreachable{};
}

View File

@ -1,3 +1,5 @@
import "test_std.zig";
#attribute("test")
fn empty_function() {}

1
test/test_std.zig Normal file
View File

@ -0,0 +1 @@
import "std.zig";