diff options
author | Jason A. Donenfeld | 2018-07-04 03:13:31 +0200 |
---|---|---|
committer | Jason A. Donenfeld | 2018-07-04 03:13:41 +0200 |
commit | 08a2b1b8f812c6d77489467c8ff120979c297bed (patch) | |
tree | 68b95757d8f410a82b2f1bb01440cc7cf0e0ed63 /ui-ssdiff.c | |
parent | c4167cbd65acef801e6132ba1182f6ce246ed630 (diff) | |
download | cgit-08a2b1b8f812c6d77489467c8ff120979c297bed.tar.gz cgit-08a2b1b8f812c6d77489467c8ff120979c297bed.tar.bz2 cgit-08a2b1b8f812c6d77489467c8ff120979c297bed.zip |
Fix gcc 8.1.1 compiler warnings
CC ../shared.o
../shared.c: In function ‘expand_macro’:
../shared.c:487:3: warning: ‘strncpy’ specified bound depends on the length of the source argument [-Wstringop-overflow=]
strncpy(name, value, len);
^~~~~~~~~~~~~~~~~~~~~~~~~
../shared.c:484:9: note: length computed here
len = strlen(value);
^~~~~~~~~~~~~
../ui-shared.c: In function ‘cgit_repobasename’:
../ui-shared.c:136:2: warning: ‘strncpy’ specified bound 1024 equals destination size [-Wstringop-truncation]
strncpy(rvbuf, reponame, sizeof(rvbuf));
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
CC ../ui-ssdiff.o
../ui-ssdiff.c: In function ‘replace_tabs’:
../ui-ssdiff.c:142:4: warning: ‘strncat’ output truncated copying between 1 and 8 bytes from a string of length 8 [-Wstringop-truncation]
strncat(result, spaces, 8 - (strlen(result) % 8));
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
Diffstat (limited to 'ui-ssdiff.c')
-rw-r--r-- | ui-ssdiff.c | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/ui-ssdiff.c b/ui-ssdiff.c index 7f261ed..68c2044 100644 --- a/ui-ssdiff.c +++ b/ui-ssdiff.c | |||
@@ -114,11 +114,10 @@ static char *replace_tabs(char *line) | |||
114 | { | 114 | { |
115 | char *prev_buf = line; | 115 | char *prev_buf = line; |
116 | char *cur_buf; | 116 | char *cur_buf; |
117 | int linelen = strlen(line); | 117 | size_t linelen = strlen(line); |
118 | int n_tabs = 0; | 118 | int n_tabs = 0; |
119 | int i; | 119 | int i; |
120 | char *result; | 120 | char *result; |
121 | char *spaces = " "; | ||
122 | 121 | ||
123 | if (linelen == 0) { | 122 | if (linelen == 0) { |
124 | result = xmalloc(1); | 123 | result = xmalloc(1); |
@@ -126,20 +125,23 @@ static char *replace_tabs(char *line) | |||
126 | return result; | 125 | return result; |
127 | } | 126 | } |
128 | 127 | ||
129 | for (i = 0; i < linelen; i++) | 128 | for (i = 0; i < linelen; i++) { |
130 | if (line[i] == '\t') | 129 | if (line[i] == '\t') |
131 | n_tabs += 1; | 130 | n_tabs += 1; |
131 | } | ||
132 | result = xmalloc(linelen + n_tabs * 8 + 1); | 132 | result = xmalloc(linelen + n_tabs * 8 + 1); |
133 | result[0] = '\0'; | 133 | result[0] = '\0'; |
134 | 134 | ||
135 | while (1) { | 135 | for (;;) { |
136 | cur_buf = strchr(prev_buf, '\t'); | 136 | cur_buf = strchr(prev_buf, '\t'); |
137 | if (!cur_buf) { | 137 | if (!cur_buf) { |
138 | strcat(result, prev_buf); | 138 | strcat(result, prev_buf); |
139 | break; | 139 | break; |
140 | } else { | 140 | } else { |
141 | strncat(result, prev_buf, cur_buf - prev_buf); | 141 | strncat(result, prev_buf, cur_buf - prev_buf); |
142 | strncat(result, spaces, 8 - (strlen(result) % 8)); | 142 | linelen = strlen(result); |
143 | memset(&result[linelen], ' ', 8 - (linelen % 8)); | ||
144 | result[linelen + 8 - (linelen % 8)] = '\0'; | ||
143 | } | 145 | } |
144 | prev_buf = cur_buf + 1; | 146 | prev_buf = cur_buf + 1; |
145 | } | 147 | } |