summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/cstore/cstore.cpp29
-rw-r--r--src/cstore/cstore.hpp1
2 files changed, 30 insertions, 0 deletions
diff --git a/src/cstore/cstore.cpp b/src/cstore/cstore.cpp
index 5f2eb79..aacd15a 100644
--- a/src/cstore/cstore.cpp
+++ b/src/cstore/cstore.cpp
@@ -527,6 +527,34 @@ Cstore::getEditResetEnv(string& env)
return true;
}
+void
+Cstore::getAllowedVarRef(string& astr){
+ size_t varloc = 0;
+ size_t strloc = 0;
+ vtw_type_e vtype = ERROR_TYPE;
+ string exe_string = "";
+ string varref = "";
+ size_t first_paren, second_paren;
+ while(true) {
+ varloc = astr.find("$VAR", strloc);
+ if (varloc == string::npos){
+ varloc = astr.size();
+ exe_string += astr.substr(strloc, (varloc-strloc+1));
+ break;
+ }
+ exe_string += astr.substr(strloc, (varloc-strloc));
+ strloc = varloc;
+ first_paren = astr.find('(', strloc);
+ second_paren = astr.find(')', strloc);
+ varref = astr.substr((first_paren+1), (second_paren-first_paren-1));
+ varref = string(getVarRef(varref.c_str(), vtype, false));
+ strloc = second_paren+1;
+ exe_string += varref;
+ }
+ astr = exe_string;
+ return;
+}
+
/* set "env" arg to the environment string needed for "completion".
* return true if successful.
*
@@ -688,6 +716,7 @@ Cstore::getCompletionEnv(const Cpath& comps, string& env)
} else {
string astr = def->getAllowed();
shell_escape_squotes(astr);
+ getAllowedVarRef(astr);
cmd_str += "_cstore_internal_allowed () { eval '";
cmd_str += astr;
cmd_str += "'; }; _cstore_internal_allowed";
diff --git a/src/cstore/cstore.hpp b/src/cstore/cstore.hpp
index 69da796..741d9f1 100644
--- a/src/cstore/cstore.hpp
+++ b/src/cstore/cstore.hpp
@@ -504,6 +504,7 @@ private:
va_list alist);
static void voutput_internal(const char *fmt, va_list alist);
static void vexit_internal(const char *fmt, va_list alist);
+ void getAllowedVarRef(string& astr);
};
} // end namespace cstore