Jump to navigation Jump to search
No change in size ,  15:30, 31 July 2016
Fix code highlighting
The second issue concerns problems causing engines to be non-reentrant. Consider a code snippet like this:
<syntax typesource lang="C++cpp">
bool foo(bool cond) {
static bool bar = false;
return bar;
Suppose this function is part of engine quux. When a new game using this engine is started, foo(false) will initially always return false. After foo(true) has been called the first time, foo will always return true. Maybe foo(true) is called when the user/player solves a certain puzzle in the game, and maybe the foo() function is meant to test whether this puzzle has already been solved.
Now imagine the player uses the "return to launcher" feature; once back in the launcher, they restart the game, again using the quux engine.
This is another important reason why global variables keeping state are dangerous. At the very least, you ''must'' re-init any global variables whenever your engine starts. Relying on one-time initialization assignments to global variables, as in
<syntax typesource lang="C++cpp">
static int myGlobal = 0;
is ''not'' sufficient.
In addition, global variables are strongly discouraged; if they are to be used, then they ''must'' be accompanied by a comment that explains why this static variable is necessary, and why it cannot be replaced by something else, like typically a member variable of a suitable class / object. The comment should also indicate where the variable is (re)set when the engine launches. If no such comment is present, a generic comment of the following form shall be added to the variable declaration:
<syntax typesource lang="C++cpp">
// FIXME: non-const global var
As a minor exception, if an existing engine uses many globals (due to not (yet) being objectified), it is permissible to use a single comment to document multiple globals at once.

Navigation menu