wok-current diff lzma/stuff/lzlib.u @ rev 1295

Up: ntfs-3g (1.2812)
author Christophe Lincoln <pankso@slitaz.org>
date Thu Aug 21 15:40:29 2008 +0200 (2008-08-21)
parents
children
line diff
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/lzma/stuff/lzlib.u	Thu Aug 21 15:40:29 2008 +0200
     1.3 @@ -0,0 +1,202 @@
     1.4 +--- CPP/7zip/Compress/LZMA_Alone/makefile.gcc
     1.5 ++++ CPP/7zip/Compress/LZMA_Alone/makefile.gcc
     1.6 +@@ -1,6 +1,6 @@
     1.7 + PROG = lzma
     1.8 +-CXX = g++ -O2 -Wall
     1.9 +-CXX_C = gcc -O2 -Wall
    1.10 ++CXX = g++ -s -O2 -Wall
    1.11 ++CXX_C = gcc -s -O2 -Wall
    1.12 + LIB = -lm
    1.13 + RM = rm -f
    1.14 + CFLAGS = -c
    1.15 +@@ -46,8 +46,47 @@
    1.16 +   LzmaDecode.o \
    1.17 +   LzmaRamDecode.o \
    1.18 + 
    1.19 ++LIB = liblz.so.1.0.0
    1.20 ++LIB_OBJS = \
    1.21 ++  LzmaRamDecode.o \
    1.22 ++  LzmaDecode.o \
    1.23 ++  BranchX86.o \
    1.24 ++  Wrapper.o \
    1.25 ++  
    1.26 ++SHARED_OBJS = \
    1.27 ++  LzmaAlone.o \
    1.28 ++  LzmaBench.o \
    1.29 ++  LzmaBenchCon.o \
    1.30 ++  LZMADecoder.o \
    1.31 ++  LZMAEncoder.o \
    1.32 ++  LzmaRam.o \
    1.33 ++  InBuffer.o \
    1.34 ++  OutBuffer.o \
    1.35 ++  CRC.o \
    1.36 ++  IntToString.o \
    1.37 ++  MyString.o \
    1.38 ++  StringConvert.o \
    1.39 ++  StringToInt.o \
    1.40 ++  MyVector.o \
    1.41 ++  7zCrc.o \
    1.42 ++  Alloc.o \
    1.43 ++  MatchFinder.o \
    1.44 ++  StreamUtils.o \
    1.45 ++  LZOutWindow.o \
    1.46 ++  RangeCoderBit.o \
    1.47 ++  FileStreams.o \
    1.48 ++  $(FILE_IO).o \
    1.49 ++  CommandLineParser.o \
    1.50 ++
    1.51 ++all: $(PROG) $(LIB)
    1.52 ++
    1.53 ++$(LIB): $(LIB_OBJS)
    1.54 ++	$(CXX) -shared -Wl,-soname -Wl,liblz.so.1 -o $(LIB) $(LIB_OBJS) -lz
    1.55 ++	$(CXX) $(LDFLAGS) -o lzma-shared $(SHARED_OBJS) liblz.so.1.0.0 $(LIB) $(LIB2)
    1.56 ++
    1.57 ++Wrapper.o: Wrapper.c
    1.58 ++	$(CXX_C) $(CFLAGS) Wrapper.c
    1.59 + 
    1.60 +-all: $(PROG)
    1.61 + 
    1.62 + $(PROG): $(OBJS)
    1.63 + 	$(CXX) -o $(PROG) $(LDFLAGS) $(OBJS) $(LIB) $(LIB2)
    1.64 +	
    1.65 +--- CPP/7zip/Compress/LZMA_Alone/lzlib.h
    1.66 ++++ CPP/7zip/Compress/LZMA_Alone/lzlib.h
    1.67 +@@ -0,0 +1,15 @@
    1.68 ++#ifndef LZLIB_H
    1.69 ++#define LZLIB_H
    1.70 ++#include <zlib.h>
    1.71 ++typedef struct {
    1.72 ++	int handlertype;
    1.73 ++	unsigned long lzsize;
    1.74 ++	int fd;
    1.75 ++	gzFile gzfd;
    1.76 ++} *lzFile;
    1.77 ++
    1.78 ++extern lzFile lzdopen(int fd, const char *mode);
    1.79 ++extern lzFile lzopen(const char *path, const char *mode);
    1.80 ++extern void *lzgrab(lzFile file, unsigned long *size);
    1.81 ++extern int lzclose(lzFile file);
    1.82 ++#endif
    1.83 +
    1.84 +--- CPP/7zip/Compress/LZMA_Alone/Wrapper.c
    1.85 ++++ CPP/7zip/Compress/LZMA_Alone/Wrapper.c
    1.86 +@@ -0,0 +1,119 @@
    1.87 ++#include <stdlib.h>
    1.88 ++#include <unistd.h>
    1.89 ++#include <sys/types.h>
    1.90 ++#include <sys/stat.h>
    1.91 ++#include <fcntl.h>
    1.92 ++#include "lzlib.h"
    1.93 ++#include "LzmaRamDecode.h"
    1.94 ++
    1.95 ++#define LZ_READ		0
    1.96 ++#define LZ_GZREAD	1
    1.97 ++#define LZ_LZREAD	2
    1.98 ++
    1.99 ++#define LZMA_PROP	0x5d
   1.100 ++
   1.101 ++static int fullread(int fd, unsigned char *buffer, size_t len)
   1.102 ++{
   1.103 ++	int i, n;
   1.104 ++	for (n = 0; (i = read(fd, buffer + n, len - n)) > 0; n += i);
   1.105 ++	return n;
   1.106 ++}
   1.107 ++
   1.108 ++lzFile lzdopen(int fd, const char *mode)
   1.109 ++{
   1.110 ++	unsigned char tmp[13];
   1.111 ++	int n;
   1.112 ++	lzFile lzfd;
   1.113 ++	
   1.114 ++	if (fd < 0) return NULL;
   1.115 ++	n = fullread(fd, tmp, sizeof(tmp));
   1.116 ++	lzfd = malloc(sizeof(*lzfd));
   1.117 ++	if (!lzfd) return NULL;
   1.118 ++	lzfd->handlertype = LZ_READ;
   1.119 ++	if (n == sizeof(tmp) && tmp[0] == LZMA_PROP && 
   1.120 ++	    !LzmaRamGetUncompressedSize(tmp-1, sizeof(tmp)+1, &lzfd->lzsize))
   1.121 ++	    	lzfd->handlertype = LZ_LZREAD;
   1.122 ++	else if (n > 2 && tmp[0] == 0x1F && tmp[1] == 0x8B)
   1.123 ++		lzfd->handlertype = LZ_GZREAD;
   1.124 ++	lzfd->fd = fd;
   1.125 ++	lseek(fd, 0, SEEK_SET);
   1.126 ++	if (lzfd->handlertype != LZ_LZREAD) {
   1.127 ++		if (lzfd->handlertype == LZ_GZREAD) {
   1.128 ++			lzfd->gzfd = gzdopen(fd, mode);
   1.129 ++			if (lzfd->gzfd == Z_NULL) {
   1.130 ++				free(lzfd);
   1.131 ++				return NULL;
   1.132 ++			}
   1.133 ++		}
   1.134 ++	}
   1.135 ++	return lzfd;
   1.136 ++}
   1.137 ++
   1.138 ++lzFile lzopen(const char *path, const char *mode)
   1.139 ++{
   1.140 ++	int fd = open(path, O_RDONLY);
   1.141 ++	return lzdopen(fd, mode);
   1.142 ++}
   1.143 ++
   1.144 ++static int lzread(lzFile file, void *buf, unsigned len)
   1.145 ++{
   1.146 ++	if (file->handlertype == LZ_GZREAD)
   1.147 ++		return gzread(file->gzfd, buf, len);
   1.148 ++	return read(file->fd, buf, len);
   1.149 ++}
   1.150 ++
   1.151 ++void *lzgrab(lzFile file, unsigned long *size)
   1.152 ++{
   1.153 ++	unsigned int n, max;
   1.154 ++	unsigned char *output;
   1.155 ++	
   1.156 ++	if (!file) return NULL;
   1.157 ++	if (file->handlertype == LZ_LZREAD) {
   1.158 ++		unsigned char *input;
   1.159 ++		size_t outsize;
   1.160 ++
   1.161 ++		output = malloc(file->lzsize + file->lzsize/20); // 105%
   1.162 ++		if (!output) return NULL;
   1.163 ++		output[0] = 0;
   1.164 ++		max = 1 + fullread(file->fd, output+1, file->lzsize);
   1.165 ++		input = realloc(output, max);
   1.166 ++		output = malloc(file->lzsize);
   1.167 ++		if (!output || LzmaRamDecompress(input, max,
   1.168 ++		     output, file->lzsize, &outsize, malloc, free)) {
   1.169 ++			if (output) free(output);
   1.170 ++			free(input);
   1.171 ++			return NULL;
   1.172 ++		}
   1.173 ++		free(input);
   1.174 ++		*size = outsize;
   1.175 ++		return output;
   1.176 ++	}
   1.177 ++	max = 16384;
   1.178 ++	output = malloc(max);
   1.179 ++	if (!output) return NULL;
   1.180 ++	*size = 0;
   1.181 ++	while ((n = lzread(file, output + *size, max - *size)) > 0) {
   1.182 ++		*size += n;
   1.183 ++		if (*size == max) {
   1.184 ++			output = realloc(output, max *= 2);
   1.185 ++			if (!output) return NULL;
   1.186 ++		}
   1.187 ++	}
   1.188 ++	if (n < 0) {
   1.189 ++		free(output);
   1.190 ++		return NULL;
   1.191 ++        }
   1.192 ++	return realloc(output, *size);
   1.193 ++}
   1.194 ++
   1.195 ++int lzclose(lzFile file)
   1.196 ++{
   1.197 ++	int status = -1;
   1.198 ++	if (file) {
   1.199 ++		if (file->handlertype == LZ_GZREAD)
   1.200 ++			status = gzclose(file->gzfd);
   1.201 ++		else	status = close(file->fd);
   1.202 ++		free(file);
   1.203 ++	}
   1.204 ++	return status;
   1.205 ++}