summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorslioch <slioch@eng-140.vyatta.com>2009-06-05 16:09:58 -0700
committerslioch <slioch@eng-140.vyatta.com>2009-06-05 16:09:58 -0700
commitb5e2645056339e2c0f9289de5f782ddce6509b12 (patch)
tree790fee4f1cd04a3a8844feb2fb5a1f58d3ecbe4a
parent647cb40c60260a52717334acfb156368f29bf6cf (diff)
downloadvyatta-cfg-b5e2645056339e2c0f9289de5f782ddce6509b12.tar.gz
vyatta-cfg-b5e2645056339e2c0f9289de5f782ddce6509b12.zip
fix for bug 4444.
Post unionfs directory magic until after all actions have been applied to node tree.
-rw-r--r--src/commit2.c37
1 files changed, 22 insertions, 15 deletions
diff --git a/src/commit2.c b/src/commit2.c
index 70e0e99..6b5dc4d 100644
--- a/src/commit2.c
+++ b/src/commit2.c
@@ -42,7 +42,7 @@ GNode*
get_transactions(GNode*, boolean priority);
boolean
-complete(GNode *node, boolean test_mode);
+complete(GSList *node_coll, boolean test_mode);
gboolean
sort_func(GNode *node, gpointer data, boolean priority_mode);
@@ -194,6 +194,7 @@ main(int argc, char** argv)
exit(0);
}
+ GSList *completed_root_node_coll = NULL;
boolean no_errors = TRUE;
set_in_commit(TRUE);
int i = 0;
@@ -226,7 +227,8 @@ main(int argc, char** argv)
}
else {
if (disable_partial_commit == FALSE && g_dump_actions == FALSE) {
- complete(comp_cp_node, test_mode);
+ // complete(comp_cp_node, test_mode);
+ completed_root_node_coll = g_slist_append(completed_root_node_coll,comp_cp_node);
}
}
}
@@ -247,12 +249,13 @@ main(int argc, char** argv)
if (no_errors == TRUE) {
if (disable_partial_commit == TRUE && g_dump_actions == FALSE) {
- complete(orig_node_tree, test_mode);
+ completed_root_node_coll = g_slist_append(completed_root_node_coll,orig_node_tree);
}
/*
* Need to add to the following func below to clean up dangling .wh. files
*/
if (g_dump_actions == FALSE) {
+ complete(completed_root_node_coll, test_mode);
common_commit_clean_temp_config(orig_node_tree, test_mode);
}
if (g_debug == TRUE) {
@@ -262,6 +265,7 @@ main(int argc, char** argv)
}
else {
fprintf(out_stream,"Commit failed\n");
+ complete(completed_root_node_coll, test_mode);
}
set_in_commit(FALSE);
@@ -437,21 +441,24 @@ process_func(GNode *node, gpointer data)
*
**/
boolean
-complete(GNode *node, boolean test_mode)
+complete(GSList *node_coll, boolean test_mode)
{
- gpointer gp = ((GNode*)node)->data;
- if (g_debug) {
- if (((struct VyattaNode*)gp)->_data._name != NULL) {
- printf("commit2::complete():name: %s, path: %s\n",((struct VyattaNode*)gp)->_data._name,((struct VyattaNode*)gp)->_data._path);
- syslog(LOG_DEBUG,"commit2::complete():name: %s, path: %s",((struct VyattaNode*)gp)->_data._name,((struct VyattaNode*)gp)->_data._path);
- }
- else {
- printf("commit2::complete()\n");
- syslog(LOG_DEBUG,"commit2::complete()");
+ GSList *l;
+ for (l = node_coll; l; l = g_slist_next (l)) {
+ gpointer gp = ((GNode*)l->data)->data;
+ if (g_debug) {
+ if (((struct VyattaNode*)gp)->_data._name != NULL) {
+ printf("commit2::complete():name: %s, path: %s\n",((struct VyattaNode*)gp)->_data._name,((struct VyattaNode*)gp)->_data._path);
+ syslog(LOG_DEBUG,"commit2::complete():name: %s, path: %s",((struct VyattaNode*)gp)->_data._name,((struct VyattaNode*)gp)->_data._path);
+ }
+ else {
+ printf("commit2::complete()\n");
+ syslog(LOG_DEBUG,"commit2::complete()");
+ }
}
+ //on transactional nodes only, note to avoid calling this if a headless root
+ common_commit_copy_to_live_config(l->data, test_mode);
}
- //on transactional nodes only, note to avoid calling this if a headless root
- common_commit_copy_to_live_config(node, test_mode);
return TRUE;
}