summaryrefslogtreecommitdiff
path: root/src/cstore/cstore.cpp
diff options
context:
space:
mode:
authorAn-Cheng Huang <ancheng@vyatta.com>2010-12-02 14:35:25 -0800
committerAn-Cheng Huang <ancheng@vyatta.com>2010-12-02 14:35:25 -0800
commit352a9e94534933aca7403e91d1dc55c26bf633ce (patch)
treedf413a5fbd1ab0e0b4776eff98149dd9cbc8006d /src/cstore/cstore.cpp
parent58005829f825c3e6843d0c2c36e1e343194ec3dd (diff)
downloadvyatta-cfg-352a9e94534933aca7403e91d1dc55c26bf633ce.tar.gz
vyatta-cfg-352a9e94534933aca7403e91d1dc55c26bf633ce.zip
implement load function in new config input/output infrastructure.
* add "commands diff" functionality to config input/output infrastructure. * consolidate similar logic in "commands diff" and "show diff". * add loadFile functionality to cstore using "commands diff". * export loadFile through shell API.
Diffstat (limited to 'src/cstore/cstore.cpp')
-rw-r--r--src/cstore/cstore.cpp75
1 files changed, 75 insertions, 0 deletions
diff --git a/src/cstore/cstore.cpp b/src/cstore/cstore.cpp
index ed18c9e..0ff8ba2 100644
--- a/src/cstore/cstore.cpp
+++ b/src/cstore/cstore.cpp
@@ -31,6 +31,9 @@
#include <cli_cstore.h>
#include <cstore/cstore.hpp>
#include <cstore/cstore-varref.hpp>
+#include <cnode/cnode.hpp>
+#include <cnode/cnode-algorithm.hpp>
+#include <cparse/cparse.hpp>
////// constants
@@ -1803,6 +1806,63 @@ Cstore::unmarkCfgPathDeactivated(const vector<string>& path_comps)
return ret;
}
+// load specified config file
+bool
+Cstore::loadFile(const char *filename)
+{
+ if (!inSession()) {
+ output_user("Cannot load config outside configuration session\n");
+ // exit handled by assert below
+ }
+ ASSERT_IN_SESSION;
+
+ FILE *fin = fopen(filename, "r");
+ if (!fin) {
+ output_user("Failed to open specified config file\n");
+ return false;
+ }
+
+ // get the config tree from the file
+ cnode::CfgNode *froot = cparse::parse_file(fin, *this);
+ if (!froot) {
+ output_user("Failed to parse specified config file\n");
+ return false;
+ }
+
+ // get the config tree from the active config
+ vector<string> args;
+ cnode::CfgNode aroot(*this, args, true, true);
+
+ // get the "commands diff" between the two
+ vector<vector<string> > del_list;
+ vector<vector<string> > set_list;
+ vector<vector<string> > com_list;
+ cnode::get_cmds_diff(aroot, *froot, del_list, set_list, com_list);
+
+ // "apply" the changes to the working config
+ for (size_t i = 0; i < del_list.size(); i++) {
+ vtw_def def;
+ if (!validateDeletePath(del_list[i], def)
+ || !deleteCfgPath(del_list[i], def)) {
+ print_str_vec("Delete [", "] failed\n", del_list[i], "'");
+ }
+ }
+ for (size_t i = 0; i < set_list.size(); i++) {
+ if (!validateSetPath(set_list[i]) || !setCfgPath(set_list[i])) {
+ print_str_vec("Set [", "] failed\n", set_list[i], "'");
+ }
+ }
+ for (size_t i = 0; i < com_list.size(); i++) {
+ vtw_def def;
+ if (!validateCommentArgs(com_list[i], def)
+ || !commentCfgPath(com_list[i], def)) {
+ print_str_vec("Comment [", "] failed\n", com_list[i], "'");
+ }
+ }
+
+ return true;
+}
+
/* "changed" status handling.
* the "changed" status is used during commit to check if a node has been
* changed. note that if a node is "changed", all of its ancestors are also
@@ -2797,3 +2857,18 @@ Cstore::shell_escape_squotes(string& str)
}
}
+// print a vector of strings
+void
+Cstore::print_str_vec(const char *pre, const char *post,
+ const vector<string>& vec, const char *quote)
+{
+ output_user("%s", pre);
+ for (size_t i = 0; i < vec.size(); i++) {
+ if (i > 0) {
+ output_user(" ");
+ }
+ output_user("%s%s%s", quote, vec[i].c_str(), quote);
+ }
+ output_user("%s", post);
+}
+