/* Copyright (c) 2013 Red Hat, Inc. This file is part of GlusterFS. This file is licensed to you under your choice of the GNU Lesser General Public License, version 3 or any later version (LGPLv3 or later), or the GNU General Public License, version 2 (GPLv2), in all cases as published by the Free Software Foundation. */ /** * get set of new changes every 10 seconds (just print the file names) * * Compile it using: * gcc -o gethistory `pkg-config --cflags libgfchangelog` get-history.c \ * `pkg-config --libs libgfchangelog` */ #include #include #include #include #include #include #include #include #include "changelog.h" #define handle_error(fn) \ printf ("%s (reason: %s)\n", fn, strerror (errno)) int main (int argc, char ** argv) { int i = 0; int ret = 0; ssize_t nr_changes = 0; ssize_t changes = 0; char fbuf[PATH_MAX] = {0,}; unsigned long end_ts = 0; ret = gf_changelog_init (NULL); if (ret) { handle_error ("init failed"); goto out; } ret = gf_changelog_register ("/export/z1/zwoop", "/tmp/scratch_v1", "/tmp/changes.log", 9, 5); if (ret) { handle_error ("register failed"); goto out; } int a, b; printf ("give the two numbers start and end\t"); scanf ("%d%d", &a, &b); ret = gf_history_changelog ("/export/z1/zwoop/.glusterfs/changelogs", a, b, 3, &end_ts); if (ret == -1) { printf ("history failed"); goto out; } printf ("end time till when changelog available : %d , ret(%d) \t", end_ts, ret); fflush(stdout); while (1) { nr_changes = gf_history_changelog_scan (); printf ("scanned, nr_changes : %d\n",nr_changes); if (nr_changes < 0) { handle_error ("scan(): "); break; } if (nr_changes == 0) { printf ("done scanning \n"); goto out; } printf ("Got %ld changelog files\n", nr_changes); while ( (changes = gf_history_changelog_next_change (fbuf, PATH_MAX)) > 0) { printf ("changelog file [%d]: %s\n", ++i, fbuf); /* process changelog */ /* ... */ /* ... */ /* ... */ /* done processing */ ret = gf_history_changelog_done (fbuf); if (ret) handle_error ("gf_changelog_done"); } /* if (changes == -1) handle_error ("gf_changelog_next_change"); if (nr_changes ==1){ printf("continue scanning\n"); } if(nr_changes == 0){ printf("done scanning \n"); goto out; } */ } out: return ret; }