luaur-analysis 0.1.3

Luau type checker and type inference (Rust).
Documentation
use crate::functions::as_mutable_type_pack_alt_d::as_mutable_type_pack;
use crate::functions::flatten_type_pack::flatten_type_pack_id;
use crate::functions::follow_type::follow_type_id;
use crate::functions::get_type_alt_j::get_type_id;
use crate::records::function_type::FunctionType;
use crate::records::magic_function_call_context::MagicFunctionCallContext;
use crate::records::type_pack::TypePack;
use crate::type_aliases::type_pack_variant::TypePackVariant;
use alloc::vec;

pub fn magic_pcall_infer(ctx: &MagicFunctionCallContext) -> bool {
    let (arg_head, _arg_tail) = flatten_type_pack_id(ctx.arguments);

    if arg_head.is_empty() {
        return false;
    }

    let fn_ty = unsafe { follow_type_id(arg_head[0]) };
    let fn_ptr = unsafe { get_type_id::<FunctionType>(fn_ty) };
    if fn_ptr.is_null() {
        return false;
    }

    let (fn_return_head, fn_return_tail) = unsafe { flatten_type_pack_id((*fn_ptr).ret_types) };
    if !fn_return_head.is_empty() || fn_return_tail.is_some() {
        return false;
    }

    let solver = unsafe { ctx.solver.as_ref() };
    let res = unsafe {
        let builtin_types = &*solver.builtin_types;
        (*solver.arena).add_type_pack_t(TypePack {
            head: vec![builtin_types.booleanType, builtin_types.unknownType],
            tail: None,
        })
    };

    let result_mut = as_mutable_type_pack(ctx.result);
    unsafe {
        (*result_mut).ty = TypePackVariant::Bound(res);
    }

    true
}