Array+=: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Fix spacing)
(Fix description)
 
Line 1: Line 1:
The <syntaxhighlight lang="cpp" inline>array[] += {}</syntaxhighlight> syntax for {{arma3}} was introduced as an attempt to add unique weapons (or magazines) to a unit without the tedium of duplicate-typing all the basic items.
{{GVI|arma3|0.50}} same-file support<!-- in 2011 --><br>
{{GVI|arma3|1.00}} full support<!-- in 2013 -->


It originally had a text-only interpreter making it quite impossible to generate config.bin's versus config.cpp's. Later, Binarize was modified to create new token code for this syntax.
This token code is broken as it bears no relationship to any other tokenised output. It 'works' simply because its data format can be ignored.


It is not present in any form in any of the official addons accompanying {{arma3}}.
The <syntaxhighlight lang="cpp" inline>array[] += {}</syntaxhighlight> syntax allows to add items to an existing array inherited from the direct parent.
 
{{Feature|important|
* This syntax has limitations in inheritance - see {{Link|#Limitations}}.
* This syntax should '''not''' be used in [[Description.ext]] - only in modded {{Link|Config.cpp/bin File Format|config.cpp}}.
}}




Line 26: Line 30:
</syntaxhighlight>
</syntaxhighlight>


{{Feature|warning|2=
 
== Limitations ==
 
Only '''direct inheritance''' of an explicitly-stated array works. The following cases do '''not''' work:
Only '''direct inheritance''' of an explicitly-stated array works. The following cases do '''not''' work:
{{{!}} style="width: 100%"
{| style="awidth: 100%"
{{!}} style="width: 50%" {{!}}
| style="width: 50%" |
<syntaxhighlight lang="cpp">
<syntaxhighlight lang="cpp">
class A { array[] = { any, thing }; }
class A { array[] = { any, thing }; };
class B : A {};
class B : A {};
class C : B // inherits from B which inherits from A (without changes)
class C : B // inherits from B which inherits from A (without changes)
Line 38: Line 44:
};
};
</syntaxhighlight>
</syntaxhighlight>
{{!}}
|
<syntaxhighlight lang="cpp">
<syntaxhighlight lang="cpp">
class A { array[] = { any, thing }; };
class A { array[] = { any, thing }; };
Line 47: Line 53:
};
};
</syntaxhighlight>
</syntaxhighlight>
{{!}}}
|}
}}




[[Category:BIS File Formats]]
[[Category:BIS File Formats]]
[[Category:Introduced with Arma 3 version 0.50]]
[[Category:Introduced with Arma 3 version 1.00]]

Latest revision as of 15:41, 13 June 2023

Arma 3 logo black.png0.50 same-file support
Arma 3 logo black.png1.00 full support


The array[] += {} syntax allows to add items to an existing array inherited from the direct parent.


Usage

class A
{
	array[] = { any, thing };
};

class B : A
{
	array += { more, Bstuff };
};

class C : A // inherits from A, -not- B
{
	array += { other, Cstuff };
};


Limitations

Only direct inheritance of an explicitly-stated array works. The following cases do not work:

class A { array[] = { any, thing }; };
class B : A {};
class C : B // inherits from B which inherits from A (without changes)
{
	array[] += { wont, work }; // result: array[] = { wont, work };
};
class A { array[] = { any, thing }; };
class B : A { array[] += { more, stuff }; };
class C : B // inherits from B which inherits from A (with += changes)
{
	array[] += { wont, work }; // result: array[] = { wont, work };
};