From ed02dd2278c30bafe2fdc5bdca1e219786c56b3e Mon Sep 17 00:00:00 2001 From: An-Cheng Huang Date: Tue, 10 Aug 2010 19:15:55 -0700 Subject: further simplify shell API extension and add more functions. --- src/cli_shell_api.cpp | 154 ++++++++++++++++++++++---------------------------- 1 file changed, 68 insertions(+), 86 deletions(-) diff --git a/src/cli_shell_api.cpp b/src/cli_shell_api.cpp index c0d70ca..f5e7681 100644 --- a/src/cli_shell_api.cpp +++ b/src/cli_shell_api.cpp @@ -25,6 +25,14 @@ #include #include +static void +print_vec(const vector& vec, const char *sep, const char *quote) +{ + for (unsigned int i = 0; i < vec.size(); i++) { + printf("%s%s%s%s", ((i > 0) ? sep : ""), quote, vec[i].c_str(), quote); + } +} + typedef void (*OpFuncT)(const vector& args); typedef struct { @@ -37,7 +45,7 @@ typedef struct { } OpT; static void -doGetSessionEnv(const vector& args) +getSessionEnv(const vector& args) { string env; UnionfsCstore cstore(args[0], env); @@ -45,7 +53,7 @@ doGetSessionEnv(const vector& args) } static void -doGetEditEnv(const vector& args) +getEditEnv(const vector& args) { UnionfsCstore cstore(true); string env; @@ -56,7 +64,7 @@ doGetEditEnv(const vector& args) } static void -doGetEditUpEnv(const vector& args) +getEditUpEnv(const vector& args) { UnionfsCstore cstore(true); string env; @@ -67,7 +75,7 @@ doGetEditUpEnv(const vector& args) } static void -doGetEditResetEnv(const vector& args) +getEditResetEnv(const vector& args) { UnionfsCstore cstore(true); string env; @@ -78,14 +86,14 @@ doGetEditResetEnv(const vector& args) } static void -doEditLevelAtRoot(const vector& args) +editLevelAtRoot(const vector& args) { UnionfsCstore cstore(true); exit(cstore.editLevelAtRoot() ? 0 : 1); } static void -doGetCompletionEnv(const vector& args) +getCompletionEnv(const vector& args) { UnionfsCstore cstore(true); string env; @@ -96,23 +104,16 @@ doGetCompletionEnv(const vector& args) } static void -doGetEditLevelStr(const vector& args) +getEditLevelStr(const vector& args) { UnionfsCstore cstore(true); vector lvec; cstore.getEditLevel(lvec); - string level; - for (unsigned int i = 0; i < lvec.size(); i++) { - if (level.length() > 0) { - level += " "; - } - level += lvec[i]; - } - printf("%s", level.c_str()); + print_vec(lvec, " ", ""); } static void -doMarkSessionUnsaved(const vector& args) +markSessionUnsaved(const vector& args) { UnionfsCstore cstore(true); if (!cstore.markSessionUnsaved()) { @@ -121,7 +122,7 @@ doMarkSessionUnsaved(const vector& args) } static void -doUnmarkSessionUnsaved(const vector& args) +unmarkSessionUnsaved(const vector& args) { UnionfsCstore cstore(true); if (!cstore.unmarkSessionUnsaved()) { @@ -130,7 +131,7 @@ doUnmarkSessionUnsaved(const vector& args) } static void -doSessionUnsaved(const vector& args) +sessionUnsaved(const vector& args) { UnionfsCstore cstore(true); if (!cstore.sessionUnsaved()) { @@ -139,7 +140,7 @@ doSessionUnsaved(const vector& args) } static void -doSessionChanged(const vector& args) +sessionChanged(const vector& args) { UnionfsCstore cstore(true); if (!cstore.sessionChanged()) { @@ -148,7 +149,7 @@ doSessionChanged(const vector& args) } static void -doTeardownSession(const vector& args) +teardownSession(const vector& args) { UnionfsCstore cstore(true); if (!cstore.teardownSession()) { @@ -157,7 +158,7 @@ doTeardownSession(const vector& args) } static void -doSetupSession(const vector& args) +setupSession(const vector& args) { UnionfsCstore cstore(true); if (!cstore.setupSession()) { @@ -166,7 +167,7 @@ doSetupSession(const vector& args) } static void -doInSession(const vector& args) +inSession(const vector& args) { UnionfsCstore cstore(true); if (!cstore.inSession()) { @@ -175,84 +176,65 @@ doInSession(const vector& args) } static void -doExists(const vector& args) +exists(const vector& args) { UnionfsCstore cstore(true); exit(cstore.cfgPathExists(args, false) ? 0 : 1); } static void -doExistsActive(const vector& args) +existsActive(const vector& args) { UnionfsCstore cstore(true); exit(cstore.cfgPathExists(args, true) ? 0 : 1); } -static int op_idx = -1; -static OpT ops[] = { - {"getSessionEnv", - 1, "Must specify session ID", -1, NULL, - &doGetSessionEnv}, - - {"getEditEnv", - -1, NULL, 1, "Must specify config path", - &doGetEditEnv}, - - {"getEditUpEnv", - 0, "No argument expected", -1, NULL, - &doGetEditUpEnv}, - - {"getEditResetEnv", - 0, "No argument expected", -1, NULL, - &doGetEditResetEnv}, - - {"editLevelAtRoot", - 0, "No argument expected", -1, NULL, - &doEditLevelAtRoot}, - - {"getCompletionEnv", - -1, NULL, 2, "Must specify command and at least one component", - &doGetCompletionEnv}, - - {"getEditLevelStr", - 0, "No argument expected", -1, NULL, - &doGetEditLevelStr}, - - {"markSessionUnsaved", - 0, "No argument expected", -1, NULL, - &doMarkSessionUnsaved}, - - {"unmarkSessionUnsaved", - 0, "No argument expected", -1, NULL, - &doUnmarkSessionUnsaved}, - - {"sessionUnsaved", - 0, "No argument expected", -1, NULL, - &doSessionUnsaved}, - - {"sessionChanged", - 0, "No argument expected", -1, NULL, - &doSessionChanged}, - - {"teardownSession", - 0, "No argument expected", -1, NULL, - &doTeardownSession}, - - {"setupSession", - 0, "No argument expected", -1, NULL, - &doSetupSession}, +static void +listNodes(const vector& args) +{ + UnionfsCstore cstore(true); + vector cnodes; + cstore.cfgPathGetChildNodes(args, cnodes, false); + print_vec(cnodes, " ", "'"); +} - {"inSession", - 0, "No argument expected", -1, NULL, - &doInSession}, +static void +listActiveNodes(const vector& args) +{ + UnionfsCstore cstore(true); + vector cnodes; + cstore.cfgPathGetChildNodes(args, cnodes, true); + print_vec(cnodes, " ", "'"); +} - {"exists", - -1, NULL, 1, "Must specify config path", - &doExists}, +#define OP(name, exact, exact_err, min, min_err) \ + { #name, exact, exact_err, min, min_err, &name } - {"existsActive", - -1, NULL, 1, "Must specify config path", - &doExistsActive}, +static int op_idx = -1; +static OpT ops[] = { + OP(getSessionEnv, 1, "Must specify session ID", -1, NULL), + OP(getEditEnv, -1, NULL, 1, "Must specify config path"), + OP(getEditUpEnv, 0, "No argument expected", -1, NULL), + OP(getEditResetEnv, 0, "No argument expected", -1, NULL), + OP(editLevelAtRoot, 0, "No argument expected", -1, NULL), + OP(getCompletionEnv, -1, NULL, + 2, "Must specify command and at least one component"), + OP(getEditLevelStr, 0, "No argument expected", -1, NULL), + + OP(markSessionUnsaved, 0, "No argument expected", -1, NULL), + OP(unmarkSessionUnsaved, 0, "No argument expected", -1, NULL), + OP(sessionUnsaved, 0, "No argument expected", -1, NULL), + OP(sessionChanged, 0, "No argument expected", -1, NULL), + + OP(teardownSession, 0, "No argument expected", -1, NULL), + OP(setupSession, 0, "No argument expected", -1, NULL), + OP(inSession, 0, "No argument expected", -1, NULL), + + OP(exists, -1, NULL, 1, "Must specify config path"), + OP(existsActive, -1, NULL, 1, "Must specify config path"), + + OP(listNodes, -1, NULL, -1, NULL), + OP(listActiveNodes, -1, NULL, -1, NULL), {NULL, -1, NULL, -1, NULL, NULL} }; -- cgit v1.2.3