printf_arg_t arg;
REGISTER int i;
int args_needed = get_args_needed(specs);
+ int spec_len = -1;
+
+ if (specs)
+ spec_len = Dynarr_length(specs);
xzero(arg);
for (i = 1; i <= args_needed; i++) {
char ch;
printf_spec_t spec = 0;
- for (j = 0; j < Dynarr_length(specs); j++) {
+ for (j = 0; j < spec_len; j++) {
spec = Dynarr_atp(specs, j);
if (spec->argnum == i) {
break;
}
}
- if (j == Dynarr_length(specs))
+ if (j >= spec_len)
error("No conversion spec for argument %d", i);
ch = spec->converter;
} else {
args = get_doprnt_args(specs, vargs);
}
-
- for (i = 0; i < Dynarr_length(specs); i++) {
+
+ for (i = 0; specs && i < Dynarr_length(specs); i++) {
printf_spec_t spec = Dynarr_atp(specs, i);
char ch;
was specified as an argument. Extract the data and forward
it to the next spec, to which it will apply. */
if (ch == '*') {
- printf_spec_t nextspec = Dynarr_atp(specs, i + 1);
- Lisp_Object obj = largs[spec->argnum - 1];
-
- if (INTP(obj)) {
- if (spec->forwarding_precision) {
- nextspec->precision = XINT(obj);
- nextspec->minwidth = spec->minwidth;
- } else {
- nextspec->minwidth = XINT(obj);
- if (XINT(obj) < 0) {
- spec->minus_flag = 1;
- nextspec->minwidth =
- -nextspec->minwidth;
+ if(!largs) {
+ error("Invalid largs and '*' converter in emacs_doprnt_1");
+ } else {
+ printf_spec_t nextspec = Dynarr_atp(specs, i + 1);
+ Lisp_Object obj = largs[spec->argnum - 1];
+
+ if (INTP(obj)) {
+ if (spec->forwarding_precision) {
+ nextspec->precision = XINT(obj);
+ nextspec->minwidth = spec->minwidth;
+ } else {
+ nextspec->minwidth = XINT(obj);
+ if (XINT(obj) < 0) {
+ spec->minus_flag = 1;
+ nextspec->minwidth =
+ -nextspec->minwidth;
+ }
}
+ nextspec->minus_flag = spec->minus_flag;
+ nextspec->plus_flag = spec->plus_flag;
+ nextspec->space_flag = spec->space_flag;
+ nextspec->number_flag = spec->number_flag;
+ nextspec->zero_flag = spec->zero_flag;
}
- nextspec->minus_flag = spec->minus_flag;
- nextspec->plus_flag = spec->plus_flag;
- nextspec->space_flag = spec->space_flag;
- nextspec->number_flag = spec->number_flag;
- nextspec->zero_flag = spec->zero_flag;
}
continue;
}