X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Flanguage%2Fstats%2Ffrequencies.q;h=ef4b7f9589d3a770fc9650a1a93b5581e9a2e33e;hb=9ade26c8349b4434008c46cf09bc7473ec743972;hp=ecaefdf64e421196160009769ffe2e4438797262;hpb=55e6e7ba37a30570f5a31e2d78c22dfa7b61a36f;p=pspp-builds.git diff --git a/src/language/stats/frequencies.q b/src/language/stats/frequencies.q index ecaefdf6..ef4b7f95 100644 --- a/src/language/stats/frequencies.q +++ b/src/language/stats/frequencies.q @@ -1,5 +1,5 @@ /* PSPP - a program for statistical analysis. - Copyright (C) 1997-9, 2000, 2007, 2009, 2010 Free Software Foundation, Inc. + Copyright (C) 1997-9, 2000, 2007, 2009, 2010, 2011 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 @@ -738,14 +738,23 @@ frq_custom_grouped (struct lexer *lexer, struct dataset *ds, struct cmd_frequenc } free (v); - if (!lex_match (lexer, T_SLASH)) - break; - if ((lex_token (lexer) != T_ID || dict_lookup_var (dataset_dict (ds), lex_tokcstr (lexer)) != NULL) - && lex_token (lexer) != T_ALL) - { - lex_put_back (lexer, T_SLASH); - break; - } + if (lex_token (lexer) != T_SLASH) + break; + + if ((lex_next_token (lexer, 1) == T_ID + && dict_lookup_var (dataset_dict (ds), + lex_next_tokcstr (lexer, 1))) + || lex_next_token (lexer, 1) == T_ALL) + { + /* The token after the slash is a variable name. Keep parsing. */ + lex_get (lexer); + } + else + { + /* The token after the slash must be the start of a new + subcommand. Let the caller see the slash. */ + break; + } } return 1; @@ -922,8 +931,7 @@ calc_percentiles (const struct frq_proc *frq, const struct var_freqs *vf) if (rank <= tp) break; - if (f->count > 1 - && (rank - (f->count - 1) > tp || f + 1 >= ft->missing)) + if (tp + 1 < rank || f + 1 >= ft->missing) pc->value = f->value.f; else pc->value = calc_percentile (pc->p, W, f->value.f, f[1].value.f);