Visual Studio Code provides variable substitution to be used in launch.json and tasks.json.
One of the variables allows the result of a command to be used with the following syntax: ${command:commandID}
If a command or variable is almost what you need you can use the transform command to perform a regular expression find-replace of the result.
Not all commands are supported yet in the web extension version. Supported commands are marked with : (Web)
- Commands
- Usage
- Configuration / Settings
- FileAsKey
- File Content
- File Content Key Value pairs
- File Content JSON Property
- File Content YAML Property
- File Content Multiple Key-Values/Properties
- File Content in Editor
- Config Expression
- Pick File
- number
- remember
- pickStringRemember
- promptStringRemember
- Multicursor and text
- inTerminal
- setClipboard
- Transform
- Variables
- checkEscapedUI
- Workspace name in argument
- UUID
- dateTime
- Credits
This extension provides a number of commands that give a result based on the current file or the workspace path or that produce a result based on arguments
- extension.commandvariable.file.relativeDirDots: The directory of the current file relative to the workspace root directory with dots as separator. Can be used to specify a Python module.
- extension.commandvariable.file.relativeFileDots: The same result as- ${relativeFile}but with dots as separator.
- extension.commandvariable.file.relativeFileDotsNoExtension: The same result as- ${relativeFile}but with dots as separator and no file extension. Can be used to specify a Python module.
- extension.commandvariable.file.filePosix: The same result as- ${file}but in Posix form. Directory separator '- /', and drive designation as '- /z/project/'
- extension.commandvariable.file.fileDirnamePosix: The same result as- ${fileDirname}but in Posix form.
- extension.commandvariable.file.fileDirname1Up: The directory path 1 Up of- ${fileDirname}
- extension.commandvariable.file.fileDirname2Up: The directory path 2 Up of- ${fileDirname}
- extension.commandvariable.file.fileDirname3Up: The directory path 3 Up of- ${fileDirname}
- extension.commandvariable.file.fileDirname4Up: The directory path 4 Up of- ${fileDirname}
- extension.commandvariable.file.fileDirname5Up: The directory path 5 Up of- ${fileDirname}
- extension.commandvariable.file.fileDirname1UpPosix: The same result as- ${extension.commandvariable.file.fileDirname1Up}but in Posix form.
- extension.commandvariable.file.fileDirname2UpPosix: The same result as- ${extension.commandvariable.file.fileDirname2Up}but in Posix form.
- extension.commandvariable.file.fileDirname3UpPosix: The same result as- ${extension.commandvariable.file.fileDirname3Up}but in Posix form.
- extension.commandvariable.file.fileDirname4UpPosix: The same result as- ${extension.commandvariable.file.fileDirname4Up}but in Posix form.
- extension.commandvariable.file.fileDirname5UpPosix: The same result as- ${extension.commandvariable.file.fileDirname5Up}but in Posix form.
- extension.commandvariable.file.relativeFileDirname1Up: The directory path 1 Up of- ${relativeFileDirname}
- extension.commandvariable.file.relativeFileDirname2Up: The directory path 2 Up of- ${relativeFileDirname}
- extension.commandvariable.file.relativeFileDirname3Up: The directory path 3 Up of- ${relativeFileDirname}
- extension.commandvariable.file.relativeFileDirname4Up: The directory path 4 Up of- ${relativeFileDirname}
- extension.commandvariable.file.relativeFileDirname5Up: The directory path 5 Up of- ${relativeFileDirname}
- extension.commandvariable.file.relativeFileDirnamePosix: The same result as- ${relativeFileDirname}but in Posix form.
- extension.commandvariable.file.relativeFileDirname1UpPosix: The same result as- ${extension.commandvariable.file.relativeFileDirname1Up}but in Posix form.
- extension.commandvariable.file.relativeFileDirname2UpPosix: The same result as- ${extension.commandvariable.file.relativeFileDirname2Up}but in Posix form.
- extension.commandvariable.file.relativeFileDirname3UpPosix: The same result as- ${extension.commandvariable.file.relativeFileDirname3Up}but in Posix form.
- extension.commandvariable.file.relativeFileDirname4UpPosix: The same result as- ${extension.commandvariable.file.relativeFileDirname4Up}but in Posix form.
- extension.commandvariable.file.relativeFileDirname5UpPosix: The same result as- ${extension.commandvariable.file.relativeFileDirname5Up}but in Posix form.
- extension.commandvariable.file.relativeFilePosix: The same result as- ${relativeFile}but in Posix form.
- extension.commandvariable.file.fileAsKey: Use part of the file path as a key in a map lookup. Can be used in- lauch.jsonto select arguments based on filename, see example.
- extension.commandvariable.file.fileDirBasename: (Web) The basename of the- ${fileDirname}
- extension.commandvariable.file.fileDirBasename1Up: (Web) The directory name 1 Up of- ${fileDirname}
- extension.commandvariable.file.fileDirBasename2Up: (Web) The directory name 2 Up of- ${fileDirname}
- extension.commandvariable.file.fileDirBasename3Up: (Web) The directory name 3 Up of- ${fileDirname}
- extension.commandvariable.file.fileDirBasename4Up: (Web) The directory name 4 Up of- ${fileDirname}
- extension.commandvariable.file.fileDirBasename5Up: (Web) The directory name 5 Up of- ${fileDirname}
- extension.commandvariable.file.content: The content of the given file name. Use "inputs", see example. Or the value of a Key-Value pair, see example. Or the value of a JSON file property, see example.
- extension.commandvariable.config.expression: Apply a JavaScript expression to the content of a configuration variable in- settings.json. Use it to extract an array element or property from an object, see example.
- extension.commandvariable.file.contentInEditor: The same as- extension.commandvariable.file.contentto be used for keybindings. Result will be inserted in the current editor.
- extension.commandvariable.file.pickFile: Show a Quick Pick selection box with file paths that match an include and an exclude glob pattern. Use "inputs", see example.
- extension.commandvariable.workspace.folder: The path of the workspace root directory of the current file.- ${workspaceFolder}does not give this path in Multi Root workspaces. You can target a particular workspace by supplying a- namein the arguments.
- extension.commandvariable.workspace.folder1Up: The directory path 1 Up of the workspace root directory of the current file. The parent of the workspace root folder.
- extension.commandvariable.workspace.folder2Up: The directory path 2 Up of the workspace root directory of the current file.
- extension.commandvariable.workspace.folder3Up: The directory path 3 Up of the workspace root directory of the current file.
- extension.commandvariable.workspace.folder4Up: The directory path 4 Up of the workspace root directory of the current file.
- extension.commandvariable.workspace.folder5Up: The directory path 5 Up of the workspace root directory of the current file.
- extension.commandvariable.workspace.workspaceFolderPosix: deprecated - identical to- extension.commandvariable.workspace.folderPosix
- extension.commandvariable.workspace.folderPosix: The same result as- extension.commandvariable.workspace.folderbut in Posix form. You can target a particular workspace by supplying a- namein the arguments.
- extension.commandvariable.workspace.folder1UpPosix: The same result as- extension.commandvariable.workspace.folder1Upbut in Posix form.
- extension.commandvariable.workspace.folder2UpPosix: The same result as- extension.commandvariable.workspace.folder2Upbut in Posix form.
- extension.commandvariable.workspace.folder3UpPosix: The same result as- extension.commandvariable.workspace.folder3Upbut in Posix form.
- extension.commandvariable.workspace.folder4UpPosix: The same result as- extension.commandvariable.workspace.folder4Upbut in Posix form.
- extension.commandvariable.workspace.folder5UpPosix: The same result as- extension.commandvariable.workspace.folder5Upbut in Posix form.
- extension.commandvariable.workspace.folderBasename: (Web) The directory name of the workspace root directory of the current file. You can get info for a particular workspace by supplying a- namein the arguments.
- extension.commandvariable.workspace.folderBasename1Up: (Web) The directory name 1 Up of the workspace root directory of the current file.
- extension.commandvariable.workspace.folderBasename2Up: (Web) The directory name 2 Up of the workspace root directory of the current file.
- extension.commandvariable.workspace.folderBasename3Up: (Web) The directory name 3 Up of the workspace root directory of the current file.
- extension.commandvariable.workspace.folderBasename4Up: (Web) The directory name 4 Up of the workspace root directory of the current file.
- extension.commandvariable.workspace.folderBasename5Up: (Web) The directory name 5 Up of the workspace root directory of the current file.
- extension.commandvariable.selectedText: (Web) The selected text in the active editor, empty string if nothing selected. Supports multicursor.
- extension.commandvariable.selectionStartLineNumber: (Web) Line number of the selection start
- extension.commandvariable.selectionStartColumnNumber: (Web) Column number of the selection start
- extension.commandvariable.selectionEndLineNumber: (Web) Line number of the selection end
- extension.commandvariable.selectionEndColumnNumber: (Web) Column number of the selection end
- extension.commandvariable.currentLineText: (Web) The text of the line in the active editor where the selection starts or where the cursor is. Supports multicursor.
- extension.commandvariable.dirSep: Directory separator for this platform. '\' on Windows, '/' on other platforms
- extension.commandvariable.envListSep: Environment variable list separator for this platform. ';' on Windows, ':' on other platforms
- extension.commandvariable.pickStringRemember: (Web) like Input variable pickString but it remembers the picked item by a key, configured by strings or [label,value] tuples, see example.
- extension.commandvariable.promptStringRemember: (Web) like Input variable promptString but it remembers the entered string by a key, see example.
- extension.commandvariable.remember: (Web) retreive a remembered pickString, promptString, pickFile or fileContent by key and/or store key-value pair(s).
- extension.commandvariable.rememberPick: deprecated - identical to- extension.commandvariable.remember, it is not only picks that are remembered
- extension.commandvariable.number: (Web) from a range of numbers return a number, in sequence with a step or random (with last uniqueCount), see example.
- extension.commandvariable.dateTime: (Web) language-sensitive format of current date and time (using a Locale), see example
- extension.commandvariable.dateTimeInEditor: (Web) language-sensitive format of current date and time (using a Locale) to be used for keybindings
- extension.commandvariable.transform: make a custom variable by echoing static text or transform the content of a variable with a Regular Expression Find-Replace, see example.
- extension.commandvariable.UUID: (Web) generate a UUID v4 (from random numbers) with different output formats, see example
- extension.commandvariable.UUIDInEditor: (Web) generate a UUID v4 (from random numbers) to be used for keybindings
- extension.commandvariable.inTerminal: type the string result of a command in the terminal (optional with Carriage Return), see example.
- extension.commandvariable.setClipboard: (Web) set the content of the clipboard, see example.
We can give an extension command arguments with input variables, but for single numeric arguments putting the argument in the command name is simpler.
An example launch.json :
{
  "version": "0.2.0",
  "configurations": [
    {
      "name": "Python: Module",
      "type": "python",
      "request": "launch",
      "console": "integratedTerminal",
      "module": "${command:extension.commandvariable.file.relativeFileDotsNoExtension}",
    }
  ]
}You can use a Task to see the value of a variable substitution.
The following settings can only be defined in the User settings:
- commandvariable.file.pickFile.labelMaximumLength: number ∈ ℕ (>= 0), the pickFile command can show a list of predefined directories. It can be that the directory path is too large to show in the QuickPick List. VSC does clip the path but only on the end and thus can make it difficult to choose a path when they have the save start. This setting allows to transform the shown label if larger than a maximum number of characters. The transforms to apply are defined in the pickFile command. If this setting is- 0(default value) no transforms are applied.
 !! Be aware that the text shown in the QuickPick List use a variable width font.
