mirror of
https://github.com/c3lang/c3c.git
synced 2026-02-27 20:11:17 +00:00
* Make StderrLogger print file and line if `FULL_LOG` * Avoid inlining a lot of code by using a macro wrapper. Fix test. --------- Co-authored-by: Christoffer Lerno <christoffer@aegik.com>
63 lines
2.5 KiB
Plaintext
63 lines
2.5 KiB
Plaintext
// #target: macos-x64
|
|
module test;
|
|
import std;
|
|
|
|
fn void main()
|
|
{
|
|
log::@category_scope(log::CATEGORY_KERNEL)
|
|
{
|
|
log::@tag_scope("YO")
|
|
{
|
|
log::info("Hello");
|
|
};
|
|
};
|
|
}
|
|
|
|
/* #expect: test.ll
|
|
|
|
define void @test.main() #0 {
|
|
entry:
|
|
%old = alloca i8, align 1
|
|
%old1 = alloca [12 x i8], align 1
|
|
%result = alloca [12 x i8], align 1
|
|
%tempcoerce = alloca { i64, i32 }, align 8
|
|
%category = alloca i8, align 1
|
|
%category2 = alloca i8, align 1
|
|
%indirectarg = alloca %"char[]", align 8
|
|
%indirectarg3 = alloca %"any[]", align 8
|
|
%0 = call ptr @llvm.threadlocal.address.p0(ptr @std.core.log.default_category)
|
|
%1 = load i8, ptr %0, align 1
|
|
store i8 %1, ptr %old, align 1
|
|
%2 = call ptr @llvm.threadlocal.address.p0(ptr @std.core.log.default_category)
|
|
store i8 2, ptr %2, align 1
|
|
call void @llvm.assume(i1 true)
|
|
%3 = call ptr @llvm.threadlocal.address.p0(ptr @std.core.log.current_tag)
|
|
call void @llvm.memcpy.p0.p0.i32(ptr align 1 %old1, ptr align 1 %3, i32 12, i1 false)
|
|
call void @llvm.assume(i1 true)
|
|
%4 = call ptr @llvm.threadlocal.address.p0(ptr @std.core.log.current_tag)
|
|
%5 = call { i64, i32 } @std.core.log.create_tag(ptr @.str, i64 2)
|
|
store { i64, i32 } %5, ptr %tempcoerce, align 8
|
|
call void @llvm.memcpy.p0.p0.i32(ptr align 1 %result, ptr align 8 %tempcoerce, i32 12, i1 false)
|
|
call void @llvm.memcpy.p0.p0.i32(ptr align 1 %4, ptr align 1 %result, i32 12, i1 false)
|
|
%6 = call ptr @llvm.threadlocal.address.p0(ptr @std.core.log.default_category)
|
|
%7 = load i8, ptr %6, align 1
|
|
store i8 %7, ptr %category, align 1
|
|
%8 = load i8, ptr %category, align 1
|
|
store i8 %8, ptr %category2, align 1
|
|
%9 = load i8, ptr %category2, align 1
|
|
store %"char[]" { ptr @.str.1, i64 5 }, ptr %indirectarg, align 8
|
|
store %"any[]" zeroinitializer, ptr %indirectarg3, align 8
|
|
call void @std.core.log.call_log_internal(i32 2, i8 zeroext %9, ptr @.emptystr, i64 0, ptr @.emptystr, i64 0, i32 0, ptr byval(%"char[]") align 8 %indirectarg, ptr byval(%"any[]") align 8 %indirectarg3)
|
|
%10 = call ptr @llvm.threadlocal.address.p0(ptr @std.core.log.current_tag)
|
|
call void @llvm.memcpy.p0.p0.i32(ptr align 1 %10, ptr align 1 %old1, i32 12, i1 false)
|
|
%11 = call ptr @llvm.threadlocal.address.p0(ptr @std.core.log.default_category)
|
|
%12 = load i8, ptr %old, align 1
|
|
store i8 %12, ptr %11, align 1
|
|
ret void
|
|
}
|
|
|
|
declare extern_weak { i64, i32 } @std.core.log.create_tag(ptr, i64) #0
|
|
|
|
declare extern_weak void @std.core.log.call_log_internal(i32, i8 zeroext, ptr, i64, ptr, i64, i32, ptr byval(%"char[]") align 8, ptr byval(%"any[]") align 8) #0
|
|
|