Как и для многих разработчиков, папка .idea в Android Studio для меня всегда была, как черный ящик: я знал, что она существует, я знал, что её всегда добавляют в .gitignore, но я решил узнать, для чего же там нужны те или иные файлы и папки, чтобы у меня была возможность обрабатывать иногда возникающие git-конфликты, и для того, чтобы точно знать, какой файл можно безопасно добавить в .gitignore, а какой нет.
Разобрал я это на примере проекта, над которым работаю. И решил поделиться результатом того, что выяснил, т.к. не нашел никакой документации по этому вопросу.
- ❌ указывает путь, который следует добавить в
.gitignore
- ❎ указывает путь, который Android Studio уже добавила в
.gitignore
, и вам не следует его версионировать - ✅ указывает путь, который вы должны хранить в git
❌
assetWizardSettings.xmlЭтот файл хранит последнюю иконку, добавленную с помощью интерфейса Android Studio. Его можно безопасно удалить из VCS.
❌
cachesКэши, как следует из названия, могут быть безопасно добавлены в .gitignore
.
Не вижу никаких оснований держать его в VCS, но по умолчанию эта папка в .gitignore
не добавлена.
❌
caches/build_file_checksums.serПо факту, этот файл представляет собой сериализированный экземпляр ProjectBuildFilesChecksums.
Файл необходим, чтобы проверить, изменились ли build.gradle
, settings.gradle
, local.properties
, ~/.gradle/gradle.properties
, gradle.properties
или файлы build.gradle
ваших модулей.
Android Studio использует этот файл для того, чтобы сообщить вам о том, что нужно синхронизировать gradle-файлы.
✅
codeStylesВ этой папке содержатся настройки стилей кода проекта. Его полезно версионировать, если вы меняли стили кода по умолчанию.
✅
dictionariesПапка содержит запись, которую вы добавили в словарь для проверки кода. Этот словарь важен, если у вас есть строгие правила в вашей CI-системе.
❌
gradle.xmlРекомендую удалить этот файл из git. Он может содержать локальный путь к вашей версии gradle, а также путь к вашему модулю. Например, вы можете разработать модуль в отдельном репозитории, поэтому путь к модулю может быть специфичным для каждого пользователя.
По всем этим причинам я окончательно удаляю файл gradle.xml
из VCS.
✅
inspectionProfilesЭта папка содержит конкретные Lint-правила для вашего проекта. Поэтому так же, как и папка dictionaries
, она должна храниться в git.
❎
librariesЗдесь содержится файл, который указывает, где хранятся jar-файлы ваших библиотек. Поскольку путь загрузки может быть специфичным для каждого пользователя, вы не должны хранить эту папку в VCS.
✅
misc.xmlФайл содержит информацию о проекте: версия Java, тип проекта и др.
Эти сведения касаются проекта и не зависят от пользователя. Поэтому его следует хранить в git.
❎
modules.xmlЭтот файл содержит пути к .iml
-файлам ваших модулей. Поэтому по аналогии с gradle.xml
его нельзя хранить в git.
✅
navEditor.xmlЗдесь хранится расположение ваших элементов в редакторе навигации. Если эта информация имеет отношение к вашему проекту, то стоит сохранить этот файл в git. В противном случае смело добавляйте его в .gitignore
, чтобы избежать конфликтов в будущем.
✅
runConfigurations.xmlИмя файла может вам намекнуть, что в нём хранятся конфигурации, которые вы можете добавить, нажав «Изменить конфигурации». Этот файл обязательно нужно хранить в VCS.
✅
vcs.xmlЭтот файл содержит информацию о VCS, которую вы используете в своём проекте. Он используется для того, чтобы вы могли использовать графический интерфейс для выполнения операций, связанных с управлением версиями. Его тоже стоит добавить в git.
❎
workspace.xmlЗдесь содержится информация о вашем рабочем пространстве в Android Studio. Например, последняя позиция курсора на открытом вами файле. Так что это определенно пользовательская информация, которую нет необходимости хранить в git.
Итоги
Я бы предложил вам добавить всего три строки к файлу .gitignore
по умолчанию:
/.idea/assetWizardSettings.xml
/.idea/gradle.xml
/.idea/caches
# Uncomment next line if keeping position of elements in Navigation Editor is not relevant for you
# /.idea/navEditor.xml
Как я уже сказал в начале этой статьи, я не нашёл никакой документации о содержимом папки .idea
, поэтому статья может быть неполной и/или не точна на 100%. Если вы знаете ещё что-то, чего нет в этой статье, то пишите об этом в комменнтарии.
Перевод статьи «Deep dive into .idea folder in Android Studio»
ПОХОЖИЕ ПУБЛИКАЦИИ
- None Found
0 комментариев к статье "Глубокое погружение в папку .idea в Android Studio"