1
/* Copyright (C) 2000-2001, 2003-2004 MySQL AB
3
This program is free software; you can redistribute it and/or modify
4
it under the terms of the GNU General Public License as published by
5
the Free Software Foundation; version 2 of the License.
7
This program is distributed in the hope that it will be useful,
8
but WITHOUT ANY WARRANTY; without even the implied warranty of
9
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10
GNU General Public License for more details.
12
You should have received a copy of the GNU General Public License
13
along with this program; if not, write to the Free Software
14
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
16
/* Calculate a checksum for a row */
18
#include "myisam_priv.h"
20
using namespace drizzled;
22
internal::ha_checksum mi_checksum(MI_INFO *info, const unsigned char *buf)
25
internal::ha_checksum crc=0;
26
MI_COLUMNDEF *rec=info->s->rec;
28
for (i=info->s->base.fields ; i-- ; buf+=(rec++)->length)
30
const unsigned char *pos;
35
length=_mi_calc_blob_length(rec->length-
36
portable_sizeof_char_ptr,
38
memcpy(&pos, buf+rec->length - portable_sizeof_char_ptr, sizeof(char*));
43
uint32_t pack_length= ha_varchar_packlength(rec->length-1);
45
length= (ulong) *(unsigned char*) buf;
47
length= uint2korr(buf);
56
crc=internal::my_checksum(crc, pos ? pos : (unsigned char*) "", length);
62
internal::ha_checksum mi_static_checksum(MI_INFO *info, const unsigned char *pos)
64
return internal::my_checksum(0, pos, info->s->base.reclength);