Visual Studio团队资源管理器 - GIT:自动忽略新文件

10
每当我创建一个新文件,例如类文件(.cs),该文件会自动被GIT忽略(尽管仍包含在项目中)。这是我的.gitignore文件还是某个Visual Studio设置的问题?是一个bug吗?
有趣的是,在我的解决方案中有7个项目,只有1个项目有此行为。
为什么我认为它被忽略而不是未跟踪呢?答案如下:
1- 通常情况下,Visual Studio将跟踪所有新的.cs文件,在除了这个之外的所有我的项目中都这样做。
2- 新文件的版本控制状态图标是一个红色圆圈(中间有一个矩形),如果悬停在上面,将显示"已忽略"一词。另外,如果我右键单击文件,我可以看到"添加被忽略的文件到源代码控制"选项。
以下是.gitignore文件(与.git文件夹在同一文件夹中):
## Ignore Visual Studio temporary files, build results, and
## files generated by popular Visual Studio add-ons.
##
## Get latest from https://github.com/github/gitignore/blob/master/VisualStudio.gitignore

# User-specific files
*.suo
*.user
*.userosscache
*.sln.docstates

# User-specific files (MonoDevelop/Xamarin Studio)
*.userprefs

# Build results
[Dd]ebug/
[Dd]ebugPublic/
[Rr]elease/
[Rr]eleases/
x64/
x86/
bld/
[Bb]in/
[Oo]bj/
[Ll]og/

# Visual Studio 2015 cache/options directory
.vs/
.vscode/
# Uncomment if you have tasks that create the project's static files in wwwroot
#wwwroot/

# MSTest test Results
[Tt]est[Rr]esult*/
[Bb]uild[Ll]og.*

# NUNIT
*.VisualState.xml
TestResult.xml

# Build Results of an ATL Project
[Dd]ebugPS/
[Rr]eleasePS/
dlldata.c

# .NET Core
project.lock.json
project.fragment.lock.json
artifacts/
**/Properties/launchSettings.json

*_i.c
*_p.c
*_i.h
*.ilk
*.meta
*.obj
*.pch
*.pdb
*.pgc
*.pgd
*.rsp
*.sbr
*.tlb
*.tli
*.tlh
*.tmp
*.tmp_proj
*.log
*.vspscc
*.vssscc
.builds
*.pidb
*.svclog
*.scc

# Chutzpah Test files
_Chutzpah*

# Visual C++ cache files
ipch/
*.aps
*.ncb
*.opendb
*.opensdf
*.sdf
*.cachefile
*.VC.db
*.VC.VC.opendb

# Visual Studio profiler
*.psess
*.vsp
*.vspx
*.sap

# TFS 2012 Local Workspace
$tf/

# Guidance Automation Toolkit
*.gpState

# ReSharper is a .NET coding add-in
_ReSharper*/
*.[Rr]e[Ss]harper
*.DotSettings.user

# JustCode is a .NET coding add-in
.JustCode

# TeamCity is a build add-in
_TeamCity*

# DotCover is a Code Coverage Tool
*.dotCover

# Visual Studio code coverage results
*.coverage
*.coveragexml

# NCrunch
_NCrunch_*
.*crunch*.local.xml
nCrunchTemp_*

# MightyMoose
*.mm.*
AutoTest.Net/

# Web workbench (sass)
.sass-cache/

# Installshield output folder
[Ee]xpress/

# DocProject is a documentation generator add-in
DocProject/buildhelp/
DocProject/Help/*.HxT
DocProject/Help/*.HxC
DocProject/Help/*.hhc
DocProject/Help/*.hhk
DocProject/Help/*.hhp
DocProject/Help/Html2
DocProject/Help/html

# Click-Once directory
publish/

# Publish Web Output
*.[Pp]ublish.xml
*.azurePubxml
# TODO: Comment the next line if you want to checkin your web deploy settings
# but database connection strings (with potential passwords) will be unencrypted
*.pubxml
*.publishproj

# Microsoft Azure Web App publish settings. Comment the next line if you want to
# checkin your Azure Web App publish settings, but sensitive information contained
# in these scripts will be unencrypted
PublishScripts/

# NuGet Packages
*.nupkg
# The packages folder can be ignored because of Package Restore
**/packages/*
# except build/, which is used as an MSBuild target.
!**/packages/build/
# Uncomment if necessary however generally it will be regenerated when needed
#!**/packages/repositories.config
# NuGet v3's project.json files produces more ignorable files
*.nuget.props
*.nuget.targets

# Microsoft Azure Build Output
csx/
*.build.csdef

# Microsoft Azure Emulator
ecf/
rcf/

# Windows Store app package directories and files
AppPackages/
BundleArtifacts/
Package.StoreAssociation.xml
_pkginfo.txt

# Visual Studio cache files
# files ending in .cache can be ignored
*.[Cc]ache
# but keep track of directories ending in .cache
!*.[Cc]ache/

# Others
ClientBin/
~$*
*~
*.dbmdl
*.dbproj.schemaview
*.jfm
*.pfx
*.publishsettings
orleans.codegen.cs

# Since there are multiple workflows, uncomment next line to ignore bower_components
# (https://github.com/github/gitignore/pull/1529#issuecomment-104372622)
#bower_components/

