From 02209d75180d76d8effa331f5a4e084718ff3221 Mon Sep 17 00:00:00 2001 From: Ivan Maidanski Date: Thu, 20 Apr 2017 11:50:03 +0300 Subject: [PATCH] Eliminate 'possible loss of data' compiler warnings in cord (MS VC) (Cherry-pick commit 1060ec9 from 'release-7_6' branch.) * cord/cordbscs.c (CORD_cat_char_star, CORD_cat, CORD_from_fn_inner): Add explicit cast in assignment of result->depth, result->len. * cord/cordbscs.c (CORD_substr_checked): Change type of "j", "lim" local variables from int to size_t. * cord/cordbscs.c (CORD_init_min_len): Add explicit cast (to int) in assignment of CORD_max_len. * cord/cordxtra.c (CORD_ncmp): Add explicit cast (to long) when "avail" local variable is updated. * cord/cordxtra.c (CORD_chr, CORD_rchr, CORD_from_file_eager): Add explicit cast to char (from int) for "c" local variable in assignment of d.target and in CORD_ec_append call. * cord/cordxtra.c (refill_cache): Add explicit cast to long (from size_t) for line_start in fseek call. * cord/tests/de.c (line_pos, fix_pos, do_command): Add explicit cast to int in assignment of *c, line, col. * cord/tests/de.c (do_command): Reset line, col and file_pos variables (of different types) in separate statements. * cord/tests/de_win.c (WinMain): Add explicit cast of msg.wParam to int in return statement. --- cord/cordbscs.c | 16 ++++++++-------- cord/cordxtra.c | 11 ++++++----- cord/tests/de.c | 10 ++++++---- cord/tests/de_win.c | 2 +- 4 files changed, 21 insertions(+), 18 deletions(-) diff --git a/cord/cordbscs.c b/cord/cordbscs.c index 277d1362..63753563 100644 --- a/cord/cordbscs.c +++ b/cord/cordbscs.c @@ -220,10 +220,10 @@ CORD CORD_cat_char_star(CORD x, const char * y, size_t leny) result = GC_NEW(struct Concatenation); if (result == 0) OUT_OF_MEMORY; result->header = CONCAT_HDR; - result->depth = depth; + result->depth = (char)depth; if (lenx <= MAX_LEFT_LEN) result->left_len = (unsigned char)lenx; - result->len = result_len; + result->len = (word)result_len; result->left = x; result->right = y; if (depth >= MAX_DEPTH) { @@ -262,10 +262,10 @@ CORD CORD_cat(CORD x, CORD y) result = GC_NEW(struct Concatenation); if (result == 0) OUT_OF_MEMORY; result->header = CONCAT_HDR; - result->depth = depth; + result->depth = (char)depth; if (lenx <= MAX_LEFT_LEN) result->left_len = (unsigned char)lenx; - result->len = result_len; + result->len = (word)result_len; result->left = x; result->right = y; if (depth >= MAX_DEPTH) { @@ -307,7 +307,7 @@ CORD CORD_from_fn(CORD_fn fn, void * client_data, size_t len) if (result == 0) OUT_OF_MEMORY; result->header = FN_HDR; /* depth is already 0 */ - result->len = len; + result->len = (word)len; result->fn = fn; result->client_data = client_data; return((CORD) result); @@ -433,8 +433,8 @@ CORD CORD_substr_checked(CORD x, size_t i, size_t n) char buf[SUBSTR_LIMIT+1]; register char * p = buf; register char c; - register int j; - register int lim = i + n; + register size_t j; + register size_t lim = i + n; for (j = i; j < lim; j++) { c = (*(f -> fn))(j, f -> client_data); @@ -614,7 +614,7 @@ void CORD_init_min_len(void) previous = last; last = current; } - CORD_max_len = last - 1; + CORD_max_len = (int)last - 1; min_len_init = 1; } diff --git a/cord/cordxtra.c b/cord/cordxtra.c index a185185c..025549b9 100644 --- a/cord/cordxtra.c +++ b/cord/cordxtra.c @@ -226,7 +226,8 @@ int CORD_ncmp(CORD x, size_t x_start, CORD y, size_t y_start, size_t len) if (avail > yavail) avail = yavail; count += avail; - if (count > len) avail -= (count - len); + if (count > len) + avail -= (long)(count - len); result = strncmp(CORD_pos_cur_char_addr(xpos), CORD_pos_cur_char_addr(ypos), (size_t)avail); if (result != 0) return(result); @@ -344,7 +345,7 @@ size_t CORD_chr(CORD x, size_t i, int c) chr_data d; d.pos = i; - d.target = c; + d.target = (char)c; if (CORD_iter5(x, i, CORD_chr_proc, CORD_batched_chr_proc, &d)) { return(d.pos); } else { @@ -357,7 +358,7 @@ size_t CORD_rchr(CORD x, size_t i, int c) chr_data d; d.pos = i; - d.target = c; + d.target = (char)c; if (CORD_riter4(x, i, CORD_rchr_proc, &d)) { return(d.pos); } else { @@ -473,7 +474,7 @@ CORD CORD_from_file_eager(FILE * f) ecord[0].ec_cord = CORD_cat(ecord[0].ec_cord, CORD_nul(count)); } if (c == EOF) break; - CORD_ec_append(ecord, c); + CORD_ec_append(ecord, (char)c); } (void) fclose(f); return(CORD_balance(CORD_ec_to_cord(ecord))); @@ -532,7 +533,7 @@ static char refill_cache(refill_data * client_data) cache_line * new_cache = client_data -> new_cache; if (line_start != state -> lf_current - && fseek(f, line_start, SEEK_SET) != 0) { + && fseek(f, (long)line_start, SEEK_SET) != 0) { ABORT("fseek failed"); } if (fread(new_cache -> data, sizeof(char), LINE_SZ, f) diff --git a/cord/tests/de.c b/cord/tests/de.c index 84aa4de8..403dcaee 100644 --- a/cord/tests/de.c +++ b/cord/tests/de.c @@ -179,7 +179,7 @@ size_t line_pos(int i, int *c) next = CORD_chr(current, cur, '\n'); if (next == CORD_NOT_FOUND) next = current_len - 1; if (next < cur + *c) { - *c = next - cur; + *c = (int)(next - cur); } cur += *c; } @@ -347,7 +347,8 @@ void fix_pos(void) { int my_col = col; - if ((size_t)line > current_len) line = current_len; + if ((size_t)line > current_len) + line = (int)current_len; file_pos = line_pos(line, &my_col); if (file_pos == CORD_NOT_FOUND) { for (line = current_map -> line, file_pos = current_map -> pos; @@ -428,7 +429,7 @@ void do_command(int c) if (file_pos > new_pos) break; line++; } - col = new_pos - line_pos(line, 0); + col = (int)(new_pos - line_pos(line, 0)); file_pos = new_pos; fix_cursor(); } else { @@ -459,7 +460,8 @@ void do_command(int c) locate_mode = 1; break; case TOP: - line = col = file_pos = 0; + line = col = 0; + file_pos = 0; break; case UP: if (line != 0) { diff --git a/cord/tests/de_win.c b/cord/tests/de_win.c index 23c1e2a1..19739e8a 100644 --- a/cord/tests/de_win.c +++ b/cord/tests/de_win.c @@ -119,7 +119,7 @@ int APIENTRY WinMain (HINSTANCE hInstance, HINSTANCE hPrevInstance, DispatchMessage (&msg); } } - return msg.wParam; + return (int)msg.wParam; } /* Return the argument with all control characters replaced by blanks. */ -- 2.40.0