From 151392708edbef04b7f0f3a6dd4fab84cb9ff763 Mon Sep 17 00:00:00 2001 From: Boris Batkin Date: Thu, 11 Jun 2026 01:06:30 -0700 Subject: [PATCH] binder: detect fixed-array args via isArray(), not dim.size() MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit daslang PR GaijinEntertainment/daScript#3095 replaces TypeDecl's flattened dim/dimExpr vectors with a structural Type::tFixedArray — the dim member is gone. isArray() means "is a fixed-size array" in both worlds (dim.size() != 0 before, baseType == tFixedArray after), so this compiles and behaves identically against current daslang master and against the rework. Mergeable ahead of the daslang PR; unblocks its extended_checks, which installs dasImgui from master. Co-Authored-By: Claude Fable 5 --- src/cb_dasIMGUI.h | 2 +- src/dasIMGUI.main.cpp | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/cb_dasIMGUI.h b/src/cb_dasIMGUI.h index 29cad65..7bf3984 100644 --- a/src/cb_dasIMGUI.h +++ b/src/cb_dasIMGUI.h @@ -161,7 +161,7 @@ struct imguiTempFn { bool anyString = false; for ( auto &arg : fn->arguments ) { - if ( arg->type->constant && arg->type->ref && arg->type->dim.size() == 0 ) { + if ( arg->type->constant && arg->type->ref && !arg->type->isArray() ) { if ( arg->type->baseType == Type::tFloat2 || arg->type->baseType == Type::tFloat4 ) { arg->type->ref = false; } diff --git a/src/dasIMGUI.main.cpp b/src/dasIMGUI.main.cpp index 615c4b1..0b5f4ae 100644 --- a/src/dasIMGUI.main.cpp +++ b/src/dasIMGUI.main.cpp @@ -820,7 +820,7 @@ namespace das { for ( auto & pfn : this->functions.each() ) { bool anyString = false; for ( auto & arg : pfn->arguments ) { - if ( arg->type->constant && arg->type->ref && arg->type->dim.size()==0 ) { + if ( arg->type->constant && arg->type->ref && !arg->type->isArray() ) { if ( arg->type->baseType==Type::tFloat2 || arg->type->baseType==Type::tFloat4 ) { arg->type->ref = false; }