int cflag = 0;
int dflag = 0;
int tflag = 0;
+ int sflag = 0;
+ int mflag = 0;
long int volumesize = 0;
int lastchunk,i,j,ch,decoded = 0;
+ char *staticmodel;
- while ((ch = getopt(argc, argv, "cdt:")) != -1) {
+ while ((ch = getopt(argc, argv, "scdm:t:")) != -1) {
switch (ch) {
case 'c': cflag = 1;
volumesize = atoi(optarg);
break;
- default: fprintf(stderr, "Usage: %s [-cdt] sourcefile targetfile\n", argv[0]);
+ case 'm': mflag = 1;
+ staticmodel = optarg;
+ break;
+
+ case 's': sflag = 1;
+ break;
+
+ default: fprintf(stderr, "Usage: %s [-cds] [-t volsizekb] sourcefile targetfile [-m modeldumpfile]\n", argv[0]);
return(2);
}
}
- if ( (argc == 1) || (cflag & dflag) || !(cflag | dflag) || ((argc - optind) < 2) ) {
- fprintf(stderr, "Usage: %s [-cdt] sourcefile targetfile\n", argv[0]);
+ if ( (argc == 1) || (cflag & dflag) || !(cflag | dflag) || ((argc - optind) < 2) || (mflag & sflag)) {
+ fprintf(stderr, "Usage: %s [-cds] [-t volsizekb] sourcefile targetfile [-m modeldumpfile]\n", argv[0]);
if ((tflag == 1) && (volumesize < 0)) fprintf(stderr,"Error: The volume size must be a non-zero value\n");
return (2);
}
if (cflag == 1) {
/* Inicio un compresor huffman estatico por chunks */
if ((shuff = shuff_init_encoder_bychunk(argv[optind+1],volumesize*1024)) == NULL) return 0;
+ if (mflag == 1) shuff_loadmodel(shuff,staticmodel);
/* Comprimo por chunks */
if ((fp = fopen(argv[optind],"rb")) == NULL) return 1;
shuff_scanfreq_chunk(shuff,chunk,i);
}
/* Le indico al huffman que efectivamente comprima los chunks */
- shuff_encode_file(shuff);
+ shuff_encode_file(shuff);
+ if (sflag == 1) shuff_savemodel(shuff);
/* De init encoder */
shuff_deinit_encoder(shuff);