代码拉取完成,页面将自动刷新
//hdiffz.cpp
// diff tool
//
/*
The MIT License (MIT)
Copyright (c) 2012-2017 HouSisong
Permission is hereby granted, free of charge, to any person
obtaining a copy of this software and associated documentation
files (the "Software"), to deal in the Software without
restriction, including without limitation the rights to use,
copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the
Software is furnished to do so, subject to the following
conditions:
The above copyright notice and this permission notice shall be
included in all copies of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
OTHER DEALINGS IN THE SOFTWARE.
*/
#include <iostream>
#include <fstream>
#include <string>
#include <vector>
#include <string.h>
#include <stdlib.h>
#include "libHDiffPatch/HDiff/diff.h"
#include "libHDiffPatch/HPatch/patch.h"
#include "_clock_for_demo.h"
#include "_atosize.h"
#include "file_for_patch.h"
#ifndef _IS_NEED_MAIN
# define _IS_NEED_MAIN 1
#endif
#ifndef _IS_NEED_ORIGINAL
# define _IS_NEED_ORIGINAL 1
#endif
#ifndef _IS_NEED_ALL_CompressPlugin
# define _IS_NEED_ALL_CompressPlugin 1
#endif
#if (_IS_NEED_ALL_CompressPlugin)
//===== select needs decompress plugins or change to your plugin=====
# define _CompressPlugin_zlib // memroy requires less
# define _CompressPlugin_bz2
# define _CompressPlugin_lzma // better compresser
# define _CompressPlugin_lz4 // faster compresser/decompresser
# define _CompressPlugin_lz4hc // faster decompresser
# define _CompressPlugin_zstd // better compresser / faster decompresser
#endif
#include "compress_plugin_demo.h"
#include "decompress_plugin_demo.h"
#define _error_return(info){ \
if (strlen(info)>0) \
printf("\n ERROR: %s\n",(info)); \
exitCode=1; \
goto clear; \
}
#define _check_error(is_error,errorInfo){ \
if (is_error){ \
exitCode=1; \
printf("\n ERROR: %s\n",(errorInfo)); \
} \
}
static void printUsage(){
printf("usage: hdiffz [-m[-matchScore]|-s[-matchBlockSize]] [-c-compressType[-compressLevel]] [-d]"
#if (_IS_NEED_ORIGINAL)
" [-o]"
#endif
" oldFile newFile outDiffFile\n"
"usage: hdiffz [-c-compressType[-compressLevel]] diffFile outDiffFile\n"
"memory options:\n"
" -m-matchScore\n"
" all file load into Memory, with matchScore; DEFAULT; best diffFileSize;\n"
" requires (newFileSize+ oldFileSize*5(or *9 when oldFileSize>=2GB))+O(1) bytes of memory;\n"
" matchScore>=0, DEFAULT 6, recommended bin: 0--4 text: 4--9 etc...\n"
" -s-matchBlockSize\n"
" all file load as Stream, with matchBlockSize; fast;\n"
" requires O(oldFileSize*16/matchBlockSize+matchBlockSize*5) bytes of memory;\n"
" matchBlockSize>=2, DEFAULT 128, recommended 32,48,1k,64k,1m etc...\n"
"special options:\n"
" -d Diff only, do't run patch check, DEFAULT run patch check;\n"
" -c-compressType-compressLevel\n"
" set outDiffFile Compress type & level, DEFAULT uncompress;\n"
" for resave diffFile,recompress diffFile to outDiffFile by new set;\n"
" support compress type & level:\n"
" (reference: https://github.com/sisong/lzbench/blob/master/lzbench171_sorted.md )\n"
#ifdef _CompressPlugin_zlib
" -zlib[-{1..9}] DEFAULT level 9\n"
#endif
#ifdef _CompressPlugin_bz2
" -bzip2[-{1..9}] DEFAULT level 9\n"
#endif
#ifdef _CompressPlugin_lzma
" -lzma[-{0..9}[-dictSize]] DEFAULT level 7\n"
" dictSize can like 4096 or 4k or 4m or 128m etc..., DEFAULT 4m\n"
#endif
#ifdef _CompressPlugin_lz4
" -lz4 no level\n"
#endif
#ifdef _CompressPlugin_lz4hc
" -lz4hc[-{3..12}] DEFAULT level 11\n"
#endif
#ifdef _CompressPlugin_zstd
" -zstd[-{0..22}] DEFAULT level 20\n"
#endif
#if (_IS_NEED_ORIGINAL)
" -o Original diff, unsupport run with -s or -c; DEPRECATED;\n"
" compatible with \"diff_demo.cpp\",\n"
" diffFile must patch by \"patch_demo.c\" or \"hpatchz -o ...\"\n"
#endif
);
}
typedef enum THDiffResult {
HDIFF_SUCCESS=0,
HDIFF_OPTIONS_ERROR,
HDIFF_OPENREAD_ERROR,
HDIFF_OPENWRITE_ERROR,
HDIFF_FILECLOSE_ERROR,
HDIFF_MEM_ERROR,
HDIFF_DIFF_ERROR,
HDIFF_PATCH_ERROR,
HDIFF_RESAVE_FILEREAD_ERROR,
HDIFF_RESAVE_HDIFFINFO_ERROR,
HDIFF_RESAVE_COMPRESSTYPE_ERROR,
HDIFF_RESAVE_ERROR,
} THDiffResult;
int hdiff_cmd_line(int argc, const char * argv[]);
int hdiff(const char* oldFileName,const char* newFileName,const char* outDiffFileName,
hpatch_BOOL isOriginal,hpatch_BOOL isLoadAll,hpatch_BOOL isPatchCheck,size_t matchValue,
hdiff_TStreamCompress* streamCompressPlugin,hdiff_TCompress* compressPlugin,
hpatch_TDecompress* decompressPlugin);
int hdiff_resave(const char* diffFileName,const char* outDiffFileName,
hdiff_TStreamCompress* streamCompressPlugin);
#if (_IS_NEED_MAIN)
int main(int argc, const char * argv[]){
return hdiff_cmd_line(argc,argv);
}
#endif
hpatch_inline static const char* find(const char* str,char c){
const char* result=strchr(str,c);
return (result!=0)?result:(str+strlen(str));
}
static bool _trySetCompress(hdiff_TStreamCompress** streamCompressPlugin,
hdiff_TCompress** compressPlugin,hpatch_TDecompress** decompressPlugin,
hdiff_TStreamCompress* _streamCompressPlugin,
hdiff_TCompress* _compressPlugin,hpatch_TDecompress* _decompressPlugin,
const char* ptype,const char* ptypeEnd,const char* ctype,
size_t* compressLevel=0,size_t levelMin=0,size_t levelMax=0,size_t levelDefault=0,
size_t* dictSize=0,size_t dictSizeMin=0,size_t dictSizeMax=0,size_t dictSizeDefault=0){
if ((*compressPlugin)!=0) return true;
const size_t ctypeLen=strlen(ctype);
if ((ctypeLen!=(size_t)(ptypeEnd-ptype))||(0!=strncmp(ptype,ctype,ctypeLen))) return true;
*streamCompressPlugin=_streamCompressPlugin;
*compressPlugin=_compressPlugin;
*decompressPlugin=_decompressPlugin;
if ((compressLevel)&&(ptypeEnd[0]=='-')){
const char* plevel=ptypeEnd+1;
const char* plevelEnd=find(plevel,'-');
if (!a_to_size(plevel,plevelEnd-plevel,compressLevel)) return false; //error
if (*compressLevel<levelMin) *compressLevel=levelMin;
else if (*compressLevel>levelMax) *compressLevel=levelMax;
if ((dictSize)&&(plevelEnd[0]=='-')){
const char* pdictSize=plevelEnd+1;
const char* pdictSizeEnd=find(pdictSize,'-');
if (!kmg_to_size(pdictSize,pdictSizeEnd-pdictSize,dictSize)) return false; //error
if (*dictSize<dictSizeMin) *dictSize=dictSizeMin;
else if (*dictSize>dictSizeMax) *dictSize=dictSizeMax;
}else{
if (plevelEnd[0]!='\0') return false; //error
if (dictSize) *dictSize=dictSizeDefault;
}
}else{
if (ptypeEnd[0]!='\0') return false; //error
if (compressLevel) *compressLevel=levelDefault;
if (dictSize) *dictSize=dictSizeDefault;
}
return true;
}
#define _options_check(value,errorInfo){ \
if (!(value)) { printf("options " errorInfo " ERROR!\n"); printUsage(); return HDIFF_OPTIONS_ERROR; } }
#define _kNULL_VALUE (-1)
int hdiff_cmd_line(int argc, const char * argv[]){
hpatch_BOOL isOriginal=_kNULL_VALUE;
hpatch_BOOL isLoadAll=_kNULL_VALUE;
hpatch_BOOL isPatchCheck=_kNULL_VALUE;
size_t matchValue=0;
size_t compressLevel=0;
#ifdef _CompressPlugin_lzma
size_t dictSize=0;
#endif
hdiff_TStreamCompress* streamCompressPlugin=0;
hdiff_TCompress* compressPlugin=0;
hpatch_TDecompress* decompressPlugin=0;
std::vector<const char *> arg_values;
for (int i=1; i<argc; ++i) {
const char* op=argv[i];
_options_check((op!=0)||(strlen(op)==0),"?");
if (op[0]!='-'){
arg_values.push_back(op); //filename
continue;
}
switch (op[1]) {
#if (_IS_NEED_ORIGINAL)
case 'o':{
_options_check((isOriginal==_kNULL_VALUE)&&(op[2]=='\0'),"-o");
isOriginal=hpatch_TRUE;
} break;
#endif
case 'm':{
_options_check((isLoadAll==_kNULL_VALUE)&&((op[2]=='-')||(op[2]=='\0')),"-m");
isLoadAll=hpatch_TRUE;
if (op[2]=='-'){
const char* pnum=op+3;
_options_check(kmg_to_size(pnum,strlen(pnum),&matchValue),"-m-?");
}else{
matchValue=kMinSingleMatchScore_default;
}
} break;
case 's':{
isLoadAll=hpatch_FALSE; //stream
if (op[2]=='-'){
const char* pnum=op+3;
_options_check(kmg_to_size(pnum,strlen(pnum),&matchValue),"-s-?");
}else{
matchValue=kMatchBlockSize_default;
}
} break;
case 'd':{
_options_check((isPatchCheck==_kNULL_VALUE)&&(op[2]=='\0'),"-d");
isPatchCheck=hpatch_FALSE; //diff only
} break;
case 'c':{
_options_check((compressPlugin==0)&&(op[2]=='-'),"-c");
const char* ptype=op+3;
const char* ptypeEnd=find(ptype,'-');
#ifdef _CompressPlugin_zlib
_options_check(_trySetCompress(&streamCompressPlugin,&compressPlugin,&decompressPlugin,
&zlibStreamCompressPlugin,&zlibCompressPlugin,&zlibDecompressPlugin,
ptype,ptypeEnd,"zlib" ,&compressLevel,1,9,9),"-c-zlib-?");
if (compressPlugin==&zlibCompressPlugin) { zlib_compress_level=(int)compressLevel; }
#endif
#ifdef _CompressPlugin_bz2
_options_check(_trySetCompress(&streamCompressPlugin,&compressPlugin,&decompressPlugin,
&bz2StreamCompressPlugin,&bz2CompressPlugin,&bz2DecompressPlugin,
ptype,ptypeEnd,"bzip2",&compressLevel,1,9,9),"-c-bzip2-?");
if (compressPlugin==&bz2CompressPlugin) { bz2_compress_level=(int)compressLevel; }
#endif
#ifdef _CompressPlugin_lzma
_options_check(_trySetCompress(&streamCompressPlugin,&compressPlugin,&decompressPlugin,
&lzmaStreamCompressPlugin,&lzmaCompressPlugin,&lzmaDecompressPlugin,
ptype,ptypeEnd,"lzma" ,&compressLevel,0,9,7,
&dictSize,1<<12,(sizeof(size_t)<=4)?(1<<27):((size_t)3<<29),1<<22),"-c-lzma-?");
if (compressPlugin==&lzmaCompressPlugin) {
lzma_compress_level=(int)compressLevel; lzma_dictSize=(UInt32)dictSize; }
#endif
#ifdef _CompressPlugin_lz4
_options_check(_trySetCompress(&streamCompressPlugin,&compressPlugin,&decompressPlugin,
&lz4StreamCompressPlugin,&lz4CompressPlugin,&lz4DecompressPlugin,
ptype,ptypeEnd,"lz4" ),"-c-lz4-?");
#endif
#ifdef _CompressPlugin_lz4hc
_options_check(_trySetCompress(&streamCompressPlugin,&compressPlugin,&decompressPlugin,
&lz4hcStreamCompressPlugin,&lz4hcCompressPlugin,&lz4DecompressPlugin,
ptype,ptypeEnd,"lz4hc",&compressLevel,3,12,11),"-c-lz4hc-?");
if (compressPlugin==&lz4hcCompressPlugin) { lz4hc_compress_level=(int)compressLevel; }
#endif
#ifdef _CompressPlugin_zstd
_options_check(_trySetCompress(&streamCompressPlugin,&compressPlugin,&decompressPlugin,
&zstdStreamCompressPlugin,&zstdCompressPlugin,&zstdDecompressPlugin,
ptype,ptypeEnd,"zstd" ,&compressLevel,0,22,20),"-c-zstd-?");
if (compressPlugin==&zstdCompressPlugin) { zstd_compress_level=(int)compressLevel; }
#endif
_options_check(compressPlugin!=0,"-c-?");
} break;
default: {
_options_check(hpatch_FALSE,"-?");
} break;
}//swich
}
_options_check((arg_values.size()==2)||(arg_values.size()==3),"count");
if (arg_values.size()==3){
if (isOriginal==_kNULL_VALUE)
isOriginal=hpatch_FALSE;
if (isOriginal){
_options_check((isLoadAll!=hpatch_FALSE)&&(compressPlugin==0),
"-o unsupport run with -s or -c");
}
if (isLoadAll==_kNULL_VALUE){
isLoadAll=hpatch_TRUE;
matchValue=kMinSingleMatchScore_default;
}
if (isPatchCheck==_kNULL_VALUE){
#if (defined(_IS_NEED_PATCH_CHECK) && (_IS_NEED_PATCH_CHECK==0))
isPatchCheck=hpatch_FALSE;
#else
isPatchCheck=hpatch_TRUE;
#endif
}
const char* oldFileName =arg_values[0];
const char* newFileName =arg_values[1];
const char* outDiffFileName=arg_values[2];
return hdiff(oldFileName,newFileName,outDiffFileName,isOriginal,isLoadAll,isPatchCheck,
matchValue,streamCompressPlugin,compressPlugin,decompressPlugin);
}else{ //resave
_options_check((isOriginal==_kNULL_VALUE),"-o unsupport run with resave mode");
_options_check((isLoadAll==_kNULL_VALUE),"-m or -s unsupport run with resave mode");
_options_check((isPatchCheck==_kNULL_VALUE),"-d unsupport run with resave mode");
const char* diffFileName =arg_values[0];
const char* outDiffFileName=arg_values[1];
return hdiff_resave(diffFileName,outDiffFileName,streamCompressPlugin);
}
}
static hpatch_BOOL readFileAll(TByte** out_pdata,size_t* out_dataSize,const char* fileName){
size_t dataSize;
hpatch_StreamPos_t file_length=0;
FILE* file=0;
assert((*out_pdata)==0);
if (!fileOpenForRead(fileName,&file,&file_length)) _file_error(file);
dataSize=(size_t)file_length;
if (dataSize!=file_length) _file_error(file);
*out_pdata=(TByte*)malloc(dataSize);
if (*out_pdata==0) _file_error(file);
*out_dataSize=dataSize;
if (!fileRead(file,*out_pdata,(*out_pdata)+dataSize)) _file_error(file);
return fileClose(&file);
}
#define _free_mem(p) { if (p) { free(p); p=0; } }
static hpatch_BOOL writeFileAll(const TByte* pdata,size_t dataSize,const char* outFileName){
FILE* file=0;
if (!fileOpenForCreateOrReWrite(outFileName,&file)) _file_error(file);
if (!fileWrite(file,pdata,pdata+dataSize)) _file_error(file);
return fileClose(&file);
}
#if (_IS_NEED_ORIGINAL)
static int saveSize(std::vector<TByte>& outBuf,hpatch_StreamPos_t size){
outBuf.push_back((TByte)size);
outBuf.push_back((TByte)(size>>8));
outBuf.push_back((TByte)(size>>16));
int writedSize;
if ((size>>31)==0){
writedSize=4;
outBuf.push_back((TByte)(size>>24));
}else{
writedSize=9;
outBuf.push_back(0xFF);
outBuf.push_back((TByte)(size>>24));
const hpatch_StreamPos_t highSize=(size>>32);
outBuf.push_back((TByte)highSize);
outBuf.push_back((TByte)(highSize>>8));
outBuf.push_back((TByte)(highSize>>16));
outBuf.push_back((TByte)(highSize>>24));
}
return writedSize;
}
#endif
#define check_on_error(errorType) { \
if (result==HDIFF_SUCCESS) result=errorType; if (!_isInClear){ goto clear; } }
#define check(value,errorType,errorInfo) { \
if (!(value)){ printf(errorInfo); check_on_error(errorType); } }
static int hdiff_m(const char* oldFileName,const char* newFileName,const char* outDiffFileName,
hpatch_BOOL isOriginal,hpatch_BOOL isPatchCheck,size_t matchScore,
hdiff_TCompress* compressPlugin,hpatch_TDecompress* decompressPlugin){
double diff_time0=clock_s();
int result=HDIFF_SUCCESS;
int _isInClear=hpatch_FALSE;
TByte* oldData=0; size_t oldDataSize=0;
TByte* newData=0; size_t newDataSize=0;
size_t originalNewDataSavedSize=0;
std::vector<TByte> diffData;
check(readFileAll(&oldData,&oldDataSize,oldFileName),HDIFF_OPENREAD_ERROR,"open oldFile ERROR!");
check(readFileAll(&newData,&newDataSize,newFileName),HDIFF_OPENREAD_ERROR,"open newFile ERROR!");
std::cout<<"oldDataSize : "<<oldDataSize<<"\nnewDataSize : "<<newDataSize<<"\n";
try {
if (isOriginal){
originalNewDataSavedSize=saveSize(diffData,newDataSize);
create_diff(newData,newData+newDataSize,oldData,oldData+oldDataSize,diffData,(int)matchScore);
}else{
create_compressed_diff(newData,newData+newDataSize,oldData,oldData+oldDataSize,
diffData,compressPlugin,(int)matchScore);
}
}catch(const std::exception& e){
std::cout<<"diff run ERROR! "<<e.what()<<"\n";
check_on_error(HDIFF_DIFF_ERROR);
}
std::cout<<"diffDataSize: "<<diffData.size()<<"\n";
check(writeFileAll(diffData.data(),diffData.size(),outDiffFileName),
HDIFF_OPENWRITE_ERROR,"open write diffFile ERROR!");
std::cout<<" out hdiffz file ok!\n";
std::cout<<"diff time: "<<(clock_s()-diff_time0)<<" s\n";
if (isPatchCheck){
double patch_time0=clock_s();
bool diffrt;
if (isOriginal){
diffrt=check_diff(newData,newData+newDataSize,oldData,oldData+oldDataSize,
diffData.data()+originalNewDataSavedSize,diffData.data()+diffData.size());
}else{
diffrt=check_compressed_diff(newData,newData+newDataSize,oldData,oldData+oldDataSize,
diffData.data(),diffData.data()+diffData.size(),decompressPlugin);
}
check(diffrt,HDIFF_PATCH_ERROR,"patch check hdiffz data ERROR!\n");
std::cout<<"patch time: "<<(clock_s()-patch_time0)<<" s\n";
std::cout<<" patch check hdiffz data ok!\n";
}
clear:
_isInClear=hpatch_TRUE;
_free_mem(newData);
_free_mem(oldData);
return result;
}
static int hdiff_s(const char* oldFileName,const char* newFileName,const char* outDiffFileName,
hpatch_BOOL isPatchCheck,size_t matchBlockSize,
hdiff_TStreamCompress* streamCompressPlugin,hpatch_TDecompress* decompressPlugin){
double diff_time0=clock_s();
int result=HDIFF_SUCCESS;
int _isInClear=hpatch_FALSE;
TFileStreamInput oldData;
TFileStreamInput newData;
TFileStreamOutput diffData;
TFileStreamInput diffData_in;
TFileStreamInput_init(&oldData);
TFileStreamInput_init(&newData);
TFileStreamOutput_init(&diffData);
TFileStreamInput_init(&diffData_in);
check(TFileStreamInput_open(&oldData,oldFileName),HDIFF_OPENREAD_ERROR,"open oldFile ERROR!");
check(TFileStreamInput_open(&newData,newFileName),HDIFF_OPENREAD_ERROR,"open newFile ERROR!");
check(TFileStreamOutput_open(&diffData,outDiffFileName,-1),HDIFF_OPENWRITE_ERROR,"open out diffFile ERROR!");
TFileStreamOutput_setRandomOut(&diffData,hpatch_TRUE);
std::cout<<"oldDataSize : "<<oldData.base.streamSize<<"\nnewDataSize : "<<newData.base.streamSize<<"\n";
try{
create_compressed_diff_stream(&newData.base,&oldData.base, &diffData.base,
streamCompressPlugin,matchBlockSize);
diffData.base.streamSize=diffData.out_length;
}catch(const std::exception& e){
std::cout<<"diff run ERROR! "<<e.what()<<"\n";
check_on_error(HDIFF_DIFF_ERROR);
}
check(TFileStreamOutput_close(&diffData),HDIFF_FILECLOSE_ERROR,"out diffFile close ERROR!");
std::cout<<"diffDataSize: "<<diffData.base.streamSize<<"\n";
std::cout<<" out hdiffz file ok!\n";
std::cout<<"diff time: "<<(clock_s()-diff_time0)<<" s\n";
if (isPatchCheck){
double patch_time0=clock_s();
check(TFileStreamInput_open(&diffData_in,outDiffFileName),HDIFF_OPENREAD_ERROR,"open check diffFile ERROR!");
check(check_compressed_diff_stream(&newData.base,&oldData.base,
&diffData_in.base,decompressPlugin),
HDIFF_PATCH_ERROR,"patch check hdiffz data ERROR!!!");
std::cout<<"patch time: "<<(clock_s()-patch_time0)<<" s\n";
std::cout<<" patch check hdiffz data ok!\n";
}
clear:
_isInClear=hpatch_TRUE;
check(TFileStreamOutput_close(&diffData),HDIFF_FILECLOSE_ERROR,"out diffFile close ERROR!");
check(TFileStreamInput_close(&diffData_in),HDIFF_FILECLOSE_ERROR,"check diffFile close ERROR!");
check(TFileStreamInput_close(&newData),HDIFF_FILECLOSE_ERROR,"newFile close ERROR!");
check(TFileStreamInput_close(&oldData),HDIFF_FILECLOSE_ERROR,"oldFile close ERROR!");
return result;
}
int hdiff(const char* oldFileName,const char* newFileName,const char* outDiffFileName,
hpatch_BOOL isOriginal,hpatch_BOOL isLoadAll,hpatch_BOOL isPatchCheck,size_t matchValue,
hdiff_TStreamCompress* streamCompressPlugin,hdiff_TCompress* compressPlugin,hpatch_TDecompress* decompressPlugin){
double time0=clock_s();
std::cout<<"old: \"" <<oldFileName<< "\"\nnew: \""<<newFileName<<"\"\nout: \""<<outDiffFileName<<"\"\n";
const char* compressType="";
if (isLoadAll){
if (compressPlugin) compressType=compressPlugin->compressType(compressPlugin);
}else{
if (streamCompressPlugin) compressType=streamCompressPlugin->compressType(streamCompressPlugin);
}
std::cout<<"hdiffz run with "<<(isLoadAll?"":"stream ")<<"compress plugin: \""<<compressType<<"\"\n";
int exitCode;
if (isLoadAll){
exitCode=hdiff_m(oldFileName,newFileName,outDiffFileName,isOriginal,isPatchCheck,
matchValue,compressPlugin,decompressPlugin);
}else{
exitCode=hdiff_s(oldFileName,newFileName,outDiffFileName,isPatchCheck,
matchValue,streamCompressPlugin,decompressPlugin);
}
if (isPatchCheck)
std::cout<<"\nall time: "<<(clock_s()-time0)<<" s\n";
return exitCode;
}
static int hdiff_r(const char* diffFileName,const char* outDiffFileName,
hdiff_TStreamCompress* streamCompressPlugin){
int result=HDIFF_SUCCESS;
int _isInClear=hpatch_FALSE;
TFileStreamInput diffData_in;
TFileStreamOutput diffData_out;
TFileStreamInput_init(&diffData_in);
TFileStreamOutput_init(&diffData_out);
hpatch_TDecompress* decompressPlugin=0;
check(TFileStreamInput_open(&diffData_in,diffFileName),HDIFF_OPENREAD_ERROR,"open diffFile ERROR!");
{
hpatch_compressedDiffInfo diffInfo;
if (!getCompressedDiffInfo(&diffInfo,&diffData_in.base)){
check(!diffData_in.fileError,HDIFF_RESAVE_FILEREAD_ERROR,"read diffFile ERROR!\n");
check(hpatch_FALSE,HDIFF_RESAVE_HDIFFINFO_ERROR,"is hdiff file? getCompressedDiffInfo() ERROR!\n");
}
if (strlen(diffInfo.compressType)>0){
#ifdef _CompressPlugin_zlib
if ((!decompressPlugin)&&zlibDecompressPlugin.is_can_open(&zlibDecompressPlugin,&diffInfo))
decompressPlugin=&zlibDecompressPlugin;
#endif
#ifdef _CompressPlugin_bz2
if ((!decompressPlugin)&&bz2DecompressPlugin.is_can_open(&bz2DecompressPlugin,&diffInfo))
decompressPlugin=&bz2DecompressPlugin;
#endif
#ifdef _CompressPlugin_lzma
if ((!decompressPlugin)&&lzmaDecompressPlugin.is_can_open(&lzmaDecompressPlugin,&diffInfo))
decompressPlugin=&lzmaDecompressPlugin;
#endif
#if (defined(_CompressPlugin_lz4) || (defined(_CompressPlugin_lz4hc)))
if ((!decompressPlugin)&&lz4DecompressPlugin.is_can_open(&lz4DecompressPlugin,&diffInfo))
decompressPlugin=&lz4DecompressPlugin;
#endif
#ifdef _CompressPlugin_zstd
if ((!decompressPlugin)&&zstdDecompressPlugin.is_can_open(&zstdDecompressPlugin,&diffInfo))
decompressPlugin=&zstdDecompressPlugin;
#endif
}
if (!decompressPlugin){
if (diffInfo.compressedCount>0){
printf("can no decompress \"%s\" data ERROR!\n",diffInfo.compressType);
check_on_error(HDIFF_RESAVE_COMPRESSTYPE_ERROR);
}else{
if (strlen(diffInfo.compressType)>0)
printf(" diffFile added useless compress tag \"%s\"\n",diffInfo.compressType);
decompressPlugin=0;
}
}else{
printf("resave diffFile with decompress plugin: \"%s\" (need decompress %d)\n",
diffInfo.compressType,diffInfo.compressedCount);
}
}
check(TFileStreamOutput_open(&diffData_out,outDiffFileName,-1),HDIFF_OPENWRITE_ERROR,"open out diffFile ERROR!");
TFileStreamOutput_setRandomOut(&diffData_out,hpatch_TRUE);
std::cout<<"inDiffSize : "<<diffData_in.base.streamSize<<"\n";
try{
resave_compressed_diff(&diffData_in.base,decompressPlugin,&diffData_out.base,streamCompressPlugin);
diffData_out.base.streamSize=diffData_out.out_length;
}catch(const std::exception& e){
std::cout<<"resave diffFile run ERROR! "<<e.what()<<"\n";
check_on_error(HDIFF_RESAVE_ERROR);
}
check(TFileStreamOutput_close(&diffData_out),HDIFF_FILECLOSE_ERROR,"out diffFile close ERROR!");
std::cout<<"outDiffSize: "<<diffData_out.base.streamSize<<"\n";
std::cout<<" out diff file ok!\n";
clear:
_isInClear=hpatch_TRUE;
check(TFileStreamOutput_close(&diffData_out),HDIFF_FILECLOSE_ERROR,"out diffFile close ERROR!");
check(TFileStreamInput_close(&diffData_in),HDIFF_FILECLOSE_ERROR,"in diffFile close ERROR!");
return result;
}
int hdiff_resave(const char* diffFileName,const char* outDiffFileName,
hdiff_TStreamCompress* streamCompressPlugin){
double time0=clock_s();
std::cout<<"in_diff : \"" <<diffFileName<< "\"\nout_diff: \""<<outDiffFileName<<"\n";
const char* compressType="";
if (streamCompressPlugin) compressType=streamCompressPlugin->compressType(streamCompressPlugin);
std::cout<<"resave diffFile with stream compress plugin: \""<<compressType<<"\"\n";
int exitCode=hdiff_r(diffFileName,outDiffFileName,streamCompressPlugin);
double time1=clock_s();
std::cout<<"\nhdiffz resave diffFile time: "<<(time1-time0)<<" s\n";
return exitCode;
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。