Сломанный проект Unity после git clone
У меня есть проект Unity ( ссылка на github), который не работает после клонирования. Даже если файлы есть, они имеют неверное содержимое. Например, файлы.png заменяются текстом:
версия https://git-lfs.github.com/spec/v1 oid sha256: 089f8198df161233681006c4243f6d6babb2e125062a21ea727d0d6c97889d26 размер 1035
Некоторые библиотеки DLL из пакетов внешних ресурсов (например, DOTween) также, вероятно, хранятся неправильно, потому что компилятор жалуется на необъявленные пространства имен.
Активы / Внешние зависимости /Demigiant/DOTween/ examples/Basics.cs(3,7): ошибка CS0246: Не удалось найти тип или имя пространства имен `DG'. Вам не хватает ссылки на сборку?
ОБНОВЛЕНИЕ: На самом деле, dlls даже не там. Зачем? Они не являются частью gitignore.
Я убедился, чтобы установить Version Control Mode
в Visible Meta Files
а также Asset Serialization Mode
в Force Text
,
Я попытался переместить проект в новый каталог, удалив папку.git, удалив Library
, переделывая все (открытие с Unity, а затем git init
) и подталкивает к новому репо. Новый репо имеет те же проблемы, что и предыдущий.
Я использую .gitignore по умолчанию для Unity
И следующие.gitattributes (для включения LFS):
# 3D models
*.3dm filter=lfs diff=lfs merge=lfs -text
*.3ds filter=lfs diff=lfs merge=lfs -text
*.blend filter=lfs diff=lfs merge=lfs -text
*.c4d filter=lfs diff=lfs merge=lfs -text
*.collada filter=lfs diff=lfs merge=lfs -text
*.dae filter=lfs diff=lfs merge=lfs -text
*.dxf filter=lfs diff=lfs merge=lfs -text
*.fbx filter=lfs diff=lfs merge=lfs -text
*.jas filter=lfs diff=lfs merge=lfs -text
*.lws filter=lfs diff=lfs merge=lfs -text
*.lxo filter=lfs diff=lfs merge=lfs -text
*.ma filter=lfs diff=lfs merge=lfs -text
*.max filter=lfs diff=lfs merge=lfs -text
*.mb filter=lfs diff=lfs merge=lfs -text
*.obj filter=lfs diff=lfs merge=lfs -text
*.ply filter=lfs diff=lfs merge=lfs -text
*.skp filter=lfs diff=lfs merge=lfs -text
*.stl filter=lfs diff=lfs merge=lfs -text
*.ztl filter=lfs diff=lfs merge=lfs -text
# Audio
*.aif filter=lfs diff=lfs merge=lfs -text
*.aiff filter=lfs diff=lfs merge=lfs -text
*.it filter=lfs diff=lfs merge=lfs -text
*.mod filter=lfs diff=lfs merge=lfs -text
*.mp3 filter=lfs diff=lfs merge=lfs -text
*.ogg filter=lfs diff=lfs merge=lfs -text
*.s3m filter=lfs diff=lfs merge=lfs -text
*.wav filter=lfs diff=lfs merge=lfs -text
*.xm filter=lfs diff=lfs merge=lfs -text
# Fonts
*.otf filter=lfs diff=lfs merge=lfs -text
*.ttf filter=lfs diff=lfs merge=lfs -text
# Images
*.bmp filter=lfs diff=lfs merge=lfs -text
*.exr filter=lfs diff=lfs merge=lfs -text
*.gif filter=lfs diff=lfs merge=lfs -text
*.hdr filter=lfs diff=lfs merge=lfs -text
*.iff filter=lfs diff=lfs merge=lfs -text
*.jpeg filter=lfs diff=lfs merge=lfs -text
*.jpg filter=lfs diff=lfs merge=lfs -text
*.pict filter=lfs diff=lfs merge=lfs -text
*.png filter=lfs diff=lfs merge=lfs -text
*.psd filter=lfs diff=lfs merge=lfs -text
*.tga filter=lfs diff=lfs merge=lfs -text
*.tif filter=lfs diff=lfs merge=lfs -text
*.tiff filter=lfs diff=lfs merge=lfs -text
# Collapse Unity-generated files on GitHub
*.asset linguist-generated
*.mat linguist-generated
*.meta linguist-generated
*.prefab linguist-generated
*.unity linguist-generated
ОБНОВИТЬ:
После дальнейшего исследования кажется, что файлы png перезаписываются (на единицу?), Когда проект открывается после клонирования. Они правильно существуют в удаленном хранилище. Внешние библиотеки с другой стороны не загружаются вообще.
3 ответа
Ваш .gitattributes
файл неверный.
*.png filter=lfs diff=lfs merge=lfs -text
Текст? ТЕКСТ? С какой стати вы хотите рассматривать файлы.png как текст? То же самое касается большинства других атрибутов.
Глядя на мой собственный .gitattributes
файл, у меня есть это:
(Да, большинство строк являются комментариями)
###############################################################################
# Set default behavior to automatically normalize line endings.
###############################################################################
* text=auto
###############################################################################
# Set default behavior for command prompt diff.
#
# This is need for earlier builds of msysgit that does not have it on by
# default for csharp files.
# Note: This is only used by command line
###############################################################################
#*.cs diff=csharp
###############################################################################
# Set the merge driver for project and solution files
#
# Merging from the command prompt will add diff markers to the files if there
# are conflicts (Merging from VS is not affected by the settings below, in VS
# the diff markers are never inserted). Diff markers may cause the following
# file extensions to fail to load in VS. An alternative would be to treat
# these files as binary and thus will always conflict and require user
# intervention with every merge. To do so, just uncomment the entries below
###############################################################################
#*.sln merge=binary
#*.csproj merge=binary
#*.vbproj merge=binary
#*.vcxproj merge=binary
#*.vcproj merge=binary
#*.dbproj merge=binary
#*.fsproj merge=binary
#*.lsproj merge=binary
#*.wixproj merge=binary
#*.modelproj merge=binary
#*.sqlproj merge=binary
#*.wwaproj merge=binary
###############################################################################
# behavior for image files
#
# image files are treated as binary by default.
###############################################################################
#*.jpg binary
#*.png binary
#*.gif binary
###############################################################################
# diff behavior for common document formats
#
# Convert binary document formats to text before diffing them. This feature
# is only available from the command line. Turn it on by uncommenting the
# entries below.
###############################################################################
#*.doc diff=astextplain
#*.DOC diff=astextplain
#*.docx diff=astextplain
#*.DOCX diff=astextplain
#*.dot diff=astextplain
#*.DOT diff=astextplain
#*.pdf diff=astextplain
#*.PDF diff=astextplain
#*.rtf diff=astextplain
#*.RTF diff=astextplain
Этот файл был создан автоматически для меня, когда я создавал репозиторий git через настольное приложение GitHub. Я слышал, что это "не очень хорошо", но я обнаружил, что он делает то, что мне нужно. А именно, не мешать совершать коммиты и выдвигать на GitHub.
Вы не должны использовать LFS для отслеживания файлов DLL, это вызовет ошибку компиляции вашей DLL.
Тоже сталкиваюсь с этой проблемой. Ошибка: пространство имен не существует. Оказывается, что DLL, содержащая это пространство имен, не была загружена. DLL вместо этого содержала текст символической ссылки. C# проигнорировал эту DLL и загрузил символы -> компиляция не удалась.
Вы можете использовать следующие команды, чтобы вернуть файлы DLL в нормальное состояние:
git lfs untrack *.dll
git rm --cached *.dll
git add *.dll
git commit -m "add dll back to non-LFS files"
А затем вы выполните новую проверку, которая может решить вашу проблему.
Некоторые из моих сообщений об ошибках:
класс com.tencent.pandora.WsOPCancelSubscribe не может быть загружен, используется в Assembly-CSharp, Version = 2.0.0.668,Culture = нейтральный, PublicKeyToken = null Класс com.tencent.pandora.WsOPCancelSubscribeAck не может быть загружен, используется в сборке -CSharp, Version = 2.0.0.668,Culture = нейтральный, PublicKeyToken = null Класс com.tencent.pandora.WsSendMsgAck не может быть загружен, используется в Assembly-CSharp, Version = 2.0.0.668,Culture = нейтральный, PublicKeyToken = null class com.tencent.pandora.WsBarrageItem не может быть загружен, используется в Assembly-CSharp, Version = 2.0.0.668,Culture = нейтральный, PublicKeyToken = null Класс com.tencent.pandora.BulletWebSocket не может быть загружен, используется в Assembly- CSharp, Версия = 2.0.0.668, Культура = нейтральный, PublicKeyToken = null Не удалось загрузить класс c__Iterator0, используется в Assembly-CSharp, Версия = 2.0.0.668, Культура = нейтральный, PublicKeyToken = null Не удалось загрузить класс com.tencent.pandora.WsEventData, используемый в Assembly-CSharp, Version = 2.0.0.668,Culture = нейтральный, PublicKeyToken = null Не удалось загрузить класс com.tencent.pandora.WsEventScene, используется в Assembly-CSharp, Версия = 2.0.0.668, Культура = нейтральный, PublicKeyToken = null Не удалось загрузить класс com.tencent.pandora.WsEventItem, используется в Assembly-CSharp, Версия = 2.0.0.668, Культура = нейтральный, PublicKeyToken = null Класс com.tencent.pandora.WsTerminalPage не может быть загружен, используется в Assembly-CSharp, Version = 2.0.0.668,Culture = нейтральный, PublicKeyToken = null Класс com.tencent.pandora.WsOPSubscribe не может быть загружен, использован в Assembly-CSharp, Версия = 2.0.0.668, Культура = нейтральный, PublicKeyToken = null Не удалось загрузить класс com.tencent.pandora.WsOPHeartBeat, используется в Assembly-CSharp, Версия = 2.0.0.668, Культура = нейтральный, PublicKeyToken = null Класс com.tencent.pandora.WsOPHeartbeatAck не может быть загружен, используется в Assembly-CSharp, Version = 2.0.0.668,Culture = нейтральный, PublicKeyToken = null Класс com.tencent.pandora.WsOPCancelSubscribe мог не загружается, используется в Assembly-CSharp, Версия = 2.0.0.668, Культура = нейтральный, PublicKeyToken = null Не удалось загрузить класс com.tencent.pandora.WsOPCancelSubscribeAck, используется в Assembly-CSharp, Версия = 2.0.0.668, Культура = нейтральный, PublicKeyToken = null Класс com.tencent.pandora.WsSendMsgAck не может быть загружен, используется в Assembly-CSharp, Version = 2.0.0.668,Culture = нейтральный, PublicKeyToken = null Класс com.tencent.pandora.WsBarrageItem не смог быть загружен, используется в Assembly-CSharp, Version = 2.0.0.668,Culture = нейтральный, PublicKeyToken = null Не удалось загрузить класс com.tencent.pandora.BulletWebSocket, используется в Assembly-CSharp, Версия = 2.0.0.668, Культура = нейтральный, PublicKeyToken = null Не удалось загрузить класс c__Iterator0, используется в Assembly-CSharp, Версия = 2.0.0.668, Культура = нейтральный, PublicKeyToken = null Класс com.tencent.pandora.WsEventData не может быть загружен, используется в Assembly-CSharp, Version = 2.0.0.668,Culture = нейтральный, PublicKeyToken = null Не удалось загрузить класс com.tencent.pandora.WsEventScene, используется в Assembly-CSharp, Version = 2.0.0.668, культура = нейтральная, PublicKeyToken = nullpandora.WsEventScene не может быть загружен, используется в Assembly-CSharp, Version = 2.0.0.668,Culture = нейтральный, PublicKeyToken = nullpandora.WsEventScene не может быть загружен, используется в Assembly-CSharp, Version = 2.0.0.668,Culture = нейтральный, PublicKeyToken = null
Если кто-то столкнется с той же проблемой, что и я, вы можете просто проверить свой файл ProjectSettings.asset, вы не должны устанавливать для него окончания строки LF, оставьте его как LFCR, и моя проблема волшебным образом исчезнет.
Удалите этот раздел, чтобы git clone извлекал ваши файлы lfs.
# Collapse Unity-generated files on GitHub
*.asset linguist-generated
*.mat linguist-generated
*.meta linguist-generated
*.prefab linguist-generated
*.unity linguist-generated
git clone
читает .gitattribute
file, прежде чем решить, разрешать ли файлы lfs. Если он находит синтаксис, он не может понять, он прерывает процесс. Я думаюlinguist-generated
- нестандартный атрибут, из-за которого ваше репо не втягивает изменения.
У меня нет репутации, чтобы комментировать другой ответ, но -text
это не проблема.
В файлах gitattribute добавление -
перед тем, как свойство "сбрасывает" свойство. В данном случае это означает, что не следует рассматривать его как текст.
Из https://git-scm.com/docs/gitattributes:
"Снятие атрибута текста на пути указывает Git не предпринимать попытки преобразования конца строки при возврате или извлечении".