// // 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 };