summaryrefslogtreecommitdiff
path: root/src/lread.c
diff options
context:
space:
mode:
authorMattias EngdegÄrd <mattiase@acm.org>2022-12-06 12:13:18 +0100
committerMattias EngdegÄrd <mattiase@acm.org>2022-12-06 12:13:18 +0100
commit9b9b39a2d8979af7430a4e2370ef7857c4a2dbce (patch)
treec573984732e7f623e0075e2071eb95ba12178394 /src/lread.c
parent717f8477284170dd59315a3c64cc7e492e9366e2 (diff)
downloademacs-9b9b39a2d8979af7430a4e2370ef7857c4a2dbce.tar.gz
emacs-9b9b39a2d8979af7430a4e2370ef7857c4a2dbce.tar.bz2
emacs-9b9b39a2d8979af7430a4e2370ef7857c4a2dbce.zip
Lisp reader undefined behaviour excision
* src/lread.c (read_bool_vector, skip_lazy_string): Replace `|` with `||` to explicitly introduce sequence points since the variables, `length` and `nskip`, are mutated more than once. The `|` was just a weak attempt at micro-optimisation in any case; sorry about that.
Diffstat (limited to 'src/lread.c')
-rw-r--r--src/lread.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/src/lread.c b/src/lread.c
index 0a6e4201e40..68bc1431765 100644
--- a/src/lread.c
+++ b/src/lread.c
@@ -3375,7 +3375,7 @@ read_bool_vector (Lisp_Object readcharfun)
break;
}
if (INT_MULTIPLY_WRAPV (length, 10, &length)
- | INT_ADD_WRAPV (length, c - '0', &length))
+ || INT_ADD_WRAPV (length, c - '0', &length))
invalid_syntax ("#&", readcharfun);
}
@@ -3421,7 +3421,7 @@ skip_lazy_string (Lisp_Object readcharfun)
break;
}
if (INT_MULTIPLY_WRAPV (nskip, 10, &nskip)
- | INT_ADD_WRAPV (nskip, c - '0', &nskip))
+ || INT_ADD_WRAPV (nskip, c - '0', &nskip))
invalid_syntax ("#@", readcharfun);
digits++;
if (digits == 2 && nskip == 0)