Switch: Difference between revisions

From EDukeWiki
Jump to navigation Jump to search
No edit summary
Remove misleading information
 
(One intermediate revision by one other user not shown)
Line 13: Line 13:
   endswitch
   endswitch


The '''case''' keyword works like an [[ifvare]] statement, and '''default''' operates on every possibility that is ''not'' specified by a case statement.
The '''case''' keyword works like an [[ifvare]] statement, and '''default''' operates on every possibility that is ''not'' specified by a case statement. Each case block must be terminated with a '''[[break]]''' statement.
 
Caution:  Nested switches do not work because of the way the CON compiler compiles them. A workaround is to put the nested switch in a separate state, and call that state from inside the first switch.
 
Also, adding extra [[break]] statements inside a case argument will cause a lot of errors. Again, the workaround is to put the commands that need to be separated in another state, along with the break.


See: [http://www.cplusplus.com/doc/tutorial/control/ Control Structures @ C++ Documentation]
See: [http://www.cplusplus.com/doc/tutorial/control/ Control Structures @ C++ Documentation]


[[Category:EDuke commands]]
[[Category:EDuke commands]]

Latest revision as of 00:16, 12 September 2021

The switch statement in CON is similar to that in C.

 switch <gamevar>
   case <constant>
     <do something>
   break
   case <constant>
     <do something>
   break
   default
     <do something>
   break
 endswitch

The case keyword works like an ifvare statement, and default operates on every possibility that is not specified by a case statement. Each case block must be terminated with a break statement.

See: Control Structures @ C++ Documentation