summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristian Göttsche <cgzones@googlemail.com>2023-03-31 14:46:50 +0200
committerSerge Hallyn <serge@hallyn.com>2023-03-31 09:53:40 -0500
commit2eaea70111f65b16d55998386e4ceb4273c19eb4 (patch)
tree230f97c966933bba177f77f994d3c2f3eef39a7d
parenta5f9ef8b7fa7dd108270459325092a2be3847331 (diff)
Overhaul valid_field()
e5905c4b ("Added control character check") introduced checking for control characters but had the logic inverted, so it rejects all characters that are not control ones. Cast the character to `unsigned char` before passing to the character checking functions to avoid UB. Use strpbrk(3) for the illegal character test and return early.
-rw-r--r--lib/fields.c24
1 files changed, 10 insertions, 14 deletions
diff --git a/lib/fields.c b/lib/fields.c
index fb51b582..53929248 100644
--- a/lib/fields.c
+++ b/lib/fields.c
@@ -37,26 +37,22 @@ int valid_field (const char *field, const char *illegal)
/* For each character of field, search if it appears in the list
* of illegal characters. */
+ if (illegal && NULL != strpbrk (field, illegal)) {
+ return -1;
+ }
+
+ /* Search if there are non-printable or control characters */
for (cp = field; '\0' != *cp; cp++) {
- if (strchr (illegal, *cp) != NULL) {
+ unsigned char c = *cp;
+ if (!isprint (c)) {
+ err = 1;
+ }
+ if (iscntrl (c)) {
err = -1;
break;
}
}
- if (0 == err) {
- /* Search if there are non-printable or control characters */
- for (cp = field; '\0' != *cp; cp++) {
- if (!isprint (*cp)) {
- err = 1;
- }
- if (!iscntrl (*cp)) {
- err = -1;
- break;
- }
- }
- }
-
return err;
}