Blame src/lzo_mchw.ch

Packit 679830
/* lzo_mchw.ch -- matching functions using a window
Packit 679830
Packit 679830
   This file is part of the LZO real-time data compression library.
Packit 679830
Packit 679830
   Copyright (C) 1996-2014 Markus Franz Xaver Johannes Oberhumer
Packit 679830
   All Rights Reserved.
Packit 679830
Packit 679830
   The LZO library is free software; you can redistribute it and/or
Packit 679830
   modify it under the terms of the GNU General Public License as
Packit 679830
   published by the Free Software Foundation; either version 2 of
Packit 679830
   the License, or (at your option) any later version.
Packit 679830
Packit 679830
   The LZO library is distributed in the hope that it will be useful,
Packit 679830
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 679830
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit 679830
   GNU General Public License for more details.
Packit 679830
Packit 679830
   You should have received a copy of the GNU General Public License
Packit 679830
   along with the LZO library; see the file COPYING.
Packit 679830
   If not, write to the Free Software Foundation, Inc.,
Packit 679830
   51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Packit 679830
Packit 679830
   Markus F.X.J. Oberhumer
Packit 679830
   <markus@oberhumer.com>
Packit 679830
   http://www.oberhumer.com/opensource/lzo/
Packit 679830
 */
Packit 679830
Packit 679830
Packit 679830
/***********************************************************************
Packit 679830
//
Packit 679830
************************************************************************/
Packit 679830
Packit 679830
typedef struct
Packit 679830
{
Packit 679830
    unsigned init;
Packit 679830
Packit 679830
    lzo_uint look;          /* bytes in lookahead buffer */
Packit 679830
Packit 679830
    lzo_uint m_len;
Packit 679830
    lzo_uint m_off;
Packit 679830
Packit 679830
    lzo_uint last_m_len;
Packit 679830
    lzo_uint last_m_off;
Packit 679830
Packit 679830
    const lzo_bytep bp;
Packit 679830
    const lzo_bytep ip;
Packit 679830
    const lzo_bytep in;
Packit 679830
    const lzo_bytep in_end;
Packit 679830
    lzo_bytep out;
Packit 679830
Packit 679830
    lzo_callback_p cb;
Packit 679830
Packit 679830
    lzo_uint textsize;      /* text size counter */
Packit 679830
    lzo_uint codesize;      /* code size counter */
Packit 679830
    lzo_uint printcount;    /* counter for reporting progress every 1K bytes */
Packit 679830
Packit 679830
    /* some stats */
Packit 679830
    unsigned long lit_bytes;
Packit 679830
    unsigned long match_bytes;
Packit 679830
    unsigned long rep_bytes;
Packit 679830
    unsigned long lazy;
Packit 679830
Packit 679830
#if defined(LZO1B)
Packit 679830
    lzo_uint r1_m_len;
Packit 679830
Packit 679830
    /* some stats */
Packit 679830
    unsigned long r1_r, m3_r, m2_m, m3_m;
Packit 679830
#endif
Packit 679830
Packit 679830
#if defined(LZO1C)
Packit 679830
    lzo_uint r1_m_len;
Packit 679830
    lzo_bytep m3;
Packit 679830
Packit 679830
    /* some stats */
Packit 679830
    unsigned long r1_r, m3_r, m2_m, m3_m;
Packit 679830
#endif
Packit 679830
Packit 679830
#if defined(LZO1F)
Packit 679830
    lzo_uint r1_lit;
Packit 679830
    lzo_uint r1_m_len;
Packit 679830
Packit 679830
    /* some stats */
Packit 679830
    unsigned long r1_r, m2_m, m3_m;
Packit 679830
#endif
Packit 679830
Packit 679830
#if defined(LZO1X) || defined(LZO1Y) || defined(LZO1Z)
Packit 679830
    lzo_uint r1_lit;
Packit 679830
    lzo_uint r1_m_len;
Packit 679830
Packit 679830
    /* some stats */
Packit 679830
    unsigned long m1a_m, m1b_m, m2_m, m3_m, m4_m;
Packit 679830
    unsigned long lit1_r, lit2_r, lit3_r;
Packit 679830
#endif
Packit 679830
Packit 679830
#if defined(LZO2A)
Packit 679830
    /* some stats */
Packit 679830
    unsigned long m1, m2, m3, m4;
Packit 679830
#endif
Packit 679830
}
Packit 679830
LZO_COMPRESS_T;
Packit 679830
Packit 679830
Packit 679830
#define getbyte(c)  ((c).ip < (c).in_end ? *((c).ip)++ : (-1))
Packit 679830
Packit 679830
#include "lzo_swd.ch"
Packit 679830
Packit 679830
Packit 679830
/***********************************************************************
Packit 679830
//
Packit 679830
************************************************************************/
Packit 679830
Packit 679830
static int
Packit 679830
init_match ( LZO_COMPRESS_T *c, lzo_swd_p s,
Packit 679830
             const lzo_bytep dict, lzo_uint dict_len,
Packit 679830
             lzo_uint32_t flags )
