add tests for function alignment handling

See #37
This commit is contained in:
Andrew Kelley 2017-08-30 00:06:14 -04:00
parent 2d57622355
commit b35dad88b4
2 changed files with 43 additions and 0 deletions

View File

@ -9,9 +9,15 @@ test "global variable alignment" {
}
fn derp() align (@sizeOf(usize) * 2) -> i32 { 1234 }
fn noop1() align 1 {}
fn noop4() align 4 {}
test "function alignment" {
assert(derp() == 1234);
assert(@typeOf(noop1) == fn() align 1);
assert(@typeOf(noop4) == fn() align 4);
noop1();
noop4();
}
@ -96,3 +102,28 @@ fn sliceExpectsOnly1(slice: []align 1 u32) {
fn sliceExpects4(slice: []align 4 u32) {
slice[0] += 1;
}
test "implicitly decreasing fn alignment" {
testImplicitlyDecreaseFnAlign(alignedSmall, 1234);
testImplicitlyDecreaseFnAlign(alignedBig, 5678);
}
fn testImplicitlyDecreaseFnAlign(ptr: fn () align 1 -> i32, answer: i32) {
assert(ptr() == answer);
}
fn alignedSmall() align 8 -> i32 { 1234 }
fn alignedBig() align 16 -> i32 { 5678 }
test "@alignCast functions" {
assert(fnExpectsOnly1(simple4) == 0x19);
}
fn fnExpectsOnly1(ptr: fn()align 1 -> i32) -> i32 {
fnExpects4(@alignCast(4, ptr))
}
fn fnExpects4(ptr: fn()align 4 -> i32) -> i32 {
ptr()
}
fn simple4() align 4 -> i32 { 0x19 }

View File

@ -2039,4 +2039,16 @@ pub fn addCases(cases: &tests.CompileErrorContext) {
\\}
,
".tmp_source.zig:2:22: error: expected pointer or slice, found 'u32'");
cases.add("passing an under-aligned function pointer",
\\export fn entry() {
\\ testImplicitlyDecreaseFnAlign(alignedSmall, 1234);
\\}
\\fn testImplicitlyDecreaseFnAlign(ptr: fn () align 8 -> i32, answer: i32) {
\\ if (ptr() != answer) unreachable;
\\}
\\fn alignedSmall() align 4 -> i32 { 1234 }
,
".tmp_source.zig:2:35: error: expected type 'fn() align 8 -> i32', found 'fn() align 4 -> i32'");
}