The change to shared pointers is being crept up on. The next step was to replace all references to Token* (pointers to tokens) with the alias TokenPtr:
using TokenPtr = Token *;This will allow for an easy change to shared pointers. The changes made during the previous failed attempt were extensive, and it was hard to determine exactly which changes caused the problems. So the alias change will be separate from the shared pointer change. The alias change was made first and thoroughly tested (using the memory test script).
Another preparatory change made included passing a constant reference to a token pointer to functions that don't modify the token passed. This doesn't have much effect for simple pointers, but for shared pointers, it will prevent a copy from being made of the pointer (which incremented its used count, only to be decremented when the argument goes out of scope at the end of the function).
The use of the NULL definition for checking if a token pointer is unset or to assign it to an unset value was changed to the C++11 nullptr, an actual null pointer. For tokens pointers initialized to a null pointer, the {} C++11 initializer syntax was used.
[branch cpp11 commit 233a8f4017]
