Difference between revisions of "Macro Constants"

From GiderosMobile
m (Text replacement - "<source" to "<syntaxhighlight")
m (Text replacement - "</source>" to "</syntaxhighlight>")
 
Line 32: Line 32:
 
world!
 
world!
 
]]
 
]]
</source>
+
</syntaxhighlight>
  
 
'''Commenting out the print command'''
 
'''Commenting out the print command'''
Line 39: Line 39:
  
 
print(x, y, z, x + y, y * z) -- this line will be skipped
 
print(x, y, z, x + y, y * z) -- this line will be skipped
</source>
+
</syntaxhighlight>
  
 
'''Advanced example'''
 
'''Advanced example'''
 
<syntaxhighlight lang="lua">
 
<syntaxhighlight lang="lua">
 
pi @ |math.atan(1.0)*4|
 
pi @ |math.atan(1.0)*4|
</source>
+
</syntaxhighlight>
  
 
{|-
 
{|-

Latest revision as of 15:31, 13 July 2023

Supported platforms: Platform android.pngPlatform ios.pngPlatform mac.pngPlatform pc.png
Available since: Gideros 2017.10

Description

Another great Gideros feature is macros. Currently Lua has no constants, you just have to define variables like pi=3.14159.

Now you can define symbolic constants like this pi @ 3.14159 and then simply use pi in the code as normal. When the Lua code is byte compiled, the constants are replaced with their literal values which saves CPU time.

Macro Constants can be used for string and numeric constants. Just use @ rather than = when defining the macro.

You can use any of these delimiters after @ but they must be used in pairs. Numbers are auto-detected.

\`~ ! # $ % ^ & * / + = |

Examples

Simple examples

num1 @ &2^0&
num2 @ &2^1&
num3 @ &num1 + num2&

pi @ 3.14159265358979324
num4 @ -100.54
num5 @ 232
num6 @ 444.10
str1 @ 'hello'
str2 @ "world"
str3 @ [[
Hello,
world!
]]

Commenting out the print command

print @ |--|

print(x, y, z, x + y, y * z) -- this line will be skipped

Advanced example

pi @ |math.atan(1.0)*4|

Methods

Events

Constants