Git本地忽略文件夹,只拉取目标文件夹

前情:我的路径为F:\UnityProject\TGILab\pico\UnityProject\Assets\EaseVSim,其中EaseVSim是一个独立的子模块文件夹,如果没有子模块只执行步骤3之后的内容即可。

  1. 关闭unity程序

  2. 因子模块已经在本地存在,执行稀疏检出可能无效,建议先把EaseVSim子模块下的内容暂存/复制/提交,确保子模块下无重要内容之后执行以下命令,删除重新加载EaseVSim子模块

    以下命令行按顺序执行

    2.1 进入项目目录
    cd /f/UnityProject/TGILab/pico(换成自己的路径)

    2.2 停用子模块
    git submodule deinit -f -- UnityProject/Assets/EaseVSim

    2.3 删除子模块的本地仓库缓存
    rm -rf .git/modules/Assets/EaseVSim

    2.4 删除子模块的工作目录
    rm -rf UnityProject/Assets/EaseVSim

    2.5 重新初始化并克隆子模块
    git submodule update --init --recursive --UnityProject/ Assets/EaseVSim

    之后子模块切换到main分支

  3. 命令行进入子模块目录
    cd /f/UnityProject/TGILab/UnityProject/Assets/EaseVSim

  4. 打开稀疏检出开关
    git config core.sparseCheckout true

  5. 打开子模块的目录(如果没有子模块直接打开.git/info)
    F:\UnityProject\TGILab\pico\.git\modules\UnityProject\Assets\EaseVSim\info

    换成自己的本地目录,找到info下面 sparse-checkout 文件

    (如果没有的话新建一个sparse-checkout.txt文件,删除后缀),右键记事本打开

    全选删除,根据自己项目情况,增删下面的记录,注意之前不要有空格

/*

!AAAExpms/DengGaoZY/

!AAAExpms/DengGaoZY.meta

第一行的/*代表全部文件,后面的 开头代表忽略这个文件夹,取消忽略就删除上面文件内容

  1. 保存文件,还是打开之前的命令行,执行
    git reset --hard HEAD

强制刷新一下就可以了,其他同事如果在本地已忽略的文件夹提交文件不会更新,更新子模块也不会失效

相关推荐
AIMath~2 小时前
如何将一个新的文件夹使用git 工具提交到github新仓库中
git·github
满天星83035772 小时前
【Git】原理及使用(二) (版本回退)
linux·git
愿天垂怜2 小时前
【C++脚手架】ffmpeg 库的介绍与使用
linux·服务器·开发语言·c++·ide·git·ffmpeg
月夜的风吹雨3 小时前
Linux 基础开发工具详解:从 yum 到 gdb 实战指南
linux·git·ubuntu·centos·vim
好运yoo3 小时前
git cherry-pick
git
不是光头 强3 小时前
Obsidian Git 插件安装与配置完全指南
git
.千余4 小时前
【C++】C++核心语法:函数重载与缺省参数原理与避坑
c语言·开发语言·c++·经验分享·笔记·git·学习
meowrain4 小时前
Git HTTPS Token 凭据配置指南
git·网络协议·https
Ws_16 小时前
Git + Gerrit 第二课:diff、暂存区与撤销修改
git
snowjlz17 小时前
鸿蒙版SVN来了!!!
git·svn·版本控制