Packit 679830
{
Packit 679830
    int r;
Packit 679830
Packit 679830
    assert(!c->init);
Packit 679830
    c->init = 1;
Packit 679830
Packit 679830
    s->c = c;
Packit 679830
Packit 679830
    c->last_m_len = c->last_m_off = 0;
Packit 679830
Packit 679830
    c->textsize = c->codesize = c->printcount = 0;
Packit 679830
    c->lit_bytes = c->match_bytes = c->rep_bytes = 0;
Packit 679830
    c->lazy = 0;
Packit 679830
Packit 679830
    r = swd_init(s,dict,dict_len);
Packit 679830
    if (r != LZO_E_OK)
Packit 679830
    {
Packit 679830
        swd_exit(s);
Packit 679830
        return r;
Packit 679830
    }
Packit 679830
Packit 679830
    s->use_best_off = (flags & 1) ? 1 : 0;
Packit 679830
    return LZO_E_OK;
Packit 679830
}
Packit 679830
Packit 679830
Packit 679830
/***********************************************************************
Packit 679830
//
Packit 679830
************************************************************************/
Packit 679830
Packit 679830
static int
Packit 679830
find_match ( LZO_COMPRESS_T *c, lzo_swd_p s,
Packit 679830
             lzo_uint this_len, lzo_uint skip )
Packit 679830
{
Packit 679830
    assert(c->init);
Packit 679830
Packit 679830
    if (skip > 0)
Packit 679830
    {
Packit 679830
        assert(this_len >= skip);
Packit 679830
        swd_accept(s, this_len - skip);
Packit 679830
        c->textsize += this_len - skip + 1;
Packit 679830
    }
Packit 679830
    else
Packit 679830
    {
Packit 679830
        assert(this_len <= 1);
Packit 679830
        c->textsize += this_len - skip;
Packit 679830
    }
Packit 679830
Packit 679830
    s->m_len = SWD_THRESHOLD;
Packit 679830
    s->m_off = 0;
Packit 679830
#ifdef SWD_BEST_OFF
Packit 679830
    if (s->use_best_off)
Packit 679830
        lzo_memset(s->best_pos,0,sizeof(s->best_pos));
Packit 679830
#endif
Packit 679830
    swd_findbest(s);
Packit 679830
    c->m_len = s->m_len;
Packit 679830
    c->m_off = s->m_off;
Packit 679830
Packit 679830
    swd_getbyte(s);
Packit 679830
Packit 679830
    if (s->b_char < 0)
Packit 679830
    {
Packit 679830
        c->look = 0;
Packit 679830
        c->m_len = 0;
Packit 679830
        swd_exit(s);
Packit 679830
    }
Packit 679830
    else
Packit 679830
    {
Packit 679830
        c->look = s->look + 1;
Packit 679830
    }
Packit 679830
    c->bp = c->ip - c->look;
Packit 679830
Packit 679830
#if 0
Packit 679830
    /* brute force match search */
Packit 679830
    if (c->m_len > SWD_THRESHOLD && c->m_len + 1 <= c->look)
Packit 679830
    {
Packit 679830
        const lzo_bytep ip = c->bp;
Packit 679830
        const lzo_bytep m  = c->bp - c->m_off;
Packit 679830
        const lzo_bytep in = c->in;
Packit 679830
Packit 679830
        if (ip - in > s->swd_n)
Packit 679830
            in = ip - s->swd_n;
Packit 679830
        for (;;)
Packit 679830
        {
Packit 679830
            while (*in != *ip)
Packit 679830
                in++;
Packit 679830
            if (in == ip)
Packit 679830
                break;
Packit 679830
            if (in != m)
Packit 679830
                if (lzo_memcmp(in,ip,c->m_len+1) == 0)
Packit 679830
                    printf("%p %p %p %5d\n",in,ip,m,c->m_len);
Packit 679830
            in++;
Packit 679830
        }
Packit 679830
    }
Packit 679830
#endif
Packit 679830
Packit 679830
    if (c->cb && c->cb->nprogress && c->textsize > c->printcount)
Packit 679830
    {
Packit 679830
        (*c->cb->nprogress)(c->cb, c->textsize, c->codesize, 0);
Packit 679830
        c->printcount += 1024;
Packit 679830
    }
Packit 679830
Packit 679830
    return LZO_E_OK;
Packit 679830
}
Packit 679830
Packit 679830
Packit 679830
/*
Packit 679830
vi:ts=4:et
Packit 679830
*/
Packit 679830