X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fdata%2Fcase.c;h=20ed8bae2810ac6bbf8b2a3766358a776598a8c4;hb=38f8cf3544615efabc0913ebd00fdf6053cf294d;hp=eab966b1867d3e6405fc4d5c818c4ca275a12923;hpb=a19b858e0ac3c69e4a28c0ca6d8674427268a863;p=pspp diff --git a/src/data/case.c b/src/data/case.c index eab966b186..20ed8bae28 100644 --- a/src/data/case.c +++ b/src/data/case.c @@ -45,9 +45,6 @@ case_unshare (struct ccase *c) { struct case_data *cd; - assert (c != NULL); - assert (c->this == c); - assert (c->case_data != NULL); assert (c->case_data->ref_cnt > 1); cd = c->case_data; @@ -72,7 +69,6 @@ void case_nullify (struct ccase *c) { c->case_data = NULL; - c->this = c; } #endif /* DEBUGGING */ @@ -100,17 +96,10 @@ case_create (struct ccase *c, size_t value_cnt) void case_clone (struct ccase *clone, const struct ccase *orig) { - assert (orig != NULL); - assert (orig->this == orig); - assert (orig->case_data != NULL); assert (orig->case_data->ref_cnt > 0); - assert (clone != NULL); if (clone != orig) - { - *clone = *orig; - clone->this = clone; - } + *clone = *orig; orig->case_data->ref_cnt++; } #endif /* DEBUGGING */ @@ -121,15 +110,13 @@ case_clone (struct ccase *clone, const struct ccase *orig) void case_move (struct ccase *dst, struct ccase *src) { - assert (src != NULL); - assert (src->this == src); - assert (src->case_data != NULL); assert (src->case_data->ref_cnt > 0); - assert (dst != NULL); - - *dst = *src; - dst->this = dst; - case_nullify (src); + + if (dst != src) + { + *dst = *src; + case_nullify (src); + } } #endif /* DEBUGGING */ @@ -141,7 +128,6 @@ case_destroy (struct ccase *c) struct case_data *cd; assert (c != NULL); - assert (c->this == c); cd = c->case_data; if (cd != NULL && --cd->ref_cnt == 0) @@ -175,38 +161,30 @@ case_swap (struct ccase *a, struct ccase *b) } /* Attempts to create C as a new case that holds VALUE_CNT - values. Returns nonzero if successful, zero if memory + values. Returns true if successful, false if memory allocation failed. */ -int +bool case_try_create (struct ccase *c, size_t value_cnt) { c->case_data = malloc (case_size (value_cnt)); if (c->case_data != NULL) { -#ifdef DEBUGGING - c->this = c; -#endif c->case_data->value_cnt = value_cnt; c->case_data->ref_cnt = 1; - return 1; - } - else - { -#ifdef DEBUGGING - c->this = c; -#endif - return 0; + return true; } + + return false; } /* Tries to initialize CLONE as a copy of ORIG. - Returns nonzero if successful, zero if memory allocation + Returns true if successful, false if memory allocation failed. */ -int +bool case_try_clone (struct ccase *clone, const struct ccase *orig) { case_clone (clone, orig); - return 1; + return true; } #ifdef DEBUGGING @@ -217,24 +195,20 @@ case_copy (struct ccase *dst, size_t dst_idx, const struct ccase *src, size_t src_idx, size_t value_cnt) { - assert (dst != NULL); - assert (dst->this == dst); - assert (dst->case_data != NULL); assert (dst->case_data->ref_cnt > 0); assert (dst_idx + value_cnt <= dst->case_data->value_cnt); - assert (src != NULL); - assert (src->this == src); - assert (src->case_data != NULL); assert (src->case_data->ref_cnt > 0); - assert (src_idx + value_cnt <= dst->case_data->value_cnt); + assert (src_idx + value_cnt <= src->case_data->value_cnt); - if (dst->case_data->ref_cnt > 1) - case_unshare (dst); if (dst->case_data != src->case_data || dst_idx != src_idx) - memmove (dst->case_data->values + dst_idx, - src->case_data->values + src_idx, - sizeof *dst->case_data->values * value_cnt); + { + if (dst->case_data->ref_cnt > 1) + case_unshare (dst); + memmove (dst->case_data->values + dst_idx, + src->case_data->values + src_idx, + sizeof *dst->case_data->values * value_cnt); + } } #endif /* DEBUGGING */ @@ -246,9 +220,6 @@ void case_to_values (const struct ccase *c, union value *output, size_t output_size UNUSED) { - assert (c != NULL); - assert (c->this == c); - assert (c->case_data != NULL); assert (c->case_data->ref_cnt > 0); assert (output_size == c->case_data->value_cnt); assert (output != NULL || output_size == 0); @@ -267,7 +238,6 @@ case_from_values (struct ccase *c, const union value *input, size_t input_size UNUSED) { assert (c != NULL); - assert (c->this == c); assert (c->case_data != NULL); assert (c->case_data->ref_cnt > 0); assert (input_size == c->case_data->value_cnt); @@ -285,10 +255,9 @@ case_from_values (struct ccase *c, const union value *input, element of C numbered IDX. The caller must not modify the returned data. */ const union value * -case_data (const struct ccase *c, size_t idx) +case_data_idx (const struct ccase *c, size_t idx) { assert (c != NULL); - assert (c->this == c); assert (c->case_data != NULL); assert (c->case_data->ref_cnt > 0); assert (idx < c->case_data->value_cnt); @@ -301,10 +270,9 @@ case_data (const struct ccase *c, size_t idx) /* Returns the numeric value of the `union value' in C numbered IDX. */ double -case_num (const struct ccase *c, size_t idx) +case_num_idx (const struct ccase *c, size_t idx) { assert (c != NULL); - assert (c->this == c); assert (c->case_data != NULL); assert (c->case_data->ref_cnt > 0); assert (idx < c->case_data->value_cnt); @@ -319,10 +287,9 @@ case_num (const struct ccase *c, size_t idx) (Note that the value is not null-terminated.) The caller must not modify the return value. */ const char * -case_str (const struct ccase *c, size_t idx) +case_str_idx (const struct ccase *c, size_t idx) { assert (c != NULL); - assert (c->this == c); assert (c->case_data != NULL); assert (c->case_data->ref_cnt > 0); assert (idx < c->case_data->value_cnt); @@ -336,10 +303,9 @@ case_str (const struct ccase *c, size_t idx) element of C numbered IDX. The caller is allowed to modify the returned data. */ union value * -case_data_rw (struct ccase *c, size_t idx) +case_data_rw_idx (struct ccase *c, size_t idx) { assert (c != NULL); - assert (c->this == c); assert (c->case_data != NULL); assert (c->case_data->ref_cnt > 0); assert (idx < c->case_data->value_cnt); @@ -372,22 +338,21 @@ case_compare_2dict (const struct ccase *ca, const struct ccase *cb, const struct variable *va = *vap; const struct variable *vb = *vbp; - assert (va->type == vb->type); - assert (va->width == vb->width); + assert (var_get_width (va) == var_get_width (vb)); - if (va->width == 0) + if (var_get_width (va) == 0) { - double af = case_num (ca, va->fv); - double bf = case_num (cb, vb->fv); + double af = case_num (ca, va); + double bf = case_num (cb, vb); if (af != bf) return af > bf ? 1 : -1; } else { - const char *as = case_str (ca, va->fv); - const char *bs = case_str (cb, vb->fv); - int cmp = memcmp (as, bs, va->width); + const char *as = case_str (ca, va); + const char *bs = case_str (cb, vb); + int cmp = memcmp (as, bs, var_get_width (va)); if (cmp != 0) return cmp; @@ -405,7 +370,6 @@ const union value * case_data_all (const struct ccase *c) { assert (c != NULL); - assert (c->this == c); assert (c->case_data != NULL); assert (c->case_data->ref_cnt > 0); @@ -421,7 +385,6 @@ union value * case_data_all_rw (struct ccase *c) { assert (c != NULL); - assert (c->this == c); assert (c->case_data != NULL); assert (c->case_data->ref_cnt > 0);