When a variable is vacant, it has no value. Some people confuse vacancy with zero. Zero is a value. When a variable is vacant, it has no value. Another term for vacancy is “null.” It is correct to say a vacant variable is null.
The representation for vacancy in custom macro B is #0. The following command will set variable #101 to vacant.
#101 = #0
While this command doesn’t have any real purpose, there are several implications of vacancy that can have a real impact on how you write custom macro programs.
When are variables vacant?
In my experience, vacancy has the biggest impact on local variables (#1 through #33). When you first turn on the machine, and whenever an M99, M02 or M30 is executed, local variables will be in a vacant state. Again, this means
variables #1 through #33 will have no value at this point.
Certain local variables are automatically set to a value when a G65 command is executed—as long as the G65 command includes letter address arguments (such as A, B, C and so forth). Which local variables will be set depend upon which argument letter addresses are specified in the G65 command.
For example, in argument assignment number one (the more common form of argument assignment in custom macro B), the value of letter address A will be placed in #1, B in #2, C in #3, D in #7 and so on (the Fanuc manual shows the rest). Consider the following G65 command:
N060 G65 P1000 A4.0 B6.5 C9.0
When the machine executes program O1000 (specified by the P word in the G65 command), #1 will have a value of 4.0, #2 will have a value of 6.5 and #3 will have a value of 9.0. All other local variables will remain vacant. You can confirm this by looking at the local variable display screen page. You’ll see values next to #1, #2 and #3, but nothing (not even zero) next to the other local variables.
Your custom macro calling (G65) command will include some important letter address arguments. If the programmer using your custom macro makes a mistake and forgets to include one, your custom macro will behave in an unpredictable manner. You can test the local variable corresponding to each important argument to confirm that it has been included in the calling command. If it has not, you can make the custom macro generate an alarm. Here is an example:
IF [#1 NE #0] GOTO 5
#3000 = 100 (A MISSING IN CALL)
As long as letter address A has been included in the G65 command, local variable #1 will have a value—it will not be vacant—and the IF statement test will be evaluated as true. On the other hand, if letter address A has been left out of the call statement (a mistake), the IF statement test will be evaluated as false, and an alarm will sound.
Setting Default Values
There may be other arguments in your G65 command that are almost always set to a given value. You may, for example, be using letter address C to specify whether or not coolant is being used by the custom macro. You almost always use coolant, so you want the default setting for C to be “with coolant.” Only if you happen across a situation when you don’t want coolant will you include a setting for C in the calling command. In this case, you’ll set the value of C to zero (0). Leaving defaulting letter address arguments out of the calling command can dramatically shorten it, minimizing what a programmer must specify. Consider these commands:
IF [#3 EQ #0] GOTO 10
Assuming the programmer leaves letter address C out of the call statement (the normal condition), the IF statement will be evaluated as true, and the M08 will be executed. This turns on the coolant. If C0 is included in the call statement (programmer wants no coolant), the IF statement will be evaluated as false—and the M09 will be executed.
When you are developing a custom macro that will be used by others, we recommend testing the local variables corresponding to all letter address arguments. Test to confirm that all mandatory letter address arguments are included and that all other letter address arguments have a default setting. By doing so, you can confirm that the custom macro will have appropriate input data when it begins the function you intend.