test unpacking of PackBits()
This commit is contained in:
parent
3ba4472626
commit
d56915edc6
@ -819,7 +819,7 @@ endif
|
|||||||
|
|
||||||
TESTSOBJS = $(patsubst %.c,%.o,$(wildcard tests/*.c)) \
|
TESTSOBJS = $(patsubst %.c,%.o,$(wildcard tests/*.c)) \
|
||||||
miscfileformats.o fileformats.o oldies.o libraw2crtc.o \
|
miscfileformats.o fileformats.o oldies.o libraw2crtc.o \
|
||||||
loadsavefuncs.o \
|
loadsavefuncs.o packbits.o \
|
||||||
unicode.o \
|
unicode.o \
|
||||||
io.o realpath.o version.o pversion.o \
|
io.o realpath.o version.o pversion.o \
|
||||||
gfx2surface.o \
|
gfx2surface.o \
|
||||||
|
|||||||
69
src/packbits.c
Normal file
69
src/packbits.c
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
/* vim:expandtab:ts=2 sw=2:
|
||||||
|
*/
|
||||||
|
/* Grafx2 - The Ultimate 256-color bitmap paint program
|
||||||
|
|
||||||
|
Copyright 2018-2019 Thomas Bernard
|
||||||
|
Copyright 2008 Yves Rizoud
|
||||||
|
Copyright 2007 Adrien Destugues
|
||||||
|
Copyright 1996-2001 Sunset Design (Guillaume Dorme & Karl Maritaud)
|
||||||
|
|
||||||
|
Grafx2 is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU General Public License
|
||||||
|
as published by the Free Software Foundation; version 2
|
||||||
|
of the License.
|
||||||
|
|
||||||
|
Grafx2 is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with Grafx2; if not, see <http://www.gnu.org/licenses/>
|
||||||
|
*/
|
||||||
|
|
||||||
|
///@file packbits.c
|
||||||
|
/// Packbits compression as used in IFF etc.
|
||||||
|
/// see http://fileformats.archiveteam.org/wiki/PackBits
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include "struct.h"
|
||||||
|
#include "gfx2log.h"
|
||||||
|
#include "packbits.h"
|
||||||
|
|
||||||
|
int PackBits_unpack_from_file(FILE * f, byte * dest, unsigned int count)
|
||||||
|
{
|
||||||
|
unsigned int i = 0;
|
||||||
|
while (i < count)
|
||||||
|
{
|
||||||
|
byte cmd;
|
||||||
|
if (fread(&cmd, 1, 1, f) != 1)
|
||||||
|
return PACKBITS_UNPACK_READ_ERROR;
|
||||||
|
if (cmd > 128)
|
||||||
|
{
|
||||||
|
// cmd > 128 => repeat (257 - cmd) the next byte
|
||||||
|
byte v;
|
||||||
|
if (fread(&v, 1, 1, f) != 1)
|
||||||
|
return PACKBITS_UNPACK_READ_ERROR;
|
||||||
|
if (count < (i + 257 - cmd))
|
||||||
|
return PACKBITS_UNPACK_OVERFLOW_ERROR;
|
||||||
|
memset(dest + i, v, (257 - cmd));
|
||||||
|
i += (257 - cmd);
|
||||||
|
}
|
||||||
|
else if (cmd < 128)
|
||||||
|
{
|
||||||
|
// cmd < 128 => copy (cmd + 1) bytes
|
||||||
|
if (count < (i + cmd + 1))
|
||||||
|
return PACKBITS_UNPACK_OVERFLOW_ERROR;
|
||||||
|
if (fread(dest + i, 1, (cmd + 1), f) != (unsigned)(cmd + 1))
|
||||||
|
return PACKBITS_UNPACK_READ_ERROR;
|
||||||
|
i += (cmd + 1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// 128 = NOP
|
||||||
|
GFX2_Log(GFX2_WARNING, "NOP in packbits stream\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return PACKBITS_UNPACK_OK;
|
||||||
|
}
|
||||||
41
src/packbits.h
Normal file
41
src/packbits.h
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
/* vim:expandtab:ts=2 sw=2:
|
||||||
|
*/
|
||||||
|
/* Grafx2 - The Ultimate 256-color bitmap paint program
|
||||||
|
|
||||||
|
Copyright 2018-2019 Thomas Bernard
|
||||||
|
Copyright 2008 Yves Rizoud
|
||||||
|
Copyright 2007 Adrien Destugues
|
||||||
|
Copyright 1996-2001 Sunset Design (Guillaume Dorme & Karl Maritaud)
|
||||||
|
|
||||||
|
Grafx2 is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU General Public License
|
||||||
|
as published by the Free Software Foundation; version 2
|
||||||
|
of the License.
|
||||||
|
|
||||||
|
Grafx2 is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with Grafx2; if not, see <http://www.gnu.org/licenses/>
|
||||||
|
*/
|
||||||
|
|
||||||
|
///@file packbits.h
|
||||||
|
/// Packbits compression as used in IFF etc.
|
||||||
|
|
||||||
|
#ifndef PACKBITS_H_INCLUDED
|
||||||
|
#define PACKBITS_H_INCLUDED
|
||||||
|
|
||||||
|
// error codes :
|
||||||
|
|
||||||
|
#define PACKBITS_UNPACK_OK 0
|
||||||
|
#define PACKBITS_UNPACK_READ_ERROR -1
|
||||||
|
#define PACKBITS_UNPACK_OVERFLOW_ERROR -2
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return PACKBITS_UNPACK_OK or PACKBITS_UNPACK_READ_ERROR or PACKBITS_UNPACK_OVERFLOW_ERROR
|
||||||
|
*/
|
||||||
|
int PackBits_unpack_from_file(FILE * f, byte * dest, unsigned int count);
|
||||||
|
|
||||||
|
#endif
|
||||||
@ -33,6 +33,7 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include "../struct.h"
|
#include "../struct.h"
|
||||||
#include "../oldies.h"
|
#include "../oldies.h"
|
||||||
|
#include "../packbits.h"
|
||||||
#include "../gfx2log.h"
|
#include "../gfx2log.h"
|
||||||
|
|
||||||
unsigned int MOTO_MAP_pack(byte * packed, const byte * unpacked, unsigned int unpacked_len);
|
unsigned int MOTO_MAP_pack(byte * packed, const byte * unpacked, unsigned int unpacked_len);
|
||||||
@ -160,6 +161,7 @@ int Test_Packbits(void)
|
|||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
const long best_packed = 7 + 22 + 23;
|
const long best_packed = 7 + 22 + 23;
|
||||||
|
byte buffer[1024];
|
||||||
|
|
||||||
snprintf(tempfilename, sizeof(tempfilename), "/tmp/gfx2test-packbits-%lx", random());
|
snprintf(tempfilename, sizeof(tempfilename), "/tmp/gfx2test-packbits-%lx", random());
|
||||||
GFX2_Log(GFX2_DEBUG, "tempfile %s\n", tempfilename);
|
GFX2_Log(GFX2_DEBUG, "tempfile %s\n", tempfilename);
|
||||||
@ -190,13 +192,30 @@ int Test_Packbits(void)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO : test unpacking
|
// test unpacking
|
||||||
f = fopen(tempfilename, "rb");
|
f = fopen(tempfilename, "rb");
|
||||||
if (f == NULL)
|
if (f == NULL)
|
||||||
{
|
{
|
||||||
GFX2_Log(GFX2_ERROR, "Failed to open %s for reading\n", tempfilename);
|
GFX2_Log(GFX2_ERROR, "Failed to open %s for reading\n", tempfilename);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
for (i = 0; tests[i]; i++)
|
||||||
|
{
|
||||||
|
size_t len = strlen(tests[i]);
|
||||||
|
memset(buffer, 0x80, len);
|
||||||
|
if (PackBits_unpack_from_file(f, buffer, len) != PACKBITS_UNPACK_OK)
|
||||||
|
{
|
||||||
|
GFX2_Log(GFX2_ERROR, "PackBits_unpack_from_file() failed\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (memcmp(buffer, tests[i], len) != 0)
|
||||||
|
{
|
||||||
|
GFX2_Log(GFX2_ERROR, "uncompressed stream mismatch !\n");
|
||||||
|
GFX2_LogHexDump(GFX2_ERROR, "original ", (const byte *)tests[i], 0, len);
|
||||||
|
GFX2_LogHexDump(GFX2_ERROR, "unpacked ", buffer, 0, len);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
fclose(f);
|
fclose(f);
|
||||||
unlink(tempfilename);
|
unlink(tempfilename);
|
||||||
return 1; // test OK
|
return 1; // test OK
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user