- commandvariable.file.pickFile.labelClipPoint: number ∈ ℤ (positive and negative), used in the pickFile label transform:- clipMiddle, determines how many characters to pick from the start (- >=0) or from the end (- <0). The characters taken from the other end are calculated using- commandvariable.file.pickFile.labelMaximumLength
The command extension.commandvariable.file.fileAsKey makes it possible to select a string based on part of a file path. The file path can be taken from the current active editor or by executing a command.
The keys of the args object are searched for in the path of the active file (directory separator is /).
If you have files with the same name use part of the full path to select the correct one like "/dir1/main.py" and "/dir2/main.py".
The args property can contain a few special keys:
- @useCommand: the value is a command variable that describes the command to execute to get the file path to use.
 Example for CMake build projects:- "@useCommand": "${command:cmake.launchTargetPath}"
- @default: the string to return when none of the keys is found in the file path (default:- Unknown)
The value strings may contain variables. If you use the variable ${selectedText} you have to embed the properties separator and filterSelection in the variable, example ${selectedText##separator=@@##filterSelection=index%3===1##}.
{
  "version": "2.0.0",
  "tasks": [
    {
      "name": "Python: Current File",
      "type": "python",
      "request": "launch",
      "program": "${file}",
      "console": "integratedTerminal",
      "args" : ["${input:chooseArgs}"]
    }
  ],
  "inputs": [
    {
      "id": "chooseArgs",
      "type": "command",
      "command": "extension.commandvariable.file.fileAsKey",
      "args": {
        "calculation.py": "-n 4224",
        "client.py": "-i calc-out.yaml"
      }
    }
  ]
}Sometimes you want to use the result of a shell script (batch file). Setting environment variables will not work because they modify only the child shell.
If you store the content in a file you can retrieve this with the extension.commandvariable.file.content command.
The content of the file is assumed to be encoded with UTF-8.
The supported arguments:
- fileName: specifies the file to read. Supports variables, like- ${workspaceFolder},- ${workspaceFolder:name},- ${pickFile:name}and- ${remember:key}
- keyRemember: (Optional) If you want to remember the value for later use. (default:- "fileContent")
Can be used as variable ${fileContent:name}
With additional arguments it is possible to parse the content of the file types:
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "echo FileContent",
      "type": "shell",
      "command": "echo",
      "args": [
        "${input:fileContent}"
      ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "fileContent",
      "type": "command",
      "command": "extension.commandvariable.file.content",
      "args": {
        "fileName": "c:\\temp\\result.txt"
      }
    }
  ]
}If you have a file that contains key-value pairs and you want the value for a given key you can use the command extension.commandvariable.file.content.
The supported arguments:
- fileName: specifies the file to read, see File Content.
- key: specifies for which key you want the value. Can contain variables.
- default: (Optional) If the key is not found and you have defined- defaultthat string is returned else- "Unknown"is returned.
- keyRemember: (Optional) If you want to remember the value for later use. (default:- "fileContent")
Can be used as variable ${fileContent:name}
A key-value file consists of lines that contain key-value pairs.
The file can contain comments and empty lines. A comment line starts with # or //. You can have whitespace before the comment characters.
A key-value pair is a line in the file that specifies the key and the value separated by a character. The supported separators are : and =. The line is split with the following regular expression: ^\s*([^:=]+)(?:[:=])(.*)
The non-capturing group (?:) is only needed in this Markdown file to prevent detection of a Markdown link.
Everything, after the starting whitespace, before the first separator is the key, everything after the separator is the value. You can have a separator character in the value. Only the first separator is important.
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "echo FileContentKey",
      "type": "shell",
      "command": "echo",
      "args": [
        "${input:fileContentKey}"
      ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "fileContentKey",
      "type": "command",
      "command": "extension.commandvariable.file.content",
      "args": {
        "fileName": "${workspaceFolder}/key-values.txt",
        "key": "PLUGIN",
        "default": "special-plugin"
      }
    }
  ]
}key-values.txt
// a few key values
PLUGIN=cool-pugin
THEME=new-schoolIf you have a JSON file and you want the value for a given property you can use the command extension.commandvariable.file.content.
The supported arguments:
- fileName: specifies the file to read, see File Content.
- json: specifies a JavaScript expression that gets the property you want from the variable- content. The variable- contentis the parsed JSON file. The JavaScript expression can contain variables like- ${remember:foobar}
- default: (Optional) If the JavaScript expression fails and you have defined- defaultthat string is returned else- "Unknown"is returned.
- keyRemember: (Optional) If you want to remember the value for later use. (default:- "fileContent")
The JSON file can be an array and you can address the elements with: content[3]
Can be used as variable ${fileContent:name}
You have a JSON configuration file in your workspace:
config.json
{
  "log": "foobar.log",
  "server1": {
    "port": 5011
  },
  "server2": {
    "port": 5023
  }
}In your tasks.json you want to use the server1 port value.
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "echo Server1Port",
      "type": "shell",
      "command": "echo",
      "args": [
        "${input:configServer1Port}"
      ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "configServer1Port",
      "type": "command",
      "command": "extension.commandvariable.file.content",
      "args": {
        "fileName": "${workspaceFolder}/config.json",
        "json": "content.server1.port",
        "default": "4321",
        "keyRemember": "ServerPort"
      }
    }
  ]
}If you have a YAML file and you want the value for a given property you can use the command extension.commandvariable.file.content.
The supported arguments:
- fileName: specifies the file to read, see File Content.
- yaml: specifies a JavaScript expression that gets the property you want from the variable- content. The variable- contentis the parsed YAML file. The JavaScript expression can contain variables like- ${remember:foobar}
- default: (Optional) If the JavaScript expression fails and you have defined- defaultthat string is returned else- "Unknown"is returned.
- keyRemember: (Optional) If you want to remember the value for later use. (default:- "fileContent")
Can be used as variable ${fileContent:name}
See File Content JSON Property for examples.
If the file contains multiple key-values or properties you want in your task or launch you can remember the picked file and use the same path in another extension.commandvariable.file.content use.
You have the follwing configuration files in your workspace:
server1-config.json
{
  "log": "foobar1.log",
  "server": {
    "port": 5011,
    "publicCryptKey": "01234abcd"
  }
}server2-config.json
{
  "log": "foobar2.log",
  "server": {
    "port": 5023,
    "publicCryptKey": "9876zyxw"
  }
}Use it in your tasks.json:
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "echo ServerPortAndCryptKey",
      "type": "shell",
      "command": "echo",
      "args": [
        "${input:configServerPort}",
        "${input:configServerCryptKey}",
        "${input:serverURL}"
      ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "configServerPort",
      "type": "command",
      "command": "extension.commandvariable.file.content",
      "args": {
        "fileName": "${pickFile:config}",
        "json": "content.server.port",
        "default": "4321",
        "keyRemember": "ServerPort",
        "pickFile": {
          "config": {
            "include": "**/*.json",
            "exclude": ".vscode/*.json",
            "keyRemember": "configFile"
          }
        }
      }
    },
    {
      "id": "configServerCryptKey",
      "type": "command",
      "command": "extension.commandvariable.file.content",
      "args": {
        "fileName": "${remember:configFile}",
        "json": "content.server.publicCryptKey"
      }
    },
    {
      "id": "serverURL",
      "type": "command",
      "command": "extension.commandvariable.transform",
      "args": { "text": "https://example.org:${remember:ServerPort}/" }
    }
  ]
}If you want the (partial) result of an external program inserted in the editor you can use the command extension.commandvariable.file.contentInEditor. This command uses the same arguments as extension.commandvariable.file.content.
Most likely you want to call the program first to write the output to a file that you read and extract the parts you want. For this you can use the extension multi-command.
- Define a task that runs the external command
- Define a multi-command that calls the task and then extension.commandvariable.file.contentInEditor
- Define a key binding that calls the multi-command
Add to .vscode/tasks.json
    {
      "label": "get Timestamp",
      "type": "shell",
      "command": "echo timestamp=2021-04-01 12:34 >${workspaceFolder}/timequery.txt",
      "problemMatcher": []
    }Add to .vscode/settings.json
  "multiCommand.commands": [
    {
      "command": "multiCommand.insertTimestamp",
      "interval": 500,
      "sequence": [
        { "command": "workbench.action.tasks.runTask",
          "args": "get Timestamp"
        },
        { "command": "extension.commandvariable.file.contentInEditor",
          "args": {
            "fileName": "${workspaceFolder}/timequery.txt",
            "key": "timestamp",
            "default": "Query failed"
          }
        }
      ]
    }
  ]Add to keybindings.json
{
    "key": "F1", // or any other key combo
    "command": "extension.multiCommand.execute",
    "args": { "command": "multiCommand.insertTimestamp" },
    "when": "editorTextFocus"
}If you have an array or object as configuration variable content (settings.json) and you want a particular element of the array or the value for a given object property you can use the command extension.commandvariable.config.expression.
The supported arguments:
- configVariable: specifies the settings variable to read. Supports variables.
- expression: specifies a JavaScript expression that has the value of the- configVariablein the variable- content. The JavaScript expression can contain variables like- ${remember:foobar}or- ${pickStringRemember:name}
- default: (Optional) If the JavaScript expression fails and you have defined- defaultthat string is returned else- "Unknown"is returned.
- keyRemember: (Optional) If you want to remember the value for later use. (default:- "configExpression")
If the configVariable is an array you can address the elements with: content[3]
If the configVariable is an object you can address a property with: content.inputDir
Any expression is allowed that does not have a function call. All arithmetic operators, comparison operators, ...
Can be used as variable ${configExpression:name}
You have the following variable in settings.json:
{
  "someExt.servers": {
    "log": "foobar.log",
    "server1": {
      "port": 5011
    },
    "server2": {
      "port": 5023
    }
  }
}In your tasks.json you want to use the server1 port value.
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "echo Server1Port",
      "type": "shell",
      "command": "echo",
      "args": [
        "${input:configServer1Port}"
      ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "configServer1Port",
      "type": "command",
      "command": "extension.commandvariable.config.expression",
      "args": {
        "configVariable": "someExt.servers",
        "expression": "content.server1.port",
        "default": "4321",
        "keyRemember": "ServerPort"
      }
    }
  ]
}If you want to select the server from a pick list you can change the inputs part:
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "echo Server1Port",
      "type": "shell",
      "command": "echo",
      "args": [
        "${input:configServerPort}"
      ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "configServerPort",
      "type": "command",
      "command": "extension.commandvariable.config.expression",
      "args": {
        "configVariable": "someExt.servers",
        "expression": "content.server${pickStringRemember:serverNr}.port",
        "pickStringRemember": {
          "serverNr": {
            "description": "Which server to use?",
            "options": [
              ["development", "1"],
              ["live", "2"]
            ]
          }
        },
        "default": "4321",
        "keyRemember": "ServerPort"
      }
    }
  ]
}If you want to pick a file and use it in your launch.json or tasks.json you can use the extension.commandvariable.file.pickFile command.
This command uses vscode.workspace.findFiles to get a list of files to show in a Quick Pick selection box.
You can set the following properties to this command:
- 
include: a Glob Pattern that defines the files to search for (default:"**/*")
- 
exclude: a Glob Pattern that defines files and folders to exclude. (default:"undefined")Two special strings are possible to pass special values: - "undefined"to set the- excludeargument to- undefinedto use default excludes
- "null"to set the- excludeargument to- nullto use no excludes
 Known problem: excludeis not working as expected under Windows. Excluded files are put at the end of the list.
