aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon Ser <contact@emersion.fr>2022-05-11 17:18:39 +0200
committerSimon Zeni <simon@bl4ckb0ne.ca>2022-05-11 11:47:49 -0400
commit1e9be019b2af7ad4aca66ba6460f56453829485d (patch)
treecb57946ad417d2ce7f59349f5a0ba81aecd989a8
parent7cfa1507881144445efd9752e18219dd5ec4a14b (diff)
downloadsway-1e9be019b2af7ad4aca66ba6460f56453829485d.tar.xz
Replace strncpy with memcpy
strncpy is useless here, is dangerous because it doesn't guarantee that the string is NUL-terminated and causes the following warning: ../sway/criteria.c: In function ‘criteria_parse’: ../sway/criteria.c:712:25: error: ‘strncpy’ destination unchanged after copying no bytes [-Werror=stringop-truncation] 712 | strncpy(value, valuestart, head - valuestart); | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-rw-r--r--sway/criteria.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/sway/criteria.c b/sway/criteria.c
index 94751c5f..97cf667e 100644
--- a/sway/criteria.c
+++ b/sway/criteria.c
@@ -682,7 +682,7 @@ struct criteria *criteria_parse(char *raw, char **error_arg) {
}
name = calloc(head - namestart + 1, 1);
if (head != namestart) {
- strncpy(name, namestart, head - namestart);
+ memcpy(name, namestart, head - namestart);
}
// Parse token value
skip_spaces(&head);
@@ -709,7 +709,7 @@ struct criteria *criteria_parse(char *raw, char **error_arg) {
}
}
value = calloc(head - valuestart + 1, 1);
- strncpy(value, valuestart, head - valuestart);
+ memcpy(value, valuestart, head - valuestart);
if (in_quotes) {
++head;
in_quotes = false;
@@ -740,7 +740,7 @@ struct criteria *criteria_parse(char *raw, char **error_arg) {
++head;
int len = head - raw;
criteria->raw = calloc(len + 1, 1);
- strncpy(criteria->raw, raw, len);
+ memcpy(criteria->raw, raw, len);
return criteria;
cleanup: