]> git.ozlabs.org Git - ccan/blobdiff - tools/ccan_depends.c
opt: Fix -Wmissing-field-initializers warning
[ccan] / tools / ccan_depends.c
index 982d13b32b9f90e3d555efffc44fa16c8ee0d486..b055e44eb1f53e1aee4c5e6f42731c195ce66555 100644 (file)
@@ -2,20 +2,49 @@
 #include <err.h>
 #include <stdlib.h>
 #include <stdio.h>
-#include "string/string.h"
+#include <ccan/str/str.h>
+#include <ccan/talloc/talloc.h>
 
 int main(int argc, char *argv[])
 {
        char **deps;
        unsigned int i;
+       bool compile = false;
+       bool recurse = true;
+       bool ccan = true;
 
+       if (argv[1] && streq(argv[1], "--direct")) {
+               argv++;
+               argc--;
+               recurse = false;
+       }
+       if (argv[1] && streq(argv[1], "--compile")) {
+               argv++;
+               argc--;
+               compile = true;
+       }
+       if (argv[1] && streq(argv[1], "--non-ccan")) {
+               argv++;
+               argc--;
+               ccan = false;
+       }
        if (argc != 2)
-               errx(1, "Usage: ccan_depends <dir>\n"
-                       "Spits out all the ccan dependencies (recursively)");
+               errx(1, "Usage: ccan_depends [--direct] [--compile] [--non-ccan] <dir>\n"
+                       "Spits out all the ccan dependencies (recursively unless --direct)");
+
+       /* We find depends without compiling by looking for ccan/ */
+       if (!ccan && !compile)
+               errx(1, "--non-ccan needs --compile");
+
+       if (compile)
+               deps = get_deps(talloc_autofree_context(), argv[1],
+                               recurse, NULL);
+       else
+               deps = get_safe_ccan_deps(talloc_autofree_context(),
+                                         argv[1], recurse, NULL);
 
-       deps = get_deps(NULL, argv[1]);
        for (i = 0; deps[i]; i++)
-               if (strstarts(deps[i], "ccan/"))
+               if (strstarts(deps[i], "ccan/") == ccan)
                        printf("%s\n", deps[i]);
        return 0;
 }