guix-commits
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

01/16: gnu: nvi: Fix Berkely DB compatability issues.


From: Ludovic Courtès
Subject: 01/16: gnu: nvi: Fix Berkely DB compatability issues.
Date: Fri, 23 Jan 2015 15:38:57 +0000

civodul pushed a commit to branch master
in repository guix.

commit 2baf46348f0d57f5c17fdf2fa74077bb25c0e787
Author: Marek Benc <address@hidden>
Date:   Thu Jan 22 23:08:16 2015 +0100

    gnu: nvi: Fix Berkely DB compatability issues.
    
    * gnu/packages/patches/nvi-db4.patch: New file.
    * gnu/packages/patches/nvi-dbpagesize-binpower.patch: New file.
    * gnu/packages/nvi.scm (nvi): Make use of them.
    * gnu-system.am (dist_patch_DATA): Add them.
    
    Signed-off-by: Ludovic Courtès <address@hidden>
---
 gnu-system.am                                      |    4 ++-
 gnu/packages/nvi.scm                               |    4 ++-
 gnu/packages/patches/nvi-db4.patch                 |   35 ++++++++++++++++++++
 gnu/packages/patches/nvi-dbpagesize-binpower.patch |   35 ++++++++++++++++++++
 4 files changed, 76 insertions(+), 2 deletions(-)

diff --git a/gnu-system.am b/gnu-system.am
index d1fc59a..5d773ca 100644
--- a/gnu-system.am
+++ b/gnu-system.am
@@ -443,7 +443,9 @@ dist_patch_DATA =                                           
\
   gnu/packages/patches/net-tools-bitrot.patch                  \
   gnu/packages/patches/ninja-tests.patch                       \
   gnu/packages/patches/nss-pkgconfig.patch                     \
-  gnu/packages/patches/nvi-assume-preserve-path.patch           \
+  gnu/packages/patches/nvi-assume-preserve-path.patch          \
+  gnu/packages/patches/nvi-dbpagesize-binpower.patch           \
+  gnu/packages/patches/nvi-db4.patch                           \
   gnu/packages/patches/orpheus-cast-errors-and-includes.patch  \
   gnu/packages/patches/ots-no-include-missing-file.patch       \
   gnu/packages/patches/patchelf-page-size.patch                        \
diff --git a/gnu/packages/nvi.scm b/gnu/packages/nvi.scm
index 8fd736d..128715f 100644
--- a/gnu/packages/nvi.scm
+++ b/gnu/packages/nvi.scm
@@ -37,7 +37,9 @@
                          ".tar.bz2"))
         (sha256
           (base32 "0nbbs1inyrqds0ywn3ln5slv54v5zraq7lszkg8nsavv4kivhh9l"))
-        (patches (list (search-patch "nvi-assume-preserve-path.patch")))
+        (patches (list (search-patch "nvi-assume-preserve-path.patch")
+                       (search-patch "nvi-dbpagesize-binpower.patch")
+                       (search-patch "nvi-db4.patch")))
         (snippet
           ;; Create a wrapper for the configure script, make it executable.
           '(let ((conf-wrap (open-output-file "configure")))
diff --git a/gnu/packages/patches/nvi-db4.patch 
b/gnu/packages/patches/nvi-db4.patch
new file mode 100644
index 0000000..03b736c
--- /dev/null
+++ b/gnu/packages/patches/nvi-db4.patch
@@ -0,0 +1,35 @@
+This patch originates from the Debian project, see https://www.debian.org/
+
+03db4.dpatch  by  <address@hidden>
+
+
+libdb4 compatibility adjustments.
+
+In particular, this patch adds extra file permission checking and passes the
+DB_CREATE flag to the first invocation of db_open on the file's database
+structure, which rids us of the following message:
+
+  BDB0635 DB_CREATE must be specified to create databases.
+
+--- nvi-1.81.6.orig/common/msg.c       2009-02-26 14:26:58.350336128 +0100
++++ nvi-1.81.6/common/msg.c    2009-02-26 14:29:05.235335829 +0100
+@@ -724,9 +724,18 @@
+               p = buf;
+       } else
+               p = file;
++      if (access(p, F_OK) != 0) {
++              if (first) {
++                      first = 0;
++                      return (1);
++              }
++              sp->db_error = ENOENT;
++              msgq_str(sp, M_DBERR, p, "%s");
++              return (1);
++      }
+       if ((sp->db_error = db_create(&db, 0, 0)) != 0 ||
+           (sp->db_error = db->set_re_source(db, p)) != 0 ||
+-          (sp->db_error = db_open(db, NULL, DB_RECNO, 0, 0)) != 0) {
++          (sp->db_error = db_open(db, NULL, DB_RECNO, DB_CREATE, 0)) != 0) {
+               if (first) {
+                       first = 0;
+                       return (1);
diff --git a/gnu/packages/patches/nvi-dbpagesize-binpower.patch 
b/gnu/packages/patches/nvi-dbpagesize-binpower.patch
new file mode 100644
index 0000000..7dde693
--- /dev/null
+++ b/gnu/packages/patches/nvi-dbpagesize-binpower.patch
@@ -0,0 +1,35 @@
+This patch originates from the Debian project, see https://www.debian.org/
+
+18dbpagesize_binpower.dpatch by  <address@hidden>
+
+
+Make sure that the pagesize passed to db__set_pagesize() is a power of two.
+
+nvi stores the content of files in BDB database structures. When initiating a
+file, it picks a page size for the database to fit the file within 15 pages,
+with a minimal page size of 1K and maximal of 10K.
+
+In vanilla nvi, this size is calculated as a multiple of 1024. Modern versions
+of BDB, however, require the page size of a database to be a power of two, 
which
+this patch addresses, ridding us of the following message:
+
+  BDB0511 page sizes must be a power-of-2
+
+--- nvi-1.81.6.orig/common/exf.c       2009-03-09 01:48:01.695862889 +0100
++++ nvi-1.81.6/common/exf.c    2009-03-09 10:42:41.147866272 +0100
+@@ -249,11 +249,10 @@
+                * (vi should have good locality) or smaller than 1K.
+                */
+               psize = ((sb.st_size / 15) + 1023) / 1024;
+-              if (psize > 10)
+-                      psize = 10;
+-              if (psize == 0)
+-                      psize = 1;
+-              psize *= 1024;
++              if (psize >= 8) psize=8<<10;
++              else if (psize >= 4) psize=4<<10;
++              else if (psize >= 2) psize=2<<10;
++              else psize=1<<10;
+ 
+               F_SET(ep, F_DEVSET);
+               ep->mdev = sb.st_dev;



reply via email to

[Prev in Thread] Current Thread [Next in Thread]