Difference command

Azure DevOps Services | Azure DevOps Server 2022 - Azure DevOps Server 2019

Visual Studio 2019 | Visual Studio 2022

The Team Foundation Version Control (TFVC) difference command compares, and if possible displays, differences between two files, files in two folders, or a shelveset and a local or a server file.

Prerequisites

To use the difference command, have the Read permission for all specified items set to Allow. For more information, see Default TFVC permissions.

Syntax

tf diff[erence] itemspec [/version:versionspec] [/type:filetype] 
[/format:format [/ignorespace] [/ignoreeol] [/ignorecase] [/recursive] 
[/options][/noprompt][/login:username,[password]]
tf diff[erence] itemspec itemspec2 [/type:filetype] [/format: format] 
[/ignorespace] [/ignoreeol] [/ignorecase] [/recursive] [/options] [/noprompt][/login:username,[password]]
tf diff[erence] [/shelveset:shelvesetname[;shelvesetowner]] 
shelveset_itemspec [/type:filetype] 
[/format: format] [/ignorespace] [/ignoreeol] [/ignorecase] 
[/recursive] [/options] [/noprompt][/login:username,[password]]
tf diff[erence] /configure

Parameters

Arguments

Argument

Description

<itemspec>

Required. Specifies the item to be compared. If no version or path is specified, the current workspace version is assumed. Accepts both local and Azure DevOps server paths.

For more information about how TFVC parses the itemspec to determine which items are within scope, see Use Team Foundation version control commands.

The difference command doesn't support wildcard characters.

This parameter can't be combined with the /shelveset option.

<itemspec2>

Optional. The item to which the itemspec is to be compared. If you don't provide a second itemspec, the latest Azure DevOps server version of the item is used.

<filetype>

Provides a value for the /type option. You can specify binary or text and a codepage number or the friendly name for a codepage.

<format>

Used with the /format option to specify an output format of one of the following types:

  • Visual
  • Brief
  • Context
  • RCS
  • SS
  • SS_SideBySide
  • SS_Unix
  • Unified
  • Unix

These output formats are explained in the Remarks section.

<versionspec>

The user-provided value for the /version option. For more information about how TFVC parses a version specification to determine which items are within its scope, see Use Team Foundation version control commands.

<shelvesetowner>

Identifies the owner of the shelveset by user name. If a value for this parameter isn't provided, the current user is assumed.

<shelvesetname>

Specifies the name of a shelveset. You can create more than one shelveset with the same name on the server that is running TFVC as long as a different user owns each shelveset.

<shelveset_itemspec>

Specifies the name of a folder or file in the shelveset to compare to the base shelveset version.

<username>

Provides a value to the /login option. You can specify a username value as either DOMAIN\username or username.

Options

Option

Description

/type

Overrides any detected encodings and uses the specified encoding to present the files to the differencing engine.

/version

Specifies the version of the file or folder to compare. By default, TFVC uses the workspace version if you don't provide a versionspec.

Instead of using the /version flag, you can specify versions by appending a semicolon and version specifier to the end of each file name.

/format

Specifies an output format specified by the format argument.

/ignorespace

Doesn't highlight whitespace differences between the compared files.

/ignoreeol

Ignores differences between the new line characters in two files or file versions. /ignoreeol works differently from ignorespace, which treats eight spaces identically to one. However, if you use the /ignoreeol option and File A has two new line characters between unchanged areas of text, and File B has one, the result displays as a difference. If both files have only one new line, but File A uses \r\n as a new line and File B uses \n, the /ignoreeol option would ignore that as a difference.

/ignorecase

Doesn't highlight differences in letter casing between the compared files.

/recursive

Compares the differences between the current folder and all its subfolders.

/options

Specifies an option string for the tool to be invoked by difference. For more information, see Associate a file type with a difference tool and Associate a file type with a merge tool.

/shelveset

Specifies a shelveset to compare to the Azure DevOps server version upon which the shelveset is based.

This option can't be combined with an itemspec argument. To compare individual shelveset items, you can provide a shelveset_itemspec.

/noprompt

Suppresses any dialog boxes that would otherwise be displayed during the completion of this operation.

/configure

Invokes the Configure User Tools dialog box from the Visual Studio user interface. For more information, see Associate a file type with a difference tool.

/login

Specifies the user name and password to authenticate the user with TFVC.

Remarks

Note

You can type tf diff or tf difference at the command line to run this command.

You can use the difference command to compare and if possible display differences between:

  • Two different files or two versions of the same file.

  • One or more of the items in a folder.

  • One, some, or all the items in a shelveset on the Azure DevOps server.

You can use the difference command to compare both versioned and non-versioned files.

TFVC categorizes all files by type. Text files can be merged and compared, side by side and line by line, as long as both files have the same encoding. If you want to compare two files whose encodings aren't the same, you can temporarily mask or override the encoding property for a file by using the /type option.

Binary files can be compared but can't be merged. When you pass one or more binary files to the difference command, TFVC indicates whether differences exist between it and the item to which it's being compared. For more information about how TFVC differentiates between and treats files of different types, see Managing file types.

If you specify two file names, the two files are compared. Instead of using the /version flag, you can specify versions by appending a semicolon and version specifier to the end of each file name.

If you pass only one itemspec to the difference command:

  • If you don't provide a versionspec, your current workspace version of the item is compared to the base workspace version, by default. For example, tf difference header.h compares the current version of header.h to the version upon which header.h is based.

  • If you include a versionspec in your itemspec, such as tf difference header.h;LBeta1, TFVC compares that version to your current workspace version on disk.

  • If you specify a range of versions such as /version:C1~C4, the versions of the file at the two endpoints of the range are compared.

For more information on how to use the tf command-line utility, see Use Team Foundation version control commands.

Output format types

The format parameter, used with the /format option, specifies many different output formats. The following output types are available:

  • Visual format type opens an external difference application. By default, diffmerge.exe is launched.

  • Brief format prints whether the files being compared differ.

  • Context format provides lines of context for the differences in the files. This format is derived from the UNIX-based diff -c output format.

  • RCS format is similar to /format:unix, except context lines aren't supplied. No special handing for a missing end of line marker at the end of the file is provided.

  • SS is the default difference output format for Visual SourceSafe. For more information, see Diff (command line).

  • SS_SideBySide is the default side-by-side output format for Visual SourceSafe.

  • SS_Unix is similar to the /format:unix output format, but /format:ss_unix includes context lines and /format:unix doesn't.

  • Unified format is derived from the UNIX-based diff -u output format. /format:context repeats identical context lines between the difference strings, but /format:unified doesn't.

    Unified format produces a new unified difference string (@@ ... @@) line only when the distance to the next difference string is larger than the number of context lines.

  • Unix output type is derived from the UNIX-based diff command output format.

    The Unix output format is constructed in the following way:

    <metadataline>
    "< " line prefix for lines from the first file
    "---" line
    "> " line prefix for lines from the second file
    
    <metadataline> can be one of these possibilities:
    #a#,# -- add lines from line # in file1 into file2 at lines #->#
    #,#d# -- delete lines from line # -> # in file 1 from file2 at line #
    #,#c#,# -- change lines from line # -> # in file1 into the lines in file2 at line # -> #
    
    # signs separated by commas indicate a line range.
    # signs before the character indicate line numbers in the first file.
    # signs after the character indicate line numbers in the second file.
    
    /// No end of line marker at the end of the file:
    /// \ No newline at end of file
    

Examples

The following example displays the differences between the local version of 314.cs and the workspace version of 314.cs that's the version of the file that was checked out from the Azure DevOps server.

c:\projects>tf difference 314.cs

The following example displays all files that have been changed in the src folder, but doesn't display files that have been changed in subfolders of src.

c:\projects>tf difference src /format:visual

The following example displays the differences between changeset 3 and changeset 8 of 1254.cs.

c:\projects>tf difference /version:C3~C8 1254.cs

The following examples display the differences between the version of 314.cs that belong to the label release and the version that belongs to changeset 3200.

c:\projects>tf difference 314.cs;Lrelease 314.cs;C3200

-or-

c:\projects>tf difference 314.cs;Lrelease~C3200

The following example displays the difference between the versions of e271.cs that a user named Pat shelved in shelveset PeerCodeReview8 and the base shelveset version that they based their changes on. The output also shows the types of changes pending against e271.cs when the user shelved.

c:\projects> tf difference /shelveset:PeerCodeReview8;Pat e271.cs

The following example displays the differences between all files in the PeerCodeReview2 shelveset and the base shelveset version of those files.

c:\projects> tf difference /shelveset:PeerCodeReview2