- 
keyRemember: (Optional) If you want to remember the filepath for later use. (default:"pickFile")
- 
description: (Optional) A text shown in the pick list box. (default:"Select a file")
- 
maxResults: Limit the number of files to choose from. Must be a number (no"characters). (default: no limits)
- 
addEmpty: [true|false] Iftrue: add an entry to the list (*** Empty ***) that will return an empty string when selected. (default:false)
- 
addAsk: [true|false] Iftrue: add an entry to the list (*** Ask ***) that will open an Input Box where you enter the path to be returned. (default:false)
- 
acceptIfOneFile: [true|false] Iftrue: if only one file is shown in the pickList accept this file. (default:false)
- 
display: How do you want to see the files displayed (default:"fullPath")- "fullpath": show the file full path, if path is big it can be clipped by the selection box
- "fileName": show the file name followed by the directory path of the file, the Fuzzy Search is now only on the file name and file extension.
 
- 
fromWorkspace: ["name"|true|false] - limit theincludepattern relative to a workspace (default:false)- if "name": find the workspace with that name
- If true: show a Pick List of Workspaces to choose from
 
- if 
- 
fromFolder: (Optional) Object with the properties (Filepaths support variables):- 
predefined: (Optional) An array with file system paths of directories to limit theincludepattern relative to that directory. Do not enter folder paths that are root folders in this workspace.
 Each entry can be a string or an object with properties:- path: file system path of directory
- label: used in certain transformations
 
- 
labelTransform: (Optional) An array of strings of the transformations to apply to the pickList label when it is longer than the setting:commandvariable.file.pickFile.labelMaximumLength
 Transformations are applied to the pickList label in the order defined as long as it is too large.
 Possible transformations are:- useLabel: regardless of the current length use the label property if defined in the entry in the- predefinedproperty.
- hasLabel: if current length is too large use the label property if defined in the entry in the- predefinedproperty.
- removeWorkspacePath: if the path can be found in one of the (Multi Root) Workspaces remove the workspace path
- clipMiddle: use the setting- commandvariable.file.pickFile.labelClipPointto determine how many characters to take from the start and from the end.
 An example would be: "labelTransform": ["useLabel", "removeWorkspacePath", "clipMiddle"]
- 
fixed: (Optional) A string with a file system directory path to limit theincludepattern relative to that directory. Do not enter folder paths that are root folders in this workspace. You do not get a pick list. On Windows it is not possible to specify a directory path in theincludeGlob Pattern.
 Show a Pick list of folders specified in the property predefinedand 2 additional entries- *** Ask ***: open an Input Box where you enter the path of the folder
- *** Workspace ***: show a Pick List of Workspaces
 "fromFolder": { "predefined": [ "C:\\temp\\log", "D:\\Data\\GPR\\2021" ] } 
- 
- 
showDirs: [true|false] Iftrue: Show the directories that contain files that are found. The result of the pick is a directory path. (default:false)
- 
checkEscapedUI: (Optional) [true|false] Check if in a compound task/launch a previous UI has been escaped, iftruebehave as if this UI is escaped. This will not start the task/launch. (default:false)
- 
transform: (Optional) an object with the same properties as thetransformcommand. It allows to extract part of the picked file URI by using a variable and perform a find-replace operation. The default value of thetextproperty is${file}.
- 
empty: (Optional) [true|false] The full file path is saved for the givenkeyRemember. Iftrue: result of command is the empty string. Can be used withremember:transformcommand or variable. This is the last test of the command (it overrules a possibletransform). (default:false)
Example:
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "echo FilePick",
      "type": "shell",
      "command": "echo",
      "args": [
        "${input:filePick}"
      ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "filePick",
      "type": "command",
      "command": "extension.commandvariable.file.pickFile",
      "args": {
        "include": "**/*.{htm,html,xhtml}",
        "exclude": "**/{scratch,backup}/**"
      }
    }
  ]
}If you want the directory name of the picked file but using forward slash (on Windows, see issue #47)
If you want a different whole number (n ∈ ℤ) in your task or launch config each time you run you can use the command extension.commandvariable.number.
The configuration attributes need to be passed to the command in the args attribute.
The command has the following configuration attributes:
- name: if you have more than 1 number you have to name them to keep track of the previous value(s)
- range: an array with 2 numbers,- [min, max], both values are inclusive and can be the result returned,- min < max(default:- [0, 100])
- random: boolean, do you want a random number from the range (default:- false)
- step: number, if- randomis- falsethe number returned is the previous value incremented with- step, can be negative (default:- 1)
- uniqueCount: number, if- randomis- truethe number returned is unique compared to the previous- uniqueCountnumbers (default:- 0)
You can get the last value of a named number with the remember command or variable.
You must use a special key format: number-name
The value of step determines the first value returned.
- if step >= 0- start with minimum
- when next value > maximum return minimum
 
- if step < 0- start with maximum
- when next value < minimum return maximum
 
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "echo Number from sequence",
      "type": "shell",
      "command": "echo",
      "args": [
        "${input:numberSeq}"
      ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "numberSeq",
      "type": "command",
      "command": "extension.commandvariable.number",
      "args": {
        "name": "sequence",
        "range": [0, 20],
        "step": 3
      }
    }
  ]
}If you want a random number but it must be unique compared to the previous n numbers you have to set the attribute uniqueCount.
The example is for debugging the Nios ii Embedded Design Suite:
{
  "version": "0.2.0",
  "configurations": [
    {
      "name": "app",
      "type": "cppdbg",
      "request": "launch",
      "program": "${workspaceFolder}/app/app.elf",
      "stopAtEntry": true,
      "cwd": "${workspaceFolder}",
      "MIMode": "gdb",
      "miDebuggerServerAddress": "localhost:${input:randomPort}",
      "miDebuggerPath": "/home/me/intelFPGA/20.1/nios2eds/bin/gnu/H-x86_64-pc-linux-gnu/bin/nios2-elf-gdb",
      "debugServerPath": "/home/me/intelFPGA/20.1/quartus/bin/nios2-gdb-server",
      "debugServerArgs": "--tcpport ${input:rememberRandomPort} --reset-target --tcptimeout 5",
    }
  ],
  "inputs": [
    {
      "id": "randomPort",
      "type": "command",
      "command": "extension.commandvariable.number",
      "args": {
        "name": "randomPort",
        "range": [1500, 60000],
        "random": true,
        "uniqueCount": 10
      }
    },
    {
      "id": "rememberRandomPort",
      "type": "command",
      "command": "extension.commandvariable.remember",
      "args": { "key": "number-randomPort" }
    }
  ]
}It can be useful to store key-value pairs to be used later. The value of the key is remembered for this session of Visual Studio Code.
Some commands in this extension can store key-value pairs: pickStringRemember, promptStringRemember, file.content (json, key-value, yaml), file.pickFile.
The stored value is retrieved with a command or a variable. In the same task/launch config or in a different one, or in a keybinding.
The command extension.commandvariable.remember is used to retreive a value for a particular key or store key-value pair(s).
The args property of this command is an object with the properties:
- store: (Optional) an object with key-value pair(s). Every key-value is stored in the- rememberstorage.
- key: (Optional) the name of the key to retreive from the remember store. The- keycan contain variables. (default:- "empty")
 To get the value of a named number use the key format:- number-name
