mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 01:17:35 +00:00
LibJS: Shrink Identifier's environment coordinate cache
This patch does two things: - We now use u32 instead of size_t for the hops and index fields in EnvironmentCoordinate. This means we're limited to an environment nesting level and variable count of 4Gs respectively. - Instead of wrapping it in an Optional, EnvironmentCoordinate now has a custom valid/invalid state using a magic marker value. These two changes reduce the size of Identifier by 16 bytes. :^)
This commit is contained in:
parent
76f438eb3e
commit
0f1f925532
4 changed files with 16 additions and 10 deletions
|
@ -12,10 +12,13 @@
|
|||
namespace JS {
|
||||
|
||||
struct EnvironmentCoordinate {
|
||||
size_t hops { 0 };
|
||||
size_t index { 0 };
|
||||
u32 hops { invalid_marker };
|
||||
u32 index { invalid_marker };
|
||||
|
||||
static constexpr size_t global_marker = 0xffffffff;
|
||||
bool is_valid() const { return hops != invalid_marker && index != invalid_marker; }
|
||||
|
||||
static constexpr u32 global_marker = 0xffffffff;
|
||||
static constexpr u32 invalid_marker = 0xfffffffe;
|
||||
};
|
||||
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue