Subversion Repositories SvarDOS

Rev

Rev 989 | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 989 Rev 1203
1
/* This file is part of the SvarCOM project and is published under the terms
1
/* This file is part of the SvarCOM project and is published under the terms
2
 * of the MIT license.
2
 * of the MIT license.
3
 *
3
 *
4
 * Copyright (C) 2021-2022 Mateusz Viste
4
 * Copyright (C) 2021-2022 Mateusz Viste
5
 *
5
 *
6
 * Permission is hereby granted, free of charge, to any person obtaining a
6
 * Permission is hereby granted, free of charge, to any person obtaining a
7
 * copy of this software and associated documentation files (the "Software"),
7
 * copy of this software and associated documentation files (the "Software"),
8
 * to deal in the Software without restriction, including without limitation
8
 * to deal in the Software without restriction, including without limitation
9
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10
 * and/or sell copies of the Software, and to permit persons to whom the
10
 * and/or sell copies of the Software, and to permit persons to whom the
11
 * Software is furnished to do so, subject to the following conditions:
11
 * Software is furnished to do so, subject to the following conditions:
12
 *
12
 *
13
 * The above copyright notice and this permission notice shall be included in
13
 * The above copyright notice and this permission notice shall be included in
14
 * all copies or substantial portions of the Software.
14
 * all copies or substantial portions of the Software.
15
 *
15
 *
16
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22
 * DEALINGS IN THE SOFTWARE.
22
 * DEALINGS IN THE SOFTWARE.
23
 */
23
 */
24
 
24
 
25
/*
25
/*
26
 * calls one batch program from another.
26
 * calls one batch program from another.
27
 *
27
 *
28
 * CALL [drive:][path]filename [batch-parameters]
28
 * CALL [drive:][path]filename [batch-parameters]
29
 *
29
 *
30
 * batch-parameters    Specifies any command-line information required by the
30
 * batch-parameters    Specifies any command-line information required by the
31
 *                     batch program.
31
 *                     batch program.
32
 */
32
 */
33
 
33
 
34
static enum cmd_result cmd_call(struct cmd_funcparam *p) {
34
static enum cmd_result cmd_call(struct cmd_funcparam *p) {
35
  if (cmd_ishlp(p)) {
35
  if (cmd_ishlp(p)) {
36
    nls_outputnl(13,0); /* "Calls one batch program from another" */
36
    nls_outputnl(13,0); /* "Calls one batch program from another" */
37
    outputnl("");
37
    outputnl("");
38
    nls_outputnl(13,1); /* "CALL [drive:][path]filename [batch-parameters]" */
38
    nls_outputnl(13,1); /* "CALL [drive:][path]filename [batch-parameters]" */
39
    return(CMD_OK);
39
    return(CMD_OK);
40
  }
40
  }
41
 
41
 
42
  /* no argument? do nothing */
42
  /* no argument? do nothing */
43
  if (p->argc == 0) return(CMD_OK);
43
  if (p->argc == 0) return(CMD_OK);
44
 
44
 
45
  /* change the command by moving batch filename and arguments to the start of the string */
45
  /* change the command by moving batch filename and arguments to the start of the string */
46
  memmove((void *)(p->cmdline), p->cmdline + p->argoffset, strlen(p->cmdline + p->argoffset) + 1);
46
  memmove((void *)(p->cmdline), p->cmdline + p->argoffset, strlen(p->cmdline + p->argoffset) + 1);
47
 
47
 
48
  return(CMD_CHANGED_BY_CALL); /* notify callee that command needs to be reevaluated */
48
  return(CMD_CHANGED_BY_CALL); /* notify callee that command needs to be reevaluated */
49
}
49
}
50
 
50