Clone of Bael'Zharon's Respite @ https://github.com/boardwalk/bzr

ChecksumXorGenerator.h 1.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /*
  2. * Bael'Zharon's Respite
  3. * Copyright (C) 2014 Daniel Skorupski
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 2 of the License, or
  8. * (at your option) any later version.
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License along
  15. * with this program; if not, write to the Free Software Foundation, Inc.,
  16. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
  17. */
  18. #ifndef BZR_CHECKSUMXORGENERATOR_H
  19. #define BZR_CHECKSUMXORGENERATOR_H
  20. #include <deque>
  21. class ChecksumXorGenerator
  22. {
  23. public:
  24. ChecksumXorGenerator();
  25. void init(uint32_t seed);
  26. uint32_t get(uint32_t sequence);
  27. void purge(uint32_t sequence);
  28. private:
  29. uint32_t generate();
  30. void initTables();
  31. static void initMix(uint32_t* xorvals);
  32. void scramble();
  33. static void scrambleRound(uint32_t shiftedVal, uint32_t* key0_ptr, uint32_t* key2_ptr, uint32_t** localunk_ptr, uint32_t** lc_unk0_ptr, uint32_t** lc_unk200_ptr, uint32_t** localxor_ptr, uint32_t* var_18_ptr, uint32_t* var_1c_ptr);
  34. static uint32_t Crazy_XOR_01(const uint32_t* data, uint32_t index);
  35. uint32_t counter_;
  36. uint32_t xorTable_[256];
  37. uint32_t unkTable_[256];
  38. uint32_t value0_;
  39. uint32_t value1_;
  40. uint32_t value2_;
  41. uint32_t cacheBegin_;
  42. deque<uint32_t> cache_;
  43. };
  44. #endif