From 0677b12f2273ed266da9dd276c129342d6a939a2 Mon Sep 17 00:00:00 2001 From: Richard Jones Date: Thu, 9 Apr 2009 19:35:16 +0100 Subject: [PATCH] Add aug-ls command (non-generated code). --- daemon/augeas.c | 43 +++++++++++++++++++++++++++++++++++++++++++ src/generator.ml | 6 ++++++ 2 files changed, 49 insertions(+) diff --git a/daemon/augeas.c b/daemon/augeas.c index 2b27387..04c4a7a 100644 --- a/daemon/augeas.c +++ b/daemon/augeas.c @@ -276,3 +276,46 @@ do_aug_load (void) return 0; } + +/* Simpler version of aug-match, which also sorts the output. */ +char ** +do_aug_ls (const char *path) +{ + char **matches; + char *buf; + int len; + + NEED_AUG (NULL); + + ABS_PATH (path, NULL); + + len = strlen (path); + + if (len > 1 && + (path[len-1] == '/' || path[len-1] == ']' || path[len-1] == '*')) { + reply_with_error ("don't use aug-ls with a path that ends with / ] *"); + return NULL; + } + + if (len == 1) + /* we know path must be "/" because of ABS_PATH above */ + matches = do_aug_match ("/"); + else { + len += 3; /* / * + terminating \0 */ + buf = malloc (len); + if (buf == NULL) { + reply_with_perror ("malloc"); + return NULL; + } + + snprintf (buf, len, "%s/*", path); + matches = do_aug_match (buf); + free (buf); + } + + if (matches == NULL) + return NULL; /* do_aug_match has already sent the error */ + + sort_strings (matches, count_strings (matches)); + return matches; /* Caller frees. */ +} diff --git a/src/generator.ml b/src/generator.ml index 4279c0d..c8809e4 100755 --- a/src/generator.ml +++ b/src/generator.ml @@ -473,6 +473,12 @@ Load files into the tree. See C in the Augeas documentation for the full gory details."); + + ("aug_ls", (RStringList "matches", P1 (String "path")), 28, [], + "list Augeas nodes under a path", + "\ +This is just a shortcut for listing C +C and sorting the files into alphabetical order."); ] let all_functions = non_daemon_functions @ daemon_functions -- 1.8.3.1