LZOSTRAW.H 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /*
  2. ** Command & Conquer Red Alert(tm)
  3. ** Copyright 2025 Electronic Arts Inc.
  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 3 of the License, or
  8. ** (at your option) any later version.
  9. **
  10. ** This program is distributed in the hope that it will be useful,
  11. ** but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. ** GNU General Public License for more details.
  14. **
  15. ** You should have received a copy of the GNU General Public License
  16. ** along with this program. If not, see <http://www.gnu.org/licenses/>.
  17. */
  18. /* $Header: /CounterStrike/LZoSTRAW.H 1 3/03/97 10:25a Joe_bostic $ */
  19. /***********************************************************************************************
  20. *** C O N F I D E N T I A L --- W E S T W O O D S T U D I O S ***
  21. ***********************************************************************************************
  22. * *
  23. * Project Name : Command & Conquer *
  24. * *
  25. * File Name : LZOSTRAW.H *
  26. * *
  27. * Programmer : Joe L. Bostic *
  28. * *
  29. * Start Date : 07/02/96 *
  30. * *
  31. * Last Update : July 2, 1996 [JLB] *
  32. * *
  33. *---------------------------------------------------------------------------------------------*
  34. * Functions: *
  35. * - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
  36. #ifndef LZOSTRAW_H
  37. #define LZOSTRAW_H
  38. #include "straw.h"
  39. /*
  40. ** This class handles LZO compression/decompression to the data stream that is drawn through
  41. ** this class. Note that for compression, two internal buffers are required. For decompression
  42. ** only one buffer is required. This changes the memory footprint of this class depending on
  43. ** the process desired.
  44. */
  45. class LZOStraw : public Straw
  46. {
  47. public:
  48. typedef enum CompControl {
  49. COMPRESS,
  50. DECOMPRESS
  51. } CompControl;
  52. LZOStraw(CompControl control, int blocksize=1024*8);
  53. virtual ~LZOStraw(void);
  54. virtual int Get(void * source, int slen);
  55. private:
  56. /*
  57. ** This tells the pipe if it should be decompressing or compressing the data stream.
  58. */
  59. CompControl Control;
  60. /*
  61. ** The number of bytes accumulated into the staging buffer.
  62. */
  63. int Counter;
  64. /*
  65. ** Pointer to the working buffer that compression/decompression will use.
  66. */
  67. char * Buffer;
  68. char * Buffer2;
  69. /*
  70. ** The working block size. Data will be compressed in chunks of this size.
  71. */
  72. int BlockSize;
  73. /*
  74. ** Probably dont need this anymore as LZO decompresses into a staging buffer.
  75. */
  76. int SafetyMargin;
  77. /*
  78. ** Each block has a header of this format.
  79. */
  80. struct {
  81. unsigned short CompCount; // Size of data block (compressed).
  82. unsigned short UncompCount; // Bytes of uncompressed data it represents.
  83. } BlockHeader;
  84. LZOStraw(LZOStraw & rvalue);
  85. LZOStraw & operator = (LZOStraw const & pipe);
  86. };
  87. #endif