Commit 794e1a12 authored by Rusty Russell's avatar Rusty Russell

Cleanup: rename is_* to starts_*, move functions together, factor out start finding code.

parent 86c41caf
...@@ -320,12 +320,12 @@ static void op_add_transaction(const char *filename, struct op op[], ...@@ -320,12 +320,12 @@ static void op_add_transaction(const char *filename, struct op op[],
op[op_num].group_len = 0; op[op_num].group_len = 0;
} }
static int op_transaction_start(struct op op[], unsigned int op_num) static int op_find_start(struct op op[], unsigned int op_num, enum op_type type)
{ {
unsigned int i; unsigned int i;
for (i = op_num-1; i > 0; i--) { for (i = op_num-1; i > 0; i--) {
if (op[i].op == OP_TDB_TRANSACTION_START && !op[i].group_len) if (op[i].op == type && !op[i].group_len)
return i; return i;
} }
return 0; return 0;
...@@ -342,7 +342,7 @@ static void op_analyze_transaction(const char *filename, ...@@ -342,7 +342,7 @@ static void op_analyze_transaction(const char *filename,
if (words[2]) if (words[2])
fail(filename, op_num+1, "Expect no arguments"); fail(filename, op_num+1, "Expect no arguments");
start = op_transaction_start(op, op_num); start = op_find_start(op, op_num, OP_TDB_TRANSACTION_START);
if (!start) if (!start)
fail(filename, op_num+1, "no transaction start found"); fail(filename, op_num+1, "no transaction start found");
...@@ -353,11 +353,6 @@ static void op_analyze_transaction(const char *filename, ...@@ -353,11 +353,6 @@ static void op_analyze_transaction(const char *filename,
op[i].group_start = start; op[i].group_start = start;
} }
struct traverse_hash {
TDB_DATA key;
unsigned int index;
};
static void op_analyze_traverse(const char *filename, static void op_analyze_traverse(const char *filename,
struct op op[], unsigned int op_num, struct op op[], unsigned int op_num,
char *words[]) char *words[])
...@@ -374,19 +369,12 @@ static void op_analyze_traverse(const char *filename, ...@@ -374,19 +369,12 @@ static void op_analyze_traverse(const char *filename,
} else } else
op[op_num].ret = 0; op[op_num].ret = 0;
for (i = op_num-1; i >= 0; i--) { start = op_find_start(op, op_num, OP_TDB_TRAVERSE_START);
if (op[i].op != OP_TDB_TRAVERSE_READ_START if (!start)
&& op[i].op != OP_TDB_TRAVERSE_START) start = op_find_start(op, op_num, OP_TDB_TRAVERSE_READ_START);
continue; if (!start)
if (op[i].group_len)
continue;
break;
}
if (i < 0)
fail(filename, op_num+1, "no traversal start found"); fail(filename, op_num+1, "no traversal start found");
start = i;
op[start].group_len = op_num - start; op[start].group_len = op_num - start;
for (i = start; i <= op_num; i++) for (i = start; i <= op_num; i++)
...@@ -743,7 +731,7 @@ unsigned run_ops(struct tdb_context *tdb, ...@@ -743,7 +731,7 @@ unsigned run_ops(struct tdb_context *tdb,
static struct op *maybe_cancel_transaction(const char *filename, static struct op *maybe_cancel_transaction(const char *filename,
struct op *op, unsigned int *num) struct op *op, unsigned int *num)
{ {
unsigned int start = op_transaction_start(op, *num); unsigned int start = op_find_start(op, *num, OP_TDB_TRANSACTION_START);
if (start) { if (start) {
char *words[] = { "<unknown>", "tdb_close", NULL }; char *words[] = { "<unknown>", "tdb_close", NULL };
...@@ -904,16 +892,32 @@ static const TDB_DATA *needs(const struct op *op) ...@@ -904,16 +892,32 @@ static const TDB_DATA *needs(const struct op *op)
} }
static bool is_transaction(const struct op *op) static bool starts_transaction(const struct op *op)
{ {
return op->op == OP_TDB_TRANSACTION_START; return op->op == OP_TDB_TRANSACTION_START;
} }
static bool in_transaction(const struct op op[], unsigned int i)
{
return op[i].group_start && starts_transaction(&op[op[i].group_start]);
}
static bool starts_traverse(const struct op *op)
{
return op->op == OP_TDB_TRAVERSE_START
|| op->op == OP_TDB_TRAVERSE_READ_START;
}
static bool in_traverse(const struct op op[], unsigned int i)
{
return op[i].group_start && starts_traverse(&op[op[i].group_start]);
}
/* What's the data after this op? pre if nothing changed. */ /* What's the data after this op? pre if nothing changed. */
static const TDB_DATA *gives(const TDB_DATA *key, const TDB_DATA *pre, static const TDB_DATA *gives(const TDB_DATA *key, const TDB_DATA *pre,
const struct op *op) const struct op *op)
{ {
if (is_transaction(op)) { if (starts_transaction(op)) {
unsigned int i; unsigned int i;
/* Cancelled transactions don't change anything. */ /* Cancelled transactions don't change anything. */
...@@ -945,22 +949,6 @@ static const TDB_DATA *gives(const TDB_DATA *key, const TDB_DATA *pre, ...@@ -945,22 +949,6 @@ static const TDB_DATA *gives(const TDB_DATA *key, const TDB_DATA *pre,
return pre; return pre;
} }
static bool in_transaction(const struct op op[], unsigned int i)
{
return op[i].group_start && is_transaction(&op[op[i].group_start]);
}
static bool is_traverse(const struct op *op)
{
return op->op == OP_TDB_TRAVERSE_START
|| op->op == OP_TDB_TRAVERSE_READ_START;
}
static bool in_traverse(const struct op op[], unsigned int i)
{
return op[i].group_start && is_traverse(&op[op[i].group_start]);
}
static struct keyinfo *hash_ops(struct op *op[], unsigned int num_ops[], static struct keyinfo *hash_ops(struct op *op[], unsigned int num_ops[],
unsigned int num) unsigned int num)
{ {
...@@ -1023,7 +1011,7 @@ static bool satisfies(const TDB_DATA *key, const TDB_DATA *data, ...@@ -1023,7 +1011,7 @@ static bool satisfies(const TDB_DATA *key, const TDB_DATA *data,
{ {
const TDB_DATA *need = NULL; const TDB_DATA *need = NULL;
if (is_transaction(op)) { if (starts_transaction(op)) {
unsigned int i; unsigned int i;
/* Look through for an op in this transaction which /* Look through for an op in this transaction which
...@@ -1283,7 +1271,7 @@ static void add_dependency(void *ctx, ...@@ -1283,7 +1271,7 @@ static void add_dependency(void *ctx,
#endif #endif
/* If you depend on a transaction, you actually depend on it ending. */ /* If you depend on a transaction, you actually depend on it ending. */
if (is_transaction(&op[satisfies_file][satisfies_opnum])) { if (starts_transaction(&op[satisfies_file][satisfies_opnum])) {
satisfies_opnum satisfies_opnum
+= op[satisfies_file][satisfies_opnum].group_len; += op[satisfies_file][satisfies_opnum].group_len;
#if DEBUG_DEPS #if DEBUG_DEPS
...@@ -1440,7 +1428,7 @@ static void make_traverse_depends(char *filename[], ...@@ -1440,7 +1428,7 @@ static void make_traverse_depends(char *filename[],
/* Traverse start (ignore those in /* Traverse start (ignore those in
* transactions; they're already covered by * transactions; they're already covered by
* transaction dependencies). */ * transaction dependencies). */
if (is_traverse(&op[i][j]) if (starts_traverse(&op[i][j])
&& !in_transaction(op[i], j)) { && !in_transaction(op[i], j)) {
dep = talloc_realloc(NULL, dep, dep = talloc_realloc(NULL, dep,
struct traverse_dep, struct traverse_dep,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment