diff options
author | Eliseo Martínez <eliseomarmol@gmail.com> | 2015-02-11 19:47:43 +0100 |
---|---|---|
committer | Eliseo Martínez <eliseomarmol@gmail.com> | 2015-02-11 19:47:43 +0100 |
commit | e177357fc8da94571d7c476d2260928dc2a8b948 (patch) | |
tree | 4473f187297541923193b9d271438a7697c2982a /src/nvim/hardcopy.c | |
parent | 5976251bb91a7d3967cf268f0eeed1f5d756ba7a (diff) | |
parent | bbfaa78dcdc1f4e3e7631c5ce6f4937bf932dc20 (diff) | |
download | rneovim-e177357fc8da94571d7c476d2260928dc2a8b948.tar.gz rneovim-e177357fc8da94571d7c476d2260928dc2a8b948.tar.bz2 rneovim-e177357fc8da94571d7c476d2260928dc2a8b948.zip |
Merge #1947: Fix coverity issues. (4)
Diffstat (limited to 'src/nvim/hardcopy.c')
-rw-r--r-- | src/nvim/hardcopy.c | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/src/nvim/hardcopy.c b/src/nvim/hardcopy.c index fb04f4407c..c01f763d20 100644 --- a/src/nvim/hardcopy.c +++ b/src/nvim/hardcopy.c @@ -2122,19 +2122,25 @@ int mch_print_init(prt_settings_T *psettings, char_u *jobname, int forceit) props = enc_canon_props(p_encoding); if (!(props & ENC_8BIT) && ((*p_pmcs != NUL) || !(props & ENC_UNICODE))) { p_mbenc_first = NULL; + int effective_cmap; for (cmap = 0; cmap < (int)ARRAY_SIZE(prt_ps_mbfonts); cmap++) if (prt_match_encoding((char *)p_encoding, &prt_ps_mbfonts[cmap], - &p_mbenc)) { - if (p_mbenc_first == NULL) + &p_mbenc)) { + if (p_mbenc_first == NULL) { p_mbenc_first = p_mbenc; - if (prt_match_charset((char *)p_pmcs, &prt_ps_mbfonts[cmap], - &p_mbchar)) + effective_cmap = cmap; + } + if (prt_match_charset((char *)p_pmcs, &prt_ps_mbfonts[cmap], &p_mbchar)) break; } /* Use first encoding matched if no charset matched */ - if (p_mbchar == NULL && p_mbenc_first != NULL) + if (p_mbchar == NULL && p_mbenc_first != NULL) { p_mbenc = p_mbenc_first; + cmap = effective_cmap; + } + + assert(p_mbenc == NULL || cmap < (int)ARRAY_SIZE(prt_ps_mbfonts)); } prt_out_mbyte = (p_mbenc != NULL); |