Author: jelmer
Date: 2007-08-04 13:13:08 +0000 (Sat, 04 Aug 2007)
New Revision: 24175

WebSVN: 
http://websvn.samba.org/cgi-bin/viewcvs.cgi?view=rev&root=samba&rev=24175

Log:
Fix regdiff and update for new API.

Modified:
   branches/4.0-regwrite/
   branches/4.0-regwrite/source/lib/registry/tools/regdiff.c


Changeset:

Property changes on: branches/4.0-regwrite
___________________________________________________________________
Name: bzr:revision-info
   - timestamp: Sun 2007-01-14 05:27:37.785000086 +0100
committer: Wilco Baan Hofman <[EMAIL PROTECTED]>
properties: 
        branch-nick: 4.0-regwrite
        rebase-of: [EMAIL PROTECTED]

   + timestamp: Sun 2007-01-14 05:35:01.158999920 +0100
committer: Wilco Baan Hofman <[EMAIL PROTECTED]>
properties: 
        branch-nick: 4.0-regwrite
        rebase-of: [EMAIL PROTECTED]

Name: bzr:revision-id:v3-trunk0
   - 11140 [EMAIL PROTECTED]
11142 [EMAIL PROTECTED]
11143 [EMAIL PROTECTED]
11144 [EMAIL PROTECTED]
11145 [EMAIL PROTECTED]
11146 [EMAIL PROTECTED]
11147 [EMAIL PROTECTED]

   + 11140 [EMAIL PROTECTED]
11142 [EMAIL PROTECTED]
11143 [EMAIL PROTECTED]
11144 [EMAIL PROTECTED]
11145 [EMAIL PROTECTED]
11146 [EMAIL PROTECTED]
11147 [EMAIL PROTECTED]
11148 [EMAIL PROTECTED]


Modified: branches/4.0-regwrite/source/lib/registry/tools/regdiff.c
===================================================================
--- branches/4.0-regwrite/source/lib/registry/tools/regdiff.c   2007-08-04 
13:13:02 UTC (rev 24174)
+++ branches/4.0-regwrite/source/lib/registry/tools/regdiff.c   2007-08-04 
13:13:08 UTC (rev 24175)
@@ -2,7 +2,8 @@
    Unix SMB/CIFS implementation.
    simple registry frontend
    
-   Copyright (C) Jelmer Vernooij 2004-2005
+   Copyright (C) Jelmer Vernooij 2004-2006
+   Copyright (C) Wilco Baan Hofman 2006
 
    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
@@ -25,7 +26,7 @@
 #include "lib/registry/reg_backend_rpc.h"
 #include "lib/cmdline/popt_common.h"
 
-int main(int argc, char **argv)
+int main(int argc, const char **argv)
 {
        int opt;
        poptContext pc;
@@ -33,22 +34,24 @@
        struct registry_context *h1 = NULL, *h2 = NULL;
        int from_null = 0;
        WERROR error;
-       struct reg_diff *diff;
        struct poptOption long_options[] = {
                POPT_AUTOHELP
-               {"output", 'o', POPT_ARG_STRING, &outputfile, 'o', "output file 
to use", NULL },
-               {"null", 'n', POPT_ARG_NONE, &from_null, 'n', "Diff from NULL", 
NULL },
-               {"remote", 'R', POPT_ARG_STRING, NULL, 0, "Connect to remote 
server" , NULL },
-               {"local", 'L', POPT_ARG_NONE, NULL, 0, "Open local registry", 
NULL },
+               {"output", 'o', POPT_ARG_STRING, &outputfile, 0, "output file 
to use", NULL },
+               {"null", 'n', POPT_ARG_NONE, &from_null, 0, "Diff from NULL", 
NULL },
+               {"remote", 'R', POPT_ARG_STRING, NULL, 'R', "Connect to remote 
server" , NULL },
+               {"local", 'L', POPT_ARG_NONE, NULL, 'L', "Open local registry", 
NULL },
                POPT_COMMON_SAMBA
                POPT_COMMON_CREDENTIALS
                POPT_COMMON_VERSION
                { NULL }
        };
+       TALLOC_CTX *ctx = talloc_init("regdiff");
+       void *callback_data;
+       struct reg_diff_callbacks *callbacks;
 
        registry_init();
 
-       pc = poptGetContext(argv[0], argc, (const char **) argv, 
long_options,0);
+       pc = poptGetContext(argv[0], argc, argv, long_options,0);
 
        while((opt = poptGetNextOpt(pc)) != -1) {
                error = WERR_OK;
@@ -74,13 +77,21 @@
 
        poptFreeContext(pc);
 
-       diff = reg_generate_diff(NULL, h1, h2);
-       if (!diff) {
-               fprintf(stderr, "Unable to generate diff between keys\n");
+       if (h1 == NULL || h2 == NULL) {
+               fprintf(stderr, "Please specify two contexts.\n");
                return -1;
+       }       
+       error = reg_diff_save(ctx, outputfile, REG_DIFF_DOTREG, &callbacks, 
&callback_data);
+       if (!W_ERROR_IS_OK(error)) {
+               fprintf(stderr, "Problem saving registry diff to '%s': %s\n", 
outputfile, win_errstr(error));
+               return -1;
        }
+       error = reg_generate_diff(h1, h2, callbacks, callback_data);
+       if (!W_ERROR_IS_OK(error)) {
+               fprintf(stderr, "Unable to generate diff between keys: %s\n", 
win_errstr(error));
+               return -1;
+       }
 
-       reg_diff_save(diff, outputfile);
 
        return 0;
 }

Reply via email to