Workfold command (Team Foundation Version Control)
TFS 2018
Visual Studio 2019 | Visual Studio 2022
The Team Foundation Version Control (TFVC) workfold
command creates, modifies, or displays information about the mappings between your workspace folders and the folders that are on the Azure DevOps server for TFVC.
Prerequisites
To use the workfold
command, you must be the owner of the specified or implied workspace or have the global Administer workspaces permission set to Allow. For more information, see Default TFVC permissions.
Syntax
tf workfold <local-folder> [/login:<username>,[<password>]]
tf workfold [/workspace:<workspace-name>] [/login:<username>,[<password>]]
tf workfold [/collection:<team-project-collection-url>] [/workspace:<workspace-name>] [/login:<username>,[<password>]]
<server-folder>
tf workfold [/map <server-folder> <local-folder>] [/collection:<team-project-collection-url>]
[/workspace:<workspace-name>][/login:<username>,[<password>]
tf workfold /unmap [/collection:<team-project-collection-url>] [/workspace:<workspace-name>]
[/recursive] (<server-folder>|<local-folder>) [/login:<username>,[<password>]]
tf workfold /cloak
<server-folder> [/workspace:<workspace-name>] [/collection:<team-project-collection-url>] [/login:<username>,[<password>]]
tf workfold /decloak <server-folder>
[/workspace:<workspace-name>] [/collection:<team-project-collection-url>][/login:<username>,[<password>]]
Parameters
The following sections describe arguments and options of the workfold
command.
Arguments
Argument
Description
<workspace-name>
Specifies the name of the workspace that the command operates on with the /workspace
option.
<server-folder>
Specifies the name of an Azure DevOps server folder.
<local-folder>
Specifies the name of a local folder.
<team-project-collection-url>
The URL of the project collection that contains the folders that you want to compare with server folders, for example, https://myserver:8080/tfs/DefaultCollection/
.
<username>
Provides a value to the /login
option. You can specify this value as either DOMAIN\<username>
or <username>
.
<password>
Provides a value to the /login
option.
Options
Option
Description
/workspace
Specifies the name of the workspace to work in.
/map
Specifies an association between a local folder and the Azure DevOps server folder. By default, the workfold
command uses this option, even if unspecified, unless /unmap
, /cloak
, or /decloak
is specified.
/unmap
Specifies which folder mapping to remove from the workspace.
/cloak
Specifies that the folder should be excluded from any version control actions that are made in the workspace.
/decloak
Decloaks a folder so that the folder can be retrieved into the workspace.
/collection
Specifies the project collection.
/login
Specifies the username and password to authenticate the user with Azure DevOps.
Remarks
You can use the workfold
command of the tf
command-line utility to create and edit workspace mappings. A workspace mapping creates a client-side folder into which all files and subfolders in the Azure DevOps server folder are retrieved when you run a tf
get
operation. The get
operation doesn't work if the client-side folder is cloaked.
You can also use an asterisk (*) wildcard character to map an Azure DevOps Server folder and its immediate items to your local workspace. This mapping is often referred to as a single folder mapping.
For more information about how to use the tf
command-line utility, see Use Team Foundation version control commands.
Options for workspace mapping
A workspace mapping is a list of active and cloaked items. You can add Azure DevOps server items to the mapped list in the workspace by using the /map
option. You can also exclude an item from the workspace explicitly by using the /cloak
option. You can only cloak items that have a mapped parent. Cloaking is an effective way to improve the speed of batch get
operations and to conserve space on disk.
Use cloaking with discretion. To avoid compilation and integration problems, you should only cloak those items that you know to be outside the scope of your current and future projects, such as images and external documentation files.
You can use the /unmap
and /decloak
options to selectively delete mapped and cloaked entries from the workspace mapping.
How workspace mappings are applied
By default, workspace mappings are applied recursively. When you map a local folder to an Azure DevOps server folder, the system implicitly creates a mapping between all its current and future subfolders.
For example, suppose you map $/projects to C:\projects. Next, you add a project called $/projects/project_one, and then you run the get
command on the workspace. In this scenario, TFVC automatically creates a local working folder named project_one in the C:\projects directory.
The following example uses an asterisk (*) wildcard character to map a server folder and its immediate items to your local workspace:
tf workfold $/projects/MyTeamProject/* C:\MyLocalWorkfold\MyTeamProject
The following example uses the workfold
command to override the mapping that's automatically created between $/projects/project_one and C:\projects\project_one:
tf workfold $/projects/project_one C:\DifferentWorkfold
Mappings under cloaks
Mappings of uncloaked folders that are located beneath a cloaked folder in the version control hierarchy can be mapped to your local workspace.
Examples
The following example displays the mappings for the workspace that c:\projects resides in:
c:\projects>tf workfold
The following example cloaks the c:\projects\lib folder:
c:\projects>tf workfold /cloak c:\projects\lib
The following example displays the mapping for the local file word.cs:
c:\projects>tf workfold word.cs
The following example maps the folder C:\DifferentWorkfold to the Azure DevOps server folder $/projects/project_one and replaces the previous workspace mapping for the $/projects/project_one Azure DevOps server folder:
c:\projects>tf workfold $/projects/project_one C:\DifferentWorkfold