mirror of
https://github.com/Atmosphere-NX/Atmosphere.git
synced 2025-05-23 03:06:52 -04:00
Results: Implement namespaced, type-safe results.
Because I was working on multiple things at once, this commit also: - Adds wrappers for/linker flags to wrap CXX exceptions to make them abort. This saves ~0x8000 of memory in every system module. - Broadly replaces lines of the pattern if (cond) { return ResultX; } with R_UNLESS(!cond, ResultX());. - Reworks the R_TRY_CATCH macros (and the result macros in general).
This commit is contained in:
parent
15773e4755
commit
4059dc6187
169 changed files with 2172 additions and 1868 deletions
|
@ -339,9 +339,7 @@ namespace sts::ldr::caps {
|
|||
|
||||
#define VALIDATE_CASE(id) \
|
||||
case CapabilityId::id: \
|
||||
if (!Capability##id::Decode(cur_cap).IsValid(acid_caps, num_acid_caps)) { \
|
||||
return ResultLoaderInvalidCapability##id; \
|
||||
} \
|
||||
R_UNLESS(Capability##id::Decode(cur_cap).IsValid(acid_caps, num_acid_caps), ldr::ResultInvalidCapability##id()); \
|
||||
break
|
||||
switch (id) {
|
||||
VALIDATE_CASE(KernelFlags);
|
||||
|
@ -356,21 +354,18 @@ namespace sts::ldr::caps {
|
|||
{
|
||||
/* Map Range needs extra logic because there it involves two sequential caps. */
|
||||
i++;
|
||||
if (i >= num_aci_caps || !CapabilityMapRange::Decode(cur_cap).IsValid(aci_caps[i], acid_caps, num_acid_caps)) {
|
||||
return ResultLoaderInvalidCapabilityMapRange;
|
||||
}
|
||||
R_UNLESS(i < num_aci_caps, ldr::ResultInvalidCapabilityMapRange());
|
||||
R_UNLESS(CapabilityMapRange::Decode(cur_cap).IsValid(aci_caps[i], acid_caps, num_acid_caps), ldr::ResultInvalidCapabilityMapRange());
|
||||
}
|
||||
break;
|
||||
default:
|
||||
if (id != CapabilityId::Empty) {
|
||||
return ResultLoaderUnknownCapability;
|
||||
}
|
||||
R_UNLESS(id == CapabilityId::Empty, ldr::ResultUnknownCapability());
|
||||
break;
|
||||
}
|
||||
#undef VALIDATE_CASE
|
||||
}
|
||||
|
||||
return ResultSuccess;
|
||||
return ResultSuccess();
|
||||
}
|
||||
|
||||
u16 GetProgramInfoFlags(const void *kac, size_t kac_size) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue