compressutil.cpp 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. /*##############################################################################
  2. HPCC SYSTEMS software Copyright (C) 2019 HPCC Systems®.
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. http://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. ############################################################################## */
  13. #include "compressutil.hpp"
  14. #include "jlzw.hpp"
  15. size32_t LZWCompress(const void* src, size32_t srcSz, void* dest, size32_t destSz, size32_t threshold)
  16. {
  17. assertex(destSz>=srcSz+sizeof(size32_t));
  18. if (srcSz>=threshold)
  19. {
  20. Owned<ICompressor> compressor = createLZWCompressor();
  21. compressor->open((byte*)dest + sizeof(size32_t), srcSz * 4 / 5);
  22. if(compressor->write(src, srcSz)==srcSz)
  23. {
  24. compressor->close();
  25. memcpy(dest, &srcSz, sizeof(size32_t));
  26. return compressor->buflen() + sizeof(size32_t);
  27. }
  28. }
  29. memcpy((byte*)dest + sizeof(size32_t), src, srcSz);
  30. memset(dest, 0, sizeof(size32_t));
  31. return srcSz + sizeof(size32_t);
  32. }
  33. size32_t LZWCompress(const void* src, size32_t srcSz, MemoryBuffer& dest, size32_t threshold)
  34. {
  35. size32_t prev = dest.length();
  36. size32_t dSz = srcSz + sizeof(size32_t);
  37. void* d = dest.reserve(dSz);
  38. size32_t ret = LZWCompress(src, srcSz, d, dSz, threshold);
  39. dest.setLength(prev+ret);
  40. return ret;
  41. }
  42. size32_t LZWCompress(const void* src, size32_t srcSz, StringBuffer& dest, size32_t threshold)
  43. {
  44. size32_t prev = dest.length();
  45. size32_t dSz = srcSz + sizeof(size32_t);
  46. void* d = dest.reserve(dSz);
  47. size32_t ret = LZWCompress(src, srcSz, d, dSz, threshold);
  48. dest.setLength(prev+ret);
  49. return ret;
  50. }
  51. size32_t LZWCompress(MemoryBuffer& src, MemoryBuffer& dest, size32_t threshold)
  52. {
  53. return LZWCompress((const void*)src.toByteArray(), src.length(), dest, threshold);
  54. }
  55. size32_t LZWExpand(const void* src, size32_t srcSz, void* dest, size32_t destSz)
  56. {
  57. size32_t ret;
  58. memcpy(&ret, src, sizeof(size32_t));
  59. byte* data = (byte*)src+sizeof(size32_t);
  60. if(ret) // compressed
  61. {
  62. Owned<IExpander> expander = createLZWExpander();
  63. assertex(destSz >= ret);
  64. expander->init(data);
  65. expander->expand(dest);
  66. }
  67. else
  68. {
  69. ret = srcSz - sizeof(size32_t);
  70. assertex(destSz >= ret);
  71. memcpy(dest, data, ret);
  72. }
  73. return ret;
  74. }
  75. size32_t LZWExpand(const void* src, size32_t srcSz, StringBuffer& dest)
  76. {
  77. size32_t sz;
  78. memcpy(&sz, src, sizeof(size32_t));
  79. size32_t bufSz = (sz == 0) ? (srcSz-sizeof(size32_t)) : sz;
  80. void* buf = dest.reserve(bufSz);
  81. return LZWExpand(src, srcSz, buf, bufSz);
  82. }
  83. size32_t LZWExpand(const void* src, size32_t srcSz, MemoryBuffer& dest)
  84. {
  85. size32_t sz;
  86. memcpy(&sz, src, sizeof(size32_t));
  87. size32_t bufSz = (sz == 0) ? (srcSz-sizeof(size32_t)) : sz;
  88. void* buf = dest.reserve(bufSz);
  89. return LZWExpand(src, srcSz, buf, bufSz);
  90. }
  91. size32_t LZWExpand(MemoryBuffer& src, MemoryBuffer& dest)
  92. {
  93. size32_t len = src.remaining();
  94. const void* pSrc = src.readDirect(len);
  95. return LZWExpand(pSrc, len, dest);
  96. }
  97. size32_t LZWExpend(const void* src, size32_t srcSz, CLargeMemoryAllocator& mem)
  98. {
  99. size32_t sz;
  100. memcpy(&sz, src, sizeof(size32_t));
  101. size32_t bufSz = (sz == 0) ? (srcSz-sizeof(size32_t)) : sz;
  102. byte* buf = mem.alloc(bufSz);
  103. return LZWExpand(src, srcSz, buf, bufSz);
  104. }