Home | History | Annotate | Line # | Download | only in lib
      1  1.1  christos /* $OpenBSD: ohash_interval.c,v 1.3 2006/01/16 15:52:25 espie Exp $ */
      2  1.1  christos /* ex:ts=8 sw=4:
      3  1.1  christos  */
      4  1.1  christos 
      5  1.1  christos /* Copyright (c) 1999, 2004 Marc Espie <espie (at) openbsd.org>
      6  1.1  christos  *
      7  1.1  christos  * Permission to use, copy, modify, and distribute this software for any
      8  1.1  christos  * purpose with or without fee is hereby granted, provided that the above
      9  1.1  christos  * copyright notice and this permission notice appear in all copies.
     10  1.1  christos  *
     11  1.1  christos  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
     12  1.1  christos  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
     13  1.1  christos  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
     14  1.1  christos  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
     15  1.1  christos  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
     16  1.1  christos  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
     17  1.1  christos  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
     18  1.1  christos  */
     19  1.1  christos 
     20  1.1  christos #include "ohash_int.h"
     21  1.1  christos 
     22  1.1  christos uint32_t
     23  1.1  christos ohash_interval(const char *s, const char **e)
     24  1.1  christos {
     25  1.1  christos 	uint32_t k;
     26  1.1  christos 
     27  1.1  christos 	if (!*e)
     28  1.1  christos 		*e = s + strlen(s);
     29  1.1  christos 	if (s == *e)
     30  1.1  christos 		k = 0;
     31  1.1  christos 	else
     32  1.1  christos 		k = *s++;
     33  1.1  christos 	while (s != *e)
     34  1.1  christos 		k =  ((k << 2) | (k >> 30)) ^ *s++;
     35  1.1  christos 	return k;
     36  1.1  christos }
     37