// Boolean return codes (must be 0 or 1 only)
#define OKAY 0
#define FAIL 1
Why is this even a thing in supermodel? This seems like crazy bad design to me. If a function returns a boolean it's reasonable to expect that true would be success .. or whatever. If someone uses a boolean like a boolean
ie
bool result = Function();
if(result) {
some code;
}
They'll be in for a bad time if randomly OKAY is returned which is defined as zero lol. To fix this madness should use something like
enum class ErrorCodes { Okay, Fail };
Then bool types can't be confused.
OKAY FAIL
Forum rules
Keep it classy!
Keep it classy!
- No ROM requests or links.
- Do not ask to be a play tester.
- Do not ask about release dates.
- No drama!
Re: OKAY FAIL
I customarily use 0 as success (i.e., no condition) and non-zero as an error code (or just true for bool), similar to the POSIX convention, for functions that otherwise have no return type. I've seen both conventions in code bases. The reason I prefer this convention to this day over the increasingly more common true-on-success is that usually one wants to handle the error cases, not the success cases, so for me it feels really bizarre to have:
The following has always felt more logical to me (like testing for a flagged result):
I defined OKAY and FAIL to be explicit because it is just a convention after all. The intent was to be explicit about returning these rather than relying on boolean results directly (e.g. "return (foo == bar) ? OKAY : FAIL" rather than "return foo != bar".
An enum would be the better way to go in retrospect.
Code: Select all
if (!SaveFileToDisk(file))
{
printf("error\n");
return 1; // especially weird in main(), which uses my convention
}
Code: Select all
if (SaveFileToDisk())
{
printf("error\n");
return 1;
}
An enum would be the better way to go in retrospect.
Re: OKAY FAIL
Yeah I understand the logic. In c you'd use something like errno_t which is simply a typedef for int. At least then the intention is clear. Any objections if we refactor this.
Re: OKAY FAIL
I think an enum would be good. Something like:
Code: Select all
enum Result
{
OKAY,
FAILED
};