summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/cli_def.l2
-rw-r--r--src/cli_new.c42
2 files changed, 32 insertions, 12 deletions
diff --git a/src/cli_def.l b/src/cli_def.l
index 4f536bd..d42119d 100644
--- a/src/cli_def.l
+++ b/src/cli_def.l
@@ -425,7 +425,7 @@ RE_ACT_FIELD (help|syntax|commit|delete|update|activate|create|begin|end|comp_he
}
}
-<expression>\$\([^)]+\) {
+<expression>\$VAR\([^)]+\) {
yy_cli_parse_lval.strp = strdup(yy_cli_def_text);
return VAR;
}
diff --git a/src/cli_new.c b/src/cli_new.c
index e3a7955..1c77a13 100644
--- a/src/cli_new.c
+++ b/src/cli_new.c
@@ -25,8 +25,12 @@
#define EXE_STRING_DELTA 512
#define PATH_DELTA 1000
#define ENDS_ALLOC 20
-#define PATH_CM_LOCATION 25 /* mcd vs. ccd location
- change when m_root changed */
+/* mcd vs. ccd location
+ change when m_root changed */
+#define PATH_CM_LOCATION 25
+
+#define VAR_REF_MARKER "$VAR("
+#define VAR_REF_MARKER_LEN 5
/* Global vars: */
vtw_path m_path, t_path;
@@ -1077,7 +1081,14 @@ static boolean check_syn_func(vtw_node *cur,const char* func,int line)
return FALSE;
}
- var_reference = strdup(cur->vtw_node_left->vtw_node_string+2);
+ if (strncmp(cur->vtw_node_left->vtw_node_string,
+ VAR_REF_MARKER, VAR_REF_MARKER_LEN) != 0) {
+ /* bad reference. should not happen */
+ return FALSE;
+ }
+ /* point to char next to '(' */
+ var_reference = strdup(cur->vtw_node_left->vtw_node_string
+ + VAR_REF_MARKER_LEN);
{
int i=0;
@@ -1236,8 +1247,8 @@ static int eval_va(valstruct *res, vtw_node *node)
pathp = node->vtw_node_string;
DPRINT("eval_va var[%s]\n", pathp);
- assert(pathp[0]=='$' && pathp[1]=='(');
- pathp += 2;
+ assert(strncmp(pathp, VAR_REF_MARKER, VAR_REF_MARKER_LEN) == 0);
+ pathp += VAR_REF_MARKER_LEN;
if(pathp[0] == '@' && pathp[1]!='@'){
/* this is why we passed at_val all around */
@@ -1367,17 +1378,26 @@ static int expand_string(char *stringp)
}
*resp++ = *scanp++;
--left;
+ } else if (strlen(scanp) < (VAR_REF_MARKER_LEN + 1 + 1)) {
+ /* shorter than "$VAR(@)". cannot be a reference */
+ *resp++ = *scanp++;
+ --left;
+ } else if (strncmp(scanp, VAR_REF_MARKER, VAR_REF_MARKER_LEN) != 0) {
+ /* doesn't start with "$VAR(". not a reference */
+ *resp++ = *scanp++;
+ --left;
} else {
-
+ /* the first char is '$'
+ * && remaining length is enough for a reference
+ * && starts with marker.
+ */
char *cp=NULL;
boolean my_cp=FALSE;
- if (scanp[1] != '('){
-
- printf("Badly formed var reference in %s\n", stringp);
- exit (VTWERR_BADPATH);
+ /* advance scanp to 'R'. */
+ scanp += 3;
- } else if(scanp[2] == '@' && scanp[3] == ')') {
+ if(scanp[2] == '@' && scanp[3] == ')') {
cp = get_at_string();
my_cp = FALSE;