]> code.delx.au - gnu-emacs/commitdiff
Use memmove instead of memcpy on overlapping regions
authorFredrik Bergroth <fbergroth@gmail.com>
Tue, 23 Feb 2016 11:41:16 +0000 (22:41 +1100)
committerLars Ingebrigtsen <larsi@gnus.org>
Wed, 24 Feb 2016 00:58:50 +0000 (11:58 +1100)
* src/editfns.c (Ftranspose_regions): Regions may overlap, so
use memmove instead of memcpy (bug#19213).

Copyright-paperwork-exempt: yes

src/editfns.c

index bd70f0a68593dbaa31ab370baca8b80bb0f98fff..2f46cfeb2b421f121c029784663be6bb4910fc59 100644 (file)
@@ -4990,7 +4990,7 @@ Transposing beyond buffer boundaries is an error.  */)
          start2_addr = BYTE_POS_ADDR (start2_byte);
           memcpy (temp, start1_addr, len1_byte);
           memcpy (start1_addr, start2_addr, len2_byte);
-          memcpy (start1_addr + len2_byte, start1_addr + len1_byte, len_mid);
+          memmove (start1_addr + len2_byte, start1_addr + len1_byte, len_mid);
           memcpy (start1_addr + len2_byte + len_mid, temp, len1_byte);
          SAFE_FREE ();