| 1 | /* deflate_p.h -- Private inline functions and macros shared with more than |
| 2 | * one deflate method |
| 3 | * |
| 4 | * Copyright (C) 1995-2013 Jean-loup Gailly and Mark Adler |
| 5 | * For conditions of distribution and use, see copyright notice in zlib.h |
| 6 | * |
| 7 | */ |
| 8 | |
| 9 | #ifndef DEFLATE_P_H |
| 10 | #define DEFLATE_P_H |
| 11 | |
| 12 | /* Forward declare common non-inlined functions declared in deflate.c */ |
| 13 | |
| 14 | #ifdef ZLIB_DEBUG |
| 15 | void check_match(deflate_state *s, IPos start, IPos match, int length); |
| 16 | #else |
| 17 | #define check_match(s, start, match, length) |
| 18 | #endif |
| 19 | void flush_pending(PREFIX3(stream) *strm); |
| 20 | |
| 21 | /* =========================================================================== |
| 22 | * Insert string str in the dictionary and set match_head to the previous head |
| 23 | * of the hash chain (the most recent string with same hash key). Return |
| 24 | * the previous length of the hash chain. |
| 25 | * IN assertion: all calls to to INSERT_STRING are made with consecutive |
| 26 | * input characters and the first MIN_MATCH bytes of str are valid |
| 27 | * (except for the last MIN_MATCH-1 bytes of the input file). |
| 28 | */ |
| 29 | |
| 30 | static inline Pos insert_string_c(deflate_state *const s, const Pos str, unsigned int count) { |
| 31 | Pos ret = 0; |
| 32 | unsigned int idx; |
| 33 | |
| 34 | for (idx = 0; idx < count; idx++) { |
| 35 | UPDATE_HASH(s, s->ins_h, str+idx); |
| 36 | |
| 37 | Pos head = s->head[s->ins_h]; |
| 38 | if (head != str+idx) { |
| 39 | s->prev[(str+idx) & s->w_mask] = head; |
| 40 | s->head[s->ins_h] = str+idx; |
| 41 | if (idx == count - 1) |
| 42 | ret = head; |
| 43 | } else if (idx == count - 1) { |
| 44 | ret = str + idx; |
| 45 | } |
| 46 | } |
| 47 | return ret; |
| 48 | } |
| 49 | |
| 50 | /* =========================================================================== |
| 51 | * Flush the current block, with given end-of-file flag. |
| 52 | * IN assertion: strstart is set to the end of the current match. |
| 53 | */ |
| 54 | #define FLUSH_BLOCK_ONLY(s, last) { \ |
| 55 | zng_tr_flush_block(s, (s->block_start >= 0L ? \ |
| 56 | (char *)&s->window[(unsigned)s->block_start] : \ |
| 57 | NULL), \ |
| 58 | (unsigned long)((long)s->strstart - s->block_start), \ |
| 59 | (last)); \ |
| 60 | s->block_start = s->strstart; \ |
| 61 | flush_pending(s->strm); \ |
| 62 | Tracev((stderr, "[FLUSH]")); \ |
| 63 | } |
| 64 | |
| 65 | /* Same but force premature exit if necessary. */ |
| 66 | #define FLUSH_BLOCK(s, last) { \ |
| 67 | FLUSH_BLOCK_ONLY(s, last); \ |
| 68 | if (s->strm->avail_out == 0) return (last) ? finish_started : need_more; \ |
| 69 | } |
| 70 | |
| 71 | /* Maximum stored block length in deflate format (not including header). */ |
| 72 | #define MAX_STORED 65535 |
| 73 | |
| 74 | /* Minimum of a and b. */ |
| 75 | #define MIN(a, b) ((a) > (b) ? (b) : (a)) |
| 76 | |
| 77 | #endif |
| 78 | |