In Snowball, you can use function attributes to modify the behaviour and properties of functions. These attributes provide additional information or instructions to the compiler. Here are a few commonly used function attributes:
llvm_function
: As mentioned earlier, This attribute allows you to embed LLVM code directly within a function. It enables low-level optimizations or specific functionality using the LLVM intermediate representation (IR).llvm_function(sanitise_void_return)
: This replaces allvoid
types in return types and argument types to ani8
in the llvm IR.
internal_linkage
: This attribute specifies that a function has internal linkage, meaning it is only accessible within the current module or translation unit. Functions with internal linkage cannot be called from other modules.inline
: This attribute suggests to the compiler that the function should be inlined, meaning the function body is directly inserted at the call site instead of making a function call. Inlining can potentially improve performance by reducing function call overhead.no_inline
: This tells the compiler to not inline the function.inline
andno_inline
can't be used in the same function!
test
: This attribute often marks functions as test cases or test functions. Test functions are typically used for unit testing purposes to verify the correctness of specific code snippets or components.test(skip=0)
: If it's 1, it will skip the test and it won't be executed.test(expect=1)
: It will be the default check value. Default is 1test(description = "")
: Add a description to the unit test.
bench
: This attribute marks a function as a benchmarking function. These functions are executed and benchmarked when runningsnowball bench
.no_mangle
: It doesn't mangle the function's name at the executable.This doesn't work on class functions!
export
: It exports a function with the specified argumentsexport(name="<name>")
: It exports the function as the specified name. Default is the function mangled name.
unsafe_fn_not_body
: This attribute leaves the function marked asunsafe
but it does not enter in an unsafe context for its block.They can only be used in
unsafe
functions
Note that there are still many more to come!
Here's an example that demonstrates the usage of these function attributes:
In this example, the example
function uses the llvm_function
attribute to embed LLVM code. The internalFunction
is marked with internal_linkage
, indicating that it has internal linkage. The inlineFunction
is annotated with inline
, suggesting the compiler to inline the function when appropriate. Finally, the testFunction
is marked with test
, indicating that it serves as a test function that expects 62
.
By using function attributes, you can customize the behaviour and optimize the performance of your Snowball functions, as well as provide additional information for testing or other purposes.
Last updated