summaryrefslogtreecommitdiff
path: root/include/GShierMemObject.h
diff options
context:
space:
mode:
authorMax <34987259+mparisi20@users.noreply.github.com>2020-11-06 21:01:27 -0500
committerGitHub <noreply@github.com>2020-11-06 21:01:27 -0500
commit2ae7b5c414293c202ef46942ad0fa34ad373763f (patch)
treea224fd4c07715992b6f750e73a6d7bacc04f32ca /include/GShierMemObject.h
parent5818130a789d0326c52b72b42240aaf16e5ecbe9 (diff)
parent3e5884629d7d078c791a2c8bae9d93042f06dcab (diff)
Merge pull request #156 from mparisi20/master
decompile code_801DD8C0.o
Diffstat (limited to 'include/GShierMemObject.h')
-rw-r--r--include/GShierMemObject.h30
1 files changed, 30 insertions, 0 deletions
diff --git a/include/GShierMemObject.h b/include/GShierMemObject.h
new file mode 100644
index 0000000..aaec6fb
--- /dev/null
+++ b/include/GShierMemObject.h
@@ -0,0 +1,30 @@
+#ifndef POKEREVO_GSHIERMEMOBJECT_H
+#define POKEREVO_GSHIERMEMOBJECT_H
+
+#include "code_801DAAE0.h"
+
+// TODO: determine file that defines this
+extern MEMHeapHandle lbl_8063E8F8;
+
+// Note: This is the root base class for various classes such as GScamera,
+// GSlight, GSmodel, etc. Instances of these classes seem to be new/deleted using an alternative set of
+// routines than the global new and delete, which may be defined inline here.
+
+class GShierMemObject
+{
+public:
+ void* operator new(size_t sz)
+ {
+ if (func_801DAB28())
+ return func_801DAC94(lbl_8063E8F8, sz);
+ else
+ return NULL;
+ }
+
+ void operator delete(void* ptr)
+ {
+ func_801DAD48(lbl_8063E8F8, ptr);
+ }
+};
+
+#endif //POKEREVO_GSHIERMEMOBJECT_H