]> granicus.if.org Git - vim/commitdiff
patch 8.2.3498: recover test may fail on some systems v8.2.3498
authorJames McCoy <jamessan@jamessan.com>
Mon, 11 Oct 2021 20:04:37 +0000 (21:04 +0100)
committerBram Moolenaar <Bram@vim.org>
Mon, 11 Oct 2021 20:04:37 +0000 (21:04 +0100)
Problem:    Recover test may fail on some systems.
Solution:   Adjust the little endian and 64 bit detection. (James McCoy,
            closes #8941)

src/testdir/test_recover.vim
src/version.c

index 9d2588313ea45b683d0b41a49ebf6188ab8c2fcd..d0129747bb0677182008f97ae54761e5dc5be8a1 100644 (file)
@@ -208,9 +208,11 @@ func Test_recover_corrupted_swap_file()
   " Not all fields are written in a system-independent manner.  Detect whether
   " the test is running on a little or big-endian system, so the correct
   " corruption values can be set.
-  let little_endian = b[1008:1011] == 0z33323130
-  " The swap file header fields can be either 32-bit or 64-bit.
-  let system_64bit = b[1012:1015] == 0z00000000
+  " The B0_MAGIC_LONG field may be 32-bit or 64-bit, depending on the system,
+  " even though the value stored is only 32-bits.  Therefore, need to check
+  " both the high and low 32-bits to compute these values.
+  let little_endian = (b[1008:1011] == 0z33323130) || (b[1012:1015] == 0z33323130)
+  let system_64bit = little_endian ? (b[1012:1015] == 0z00000000) : (b[1008:1011] == 0z00000000)
 
   " clear the B0_MAGIC_LONG field
   if system_64bit
index c360692f2c2b29b91f0b65687ba7c254a2b7ef8a..c916c5e89ed49e4fa5ad2c3a013da07527b16981 100644 (file)
@@ -757,6 +757,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    3498,
 /**/
     3497,
 /**/