X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fdata%2Fcasereader-filter.c;h=5c46ed50dba436d1584a320e134be8fefc5e5de0;hb=b65cf0519aa1db140d30c878978f29b1e23c9cd0;hp=969bb4fae82f8088d35d88c790ec8d88448b1bea;hpb=43b1296aafe7582e7dbe6c2b6a8b478d7d9b0fcf;p=pspp-builds.git diff --git a/src/data/casereader-filter.c b/src/data/casereader-filter.c index 969bb4fa..5c46ed50 100644 --- a/src/data/casereader-filter.c +++ b/src/data/casereader-filter.c @@ -43,7 +43,7 @@ struct casereader_filter struct casewriter *exclude; /* Writer that gets filtered cases, or NULL. */ }; -static struct casereader_class casereader_filter_class; +static const struct casereader_class casereader_filter_class; /* Creates and returns a casereader whose content is a filtered version of the data in SUBREADER. Only the cases for which @@ -130,7 +130,7 @@ casereader_filter_destroy (struct casereader *reader, void *filter_) } /* Filtering casereader class. */ -static struct casereader_class casereader_filter_class = +static const struct casereader_class casereader_filter_class = { casereader_filter_read, casereader_filter_destroy, @@ -245,6 +245,7 @@ struct casereader_filter_missing struct variable **vars; /* Variables whose values to filter. */ size_t var_cnt; /* Number of variables. */ enum mv_class class; /* Types of missing values to filter. */ + casenumber *n_missing; }; static bool casereader_filter_missing_include (const struct ccase *, void *); @@ -264,6 +265,9 @@ static bool casereader_filter_missing_destroy (void *); read or, if that never occurs, until the filtering casereader is destroyed. + If N_MISSING is non-null, then after reading, it will be filled + with the total number of dropped cases. + After this function is called, READER must not ever again be referenced directly. It will be destroyed automatically when the filtering casereader is destroyed. */ @@ -271,6 +275,7 @@ struct casereader * casereader_create_filter_missing (struct casereader *reader, const struct variable **vars, size_t var_cnt, enum mv_class class, + casenumber *n_missing, struct casewriter *exclude) { if (var_cnt > 0 && class != MV_NEVER) @@ -279,6 +284,9 @@ casereader_create_filter_missing (struct casereader *reader, cfm->vars = xmemdup (vars, sizeof *vars * var_cnt); cfm->var_cnt = var_cnt; cfm->class = class; + cfm->n_missing = n_missing; + if (n_missing) + *n_missing = 0; return casereader_create_filter_func (reader, casereader_filter_missing_include, casereader_filter_missing_destroy, @@ -302,7 +310,11 @@ casereader_filter_missing_include (const struct ccase *c, void *cfm_) struct variable *var = cfm->vars[i]; const union value *value = case_data (c, var); if (var_is_value_missing (var, value, cfm->class)) - return false; + { + if ( cfm->n_missing ) + (*cfm->n_missing)++; + return false; + } } return true; }