In Pascal there is the Set object, that you set (n<256) bits and then can later check if bit n is set or not. Sort of like a bool array.
When you decompile a DOS Pascal program the IDA-Pro Flirt signatures will find the Set functions, in this example we will focus Set::MemberOf
data:image/s3,"s3://crabby-images/6cc9a/6cc9aa06bc3b8ed15dd6086c1a714f8523d16957" alt="Set MemberOf Set MemberOf"
arg_0
is the Set object and arg_4
is the byte we are checking to see if it’s set. When this code is called it looks like this:
data:image/s3,"s3://crabby-images/b84c0/b84c092133b75bab76095545442bbd269b301aab" alt="Set MemberOf in use Set MemberOf in use"
and the byte_152FE
location is an unknown mess like so:
data:image/s3,"s3://crabby-images/d640f/d640fa2b2f4deda7b0a757756ce01e35e12833ed" alt="Set data Set data"
as we know this data is a Set object, it would be nice if it was represented as such. Now we could Declare this a structure variable (Alt-Q)
by hand and then rename it.
data:image/s3,"s3://crabby-images/67d4a/67d4ac733dfc7731327f214a1c108e61e4413762" alt="Set Declare a structure variable (Alt-Q) Set Declare a structure variable (Alt-Q)"
This works for a few small cases, but in the Gold Box games, Sets
are used to manage lots of things so there are too many of them. The best trick here is to get IDA-Pro to do the work for us.
First you will need to have created a Set
structure (needed for the above manual process) that is 0x20 bytes long.
data:image/s3,"s3://crabby-images/f9018/f90187e3af31f78e65825fa4bb5b3067be7040e7" alt="set-structure set-structure"
Now go back to Set::MemberOf
and Associate a prototype to a function (Y)
and change the prototype from:
data:image/s3,"s3://crabby-images/31bb0/31bb0a9cfe12a92329895edb7cdf163690ed6afa" alt="Set Associate a prototype to a function (Y) Set Associate a prototype to a function (Y)"
int __stdcall far Set__MemberOf(__int32 _set);
to:
int __stdcall far Set__MemberOf(Set set, char);
and ta-da the code call Set::MemberOf
is tidy:
data:image/s3,"s3://crabby-images/c210b/c210ba141a4243d8034a8c08bf0b5f7b34619654" alt="set-member-of-in-use-clean set-member-of-in-use-clean"
and all the Set data blocks are typed for us also:
data:image/s3,"s3://crabby-images/af56e/af56eef0e97f5dc6d94c147931d493b9bb0a6dcd" alt="set-data-clean set-data-clean"
Magic!