Files that define symbols such as classes and variables may be included into many files. Simply performing that inclusion should have no effect on those files other than declaring new symbols. For instance, a file containing a class definition should not also contain side-effects such as ``++print++`` statements that will be evaluated automatically on inclusion. Logic should be segregated into symbol-only files and side-effect-only files. The type of operation which is not allowed in a symbol-definition file includes but is not limited to:
\[~ann.campbell.2] Explanation is great IMO. I just have 3 comments:
* I would use the word *evaluated* instead of *executed* in the sentence _"should not contain ``++print++`` statements that will be *executed* automatically on inclusion"_
* "side-effects" is present in the title but not in the description, I think it would be worth to mention it just be clear on its meaning.
* I would add a bullet point with "..." jus to be clear that the list is not exhaustive, even if you used the word "include".