Care should be taken if you define a goto label as as variable. A literal or constant-defined label will take precedence over a variable-defined label. You cannot define multiple labels within the same scope with the same value (or with the same variable, though it won't cause an error if a variable later takes on the same value as another label). If multiple variable-defined labels have variables with the same value, then the label that is declared earlier in the program will be the target.
Labels are defined by using a colon (':') followed by the value (or a constant or variable). If the label is a word, it must be enclosed in quotes. A sequence (created using braces) can be used, but if there is anything other than literals delimited by commas, the label is treated like a variable, since it must be evaluated at run time, not compile time. You cannot have a label as the first statement after a function declaration, because it will be interpreted as a return type.
ex: -- Illegal: function foo( integer bar ) :1 return bar + 1 end function -- Legal: function foo( integer bar ) integer x :1 x = bar + 1 end function
ex: object labelA procedure foo() goto "Label B" goto "Label A" :labelA -- This label is known as soon as labelA is assigned a value. puts(1, "Label A\n") :"Label " & "B" -- This label isn't known until it is executed in normal program flow -- during run-time. The evaluation must happen each time the procedure -- is called. puts(1, "label B\n") end procedure labelA = "Label " & "A" foo()
If a goto jumps past an abort() call or a return statement, you may get false warnings that the statements after the abort() or return will not be executed.
The following demonstrates legal (though not necessarily recommended) uses of goto:
: "start" printf(1, ": \"%s\"\n", {"start"} ) goto "spaghetti" :1 printf(1, ": %d\n", 1 ) constant sequence_label = {1,{2}} goto {1,{2}} abort(0) object label : label printf( 1, ": %d\n", label ) label = "end" goto label : "spaghetti" printf( 1, ": \"%s\"\n", {"spaghetti"}) label = 5 goto 4 + 1 : "end" printf(1,": \"%s\"\n",{"end"}) goto 1 : sequence_label puts(1, ": " ) print(1, {1,{2}}) puts(1,"\n")
This sets a default label to use if the supplied label does not match a valid target. If the default label is itself not a valid target, then the goto is resolved based on the status of the strict_goto directive. The scope of default gotos is confined to routines and files just like other labels.
See Also: goto, is_goto, strict_goto
The syntax for using a goto is:
goto <target>
See Also: default_goto, is_goto, strict_goto
This function returns 1 if the specified label is a valid goto target, or zero if it is not.
See Also: default_goto, goto, strict_goto
This keyword is meant to be used with "with/without". The default is for strict_goto to be off. This means that if goto is called with a non-existent label, execution will continue with the next statement. In code with strict_goto turned on, an invalid goto target will result in an error.
See Also: default_goto, goto, is_goto