]> icculus.org git repositories - icculus/xz.git/blob - debug/full_flush.c
Sort of garbage collection commit. :-| Many things are still
[icculus/xz.git] / debug / full_flush.c
1 ///////////////////////////////////////////////////////////////////////////////
2 //
3 /// \file       full_flush.c
4 /// \brief      Encode files using LZMA_FULL_FLUSH
5 //
6 //  Copyright (C) 2008 Lasse Collin
7 //
8 //  This library is free software; you can redistribute it and/or
9 //  modify it under the terms of the GNU Lesser General Public
10 //  License as published by the Free Software Foundation; either
11 //  version 2.1 of the License, or (at your option) any later version.
12 //
13 //  This library is distributed in the hope that it will be useful,
14 //  but WITHOUT ANY WARRANTY; without even the implied warranty of
15 //  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16 //  Lesser General Public License for more details.
17 //
18 ///////////////////////////////////////////////////////////////////////////////
19
20 #include "sysdefs.h"
21 #include <stdio.h>
22
23
24 static lzma_stream strm = LZMA_STREAM_INIT;
25 static FILE *file_in;
26
27
28 static void
29 encode(size_t size, lzma_action action)
30 {
31         static const size_t CHUNK = 64;
32         uint8_t in[CHUNK];
33         uint8_t out[CHUNK];
34         lzma_ret ret;
35
36         do {
37                 if (strm.avail_in == 0 && size > 0) {
38                         const size_t amount = MIN(size, CHUNK);
39                         strm.avail_in = fread(in, 1, amount, file_in);
40                         strm.next_in = in;
41                         size -= amount; // Intentionally not using avail_in.
42                 }
43
44                 strm.next_out = out;
45                 strm.avail_out = CHUNK;
46
47                 ret = lzma_code(&strm, size == 0 ? action : LZMA_RUN);
48
49                 if (ret != LZMA_OK && ret != LZMA_STREAM_END) {
50                         fprintf(stderr, "%s:%u: %s: ret == %d\n",
51                                         __FILE__, __LINE__, __func__, ret);
52                         exit(1);
53                 }
54
55                 fwrite(out, 1, CHUNK - strm.avail_out, stdout);
56
57         } while (size > 0 || strm.avail_out == 0);
58
59         if ((action == LZMA_RUN && ret != LZMA_OK)
60                         || (action != LZMA_RUN && ret != LZMA_STREAM_END)) {
61                 fprintf(stderr, "%s:%u: %s: ret == %d\n",
62                                 __FILE__, __LINE__, __func__, ret);
63                 exit(1);
64         }
65 }
66
67
68 int
69 main(int argc, char **argv)
70 {
71         lzma_init_encoder();
72
73         file_in = argc > 1 ? fopen(argv[1], "rb") : stdin;
74
75
76         // Config
77         lzma_filter filters[LZMA_BLOCK_FILTERS_MAX + 1];
78         filters[0].id = LZMA_FILTER_LZMA2;
79         filters[0].options = (void *)&lzma_preset_lzma[0];
80         filters[1].id = LZMA_VLI_VALUE_UNKNOWN;
81
82         // Init
83         if (lzma_stream_encoder(&strm, filters, LZMA_CHECK_SHA256) != LZMA_OK) {
84                 fprintf(stderr, "init failed\n");
85                 exit(1);
86         }
87
88 //      if (lzma_easy_encoder(&strm, 1)) {
89 //              fprintf(stderr, "init failed\n");
90 //              exit(1);
91 //      }
92
93         // Encoding
94         encode(0, LZMA_FULL_FLUSH);
95         encode(6, LZMA_FULL_FLUSH);
96         encode(0, LZMA_FULL_FLUSH);
97         encode(7, LZMA_FULL_FLUSH);
98         encode(0, LZMA_FULL_FLUSH);
99         encode(0, LZMA_FINISH);
100
101         // Clean up
102         lzma_end(&strm);
103
104         return 0;
105 }