- checkEscapedUI: (Optional) [- true|- false] Check if in a compound task/launch a previous UI has been escaped, if- truebehave as if this UI is escaped. This will not start the task/launch. (default:- false)
- transform: (Optional) (Not in Web) an object with the same properties as the- transformcommand. It allows to find and replace in the string or to extract part of the- file.pickFilepicked file URI by using a variable. The default value of the- textproperty is- ${result}. This is the value stored in the remember store for the given- key.
If you need to construct a new string with the value you can use the variable: ${remember:key}. This can only be used in args properties of commands in this extension. The inputs list of launch.json and tasks.json or in keybindings or extensions that call commands with arguments (Multi Command). You can modify the value with the transform command or the transform property.
The default content of the remember store:
- empty:- "", the empty string, useful if you want to store the value(s) but not return some string in- pickStringRemember
The example is a bit contrived but it shows how you can store key-value pair(s) in a launch config or task without using a stored value, the result of the ${input:rememberConfig} is the empty string. This enables you to store values in a launch config to be used in a prelaunchTask in tasks.json.
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "DoSomething",
      "type": "shell",
      "command": "${config:python.pythonPath}${input:rememberConfig}",
      "args": [
        "my_script.py",
        "${input:remember.path}",
        "${input:remember.name}"
      ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "rememberConfig",
      "type": "command",
      "command": "extension.commandvariable.remember",
      "args": {
        "store": {"path":"server","name":"boya","user":"Mememe","option":"yeah"}
      }
    },
    {
      "id": "remember.path",
      "type": "command",
      "command": "extension.commandvariable.remember",
      "args": { "key": "path" }
    },
    {
      "id": "remember.name",
      "type": "command",
      "command": "extension.commandvariable.remember",
      "args": { "key": "name" }
    }
  ]
}If you have picked a file, the key used is sourceFile, and you don't want the full file path you can get certain parts with the transform property:
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "DoSomething2",
      "type": "shell",
      "command": "${config:python.pythonPath}",
      "args": [
        "my_script2.py",
        "${input:remember.showWorkspace}",
        "${input:remember.showBasename}"
      ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "remember.showWorkspace",
      "type": "command",
      "command": "extension.commandvariable.remember",
      "args": { "key": "sourceFile", "transform": { "text": "${workspaceFolder}" } }
    },
    {
      "id": "remember.showBasename",
      "type": "command",
      "command": "extension.commandvariable.remember",
      "args": { "key": "sourceFile", "transform": { "text": "${fileBasename}" } }
    }
  ]
}The command extension.commandvariable.pickStringRemember look a lot like the Input variable pickString.
The configuration attributes need to be passed to the command in the args attribute.
The command has the following configuration attributes:
- 
description: Shown some context for the input.
- 
default: Value returned if the user does not make a choice.
 (Not in Web) It can contain variables.
- 
options: An array that can contain the following elements:- string: The label in the pickList and the value returned are this string.
- [label,value]tuple : The label in the pickList is the first element of the tuple, the second element is the value returned and the description in the pickList.
- An object with the following attributes:
- value: The value returned when selected.
- label: (Optional) The label to be displayed for the item in the pick list. If not specified, the- valueis used as the label in the pick list.
- description: (Optional) The description to be used for the item in the pick list. If not specified and- labelis specified, the- valueis used as the description in the pick list, otherwise no description is used in the pick list.
- preProcess: (Optional) If- true, any variables within the- valueare expanded prior to displaying the pick list. If the expansion of the variables requires user interaction, then that interaction will occur prior to the pick list being displayed.
 
 The valuecan be an object with key-value pair(s). Every key-value is stored in therememberstorage.pickStringRememberreturns the value from therememberstorage for thekeyargument of the command (see example).
 If you only want to store some key-value pairs you can set thekeyargument of the command to"empty". The command will then return an empty string (seeremembercommand).
- 
key: (Optional) Used to store and retrieve a particular pick. (default:pickString)
 The value can later be retrieved with theremembercommand or${remember}variable.
