*formats = pool_nalloc (pool, var_cnt + 1, sizeof **formats);
*format_cnt = var_cnt + 1;
- (*formats)[0].type = PRS_TYPE_T;
+ (*formats)[0].type = (enum fmt_type) PRS_TYPE_T;
(*formats)[0].w = fc;
for (i = 1; i <= var_cnt; i++)
(*formats)[i] = format;
new_formats = &f;
new_format_cnt = 1;
if (use == FMT_FOR_INPUT && lex_match (lexer, T_SLASH))
- f.type = PRS_TYPE_NEW_REC;
+ f.type = (enum fmt_type) PRS_TYPE_NEW_REC;
else
{
char type[FMT_TYPE_LEN_MAX + 1];
return false;
if (!c_strcasecmp (type, "T"))
- f.type = PRS_TYPE_T;
+ f.type = (enum fmt_type) PRS_TYPE_T;
else if (!c_strcasecmp (type, "X"))
{
- f.type = PRS_TYPE_X;
+ f.type = (enum fmt_type) PRS_TYPE_X;
f.w = count;
count = 1;
}
{
if (lex_is_number (lexer))
{
- double orignum = lex_number (lexer);
- long n = (lex_is_integer (lexer)?lex_integer (lexer):*record);
- bool out_of_range = orignum > INT_MAX || orignum < INT_MIN;
- if (n <= *record || out_of_range)
- {
- msg (SE, _("The record number specified, %.0f, is at or "
- "before the previous record, %d. Data "
- "fields must be listed in order of "
- "increasing record number."),
- orignum, *record);
- return false;
- }
- *record = n;
+ if (!lex_force_int_range (lexer, NULL, *record + 1, INT_MAX))
+ return false;
+ *record = lex_integer (lexer);
lex_get (lexer);
}
else