# RIA/Silverlight projects
Generated_Code/

# Backup & report files from converting an old project file
# to a newer Visual Studio version. Backup files are not needed,
# because we have git ;-)
_UpgradeReport_Files/
Backup*/
UpgradeLog*.XML
UpgradeLog*.htm

# SQL Server files
*.mdf
*.ldf
*.ndf

# Business Intelligence projects
*.rdl.data
*.bim.layout
*.bim_*.settings

# Microsoft Fakes
FakesAssemblies/

# GhostDoc plugin setting file
*.GhostDoc.xml

# Node.js Tools for Visual Studio
.ntvs_analysis.dat
node_modules/

# Typescript v1 declaration files
typings/

# Visual Studio 6 build log
*.plg

# Visual Studio 6 workspace options file
*.opt

# Visual Studio 6 auto-generated workspace file (contains which files were open etc.)
*.vbw

# Visual Studio LightSwitch build output
**/*.HTMLClient/GeneratedArtifacts
**/*.DesktopClient/GeneratedArtifacts
**/*.DesktopClient/ModelManifest.xml
**/*.Server/GeneratedArtifacts
**/*.Server/ModelManifest.xml
_Pvt_Extensions

# Paket dependency manager
.paket/paket.exe
paket-files/

# FAKE - F# Make
.fake/

# JetBrains Rider
.idea/
*.sln.iml

# CodeRush
.cr/

# Python Tools for Visual Studio (PTVS)
__pycache__/
*.pyc

# Cake - Uncomment if you are using it
# tools/**
# !tools/packages.config

# Telerik's JustMock configuration file
*.jmconfig

# BizTalk build output
*.btp.cs
*.btm.cs
*.odx.cs
*.xsd.cs

我认为Git的标准行为是将新文件视为未跟踪,直到您手动添加它们。 - Tim Biegeleisen
1
如果您没有包含.gitignore文件或更多信息,我们只能猜测。 - Esko
@Esko,我花了一些时间,但是git文件已经在那里了。抱歉耽搁了。 - Raikol Amaro
你能详细解释一下“自动忽略”的意思吗?你在哪里看到它被忽略了(与@TimBiegeleisen所说的未跟踪相对)?git status的输出是什么? - bto
@TimBiegeleisen,Visual Studio 应该自动将文件添加到源代码控制中,这是它在所有项目中的行为(即使在同一解决方案中),但除了这个项目。 - Raikol Amaro
显示剩余2条评论
3个回答

10

Eureka!!我的项目名称符合.gitignore文件中的*.sap模式,所以该项目上的所有新文件都会自动被忽略。我从.gitignore文件中删除了*.sap模式,现在一切都按预期工作。


我正在与SAP Concur合作的项目上工作。我一直在苦思冥想,然后看到了这个答案。这就是我的问题所在。项目名称以.SAP结尾。 - Melsy

2

有时会出现这种情况。只需关闭并重新打开Visual Studio即可。

由于这种不一致性(我认为这是一个错误),我还会在另一个“视觉”Git应用程序(SourceTree)中查找未跟踪的文件,以确保没有留下任何东西在某个目录内。


在我的情况下,即使重新启动VS,它也不会消失。 - Raikol Amaro

0

我在本地测试了你的 .gitignore 文件,它可以正常工作。我的猜测是你需要将文件进行暂存。我认为你混淆了被忽略的文件和未跟踪的文件。

Git 分为三个 "目录"。当你 "跟踪" 一个文件时,意味着这三个目录之间的更改会被保存。被忽略的文件不会被跟踪。

工作目录 工作目录基本上就是你的硬盘上的文件。Git 会跟踪工作目录和暂存区之间的文件和文件夹的差异。所有未跟踪的内容都在工作目录中。每次对已跟踪的文件进行更改都会包含在工作目录中。

暂存区 每当你 "暂存" 东西(使用 git add),你就会将更改暂存起来。这意味着你将更改从工作目录复制到暂存区。当你将文件或文件夹暂存时,文件会保留在工作目录中(即硬盘中),但同时也会复制到暂存区中。

暂存区是提交和未跟踪文件之间的一种中间状态。在提交文件之前,你需要将文件暂存。

本地分支 当你提交代码时,你会将当前的暂存区中的内容打成一个提交,并将该提交附加到当前分支。这也会将变更集从暂存区中移除。


感谢@Andersnk的解释,但是在使用Visual Studio时流程是不同的。通常在VS中,新文件将自动被跟踪并包含在源代码控制中(我假设VS会自动暂存它),这样我只需要执行最后一步提交即可。 - Raikol Amaro
Visual Studio不会自动跟踪文件,也不会将它们暂存,除非您安装一个能为您完成这些操作的插件。 - Andersnk
我正在使用Visual Studio的Team Explorer,并没有安装任何插件。我已经使用VS和GIT超过一年了,新文件总是显示在“更改”部分,准备提交。这就是我所说的自动跟踪。无论VS在幕后执行什么命令,我都不知道。 - Raikol Amaro
你的插件可能出了问题。不是你的.gitignore文件有问题。 - Andersnk

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接