- 
rememberTransformed: (Not in Web) ifvaluecontains variables they are transformed in the result of the command. Iftruewe store the transformed string. Iffalsewe store thevaluestring as given in theoptionsproperty. (default:false)
- 
fileName: (Not in Web) A string, with possible variables, specifying a file path that contains additional options. The options in the file are matched using thepatternattribute and appended to the already specifiedoptions. The file is assumed to have an UTF-8 encoding.
- 
pattern: (Not in Web) An object describing a line to match in the file containing the label and optional value of the option. Optional if all attributes have the default value.
 The object has the following attributes:- regexp: (Optional) A regular expression describing a line with capture groups for the label and value for the option. (default:- ^(.*)$)
- label: (Optional) A string containing capture group references- $n(like- $1) that makes up the label in the pickList. (default:- $1)
- value: (Optional) A string containing capture group references- $n(like- $1) that makes up the value in the pickList. (default: the same as- label)
- json: (Optional) A string containing a capture group reference- $n(like- $1) that makes up the value object in the pickList. You have to write the- regexpto recognize a possible JSON object string. (default:- undefined)
 
- 
checkEscapedUI: (Optional) [true|false] Check if in a compound task/launch a previous UI has been escaped, iftruebehave as if this UI is escaped. This will not start the task/launch. (default:false)
(Not in Web) The value string can contain variables, so you can add a pickFile or promptString or .... and use that result.
    ["pick directory", "${pickFile:someDir}"]
If you Escape the UI and a default property is given the UI is not marked as Escaped.
(Not in Web) If the default property contains variables that have a UI they can be Escaped and that will be remembered.
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "Task 1",
      "type": "shell",
      "command": "dostuff1",
      "args": ["-p", "${input:pickPath}"]
    },
    {
      "label": "Task 2",
      "type": "shell",
      "command": "dostuff2",
      "args": ["-p", "${input:rememberPath}"]
    },
    {
      "label": "Do Task 1 and 2",
      "dependsOrder": "sequence",
      "dependsOn": ["Task 1", "Task 2"],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "pickPath",
      "type": "command",
      "command": "extension.commandvariable.pickStringRemember",
      "args": {
        "key": "path",
        "options": [ "path/to/directory/A", "path/to/Z" ],
        "description": "Choose a path"
      }
    },
    {
      "id": "rememberPath",
      "type": "command",
      "command": "extension.commandvariable.remember",
      "args": { "key": "path" }
    }
  ]
}An example of choosing a port number in a launch configuration:
{
  "version": "0.2.0",
  "configurations": [
    {
      "name": "Service1",
      "type": "python",
      "request": "attach",
      "connect": {
        "host": "127.0.0.1",
        "port": "${input:envType}"
      }
    }
  ],
  "inputs": [
    {
      "id": "envType",
      "type": "command",
      "command": "extension.commandvariable.pickStringRemember",
      "args": {
        "description": "Which env do you want to debug?",
        "options": [
          ["development", "5000"],
          ["staging", "5100"],
          ["live", "5200"]
        ],
        "default": "5000"
      }
    }
  ]
}If you have additional options in a file:
- the line is not a comment, does not start with a #character
- the separator of label and value is a =
- value can be a JSON object
{
  "version": "0.2.0",
  "configurations": [
    // see previous example
  ],
  "inputs": [
    {
      "id": "envType",
      "type": "command",
      "command": "extension.commandvariable.pickStringRemember",
      "args": {
        "description": "Which env do you want to debug?",
        "options": [
          ["development", "5000"],
          ["staging", "5100"],
          ["live", "5200"]
        ],
        "default": "5000",
        "fileName": "${workspaceFolder}/dynamic-env.txt",
        "pattern": {
          "regexp": "^\\s*(?!#)([^=]+?)\\s*=\\s*(?:(\\{.+\\})|(.+))$",
          "label": "$1",
          "json": "$2",
          "value": "$3"
        }
      }
    }
  ]
}An example task that picks multiple values:
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "Do some project",
      "type": "process",
      "command": "echo",
      "args": [
        "${input:selectProject.path}",
        "${input:selectProject.name}",
        "${input:selectProject.link}",
        "${input:selectProject.anyOther}"
      ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "selectProject.path",
      "type": "command",
      "command": "extension.commandvariable.pickStringRemember",
      "args": {
        "key": "path",
        "options": [
          { "label": "project1", "value": {"path":"p1","name":"n1","link":"lnk1","anyOther":"any1"}, "description": "Project 1 description" },
          { "label": "project2", "value": {"path":"p2","name":"n2","link":"lnk2","anyOther":"any2"}, "description": "Project 2 description" }
        ],
        "description": "Pick a project"
      }
    },
    {
      "id": "selectProject.name",
      "type": "command",
      "command": "extension.commandvariable.remember",
      "args": { "key": "name" }
    },
    {
      "id": "selectProject.link",
      "type": "command",
      "command": "extension.commandvariable.remember",
      "args": { "key": "link" }
    },
    {
      "id": "selectProject.anyOther",
      "type": "command",
      "command": "extension.commandvariable.remember",
      "args": { "key": "anyOther" }
    }
  ]
}If you have a src directory with a lot of subdirs and you want to run cpplint on all or only on a subdir you can add a pickFile variable as the value of a pickString:
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "cpp lint",
      "type": "shell",
      "command": "cpplint ${input:selectDir}"
    }
  ],
  "inputs": [
    {
      "id": "selectDir",
      "type": "command",
      "command": "extension.commandvariable.pickStringRemember",
      "args": {
        "description": "Which directory to Lint for C++?",
        "options": [
          { "label": "Use previous directory", "value": "${remember:lintPath}", "preProcess": true },
          { "label": "All", "value": "all" },
          { "label": "Pick directory", "value": "${pickFile:srcSubDir}", "description": "Select to pick a directory" }
        ],
        "rememberTransformed": true,
        "key": "lintPath",
        "pickFile": {
          "srcSubDir": {
            "description": "Which directory?",
            "include": "src/**/*.{cpp,h}",
            "showDirs": true,
            "keyRemember": "srcSubDir"
          }
        }
      }
    }
  ]
}extension.commandvariable.promptStringRemember has the same configuration attributes as the Input variable promptString.
extension.commandvariable.promptStringRemember also has the configuration attributes:
- key: (Optional) It is used to store and retrieve a particular entered string. (default:- promptString)
- checkEscapedUI: (Optional) [- true|- false] Check if in a compound task/launch a previous UI has been escaped, if- truebehave as if this UI is escaped. This will not start the task/launch. (default:- false)
The configuration attributes need to be passed to the command in the args attribute. The key attribute is optional if you only have one prompt to remember or every prompt can use the same key name.
The string can later be retrieved with the remember command or variable.
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "Task 1",
      "type": "shell",
      "command": "dostuff1",
      "args": ["-p", "${input:promptPath}"]
    },
    {
      "label": "Task 2",
      "type": "shell",
      "command": "dostuff2",
      "args": ["-p", "${input:rememberPath}"]
    },
    {
      "label": "Do Task 1 and 2",
      "dependsOrder": "sequence",
      "dependsOn": ["Task 1", "Task 2"],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "promptPath",
      "type": "command",
      "command": "extension.commandvariable.promptStringRemember",
      "args": {
        "key": "path",
        "description": "Enter a path"
      }
    },
    {
      "id": "rememberPath",
      "type": "command",
      "command": "extension.commandvariable.remember",
      "args": { "key": "path" }
    }
  ]
}The commands extension.commandvariable.selectedText and extension.commandvariable.currentLineText combine the content in case of multi cursors. The default separator used is "\n".
The selections are sorted in the order they appear in the file.
You can change the separator by specifying an argument object for the command with a property "separator":
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "echo (selected:currentLine) Text",
      "type": "shell",
      "command": "echo",
      "args": [ "${input:multiCursorText}" ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "multiCursorText",
      "type": "command",
      "command": "extension.commandvariable.selectedText",
      "args": { "separator": "@--@" }
    }
  ]
}The command extension.commandvariable.inTerminal types the string result of a command in the terminal and optional types a Carriage Return.
The command extension.commandvariable.inTerminal has an argument that is an object with the following properties:
- command: the command to execute
- args: (Optional) the argument (string, array or object) for the- command
- addCR: (Optional) boolean: end the text from the- commandwith a Carriage Return (- \u000D) (default:- false)
If you want to use the value of a standard variable in the terminal you have to use the command extension.commandvariable.transform in the extension.commandvariable.inTerminal arguments. An example:
  {
    "key": "ctrl+i f5",  // or any other combo
    "command": "extension.commandvariable.inTerminal",
    "args": {
      "command": "extension.commandvariable.transform",
      "args": { "text": "${relativeFile}" }
    }
  }The command extension.commandvariable.setClipboard sets the content of the clipboard with the string property text of the args object.
  {
    "key": "ctrl+i f6",  // or any other combo
    "command": "extension.commandvariable.setClipboard",
    "args": { "text": "This is the new clipboard content" }
  }Sometimes you want to modify a variable before you use it. Change the filename of the file in the editor to construct a different filename.
