GVFS stands for Git Virtual File System. GVFS virtualizes the file system beneath your git repo so that git and all tools see what appears to be a normal repo, but GVFS only downloads objects as they are needed. GVFS also manages git's sparse-checkout to ensure that git operations like 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 repo.
GVFS is still in progress, but it is available here for anyone to try out. Feel free to send us feedback, bug reports, suggestions, and pull requests!
- Install Visual Studio 2017 Community Edition or higher (https://www.visualstudio.com/downloads/). Include the ".Net desktop development" and
"Desktop development with C++" workloads, as well as the following additional components:
- .Net Framework 3.5 development tools
- C++/CLI support
- VC++ 2015.3 v140 toolset
- Windows 10 SDK (10.0.10240.0)
- Install InnoSetup 5.5.9 or later (http://www.jrsoftware.org/isdl.php) to its default location (or you'll have to change the path in
GVFS.csproj
post-build step to match) - Create a folder to clone into, e.g.
C:\Repos\GVFS
- Clone this repo into the
src
subfolder, e.g.C:\Repos\GVFS\src
- Open
src\GVFS.sln
in Visual Studio. Do not upgrade any projects. - Build
GVFS.sln
- GVFS requires Windows 10 Creators Update or later
- Install GVFS-enabled Git for Windows (2.12.2.gvfs.2 or later) from https://github.com/Microsoft/git/releases
- This build behaves the same as Git for Windows except if the config value
core.gvfs
is set totrue
.
- This build behaves the same as Git for Windows except if the config value
- Install GVFS from your build output
- If you built it as described above, the installer can be found at
C:\Repos\GVFS\BuildOutput\GVFS\bin\x64\[Debug|Release]\Setup\SetupGVFS.exe
- If you built it as described above, the installer can be found at
- GVFS will work with any git service that supports the GVFS protocol. For now, that means you'll need to create a repo in
Team Services (https://www.visualstudio.com/team-services/), 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>
cd <root>\src
- Run git commands as you normally would
gvfs unmount
when done
The GVFS source code in this repo is available under the MIT license. See License.md.
GVFS relies on the GvFlt filter driver, available as a prerelease NuGet package with its own license.