There is no hard reason. As ralismark said, a paper was discussed this year (for C++20, not 17!). There are concerns, but also counterpoints:
- It could be seen as making the language less regular (as codeshot said), but the new idea is that disambiguating
typenamewill become rare enough as to have near-consistency in the other direction. (As has been said, there was already an exceptional case in the form of base class names.) - It could foreclose possible extensions (as T.C. reported), but the extensions could have their own disambiguation rather than burdening the common case.
The paper has strong support and the new rules will probably appear in the working draft in a few months.