The transform you can apply to fields in snippets is not supported in the variables in the task and launch json files.
With the command extension.commandvariable.transform you can find-replace with Regular Expression a selection of variables combined with static text.
The command can be used with the ${input:} variable and has the following arguments:
- 
text: the string where you want to apply a find-replace. It can contain a selection of variables and literal text.
- 
find: (Optional) the Regular Expression to search intext. Can contain capture groups and variables. If nofindargument there is nofind-replaceoperation.
- 
replace: (Optional) the replace string of what is matched byfind, can contain group references ($1) and variables, default ("")
- 
flags: (Optional) the flags to be used in the Regular Expression, likegims, default ("")- g: replace all occurences (global)
- i: find case insensitive
 
- 
apply: (Optional) defines a sequence of find-replace operations.
 It is an array of objects, each object can have the properties:find,replaceandflags.
 See${transform}variable for an example.
- 
key: (Optional) It is used to store and retrieve the transformed string. (default:transform)
- 
separator: (Optional) the string used to join the (multi cursor) selections for${selectedText}, default ("\n")
- 
filterSelection: (Optional) a JavaScript expression that allows which (multi cursor) selections to use for${selectedText}, default ("true") all are selected.
 The expression can use the following variables:- index: the 0-base sequence number of the selection
- value: the text of the selection
- numSel: number of selections (or cursors)
 The indexis 0-based to make (modulo) calculations easier. The firstindexis 0.
Example:
If you want the directory name of the active editor file but using forward slash (on Windows, see issue #47)
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "echo Current File Dirname Forward Slash",
      "type": "shell",
      "command": "my_program",
      "args": [
        "${input:fileDirnameForwardSlash}"
      ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "fileDirnameForwardSlash",
      "type": "command",
      "command": "extension.commandvariable.transform",
      "args": {
        "text": "${fileDirname}",
        "find": "\\\\",  // Reason for four '\': https://stackoverflow.com/a/4025505/2909854
        "replace": "/",
        "flags": "g"
      }
    }
  ]
}We can use this command to construct custom variables by setting the text argument and not defining a find argument. The id of the inputs record is the name of the variable.
{
  "version": "0.2.0",
  "configurations": [
    {
      "type": "node",
      "request": "launch",
      "name": "Node",
      "runtimeArgs": ["user", "${input:TEST_USER}"],
    },
    {
      "type": "chrome",
      "request": "launch",
      "name": "Chrome",
      "url": "http://localhost:3000?${input:TEST_USER}",
    }
  ],
  "inputs": [
    {
      "id": "TEST_USER",
      "type": "command",
      "command": "extension.commandvariable.transform",
      "args": { "text": "BobSmith" }
    }
  ]
}Many strings of commands support variables.
If the variable substitution is done with a pickFile:transform or remember:transform of a picked file, command or variable, the text "current opened file" should be replaced with "picked file".
VSC does not perform variable substitution in the strings of the inputs fields, so currently only a selection of variables is replicated here:
- 
${selectedText}: a joined string constructed from the (multi cursor) selections.
 You can overide the used properties by embedding them in the variable
- 
${env:name}: get the value for environment variablename
- 
${pathSeparator}: the character used by the operating system to separate components in file paths
- 
${userHome}: the path of the user's home folder
- 
${workspaceFolder}: the path of the workspace folder opened in VS Code containing the current file.
- 
${workspaceFolder:name}: the path of the workspace folder with the specified name opened in VS Code
- 
${workspaceFolderBasename}: the name of the workspace folder opened in VS Code containing the current file without any slashes
- 
${file}: the current opened file (the file system path)
- 
${relativeFile}: the current opened file relative to workspaceFolder
- 
${relativeFileDirname}: the current opened file's dirname relative to workspaceFolder
- 
${fileBasename}: the current opened file's basename
- 
${fileBasenameNoExtension}: the current opened file's basename with no file extension
- 
${fileExtname}: the current opened file's extension
- 
${fileDirname}: the current opened file's dirname
- 
${pickStringRemember:name}: use thepickStringRemembercommand as a variable, arguments are part of thepickStringRememberproperty of the (parent) command
- 
${promptStringRemember:name}: use thepromptStringRemembercommand as a variable, arguments are part of thepromptStringRememberproperty of the (parent) command
- 
${remember:key}: use the remember command as a variable,
 keyis first tested as a named argument object property (likepickStringRemember), arguments are part of therememberproperty of the (parent) command.
 If not found andkeyhas the formatnumber-namethe name is used to get the last value of a named number.
 If not foundkeyis a key in the remeber store.keymatches:- keyargument of the- pickStringRememberor- promptStringRemembervariable/command
- keyRememberargument of the- pickFileor- fileContentvariable/command
- or a key used in storing multiple values in the remembercommand.
 You can add the checkEscapedUIproperty to thekeyname if it is not a named argument object like${remember:key__checkEscapedUI}.
 See a few examples of the${remember}variable.
- 
${pickFile:name}: use thepickFilecommand as a variable, arguments are part of thepickFileproperty of the (parent) command
- 
${fileContent:name}: use thefile.contentcommand (File Content Key Value pairs, File Content JSON Property ) as a variable, arguments are part of thefileContentproperty of the (parent) command. (works the same as${pickStringRemember:name})
- 
${configExpression:name}: use theconfig.expressioncommand as a variable, arguments are part of theconfigExpressionproperty of the (parent) command (works the same as${pickStringRemember:name})
- 
${command:name}: use the result of a command as a variable.namecan be a commandID or a named argument object property (likepickStringRemember), arguments are part of thecommandproperty of the (parent) command
- 
${transform:name}: use the result of a transform as a variable.nameis a named argument object property (likepickStringRemember), arguments are part of thetransformproperty of the (parent) command. You can transform strings that are the result of a transform.
- 
${result}: a special variable used in theremember:transform:textproperty. It contains the string stored for the givenkey. In all other cases it is the empty string.
The variables are processed in the order mentioned. This means that if the selected text contains variable descriptions they are handled as if typed in the text.
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "echo first part fileBaseNameNoExtension",
      "type": "shell",
      "command": "echo",
      "args": [ "${input:firstPart}" ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "firstPart",
      "type": "command",
      "command": "extension.commandvariable.transform",
      "args": {
        "text": "${fileBasenameNoExtension}",
        "find": "(.*?)-.*",
        "replace": "$1",
      }
    }
  ]
}The variable ${workspaceFolder} is only valid in certain cases and depends on the URI of a file:
The URI used is:
| location ${workspaceFolder} | File Open | URI | 
|---|---|---|
| pickFile:transform | -- | URI of the picked file | 
| remember:transformof a picked file | -- | URI of the picked file | 
| other | No | undefined | 
| other | Yes | URI of the open file | 
Be aware that "other" also refers to the pickFile:fromFolder property.
| URI | Workspace | ${workspaceFolder} | 
|---|---|---|
| -- | No | "Unknown"and Error:"No Folder" | 
| -- | Folder | Path of the open folder | 
| undefined | Multi Root | "Unknown"and Error:"Use workspace name" | 
| valid | Multi Root | Path of the workspace containing URI or first workspace in the list | 
An example:
${workspaceFolder:server}
The variable ${workspaceFolder:name} is only invalid when there is no folder open.
In most cases the name is the basename of the workspace folder path (last directory name).
If you have 2 workspaces with the same (folder base)name you can't target the second one by name only. You have to use more parts of the directory path to make the name unique. Use the / as path separator on all platforms. The name is tested to be at the end of the workspace folder path (using / as separator).
An example:
${workspaceFolder:/websiteA/server}
The variable ${workspaceFolderBasename} uses the same strategy as variable ${workspaceFolder} to determine the workspace to use.
If you only have 1 selection you don't need the properties separator and filterSelection.
For the transform command you can define the properties separator and filterSelection in the args property of the command.
- 
separator: (Optional) the string used to join the (multi cursor) selections for${selectedText}, default ("\n")
- 
filterSelection: (Optional) a JavaScript expression that allows which (multi cursor) selections to use for${selectedText}, default ("true") all are selected.
 The expression can use the following variables:- index: the 0-base sequence number of the selection
- value: the text of the selection
- numSel: number of selections (or cursors)
 The indexis 0-based to make (modulo) calculations easier. The firstindexis 0.
      "args": {
        "text": "${selectedText}",
        "separator": "@-@",
        "filterSelection": "index%2===1",
      }And you can define/overrule the properties by embedding them in the variable:
