aec0012676
The PreModify and FileDeleted event notification types are only used on Windows, or not at all, so we can remove them from the Mac and Linux implementations. This is akin to the changes made in fc85024193ba0a06dad12f620d6518b97f008779 to remove the NotificationMapping class on Mac and Linux. Note that we do still send PreDelete event notifications, and per the comments in GVFS/GVFS.Virtualization/FileSystemCallbacks.cs, the FileSystemVirtualizers currently expect to only receive either PreDelete or FileDeleted events, but not both, so removing the FileDeleted type should align with this expectation. |
||
---|---|---|
.azure-pipelines | ||
GVFS | ||
GitHooksLoader | ||
MirrorProvider | ||
ProjFS.Linux | ||
ProjFS.Mac | ||
Scripts | ||
docs | ||
.editorconfig | ||
.gitattributes | ||
.gitignore | ||
.vsconfig | ||
AuthoringTests.md | ||
CONTRIBUTING.md | ||
GVFS.sln | ||
GvFlt_EULA.md | ||
License.md | ||
Protocol.md | ||
Readme.md | ||
ThirdPartyNotices.txt | ||
nuget.config |
Readme.md
VFS for Git
Branch | Unit Tests | Functional Tests | Large Repo Perf | Large Repo Build |
---|---|---|---|---|
master | ||||
shipped |
What is VFS for Git?
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.
See our documentation for instructions to get started.
New name
This project was formerly known as GVFS (Git Virtual File System). It is undergoing a rename to VFS for Git. While the rename is in progress, the code, protocol, built executables, and releases may still refer to the old GVFS name. See https://github.com/Microsoft/VFSForGit/projects/4 for the latest status of the rename effort.
Installing VFS for Git
- VFS for Git requires Windows 10 Anniversary Update (Windows 10 version 1607) or later
- Run the latest GVFS and Git for Windows installers from https://github.com/Microsoft/VFSForGit/releases
Building VFS for Git
If you'd like to build your own VFS for Git Windows installer:
- Install Visual Studio 2017 Community Edition or higher (https://www.visualstudio.com/downloads/).
- Include the following workloads:
- .NET desktop development
- Desktop development with C++
- .NET Core cross-platform development
- Include the following additional components:
- .NET Core runtime
- Windows 10 SDK (10.0.10240.0)
- Include the following workloads:
- Install the .NET Core 2.1 SDK (https://www.microsoft.com/net/download/dotnet-core/2.1)
- Install
nuget.exe
- Create a folder to clone into, e.g.
C:\Repos\VFSForGit
- Clone this repo into the
src
subfolder, e.g.C:\Repos\VFSForGit\src
- Run
\src\Scripts\BuildGVFSForWindows.bat
- You can also build in Visual Studio by opening
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.
- You can install Visual Studio 2017 side by side with Visual Studio 2019, and make sure that you have all the dependencies from Visual Studio 2017 installed
- Alternatively, if you only want to have Visual Studio 2019 installed, install the following extra dependencies:
- MSVC v141 VS 2017 C++ build tools via the optional components in the Visual Studio 2019 installer. It is under the "Desktop Development with C++" heading.
- Windows 10 SDK (10.0.10240.0) via the archived SDK page: https://developer.microsoft.com/en-us/windows/downloads/sdk-archive
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
Trying out VFS for Git
- VFS for Git will work with any Git service that supports the
GVFS protocol. For example, you can create a repo in
Azure DevOps, and push
some contents to it. There are two constraints:
- Your repo must not enable any clean/smudge filters
- Your repo must have a
.gitattributes
file in the root that includes the line* -text
gvfs clone <URL of repo you just created>
- Please choose the Clone with HTTPS option in the
Clone Repository
dialog in Azure Repos, not Clone with SSH.
- Please choose the Clone with HTTPS option in the
cd <root>\src
- Run Git commands as you normally would
gvfs unmount
when done
Licenses
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.