+/*----------------------------------------------------------------------------
+ * jacu - Just Another Compression Utility
+ *----------------------------------------------------------------------------
+ * This file is part of jacu.
+ *
+ * jacu 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; either version 2 of the License, or (at your option) any later
+ * version.
+ *
+ * jacu 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 jacu; if not, write to the Free Software Foundation, Inc., 59 Temple
+ * Place, Suite 330, Boston, MA 02111-1307 USA
+ *----------------------------------------------------------------------------
+ */
+
#include "statichuff.h"
#include <stdlib.h>
int cflag = 0;
int dflag = 0;
int tflag = 0;
+ int mflag = 0;
+ int sflag = 0;
long int volumesize = 0;
int ch;
+ HUFF_STATE *shuff;
+ char *staticmodel = NULL;
- 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 ((tflag == 1) && (volumesize <= 0)) fprintf(stderr,"Error: The volume size must be a non-zero value\n");
+ 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) {
/* Comprimo */
- return shuff_encode_file(argv[optind],argv[optind+1]);
+ shuff = shuff_init_encoder_byfile(argv[optind],argv[optind+1],volumesize*1024);
+ if (mflag == 1) shuff_loadmodel(shuff,staticmodel);
+ shuff_encode_file(shuff);
+ if (sflag == 1) shuff_savemodel(shuff);
+ shuff_deinit_encoder(shuff);
+ free(shuff);
}
if (dflag == 1) {
/* Descomprimo */
- return shuff_decode_file(argv[optind],argv[optind+1]);
+ shuff = shuff_init_decoder(argv[optind],argv[optind+1]);
+ shuff_decode_file(shuff);
+ shuff_deinit_decoder(shuff);
+ free(shuff);
}
return 0;
}
-