diff options
author | aap <aap@papnet.eu> | 2020-12-01 11:25:02 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-12-01 11:25:02 +0100 |
commit | 56c471d02e1c704202f809de7f3d179c98ae121f (patch) | |
tree | a1886f8b54f498c02c9ffecb9f1541f65ecedfae /src/core/templates.h | |
parent | cam stuff (diff) | |
parent | Merge remote-tracking branch 'upstream/master' (diff) | |
download | re3-56c471d02e1c704202f809de7f3d179c98ae121f.tar re3-56c471d02e1c704202f809de7f3d179c98ae121f.tar.gz re3-56c471d02e1c704202f809de7f3d179c98ae121f.tar.bz2 re3-56c471d02e1c704202f809de7f3d179c98ae121f.tar.lz re3-56c471d02e1c704202f809de7f3d179c98ae121f.tar.xz re3-56c471d02e1c704202f809de7f3d179c98ae121f.tar.zst re3-56c471d02e1c704202f809de7f3d179c98ae121f.zip |
Diffstat (limited to 'src/core/templates.h')
-rw-r--r-- | src/core/templates.h | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/src/core/templates.h b/src/core/templates.h index 86239664..166f865c 100644 --- a/src/core/templates.h +++ b/src/core/templates.h @@ -124,12 +124,18 @@ public: (T*)&m_entries[handle >> 8] : nil; } int GetIndex(T *entry){ - int i = GetJustIndex(entry); + int i = GetJustIndex_NoFreeAssert(entry); return m_flags[i].u + (i<<8); } int GetJustIndex(T *entry){ - // TODO: the cast is unsafe - return (int)((U*)entry - m_entries); + int index = GetJustIndex_NoFreeAssert(entry); + assert(!IsFreeSlot(index)); + return index; + } + int GetJustIndex_NoFreeAssert(T* entry){ + int index = ((U*)entry - m_entries); + assert((U*)entry == (U*)&m_entries[index]); // cast is unsafe - check required + return index; } int GetNoOfUsedSpaces(void) const{ int i; |