Clean up mdb_copy.
authorHallvard Furuseth <hallvard@openldap.org>
Wed, 11 Dec 2013 10:57:12 +0000 (11:57 +0100)
committerHallvard Furuseth <hallvard@openldap.org>
Wed, 11 Dec 2013 10:57:12 +0000 (11:57 +0100)
Support MDB_NOSUBDIR. Catch more errors.  Write messages
to stderr, not stdout which the data too may be piped to.

libraries/liblmdb/mdb_copy.1
libraries/liblmdb/mdb_copy.c

index 9b053f97d518be547fdf2665338086fb9e67306a..b4ab7531a8685fb60c5d3b2fc323b01a054a8bb1 100644 (file)
@@ -5,7 +5,11 @@
 mdb_copy \- LMDB environment copy tool
 .SH SYNOPSIS
 .B mdb_copy
-.I srcpath\ [dstpath]
+[\c
+.BR \-n ]
+.B srcpath
+[\c
+.BR dstpath ]
 .SH DESCRIPTION
 The
 .B mdb_copy
@@ -19,6 +23,10 @@ is specified it must be the path of an empty directory
 for storing the backup. Otherwise, the backup will be
 written to stdout.
 
+.SH OPTIONS
+.BR \-n
+Open LDMB environment(s) which do not use subdirectories.
+
 .SH DIAGNOSTICS
 Exit status is zero if no errors occur.
 Errors result in a non-zero exit status and
index ca92009cffda2e7e3da1a8e76e23befde8d2f2b8..bbf0dc902ba3327e267d5a9fae36b90732c064c9 100644 (file)
@@ -31,10 +31,18 @@ int main(int argc,char * argv[])
 {
        int rc;
        MDB_env *env;
-       char *envname = argv[1];
+       const char *progname = argv[0], *act;
+       unsigned flags = MDB_RDONLY;
+
+       for (; argc > 1 && argv[1][0] == '-'; argc--, argv++) {
+               if (argv[1][1] == 'n' && argv[1][2] == '\0')
+                       flags |= MDB_NOSUBDIR;
+               else
+                       argc = 0;
+       }
 
        if (argc<2 || argc>3) {
-               fprintf(stderr, "usage: %s srcpath [dstpath]\n", argv[0]);
+               fprintf(stderr, "usage: %s [-n] srcpath [dstpath]\n", progname);
                exit(EXIT_FAILURE);
        }
 
@@ -47,19 +55,21 @@ int main(int argc,char * argv[])
        signal(SIGINT, sighandle);
        signal(SIGTERM, sighandle);
 
+       act = "opening environment";
        rc = mdb_env_create(&env);
-
-       rc = mdb_env_open(env, envname, MDB_RDONLY, 0);
-       if (rc) {
-               printf("mdb_env_open failed, error %d %s\n", rc, mdb_strerror(rc));
-       } else {
+       if (rc == MDB_SUCCESS) {
+               rc = mdb_env_open(env, argv[1], flags, 0);
+       }
+       if (rc == MDB_SUCCESS) {
+               act = "copying";
                if (argc == 2)
                        rc = mdb_env_copyfd(env, MDB_STDOUT);
                else
                        rc = mdb_env_copy(env, argv[2]);
-               if (rc)
-                       printf("mdb_env_copy failed, error %d %s\n", rc, mdb_strerror(rc));
        }
+       if (rc)
+               fprintf(stderr, "%s: %s failed, error %d (%s)\n",
+                       progname, act, rc, mdb_strerror(rc));
        mdb_env_close(env);
 
        return rc ? EXIT_FAILURE : EXIT_SUCCESS;