I only looked at PodVector and Vector but im seeing that operator[] uses a unsigned (assumed int) instead of a size_t wich could limit the maximum index to 0xFFFFFFFF even if you compile for x64. Is that a oversight ?
Is there a reason to use unsigned instead of size_t
I am not the original author of the code. If I have to guess a reason, I would say it is done for portability. Urho3D is a cross-platform engine supporting both 32 and 64 bit architecture. The “unsigned” data type is the same in any platforms that Urho3D supports.
AFAIK it was intentional decision
- To keep things the same on x86 and x64 as far as it’s possible.
- To use as few integer types in codebase as possible.
size_t is viral: once you use it in one place, you have to either use it in many places or cast away high part of 64-bit integer. Both ways are nasty.
I’m guessing that everyone assumed you wont be using a vector or string bigger than 4gb. This is a game engine, not a general purpose library. Here you have to be reasonable about this particular usage of the library and not in general. If your game does need that then you’re doing something wrong and need to look for another solution.
And I have to agree that
size_t
is not for everyone.