The library folder is a large cache containing imported assets and other data from the project after import. It is generally always 100% safe to delete the Library folder. As Unity has become more stable, this has become much less necessary than it once was. It is also possible to remove some subfolders without requiring to delete the entire Library folder and have it re-import/re-compile everything.xssss
Folder | Purpose | Removable? |
---|---|---|
APIUpdater | Contains project dependency graph | ? |
Artifacts | All the imported assets | ? |
BuildPlayerData | ? | ? |
BurstCache | Files compiled in the editor using Burst | Yes |
il2cpp_cache | Files from il2cpp build | Yes |
PackageCache | Downloaded packages, it is possible for these to be corrupted | Yes |
PackageManager | ? | ? |
PlayerDataCache | Data from player builds | Yes |
Recorder | ? | ? |
ScriptAssemblies | All compiled and referenced assemblies | Yes |
ShaderCache | Cached compiled shaders | Yes |
StateCache | State of the Editor | Yes |
TempArtifacts | ? | Yes |
UIElements | UIElements preferences | Yes |
File | Purpose | Removable? |
---|---|---|
ArtifactDB | Artifact DB of everything in Artifacts folder | Deleting this will invalidate Artifacts folder |
ArtifactDB-lock | Artifact DB lock file | ? |
LastBuild.buildreport | Binary build report from last build | Yes |
shadercompiler-UnityShaderCompiler.exe* | Log files from shader compilers | Yes |
SourceAssetDB | The source Asset Database contains meta-information about your source asset files which Unity uses to determine whether the file has been modified, and therefore whether it should reimport the files. This includes information such as last modified date, a hash of the file’s contents, GUIDs and other meta-information. | ? |
SourceAssetDB-lock | SourceAsset DB lock file | ? |
Unity provides this tool in C:\Program Files\Unity\Hub\Editor\2020.2.1f1\Editor\Data\Tools
which allows you to inspect data in the Library folder.
(AssetDatabase v1. See Artifacts for AssetDatabase v2.)
Contains the serialized, imported data keyed by an asset's GUID. binary2text.exe
can be used to dump and view the cached imported data.1)
(AssetDatabase v2. See metadata for AssetDatabase v1.)
During import of an asset, the asset importer is run, which produces some number of Unity serializable assets.
This folder is also related to the ArtifactDB
and ArtifactDB-lock
files.
The Artifacts folder stores these post-import generated files for every asset, keyed by the hash of the generated asset.2) These generated assets are also called producedFiles
in Unity internal.
You can look up a disk Asset's post-import representation by 3):
Editor.log
producedFiles[0].contentHash:
binary2text.exe
can be used to dump and view the post-import asset data in this folder.4)
You can query the path of an artifact using AssetDatabaseExperimental
5). An artifact may have an ArtifactPath that looks like: VirtualArtifacts/Primary/f1a775a1988b4d6418f6ccb2522b70a3
, rather than having a disk path. I can only assume that these “VirtualArtifacts” are stored somewhere in memory, for efficiency, rather than stored on disk.