-int fc_process_chain (const data_set_t *ds, value_list_t *vl, /* {{{ */
- fc_chain_t *chain)
-{
- fc_rule_t *rule;
- fc_target_t *target;
- int status;
-
- if (chain == NULL)
- return (-1);
-
- DEBUG ("fc_process_chain (chain = %s);", chain->name);
-
- status = FC_ACTION_CONTINUE;
-
- for (rule = chain->rules; rule != NULL; rule = rule->next)
- {
- fc_match_t *match;
-
- if (rule->name[0] != 0)
- {
- DEBUG ("fc_process_chain: Testing the `%s' rule.", rule->name);
- }
-
- /* N. B.: rule->matches may be NULL. */
- for (match = rule->matches; match != NULL; match = match->next)
- {
- status = (*match->proc.match) (ds, vl, /* meta = */ NULL,
- &match->user_data);
- if (status < 0)
- {
- WARNING ("fc_process_chain: A match failed.");
- break;
- }
- else if (status != FC_MATCH_MATCHES)
- break;
- }
-
- /* for-loop has been aborted: Either error or no match. */
- if (match != NULL)
- continue;
-
- if (rule->name[0] != 0)
- {
- DEBUG ("fc_process_chain: Rule `%s' matches.", rule->name);
- }
-
- for (target = rule->targets; target != NULL; target = target->next)
- {
- /* If we get here, all matches have matched the value. Execute the
- * target. */
- status = (*target->proc.invoke) (ds, vl, /* meta = */ NULL,
- &target->user_data);
- if (status < 0)
- {
- WARNING ("fc_process_chain: A target failed.");
- continue;
- }
- else if (status == FC_ACTION_CONTINUE)
- continue;
- else if (status == FC_ACTION_STOP)
- break;
- else
- {
- WARNING ("fc_process_chain: Unknown target return value: %i", status);
- }
- }
-
- if (status == FC_ACTION_STOP)
- {
- if (rule->name[0] != 0)
- {
- DEBUG ("fc_process_chain: Rule `%s' signaled the stop condition.",
- rule->name);
- }
- break;
- }
- } /* for (rule) */
-
- /* for-loop has been aborted: A target returned `FC_ACTION_STOP' */
- if (rule != NULL)
- return (0);
-
- DEBUG ("fc_process_chain (%s): Executing the default targets.",
- chain->name);
-
- for (target = chain->targets; target != NULL; target = target->next)
- {
- /* If we get here, all matches have matched the value. Execute the
- * target. */
- status = (*target->proc.invoke) (ds, vl, /* meta = */ NULL,
- &target->user_data);
- if (status < 0)
- {
- WARNING ("fc_process_chain (%s): The default target failed.",
- chain->name);
- }
- else if (status == FC_ACTION_CONTINUE)
- continue;
- else if (status == FC_ACTION_STOP)
- break;
- else
- {
- WARNING ("fc_process_chain (%s): Unknown return value "
- "from target `%s': %i",
- chain->name, target->name, status);
- }
- }
-
- if (target != NULL)
- {
- DEBUG ("fc_process_chain (%s): Default target `%s' signaled "
- "the stop condition.",
- chain->name, target->name);
- }
-
- return (0);
-} /* }}} int fc_process_chain */
-