//
// cook - file construction tool
// Copyright (C) 1994, 2003-2006, 2008 Peter Miller.
//
// This program 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 3 of the License, or
// (at your option) any later version.
//
// This program 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 this program. If not, see
// .
//
#include
#include
#include
#include
struct cksum_ty
{
FINGERPRINT_BASE_CLASS
fingerprint_ty *crc32;
fingerprint_ty *len;
};
static void
cksum_constructor(fingerprint_ty *p)
{
cksum_ty *f;
f = (cksum_ty *)p;
f->crc32 = fingerprint_new(&fp_crc32);
f->len = fingerprint_new(&fp_len);
}
static void
cksum_destructor(fingerprint_ty *p)
{
cksum_ty *f;
f = (cksum_ty *)p;
fingerprint_delete(f->crc32);
fingerprint_delete(f->len);
}
static void
cksum_addn(fingerprint_ty *p, unsigned char *s, size_t n)
{
cksum_ty *f;
f = (cksum_ty *)p;
fingerprint_addn(f->crc32, s, n);
fingerprint_addn(f->len, s, n);
}
static int
cksum_hash(fingerprint_ty *p, unsigned char *h)
{
cksum_ty *f;
int nbytes;
unsigned char *obuf;
f = (cksum_ty *)p;
obuf = h;
nbytes = fingerprint_hash(f->crc32, h);
h += nbytes;
nbytes = fingerprint_hash(f->len, h);
h += nbytes;
return (h - obuf);
}
static void
cksum_sum(fingerprint_ty *p, char *data, size_t data_len)
{
char *s;
cksum_ty *f;
s = data;
f = (cksum_ty *)p;
fingerprint_sum(f->crc32, s, data_len - 1);
s += strlen(s);
*s++ = ' ';
fingerprint_sum(f->len, s, data + data_len - s);
}
fingerprint_methods_ty fp_cksum =
{
sizeof(cksum_ty),
"cksum",
cksum_constructor,
cksum_destructor,
cksum_addn,
cksum_hash,
cksum_sum
};