Subversion Repositories SvarDOS

Rev

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

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