tdb: allow reads after prepare commit
[ccan] / tools / ccanlint / ccanlint.h
index ee12ce04fb81083c228e2ac47604c27ed39e25b8..d832332dc757197280b6ac3c4eb79427781a0b75 100644 (file)
@@ -11,6 +11,7 @@
 #define REGISTER_TEST(name, ...) 
 
 struct manifest {
+       /* The module name, ie. final element of dir name */
        char *basename;
        struct ccan_file *info_file;
 
@@ -24,9 +25,14 @@ struct manifest {
        struct list_head other_test_files;
 
        struct list_head other_files;
+
+       /* From tests/check_depends_exist.c */
+       struct list_head dep_dirs;
+       /* From tests/check_depends_built.c */
+       struct list_head dep_objs;
 };
 
-struct manifest *get_manifest(void);
+struct manifest *get_manifest(const void *ctx);
 
 struct ccanlint {
        struct list_node list;
@@ -37,6 +43,9 @@ struct ccanlint {
        /* Total score that this test is worth.  0 means compulsory tests. */
        unsigned int total_score;
 
+       /* Can we run this test?  Return string explaining why, if not. */
+       const char *(*can_run)(struct manifest *m);
+
        /* If this returns non-NULL, it means the check failed. */
        void *(*check)(struct manifest *m);
 
@@ -56,6 +65,10 @@ struct ccanlint {
        struct list_head dependencies;
        /* How many things do we (still) depend on? */
        unsigned int num_depends;
+       /* Did we skip a dependency?  If so, must skip this, too. */
+       bool skip;
+       /* Did we fail a dependency?  If so, skip and mark as fail. */
+       bool skip_fail;
 };
 
 /* Ask the user a yes/no question: the answer is NO if there's an error. */
@@ -113,6 +126,9 @@ struct ccan_file {
        struct list_head *doc_sections;
 };
 
+/* A new ccan_file, with the given name (talloc_steal onto returned value). */
+struct ccan_file *new_ccan_file(const void *ctx, char *name);
+
 /* Use this rather than accessing f->lines directly: loads on demand. */
 char **get_ccan_file_lines(struct ccan_file *f);
 
@@ -155,4 +171,7 @@ struct dependent {
        struct ccanlint *dependent;
 };
 
+/* Are we happy to compile stuff, or just non-intrusive tests? */
+extern bool safe_mode;
+
 #endif /* CCAN_LINT_H */