On my PC, this new change is causing a test failure:

 SELECT SUBSTR(f1, 2000, 50) FROM cmdata1;
-                       substr                       
-----------------------------------------------------
- 01234567890123456789012345678901234567890123456789
-(1 row)
-
+ERROR:  compressed lz4 data is corrupt

@@ -119,15 +119,15 @@ lz4_cmdecompress_slice(const struct varlena *value, int32 
slicelength)
        int32           rawsize;
        struct varlena *result;
 
-       /* allocate memory for holding the uncompressed data */
-       result = (struct varlena *) palloc(VARRAWSIZE_4B_C(value) + VARHDRSZ);
+       /* allocate memory for the uncompressed data */
+       result = (struct varlena *) palloc(slicelength + VARHDRSZ);
 
-       /* decompress partial data using lz4 routine */
+       /* decompress the data */
        rawsize = LZ4_decompress_safe_partial((char *) value + 
VARHDRSZ_COMPRESS,
                                                                                
  VARDATA(result),
                                                                                
  VARSIZE(value) - VARHDRSZ_COMPRESS,
                                                                                
  slicelength,
-                                                                               
  VARRAWSIZE_4B_C(value));
+                                                                               
  slicelength);

Also, in the tests, you have this at both the top and bottom of the file:

src/test/regress/sql/compression.sql:\set HIDE_COMPRESSAM false
src/test/regress/sql/compression.sql:\set HIDE_COMPRESSAM false

Whereas the patch I sent had at the end:

+\set HIDE_COMPRESSAM on

("on" is the default when run under pg_regress)


Reply via email to