diff options
author | Petr Mrázek <peterix@users.noreply.github.com> | 2021-02-09 23:12:32 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-02-09 23:12:32 +0100 |
commit | 485f123362b3e49cff3f162ace27f4c2fc0436fe (patch) | |
tree | feb81d168eef0d198dcb613cf3a2433c869b3c65 /libraries/classparser/src/javaendian.h | |
parent | 7265abf7636cc19b1b7c65f74b1111215914368c (diff) | |
parent | 6995a2e1bac6812ec4f48b98cfaf321f75c320d8 (diff) | |
download | PrismLauncher-485f123362b3e49cff3f162ace27f4c2fc0436fe.tar.gz PrismLauncher-485f123362b3e49cff3f162ace27f4c2fc0436fe.tar.bz2 PrismLauncher-485f123362b3e49cff3f162ace27f4c2fc0436fe.zip |
Merge pull request #3311 from AbigailBuccaneer/develop
Fix endianness handling errors
Diffstat (limited to 'libraries/classparser/src/javaendian.h')
-rw-r--r-- | libraries/classparser/src/javaendian.h | 33 |
1 files changed, 8 insertions, 25 deletions
diff --git a/libraries/classparser/src/javaendian.h b/libraries/classparser/src/javaendian.h index 076bff5e..5a6e107b 100644 --- a/libraries/classparser/src/javaendian.h +++ b/libraries/classparser/src/javaendian.h @@ -11,32 +11,17 @@ inline uint64_t bigswap(uint64_t x) { return x; } -; + inline uint32_t bigswap(uint32_t x) { return x; } -; + inline uint16_t bigswap(uint16_t x) { return x; } -; -inline int64_t bigswap(int64_t x) -{ - return x; -} -; -inline int32_t bigswap(int32_t x) -{ - return x; -} -; -inline int16_t bigswap(int16_t x) -{ - return x; -} -; + #else inline uint64_t bigswap(uint64_t x) { @@ -55,22 +40,20 @@ inline uint16_t bigswap(uint16_t x) return (x >> 8) | (x << 8); } +#endif + inline int64_t bigswap(int64_t x) { - return (x >> 56) | ((x << 40) & 0x00FF000000000000) | ((x << 24) & 0x0000FF0000000000) | - ((x << 8) & 0x000000FF00000000) | ((x >> 8) & 0x00000000FF000000) | - ((x >> 24) & 0x0000000000FF0000) | ((x >> 40) & 0x000000000000FF00) | (x << 56); + return static_cast<int64_t>(bigswap(static_cast<uint64_t>(x))); } inline int32_t bigswap(int32_t x) { - return (x >> 24) | ((x << 8) & 0x00FF0000) | ((x >> 8) & 0x0000FF00) | (x << 24); + return static_cast<int32_t>(bigswap(static_cast<uint32_t>(x))); } inline int16_t bigswap(int16_t x) { - return (x >> 8) | (x << 8); + return static_cast<int16_t>(bigswap(static_cast<uint16_t>(x))); } - -#endif } |