Subversion Repositories SvarDOS

Rev

Rev 371 | Rev 378 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 371 Rev 372
1
/*
1
/*
2
 * set [varname[=value]]
2
 * set [varname[=value]]
3
 *
3
 *
4
 * value cannot contain any '=' character, but it can contain spaces
4
 * value cannot contain any '=' character, but it can contain spaces
5
 * varname can also contain spaces
5
 * varname can also contain spaces
6
 */
6
 */
7
 
7
 
8
 
8
 
9
static int cmd_set(const struct cmd_funcparam *p) {
9
static int cmd_set(struct cmd_funcparam *p) {
10
  char far *env = MK_FP(p->env_seg, 0);
10
  char far *env = MK_FP(p->env_seg, 0);
11
  char buff[256];
11
  char *buff = p->BUFFER;
12
  int i;
-
 
13
  /* no arguments - display content */
12
  /* no arguments - display content */
14
  if (p->argc == 0) {
13
  if (p->argc == 0) {
15
    while (*env != 0) {
14
    while (*env != 0) {
-
 
15
      unsigned short i;
16
      /* copy string to local buff for display */
16
      /* copy string to local buff for display */
17
      for (i = 0;; i++) {
17
      for (i = 0;; i++) {
18
        buff[i] = *env;
18
        buff[i] = *env;
19
        env++;
19
        env++;
20
        if (buff[i] == 0) break;
20
        if (buff[i] == 0) break;
21
      }
21
      }
22
      puts(buff);
22
      outputnl(buff);
23
    }
23
    }
24
  } else if ((p->argc == 1) && (imatch(p->argv[0], "/?"))) {
24
  } else if ((p->argc == 1) && (imatch(p->argv[0], "/?"))) {
25
    outputnl("TODO: help screen"); /* TODO */
25
    outputnl("TODO: help screen"); /* TODO */
26
  } else { /* set variable (do not rely on argv, SET has its own rules...) */
26
  } else { /* set variable (do not rely on argv, SET has its own rules...) */
27
    const char far *ptr;
27
    const char far *ptr;
28
    char buff[256];
-
 
29
    unsigned short i;
28
    unsigned short i;
30
    /* locate the first space */
29
    /* locate the first space */
31
    for (ptr = p->cmdline; *ptr != ' '; ptr++);
30
    for (ptr = p->cmdline; *ptr != ' '; ptr++);
32
    /* now locate the first non-space: that's where the variable name begins */
31
    /* now locate the first non-space: that's where the variable name begins */
33
    for (; *ptr == ' '; ptr++);
32
    for (; *ptr == ' '; ptr++);
34
    /* copy variable to buff and switch it upercase */
33
    /* copy variable to buff and switch it upercase */
35
    i = 0;
34
    i = 0;
36
    for (; *ptr != '='; ptr++) {
35
    for (; *ptr != '='; ptr++) {
37
      if (*ptr == '\r') goto syntax_err;
36
      if (*ptr == '\r') goto syntax_err;
38
      buff[i] = *ptr;
37
      buff[i] = *ptr;
39
      if ((buff[i] >= 'a') && (buff[i] <= 'z')) buff[i] -= ('a' - 'A');
38
      if ((buff[i] >= 'a') && (buff[i] <= 'z')) buff[i] -= ('a' - 'A');
40
      i++;
39
      i++;
41
    }
40
    }
42
 
41
 
43
    /* copy value now */
42
    /* copy value now */
44
    while (*ptr != '\r') {
43
    while (*ptr != '\r') {
45
      buff[i++] = *ptr;
44
      buff[i++] = *ptr;
46
      ptr++;
45
      ptr++;
47
    }
46
    }
48
 
47
 
49
    /* terminate buff */
48
    /* terminate buff */
50
    buff[i] = 0;
49
    buff[i] = 0;
51
 
50
 
52
    /* commit variable to environment */
51
    /* commit variable to environment */
53
    i = env_setvar(p->env_seg, buff);
52
    i = env_setvar(p->env_seg, buff);
54
    if (i == ENV_INVSYNT) goto syntax_err;
53
    if (i == ENV_INVSYNT) goto syntax_err;
55
    if (i == ENV_NOTENOM) outputnl("Not enough available space within the environment block");
54
    if (i == ENV_NOTENOM) outputnl("Not enough available space within the environment block");
56
  }
55
  }
57
  return(-1);
56
  return(-1);
58
 
57
 
59
  syntax_err:
58
  syntax_err:
60
 
59
 
61
  outputnl("Syntax error");
60
  outputnl("Syntax error");
62
  return(-1);
61
  return(-1);
63
}
62
}
64
 
63