${selectedText separator properties separator}
All separator's used in a variable need to be the same.
The separator is a string of 1 or more characters that are not part of the a to z alfabet or {}, in regular expression [^a-zA-Z{}]+. Choose a character string that is not used in the values of the properties part. If you need to use more than 1 character do not use all the same character, it can lead to non conformant properties description that is still parsed. The reason is that JavaScript does not have non-backtrack greedy quantifiers. Currently the variable is matched with 1 regular expression. This makes everything easy to implement.
The properties are the properties you want separated with the separator string. Each property is defined as:
propertyName=value
Everyting between = and the next separator is the value
The above example can be written as
      "args": {
        "text": "${selectedText#separator=@-@#filterSelection=index%2===1#}"
      }A few examples of filterSelection expressions
- every other odd selection : "filterSelection": "index%2===1"
- every selection containing fooorbar:"filterSelection": "value.match(/foo|bar/)"
- the before last selection : "filterSelection": "index===numSel-2"
You can use multiple ${selectedText} variables that have different properties:
      "args": {
        "text": "${selectedText#filterSelection=index===3#} ${selectedText#filterSelection=index===1#}"
      }If you want to add an entry you pick from a list use the variable: ${pickStringRemember:name}
name is the property name of the pickStringRemember property of the args object of the command.
Because the command has no way to determine if it is called from which workspace tasks.json or launch.json file or from a key binding the arguments for pickStringRemember have to be part of the arguments of the command.
See the command extension.commandvariable.pickStringRemember for the arguments you can use.
An example shows faster how it is to be used compared to a lot of text.
"inputs": [
  {
    "id": "appSelect",
    "type": "command",
    "command": "extension.commandvariable.transform",
    "args": {
      "text": "We are using ${pickStringRemember:appName} on port ${pickStringRemember:portNum}",
      "pickStringRemember": {
        "appName": {
            "description": "What APP are you running?",
            "options": [ "client", "server", "stresstest", "pentest", "unittest" ],
            "default": "server"
        },
        "portNum": {
          "description": "What protocol?",
          "options": [
            ["http", "80"],
            ["http over proxy", "8080"],
            ["ftp", "21"]
          ],
          "default": "80"
        }
      }
    }
  }
]The promptStringRemember variable works the same as the pickStringRemember variable.
If you want to add an entry you type on the keyboard use the variable: ${promptStringRemember:name}
name is the property name of the promptStringRemember property of the args object of the command.
Because the command has no way to determine if it is called from which workspace tasks.json or launch.json file or from a key binding the arguments for promptStringRemember have to be part of the arguments of the command.
See the command extension.commandvariable.promptStringRemember for the arguments you can use.
The pickFile variable works the same as the pickStringRemember variable.
If you want a file path use the variable: ${pickFile:name}
name is the property name of the pickFile property of the args object of the command.
Because the command has no way to determine if it is called from which workspace tasks.json or launch.json file or from a key binding the arguments for pickFile have to be part of the arguments of the command.
See the command extension.commandvariable.pickFile for the arguments you can use.
An example: you have a number of key-value files and you want to select which environment to use
{
  "version": "0.2.0",
  "tasks": [
    {
      "label": "echo theme name",
      "type": "shell",
      "command": "echo",
      "args": [ "${input:themeName}" ]
    }
  ],
  "inputs": [
    {
      "id": "themeName",
      "type": "command",
      "command": "extension.commandvariable.file.content",
      "args": {
        "fileName": "${pickFile:environ}",
        "key": "THEME",
        "pickFile": {
          "environ": {
            "description": "Which environment?",
            "include": "**/*environ*",
            "display": "fileName"
          }
        }
      }
    }
  ]
}If you want to transform result of a command you use the ${command:name} variable in the text property of the extension.commandvariable.transform command.
name can be a commandID or a named argument object property (like pickStringRemember)
If the command does not use arguments you place the commandID directly in the variable.
{
  "version": "0.2.0",
  "tasks": [
    {
      "label": "echo relative file no ext with dots - first dir removed",
      "type": "shell",
      "command": "echo",
      "args": [ "${input:relativeNoExtDotsBaseOff}" ]
    }
  ],
  "inputs": [
    {
      "id": "relativeNoExtDotsBaseOff",
      "type": "command",
      "command": "extension.commandvariable.transform",
      "args": {
        "text": "${command:extension.commandvariable.file.relativeFileDotsNoExtension}",
        "find": "^[^.]+\\."
      }
    }
  ]
}If the command uses arguments you have to put these in the arguments of the parent command in the property command. (Just like with the ${pickStringRemember:name} variable)
The named arguments have the following properties:
- command: the commandID to execute
- args: the arguments for this commandID
{
  "version": "0.2.0",
  "tasks": [
    {
      "label": "echo top 2 workspace folder names",
      "type": "shell",
      "command": "echo",
      "args": [ "${input:workspaceTop2Folders}" ]
    }
  ],
  "inputs": [
    {
      "id": "workspaceTop2Folders",
      "type": "command",
      "command": "extension.commandvariable.transform",
      "args": {
        "text": "${command:folderPosix}",
        "find": "^.*/([^/]+/[^/]+)$",
        "replace": "$1",
        "command": {
          "folderPosix": {
            "command": "extension.commandvariable.workspace.folderPosix",
            "args": { "name": "server" }
          }
        }
      }
    }
  ]
}Say you have a command/script that wants a series of numbers and they can be in a single argument. The numbers have to be clean, no other text in between. You also want to be able to select some text in an editor and use that to filter out the numbers.
{
  "version": "0.2.0",
  "tasks": [
    {
      "label": "echo top 2 workspace folder names",
      "type": "shell",
      "command": "myScript",
      "args": [ "${input:numberSequence}" ]
    }
  ],
  "inputs": [
    {
      "id": "numberSequence",
      "type": "command",
      "command": "extension.commandvariable.pickStringRemember",
      "args": {
        "description": "Which number list?",
        "options": [
          "100 200 300",
          "51 99 2",
          ["Use a raw number list", "${transform:removeLeadingTrailingSpaces}"]
        ],
        "rememberTransformed": true,
        "key": "numSeq",
        "transform": {
          "removeLeadingTrailingSpaces": {
            "text": "${transform:nonNumbersToSpace}",
            "find": "^ +| +$",
            "flags": "g",
            "transform": {
              "nonNumbersToSpace": {
                "text": "${pickStringRemember:getRawNumberList}",
                "find": "[^0-9]+",
                "replace": " ",
                "flags": "g",
                "pickStringRemember": {
                  "getRawNumberList": {
                    "description": "Which raw number list?",
                    "options": [
                      "foo 123 bar bar 456      ",
                      "Alice: 10,  Bob: 3",
                      ["Selected text", "${selectedText}"]
                    ]
                  }
                }
              }
            }
          }
        }
      }
    }
  ]
}The above example can be made more readable with the apply property to define a sequence of find-replace operations (we also replace multiple spaces by 1 space)
  "inputs": [
    {
      "id": "numberSequence",
      "type": "command",
      "command": "extension.commandvariable.pickStringRemember",
      "args": {
        "description": "Which number list?",
        "options": [
          "100 200 300",
          "51 99 2",
          ["Use a raw number list", "${transform:rawNumberList}"]
        ],
        "rememberTransformed": true,
        "key": "numSeq",
        "transform": {
          "rawNumberList": {
            "text": "${pickStringRemember:getRawNumberList}",
            "apply": [
              {
                "find": "[^0-9]+",
                "replace": " ",
                "flags": "g",
              },
              {
                "find": "^ +| +$",
                "flags": "g",
              },
              {
                "find": " {2,}",
                "replace": " ",
                "flags": "g",
              }
            ]
            "pickStringRemember": {
              "getRawNumberList": {
                "description": "Which raw number list?",
                "options": [
                  "foo 123 bar bar 456      ",
                  "Alice: 10,  Bob: 3",
                  ["Selected text", "${selectedText}"]
                ]
              }
            }
          }
        }
      }
    }
  ]If you want to use one of the stored values you can use the ${remember:name} variable in the text property of the extension.commandvariable.transform command.
