summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xscripts/vyatta-save-config.pl3
-rw-r--r--src/cli_shell_api.cpp6
-rw-r--r--src/cnode/cnode-algorithm.cpp4
-rw-r--r--src/cnode/cnode-algorithm.hpp2
4 files changed, 10 insertions, 5 deletions
diff --git a/scripts/vyatta-save-config.pl b/scripts/vyatta-save-config.pl
index a9b5779..4af5d97 100755
--- a/scripts/vyatta-save-config.pl
+++ b/scripts/vyatta-save-config.pl
@@ -100,7 +100,8 @@ if ($mode eq 'local') {
}
select $save;
-my @show_cmd = ('cli-shell-api', 'showCfg', '--show-active-only');
+my @show_cmd = ('cli-shell-api', 'showConfig', '--show-active-only',
+ '--show-ignore-edit');
if ($show_default) {
push @show_cmd, '--show-show-defaults';
}
diff --git a/src/cli_shell_api.cpp b/src/cli_shell_api.cpp
index 9678e5c..363a38f 100644
--- a/src/cli_shell_api.cpp
+++ b/src/cli_shell_api.cpp
@@ -60,6 +60,7 @@ int op_show_hide_secrets = 0;
int op_show_working_only = 0;
int op_show_context_diff = 0;
int op_show_commands = 0;
+int op_show_ignore_edit = 0;
char *op_show_cfg1 = NULL;
char *op_show_cfg2 = NULL;
@@ -429,6 +430,8 @@ showCfg(Cstore& cstore, const Cpath& args)
* show "context diff" between two configs
* --show-commands
* show output in "commands"
+ * --show-ignore-edit
+ * don't use the edit level in environment
*
* note that when neither cfg1 nor cfg2 specifies a config file, the "args"
* argument specifies the root path for the show output, and the "edit level"
@@ -456,7 +459,7 @@ showConfig(Cstore& cstore, const Cpath& args)
cnode::showConfig(cfg1, cfg2, args, op_show_show_defaults,
op_show_hide_secrets, op_show_context_diff,
- op_show_commands);
+ op_show_commands, op_show_ignore_edit);
}
static void
@@ -535,6 +538,7 @@ struct option options[] = {
{"show-working-only", no_argument, &op_show_working_only, 1},
{"show-context-diff", no_argument, &op_show_context_diff, 1},
{"show-commands", no_argument, &op_show_commands, 1},
+ {"show-ignore-edit", no_argument, &op_show_ignore_edit, 1},
{"show-cfg1", required_argument, NULL, SHOW_CFG1},
{"show-cfg2", required_argument, NULL, SHOW_CFG2},
{NULL, 0, NULL, 0}
diff --git a/src/cnode/cnode-algorithm.cpp b/src/cnode/cnode-algorithm.cpp
index 7574e2e..602d9fb 100644
--- a/src/cnode/cnode-algorithm.cpp
+++ b/src/cnode/cnode-algorithm.cpp
@@ -894,14 +894,14 @@ cnode::get_cmds(const CfgNode& cfg, vector<Cpath>& set_list,
void
cnode::showConfig(const string& cfg1, const string& cfg2,
const Cpath& path, bool show_def, bool hide_secret,
- bool context_diff, bool show_cmds)
+ bool context_diff, bool show_cmds, bool ignore_edit)
{
tr1::shared_ptr<CfgNode> aroot, wroot, croot1, croot2;
tr1::shared_ptr<Cstore> cstore;
Cpath rpath(path);
Cpath cur_path;
- if ((cfg1 == ACTIVE_CFG || cfg1 == WORKING_CFG)
+ if (!ignore_edit && (cfg1 == ACTIVE_CFG || cfg1 == WORKING_CFG)
&& (cfg2 == ACTIVE_CFG || cfg2 == WORKING_CFG)) {
// active/working config only => use edit level and path
cstore.reset(Cstore::createCstore(true));
diff --git a/src/cnode/cnode-algorithm.hpp b/src/cnode/cnode-algorithm.hpp
index 2f8995d..3985b9f 100644
--- a/src/cnode/cnode-algorithm.hpp
+++ b/src/cnode/cnode-algorithm.hpp
@@ -42,7 +42,7 @@ extern const string WORKING_CFG;
void showConfig(const string& cfg1, const string& cfg2,
const Cpath& path, bool show_def = false,
bool hide_secret = false, bool context_diff = false,
- bool show_cmds = false);
+ bool show_cmds = false, bool ignore_edit = false);
} // namespace cnode