This repository has been archived by the owner on Nov 13, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 31
/
ICommandPositionalDefinition.ts
64 lines (61 loc) · 2.18 KB
/
ICommandPositionalDefinition.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
/*
* This program and the accompanying materials are made available under the terms of the
* Eclipse Public License v2.0 which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-v20.html
*
* SPDX-License-Identifier: EPL-2.0
*
* Copyright Contributors to the Zowe Project.
*
*/
import { CommandOptionType } from "./ICommandOptionDefinition";
/**
* Positional option definition - used on a command definition to define positional operands.
* Positional operands do not use --dashes. They are values specified after the full command string
* e.g. group group group group command mypositional --dash-option
*/
export interface ICommandPositionalDefinition {
/**
* The name of the positional operand.
*
* This name cannot contain a dash (-) or else the positional argument will not function properly.
* This is a limitation of yargs.
*
* Appending "..." to the end of a name will allow for a space delimited
* array of arguments. So if you specify `name = "abcd..."` and then
* "a b c d" is specified for the positional argument, abcd = ["a", "b", "c", "d"]
* @type {string}
* @memberOf ICommandPositionalDefinition
*/
name: string;
/**
* The option type - used to validate that the user provided value is acceptable.
* @type {CommandOptionType}
* @memberOf ICommandPositionalDefinition
*/
type: CommandOptionType;
/**
* The description for the positional operand - used in the help and error messages.
* @type {string}
* @memberOf ICommandPositionalDefinition
*/
description: string;
/**
* True if this positional is required.
* @type {boolean}
* @memberOf ICommandPositionalDefinition
*/
required?: boolean;
/**
* A regex that will be used to match the input for this positional for validation.
* @type {string}
* @memberOf ICommandPositionalDefinition
*/
regex?: string;
/**
* What is an acceptable length range for your positional? e.g. between 1 and 8 characters: [1,8]
* @type {[number, number]}
* @memberOf ICommandPositionalDefinition
*/
stringLengthRange?: [number, number];
}