If you only want to retreive a value for a stored key just use the key name ${remember:key_name}.
The value for key serverPortNr was stored with another command.
{
  "version": "0.2.0",
  "tasks": [
    {
      "label": "echo Server Port",
      "type": "shell",
      "command": "echo",
      "args": [ "Attach to port ${input:severPortNr}" ]
    }
  ],
  "inputs": [
    {
      "id": "severPortNr",
      "type": "command",
      "command": "extension.commandvariable.transform",
      "args": {
        "text": "${remember:serverPortNr}"
      }
    }
  ]
}If you want to pass more arguments to the remember command you have to put these in the arguments of the parent command in the property remember. (Just like with the ${pickStringRemember:name} variable)
If you have picked a file, the key used is sourceFile, and you don't want the full file path you can get certain parts with the transform property:
{
  "version": "0.2.0",
  "tasks": [
    {
      "label": "echo Source file",
      "type": "shell",
      "command": "echo",
      "args": [ "${input:sourceFileInfo}" ]
    }
  ],
  "inputs": [
    {
      "id": "sourceFileInfo",
      "type": "command",
      "command": "extension.commandvariable.transform",
      "args": {
        "text": "From Workspace ${remember:showWorkspace} we use ${remember:showBasename}",
        "remember": {
          "showWorkspace": {
            "key": "sourceFile",
            "transform": { "text": "${workspaceFolder}" }
          },
          "showBasename": {
            "key": "sourceFile",
            "transform": { "text": "${fileBasename}" }
          }
        }
      }
    }
  ]
}If you have a task/launch that uses variables that have a UI and you Escape the UI the task/launch is not executed.
If you have a compound task/launch you want to also terminate all following tasks/launches. All UI elements in this extension (pickFile, pickString and promptString), as command or variable, record if they are Escaped. They can test if there has been an Escaped UI and behave as if Escaped themself. Also the remember command and variable can test for an Escaped UI and behave as being an Escaped UI.
You don't add the checkEscapedUI property to the first UI in the compound task/launch because it would check if the previous run was Escaped.
This example uses simple echo tasks to keep it short.
{
  "version": "0.2.0",
  "tasks": [
    {
      "label": "Task 1",
      "type": "shell",
      "command": "echo",
      "args": [ "Task 1 using envType: ${input:envType}" ],
      "problemMatcher": []
    },
    {
      "label": "Task 2",
      "type": "shell",
      "command": "echo",
      "args": [ "Task 2 with envMessage: ${input:envMessage}" ],
      "problemMatcher": []
    },
    {
      "label": "Task 3",
      "type": "shell",
      "command": "echo",
      "args": [ "Task 3 with message: ${input:transformEnvMessage}" ],
      "problemMatcher": []
    },
    {
      "label": "Task Sequence",
      "dependsOrder": "sequence",
      "dependsOn": ["Task 1", "Task 2", "Task 3"],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "envType",
      "type": "command",
      "command": "extension.commandvariable.pickStringRemember",
      "args": {
        "description": "Which env do you want to debug?",
        "key": "envType",
        "options": [
          ["development", "5000"],
          ["staging", "5100"],
          ["live", "5200"]
        ]
      }
    },
    {
      "id": "envMessage",
      "type": "command",
      "command": "extension.commandvariable.promptStringRemember",
      "args": {
        "key": "envMessage",
        "description": "Enter message",
        "checkEscapedUI": true
      }
    },
    {
      "id": "transformEnvMessage",
      "type": "command",
      "command": "extension.commandvariable.transform",
      "args": {
        "text": "${remember:envMessage__checkEscapedUI}",
        "find": "(\\d+)",
        "replace": "Number($1)"
      }
    }
  ]
}The commands
- extension.commandvariable.workspace.folder
- extension.commandvariable.workspace.folderPosix
- extension.commandvariable.workspace.folderNUp
- extension.commandvariable.workspace.folderNUpPosix
- extension.commandvariable.workspace.folderBasename
- extension.commandvariable.workspace.folderBasenameNUp
allow to get the information from a different workspace by specifying the name or last parts of the file path of the workspace directory. This can also be done when there is no editor active.
You supply the name in the arguments of the command. You have to use an ${input} variable.
{
  "version": "0.2.0",
  "tasks": [
    {
      "label": "echo server name",
      "type": "shell",
      "command": "echo",
      "args": [ "${input:server1Up}" ]
    }
  ],
  "inputs": [
    {
      "id": "server1Up",
      "type": "command",
      "command": "extension.commandvariable.workspace.folderBasename1Up",
      "args": { "name": "server" }
    }
  ]
}If you have 2 workspaces with the same (folder base)name you can't target the second one by name only. You have to use more parts of the directory path to make the name unique. Use the / as path separator on all platforms. The name argument is tested to be at the end of the workspace folder path (using / as separator). An example of an args property is:
"args": { "name": "/websiteA/server" }The commands extension.commandvariable.UUID and extension.commandvariable.UUIDInEditor generate a v4 UUID.
It has the following arguments:
- 
output: can change the output format (default:hexString):- hexString:- a0e0f130-8c21-11df-92d9-95795a3bcd40
- hexNoDelim:- a0e0f1308c2111df92d995795a3bcd40
- bitString:- 101000001110000 ... 1100110101000000
- urn:- urn:uuid:a0e0f130-8c21-11df-92d9-95795a3bcd40
 
- 
use: which UUID to use (default:new):- new: generate a new UUID
- previous,- prev: use the previous generated UUID
 
In this example the 3 printed UUIDs are all different
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "echo UUIDs",
      "type": "shell",
      "command": "echo",
      "args": [
        "${command:extension.commandvariable.UUID}",
        "${input:uuid-hexnodelim}",
        "${input:uuid-urn}"
      ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "uuid",
      "type": "command",
      "command": "extension.commandvariable.UUID"
    },
    {
      "id": "uuid-hexnodelim",
      "type": "command",
      "command": "extension.commandvariable.UUID",
      "args": { "output": "hexNoDelim" }
    },
    {
      "id": "uuid-urn",
      "type": "command",
      "command": "extension.commandvariable.UUID",
      "args": { "output": "urn" }
    },
    {
      "id": "uuid-bits",
      "type": "command",
      "command": "extension.commandvariable.UUID",
      "args": { "output": "bitString" }
    }
  ]
}For keybindings.json use extension.commandvariable.dateTimeInEditor.
For launch.json and tasks.json use extension.commandvariable.dateTime.
This command uses Intl.DateTimeFormat to create a language-sensitive format of current date and time.
The locale and options command arguments are the arguments for the Intl.DateTimeFormat constructor and are optional.
The locale command argument can be a single string or an array of strings of language tags. If not specified the browser default locale is used.
The template command argument is an optional template string that uses the same placeholder syntax as the Javascript template strings. You can add as many literal text as needed.
The only expressions valid are the type values returned by the Intl.DateTimeFormat.prototype.formatToParts() method. See first example.
If there is no template command argument the value parts of the Intl.DateTimeFormat.prototype.formatToParts() are joined. See second example.
  {
    "key": "ctrl+shift+alt+f4",
    "when": "editorTextFocus",
    "command": "extension.commandvariable.dateTimeInEditor",
    "args": {
      "locale": "en-US",
      "options": {
        "year": "numeric",
        "month": "2-digit",
        "day": "2-digit",
        "hour12": false,
        "hour": "2-digit",
        "minute": "2-digit",
        "second": "2-digit"
      },
      "template": "${year}/${month}/${day}-${hour}:${minute}:${second}"
    }
  }The result is
2020/03/19-18:01:18
You can use a different locale and number system and use the long format:
  {
    "key": "ctrl+shift+alt+f5",
    "when": "editorTextFocus",
    "command": "extension.commandvariable.dateTimeInEditor",
    "args": {
      "locale": "fr-FR-u-nu-deva",
      "options": {
        "dateStyle": "full",
        "timeStyle": "full"
      }
    }
  }The result is
jeudi १९ mars २०२० à १७:५९:५७ heure normale d’Europe centrale
For launch.json and tasks.json use the inputs attribute:
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "echo date",
      "type": "shell",
      "command": "echo",
      "args": [ "${input:shortDate}" ],
      "problemMatcher": []
    }
  ],
  "inputs": [
    {
      "id": "shortDate",
      "type": "command",
      "command": "extension.commandvariable.dateTime",
      "args": {
        "locale": "es-ES",
        "options": {
          "weekday": "long",
          "year": "numeric",
          "month": "2-digit",
          "day": "2-digit",
          "hour12": false,
          "hour": "2-digit",
          "minute": "2-digit",
          "second": "2-digit"
        },
        "template": "${weekday}__${year}${month}${day}T${hour}${minute}${second}"
      }
    }
  ]
}The result is:
jueves__20200319T184634
{ "version": "2.0.0", "tasks": [ { "label": "echo FilePick Dirname Forward Slash", "type": "shell", "command": "echo", "args": [ "${input:filePickDirnameForwardSlash}" ], "problemMatcher": [] } ], "inputs": [ { "id": "filePickDirnameForwardSlash", "type": "command", "command": "extension.commandvariable.file.pickFile", "args": { "include": "**/*.{htm,html,xhtml}", "exclude": "**/{scratch,backup}/**", "transform": { "text": "${fileDirname}", "find": "\\\\", // Reason for four '\': https://stackoverflow.com/a/4025505/2909854 "replace": "/", "flags": "g" } } } ] }