X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fdata%2Fvalue.c;h=180f1b6d1e064d8195fda7f033bf72ecb3cccfd6;hb=2c411d651e22704f60f117d944b9380a07d247fe;hp=9fcf1cbb9b8fa0a97cb4e75544a9a6892879ab68;hpb=015e221b0f8578afee769528572c76387f26c629;p=pspp-builds.git diff --git a/src/data/value.c b/src/data/value.c index 9fcf1cbb..180f1b6d 100644 --- a/src/data/value.c +++ b/src/data/value.c @@ -1,5 +1,5 @@ /* PSPP - a program for statistical analysis. - Copyright (C) 1997-9, 2000 Free Software Foundation, Inc. + Copyright (C) 1997-9, 2000, 2009 Free Software Foundation, Inc. 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 @@ -47,28 +47,25 @@ value_create (int width) Only the short string portion of longer strings are compared. */ int -compare_values (const void *a_, const void *b_, const void *var_) +compare_values_short (const void *a_, const void *b_, const void *var_) { const union value *a = a_; const union value *b = b_; const struct variable *var = var_; int width = var_get_width (var); - return (width == 0 - ? (a->f < b->f ? -1 : a->f > b->f) - : memcmp (a->s, b->s, MIN (MAX_SHORT_STRING, width))); + return value_compare_3way (a, b, MIN (width, MAX_SHORT_STRING)); } + /* Create a hash of V, which has the given WIDTH. Only the short string portion of a longer string is hashed. */ unsigned -hash_value (const void *v_, const void *var_) +hash_value_short (const void *v_, const void *var_) { const union value *v = v_; const struct variable *var = var_; int width = var_get_width (var); - return (width == 0 - ? hsh_hash_double (v->f) - : hsh_hash_bytes (v->s, width)); + return width == 0 ? hash_double (v->f, 0) : hash_bytes (v->s, width, 0); } @@ -122,3 +119,13 @@ value_resize (union value *value, int old_width, int new_width) if (new_width > old_width) memset (&value->s[old_width], ' ', new_width - old_width); } + +/* Compares A and B, which both have the given WIDTH, and returns + a strcmp()-type result. */ +int +value_compare_3way (const union value *a, const union value *b, int width) +{ + return (width == 0 + ? (a->f < b->f ? -1 : a->f > b->f) + : memcmp (a->s, b->s, width)); +}