Сломанный проект 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 читает .gitattributefile, прежде чем решить, разрешать ли файлы lfs. Если он находит синтаксис, он не может понять, он прерывает процесс. Я думаюlinguist-generated - нестандартный атрибут, из-за которого ваше репо не втягивает изменения.

У меня нет репутации, чтобы комментировать другой ответ, но -text это не проблема.

В файлах gitattribute добавление -перед тем, как свойство "сбрасывает" свойство. В данном случае это означает, что не следует рассматривать его как текст.

Из https://git-scm.com/docs/gitattributes:

"Снятие атрибута текста на пути указывает Git не предпринимать попытки преобразования конца строки при возврате или извлечении".

Другие вопросы по тегам