mirror of https://github.com/AxioDL/metaforce.git
RetroTypes: Take types in comparisons by value where applicable
CAssetId, TEditorId, and TUniqueId are all small enough to fit within registers as is, so we can take these types by value, which allows for eliminating unnecessary memory referencing.
This commit is contained in:
parent
6ed2415f6f
commit
8cd27ac822
|
@ -38,9 +38,9 @@ public:
|
||||||
constexpr void Assign(u64 v) noexcept { id = (v == UINT32_MAX ? UINT64_MAX : (v == 0 ? UINT64_MAX : v)); }
|
constexpr void Assign(u64 v) noexcept { id = (v == UINT32_MAX ? UINT64_MAX : (v == 0 ? UINT64_MAX : v)); }
|
||||||
constexpr void Reset() noexcept { id = UINT64_MAX; }
|
constexpr void Reset() noexcept { id = UINT64_MAX; }
|
||||||
void PutTo(COutputStream& out);
|
void PutTo(COutputStream& out);
|
||||||
[[nodiscard]] constexpr bool operator==(const CAssetId& other) const noexcept { return id == other.id; }
|
[[nodiscard]] constexpr bool operator==(CAssetId other) const noexcept { return id == other.id; }
|
||||||
[[nodiscard]] constexpr bool operator!=(const CAssetId& other) const noexcept { return !operator==(other); }
|
[[nodiscard]] constexpr bool operator!=(CAssetId other) const noexcept { return !operator==(other); }
|
||||||
[[nodiscard]] constexpr bool operator<(const CAssetId& other) const noexcept { return id < other.id; }
|
[[nodiscard]] constexpr bool operator<(CAssetId other) const noexcept { return id < other.id; }
|
||||||
};
|
};
|
||||||
|
|
||||||
//#define kInvalidAssetId CAssetId()
|
//#define kInvalidAssetId CAssetId()
|
||||||
|
@ -73,11 +73,11 @@ struct TEditorId {
|
||||||
[[nodiscard]] constexpr u8 LayerNum() const noexcept { return u8((id >> 26) & 0x3f); }
|
[[nodiscard]] constexpr u8 LayerNum() const noexcept { return u8((id >> 26) & 0x3f); }
|
||||||
[[nodiscard]] constexpr u16 AreaNum() const noexcept { return u16((id >> 16) & 0x3ff); }
|
[[nodiscard]] constexpr u16 AreaNum() const noexcept { return u16((id >> 16) & 0x3ff); }
|
||||||
[[nodiscard]] constexpr u16 Id() const noexcept { return u16(id & 0xffff); }
|
[[nodiscard]] constexpr u16 Id() const noexcept { return u16(id & 0xffff); }
|
||||||
[[nodiscard]] constexpr bool operator<(const TEditorId& other) const noexcept { return (id & 0x3ffffff) < (other.id & 0x3ffffff); }
|
[[nodiscard]] constexpr bool operator<(TEditorId other) const noexcept { return (id & 0x3ffffff) < (other.id & 0x3ffffff); }
|
||||||
[[nodiscard]] constexpr bool operator==(const TEditorId& other) const noexcept {
|
[[nodiscard]] constexpr bool operator==(TEditorId other) const noexcept {
|
||||||
return (id & 0x3ffffff) == (other.id & 0x3ffffff);
|
return (id & 0x3ffffff) == (other.id & 0x3ffffff);
|
||||||
}
|
}
|
||||||
[[nodiscard]] constexpr bool operator!=(const TEditorId& other) const noexcept { return !operator==(other); }
|
[[nodiscard]] constexpr bool operator!=(TEditorId other) const noexcept { return !operator==(other); }
|
||||||
};
|
};
|
||||||
|
|
||||||
#define kInvalidEditorId TEditorId()
|
#define kInvalidEditorId TEditorId()
|
||||||
|
@ -89,9 +89,9 @@ struct TUniqueId {
|
||||||
constexpr TUniqueId(u16 value, u16 version) noexcept : id(value | (version << 10)) {}
|
constexpr TUniqueId(u16 value, u16 version) noexcept : id(value | (version << 10)) {}
|
||||||
[[nodiscard]] constexpr u16 Version() const noexcept { return u16((id >> 10) & 0x3f); }
|
[[nodiscard]] constexpr u16 Version() const noexcept { return u16((id >> 10) & 0x3f); }
|
||||||
[[nodiscard]] constexpr u16 Value() const noexcept { return u16(id & 0x3ff); }
|
[[nodiscard]] constexpr u16 Value() const noexcept { return u16(id & 0x3ff); }
|
||||||
[[nodiscard]] constexpr bool operator<(const TUniqueId& other) const noexcept { return id < other.id; }
|
[[nodiscard]] constexpr bool operator<(TUniqueId other) const noexcept { return id < other.id; }
|
||||||
[[nodiscard]] constexpr bool operator==(const TUniqueId& other) const noexcept { return id == other.id; }
|
[[nodiscard]] constexpr bool operator==(TUniqueId other) const noexcept { return id == other.id; }
|
||||||
[[nodiscard]] constexpr bool operator!=(const TUniqueId& other) const noexcept { return !operator==(other); }
|
[[nodiscard]] constexpr bool operator!=(TUniqueId other) const noexcept { return !operator==(other); }
|
||||||
};
|
};
|
||||||
|
|
||||||
#define kInvalidUniqueId TUniqueId()
|
#define kInvalidUniqueId TUniqueId()
|
||||||
|
|
Loading…
Reference in New Issue