summaryrefslogtreecommitdiffstats
path: root/src/core/templates.h
diff options
context:
space:
mode:
authoraap <aap@papnet.eu>2020-12-01 11:25:02 +0100
committerGitHub <noreply@github.com>2020-12-01 11:25:02 +0100
commit56c471d02e1c704202f809de7f3d179c98ae121f (patch)
treea1886f8b54f498c02c9ffecb9f1541f65ecedfae /src/core/templates.h
parentcam stuff (diff)
parentMerge remote-tracking branch 'upstream/master' (diff)
downloadre3-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.h12
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;