memcpy(str, old_fmt, copy);
}
str += read;
- break;
+ continue;
}
case FORMAT_TYPE_WIDTH:
set_field_width(&spec, va_arg(args, int));
- break;
+ continue;
case FORMAT_TYPE_PRECISION:
set_precision(&spec, va_arg(args, int));
- break;
+ continue;
case FORMAT_TYPE_CHAR: {
char c;
*str = ' ';
++str;
}
- break;
+ continue;
}
case FORMAT_TYPE_STR:
str = string(str, end, va_arg(args, char *), spec);
- break;
+ continue;
case FORMAT_TYPE_PTR:
str = pointer(fmt, str, end, va_arg(args, void *),
spec);
while (isalnum(*fmt))
fmt++;
- break;
+ continue;
case FORMAT_TYPE_PERCENT_CHAR:
if (str < end)
*str = '%';
++str;
- break;
+ continue;
case FORMAT_TYPE_INVALID:
/*
*/
goto out;
- default:
- if (spec.type == FORMAT_TYPE_8BYTE)
- num = va_arg(args, long long);
- else
- num = convert_num_spec(va_arg(args, int), spec);
+ case FORMAT_TYPE_8BYTE:
+ num = va_arg(args, long long);
+ break;
- str = number(str, end, num, spec);
+ default:
+ num = convert_num_spec(va_arg(args, int), spec);
+ break;
}
+
+ str = number(str, end, num, spec);
}
out:
fmt++;
break;
+ case FORMAT_TYPE_8BYTE:
+ save_arg(long long);
+ break;
+ case FORMAT_TYPE_1BYTE:
+ save_arg(char);
+ break;
+ case FORMAT_TYPE_2BYTE:
+ save_arg(short);
+ break;
default:
- switch (spec.type) {
- case FORMAT_TYPE_8BYTE:
- save_arg(long long);
- break;
- case FORMAT_TYPE_1BYTE:
- save_arg(char);
- break;
- case FORMAT_TYPE_2BYTE:
- save_arg(short);
- break;
- default:
- save_arg(int);
- }
+ save_arg(int);
}
}
while (*fmt) {
const char *old_fmt = fmt;
int read = format_decode(fmt, &spec);
+ unsigned long long num;
fmt += read;
memcpy(str, old_fmt, copy);
}
str += read;
- break;
+ continue;
}
case FORMAT_TYPE_WIDTH:
set_field_width(&spec, get_arg(int));
- break;
+ continue;
case FORMAT_TYPE_PRECISION:
set_precision(&spec, get_arg(int));
- break;
+ continue;
case FORMAT_TYPE_CHAR: {
char c;
*str = ' ';
++str;
}
- break;
+ continue;
}
case FORMAT_TYPE_STR: {
const char *str_arg = args;
args += strlen(str_arg) + 1;
str = string(str, end, (char *)str_arg, spec);
- break;
+ continue;
}
case FORMAT_TYPE_PTR: {
while (isalnum(*fmt))
fmt++;
- break;
+ continue;
}
case FORMAT_TYPE_PERCENT_CHAR:
if (str < end)
*str = '%';
++str;
- break;
+ continue;
case FORMAT_TYPE_INVALID:
goto out;
- default: {
- unsigned long long num;
-
- switch (spec.type) {
- case FORMAT_TYPE_8BYTE:
- num = get_arg(long long);
- break;
- case FORMAT_TYPE_2BYTE:
- num = convert_num_spec(get_arg(short), spec);
- break;
- case FORMAT_TYPE_1BYTE:
- num = convert_num_spec(get_arg(char), spec);
- break;
- default:
- num = convert_num_spec(get_arg(int), spec);
- }
+ case FORMAT_TYPE_8BYTE:
+ num = get_arg(long long);
+ break;
+ case FORMAT_TYPE_2BYTE:
+ num = convert_num_spec(get_arg(short), spec);
+ break;
+ case FORMAT_TYPE_1BYTE:
+ num = convert_num_spec(get_arg(char), spec);
+ break;
+ default:
+ num = convert_num_spec(get_arg(int), spec);
+ break;
+ }
- str = number(str, end, num, spec);
- } /* default: */
- } /* switch(spec.type) */
+ str = number(str, end, num, spec);
} /* while(*fmt) */
out: