Notice: With the release of VFS for Git 2.32, VFS for Git is in maintenance mode. Only required updates as a reaction to critical security vulnerabilities will prompt a release.
Branch | Unit Tests | Functional Tests | Large Repo Perf | Large Repo Build |
---|---|---|---|---|
master | ||||
shipped |
VFS stands for Virtual File System. VFS for Git virtualizes the file system
beneath your Git repository so that Git and all tools see what appears to be a
regular working directory, but VFS for Git only downloads objects as they
are needed. VFS for Git also manages the files that Git will consider, to
ensure that Git operations such as status
, checkout
, etc., can be as quick
as possible because they will only consider the files that the user has
accessed, not all files in the repository.
Note: for new deployments, we strongly recommend you consider Scalar instead of VFS for Git. By combining the lessons from operating VFS for Git at scale with new developments in Git, Scalar offers a clearer path forward for all large monorepos.
VFS for Git requires Windows 10 Anniversary Update (Windows 10 version 1607) or later.
To install, use winget
to install the
microsoft/git
fork of Git and VFS for Git
using:
winget install --id Microsoft.Git
winget install --id Microsoft.VFSforGit
You will need to continue using the microsoft/git
version of Git, and it
will notify you when new versions are available.
If you'd like to build your own VFS for Git Windows installer:
nuget.exe
C:\Repos\VFSForGit
src
subfolder, e.g. C:\Repos\VFSForGit\src
\src\Scripts\BuildGVFSForWindows.bat
src\GVFS.sln
(do not upgrade any projects) and building. However, the very first
build will fail, and the second and subsequent builds will succeed. This is because the build requires a prebuild code generation step.
For details, see the build script in the previous step.You can also use Visual Studio 2019. There are a couple of options for getting all the dependencies.
Visual Studio 2019 will automatically prompt you to install these dependencies when you open the solution. The .vsconfig file that is present in the root of the repository specifies all required components except the Windows 10 SDK (10.0.10240.0) as this component is no longer shipped with VS2019 - you'll still need to install that separately.
The installer can now be found at C:\Repos\VFSForGit\BuildOutput\GVFS.Installer.Windows\bin\x64\[Debug|Release]\SetupGVFS.<version>.exe
.gitattributes
file in the root that includes the line * -text
gvfs clone <URL of repo you just created>
Clone Repository
dialog in Azure Repos, not Clone with SSH.cd <root>\src
gvfs unmount
when doneThis project was formerly known as GVFS (Git Virtual File System). You may occasionally see collateral, including code and protocol names, which refer to the previous name.
The VFS for Git source code in this repo is available under the MIT license. See License.md.
VFS for Git relies on the PrjFlt filter driver, formerly known as the GvFlt filter driver, available as a prerelease NuGet package.