{{about|the data pack system|the command|Commands/datapack|the resource pack system|Resource pack}}
{{relevant tutorial|Creating a data pack|Installing a data pack}}
{{exclusive|java}}
{{relevant tutorial|Creating a data pack|Installing a data pack}}
A '''data pack''' is a collection of data used to configure a number of features of ''Minecraft''. A data pack is either a folder or a [[wikipedia:Zip (file format)|{{code|.zip}} file]] containing a {{cd|pack.mcmeta}} file. Data packs are used to define among others [[Custom advancement|advancements]], [[Custom dimension|dimensions]], [[Enchanting|enchantments]], [[loot table]]s, [[recipe]]s, [[Custom structure|structures]], and [[biomes]] (see {{slink||Contents}} for a full list). The definitions of the vanilla features is done using a built-in data pack. [[Experiments]] are enabled by adding separate bundled data packs to a world. Similarly, custom data packs can be added to a world to add or modify features and define [[Function (Java Edition)|functions]]. == Usage == Data packs can be added to a world during world creation in the [[Create New World]] screen in the '''More''' tab by clicking the '''Data Packs''' button. This menu allows drag-and-drop of data packs from a file explorer. Alternatively, data packs can be added to an existing world by manually placing them in the {{code|[[.minecraft]]/saves/{{ph|world}}/datapacks}} folder of a world. When adding a data pack while the world is loaded, [[Tag|registry tags]], [[loot table]]s, [[recipe]]s, [[advancement]]s, [[item modifier]]s, [[predicate]]s, [[Function (Java Edition)|functions]], and [[Structure_file|structure templates]] can be loaded using the {{cmd|reload}} command. The remaining features require closing and reloading the world (or restarting a [[server]]) to become active or modified, and are considered "experimental". Data packs load their data based on the load order. This order can be seen and altered in the '''Data Packs''' screen during world creation, and by using the {{cmd|datapack}} command. The loading order of data packs is stored in the [[Java Edition level format#level.dat_format|{{cd|level.dat}} file]]. If a file exists in multiple data packs only the file in the last data pack is used. This is often referred to this file '''overriding''' the files in the earlier packs. However, [[tag]] files without {{cd|"replace": true}} merge their content with the files loaded from earlier packs. == Contents == Data packs use a folder structure to contain the data. On the top level, a data pack has to contain a {{cd|pack.mcmeta}} file containing meta-data about the data pack. The data is organized into [[namespace]]s to avoid files from different packs unintentionally interfering with each other. Files are loaded as follows: * The file {{cd|data/{{ph|namespace}}/{{ph|registry name}}/{{ph|path}}.json}} is loaded into the {{cd|{{ph|registry name}}}} registry with ID {{cd|{{ph|namespace}}:{{ph|path}}}}. Both {{cd|{{ph|registry name}}}} and {{cd|{{ph|path}}}} can contain slashes ({{cd|/}}), which results in extra sub-folders. ** [[Function (Java Edition)|Functions]] use the {{cd|.mcfunction}} extension ** [[Structure files]] use the {{cd|.nbt}} extension * [[Tag]]s are loaded from files {{cd|data/{{ph|namespace}}/tags/{{ph|registry name}}/{{ph|path}}.json}} which results in a {{cd|{{ph|registry name}}}} tag named {{cd|#{{ph|namespace}}:{{ph|path}}}}. === Folder structure ===
*{{File|archive}}/{{File|directory|{{ph|data pack name}}}} **{{File|file|[[#pack.mcmeta|pack.mcmeta]]}}: Metadata of the data pack. This is the only mandatory file. **{{File|file|pack.png}}: The picture to display next to the data pack in the "Data Pack Selection" screen. **{{File|directory|data}} ***{{File|directory|{{ph|namespace}}}}: Folder of the namespace to use, see {{slink|Resource location|Namespaces}}. More than one directory for different namespaces may exist under the {{cd|data}} directory. ****{{File|directory|[[Function (Java Edition)|function]]}}: {{cd|.mcfunction}} files with lists of commands. ****{{File|directory|[[Structure file|structure]]}}: {{cd|.nbt}} files defining a saved structure of blocks. ****{{File|directory|[[tag]]s}}: Collections of things. Each sub-folder defines tags of a specific type using {{cd|.json}} files. *****{{File|directory|{{ph|registry name}}}}: Tags can be defined for any registry, see {{slink|Tag|List of tags}} for tag types used. ****; All following folders contain {{cd|.json}} files defining the content: ****{{File|directory|[[advancement definition|advancement]]}}: Definitions of [[advancements]]. ****{{File|directory|[[Banner/Patterns#JSON_Format|banner_pattern]]}}: Textures and names to use for banner patterns. ****{{File|directory|[[chat_type]]}}: Formatting of [[chat]] messages. ****{{File|directory|[[damage_type]]}}: Attributes of damage and death messages. ****{{File|directory|[[dimension_definition|dimension]]}}: Biome layout and terrain of dimensions. ****{{File|directory|[[dimension_type]]}}: Properties of dimensions. ****{{File|directory|[[enchantment definition|enchantment]]}}: Enchantment effects, supported items, level cost, etc. ****{{File|directory|[[enchantment_provider]]}}: Selection of enchantments for specific uses. ****{{File|directory|[[goat_horn_instrument_definition|instrument]]}}: Instruments for goat horns. ****{{File|directory|[[item_modifier]]}}: Loot functions used to modify items. ****{{File|directory|[[Jukebox song definition|jukebox_song]]}}: Jukebox song definitions. ****{{File|directory|[[loot_table]]}}: Loot from mobs, blocks, chests, etc. ****{{File|directory|[[painting variant definition|painting_variant]]}}: Size and texture of paintings. ****{{File|directory|[[predicate]]}}: Tests for specific conditions based on position, mobs, etc. ****{{File|directory|[[recipe]]}}: Recipes for [[crafting]], [[smelting]], etc. ****{{File|directory|trim_material}}: Colors, ingredients, and name of materials for [[trimming]] ****{{File|directory|trim_pattern}}: Textures and name of patterns for [[trimming]] ****{{File|directory|[[Wolf#Wolf_variants|wolf_variant]]}}: Textures and biomes of wolf variants. ****{{File|directory|worldgen}} *****{{File|directory|[[biome definition|biome]]}}: Biome generation options, effects, etc. *****{{File|directory|[[carver definition|configured_carver]]}}: Carver cave definitions *****{{File|directory|[[configured_feature]]}}: Configuration of [[feature]]s. *****{{File|directory|[[density_function]]}}: Mathematical operations to calculate values for each position in the world. *****{{File|directory|[[noise]]}}: Size and amplitudes of a [[Wikipedia:Perlin noise|noise]]. *****{{File|directory|[[noise_settings]]}}: Terrain shape including noise caves, and main terrain block types. *****{{File|directory|[[placed_feature]]}}: Placement of features within a chunk. *****{{File|directory|[[processor_list]]}}: Post-processing of blocks in structures. *****{{File|directory|[[structure definition|structure]]}}: Definition of structure generation and allowed biomes. *****{{File|directory|[[structure_set]]}}: Distribution of a set of structures within the world. *****{{File|directory|[[template_pool]]}}: A set of templates (structure files) for use in [[jigsaw structure]]s. *****{{File|directory|[[world preset definition|world_preset]]}}: Sets of dimensions selectable in the '''Create World''' screen. *****{{File|directory|[[world_preset_definition#Superflat_Level_Generation_Preset|flat_level_generator_preset]]}}: Presets selectable for the "Superflat" world type. *****{{File|directory|[[dimension_definition#Multi_noise_parameter_list|multi_noise_biome_source_parameter_list]]}}: Name of a preset to use for the multi noise biome layout.
=== {{mono|pack.mcmeta}} === {{main|pack.mcmeta}} A data pack is identified by ''Minecraft'' based on the presence of the {{code|pack.mcmeta}} file in the root directory of the data pack, which contains data in [[wikipedia:JSON|JSON]] format. {{code|pack.mcmeta}}, as used by the "vanilla" data pack in [[Java Edition 1.21.4|1.21.4]], as found in the [[client.jar|client]] and [https://minecraft.net/download/server official server] jars: {{filename|pack.mcmeta}} { "pack": { "description": "The default data for Minecraft", "pack_format": 61 } } ==== Pack format ==== {{For|the full list of pack formats in all versions|Pack format#List of data pack formats}} {{Data pack format|releaseonly}} == History == {{for|pack format history|#Pack format}} {{HistoryTable |{{HistoryLine|java}} |{{HistoryLine||1.13|dev=17w43a|Added data packs.}} |{{HistoryLine|||dev=17w46a|Added {{cmd|datapack}}, a command to control loaded data packs.}} |{{HistoryLine|||dev=17w48a|Data packs can now load custom recipes. |Added the initial pack format version of 4.}} |{{HistoryLine|||dev=17w49a|[[Tag]]s can now be created with data packs.}} |{{HistoryLine|||dev=17w49b|Tags can now be created for functions. |Functions tagged in minecraft:tick now run at the beginning of every tick.}} |{{HistoryLine|||dev=18w01a|Functions tagged in minecraft:load now run once after a (re)load. |Crash reports now list what data packs are enabled.}} |{{HistoryLine||1.14|dev=18w43a|Tags can now be created for entity types.}} |{{HistoryLine||1.15|dev=19w38a|Added [[predicates]].}} |{{HistoryLine||1.16|dev=20w22a|Slightly changed data pack loading to prevent custom data packs from crashing. |If data pack reload fails, changes are not applied and the game continues using previous data. |Changes to data pack list are stored only after successful reload. |If existing data packs prevent the world from loading, the game gives an option to load the world in safe mode, which loads only vanilla data pack. |Added --safeMode option for servers to load only with vanilla data pack. |Game now detects any critical data pack issues, such as required tags being missing, and prevent the world from being loaded.}} |{{HistoryLine|||dev=Pre-release 1|Data packs can now be loaded before the world is created. |Data packs can now add and change [[dimension]]s and dimension types.}} |{{HistoryLine||1.16.2|dev=20w27a|Data packs can now have a [[pack.png]] in the root folder, and display it in the data pack menu.}} |{{HistoryLine|||dev=20w28a|Custom worlds now support custom [[biomes]] and can now be used in custom [[dimension]] generators. |Data packs can now customize world generation in the worldgen folder.}} |{{HistoryLine||1.17|dev=20w45a|Pack format in version.json has been split into data and resource versions.}} |{{HistoryLine|||dev=20w46a|Added [[item modifier]]s.}} |{{HistoryLine||1.18.2|dev=Pre-release 1|It is now possible to add custom structures in experimental data packs: the game now generates and stores data-driven configured structures. |A lot of the cave generation is now configurable through data packs.}} |{{HistoryLine||1.19|dev=22w11a|Data packs can now apply [[pack.mcmeta|filters]] which block files from packs applied before the current pack.}} |{{HistoryLine||1.19.3|dev=22w42a|Added [[chat type]]s. |Added a subsection called datapacks. |The Vanilla world generation data pack is now visible within the game's jar.}} |{{HistoryLine||1.19.4|dev=23w06a|Added [[damage type]]s.}} |{{HistoryLine||1.20.2|dev=23w31a|Data packs can now support multiple [[pack format]]s.|Data packs can now contain [[pack.mcmeta|overlay]]s which are applied over the "normal" contents of a pack.}} |{{HistoryLine||1.20.5|dev=24w10a|Added [[wolf#Wolf_variants|wolf variants]] which can be defined through data packs. | Data packs can now define custom [[Banner_Pattern#JSON_Format|banner patterns]].}} |{{HistoryLine||1.21|dev=24w18a|Data packs can now define custom [[painting variant definition|painting variants]]. |[[Enchantments]] are now data-driven and can be defined through data packs. | Data packs can additionally define [[enchantment provider|enchantment providers]].}} |{{HistoryLine|||dev=24w19a|Renamed several directories: *tags/items -> tags/item *tags/blocks -> tags/block *tags/entity_types -> tags/entity_type *tags/fluids -> tags/fluid *tags/game_events -> tags/game_event }} |{{HistoryLine|||dev=24w21a|Renamed several directories: *structures -> structure *advancements -> advancement *recipes -> recipe *loot_tables -> loot_table *predicates -> predicate *item_modifiers ->item_modifier *functions -> function *tags/functions -> tags/function | Data packs can now define custom [[Jukebox song definition|jukebox songs]].}} |{{HistoryLine||1.21.2|dev=24w33a|Data packs can now define custom [[Goat_horn_instrument_definition|goat horn instruments]].}} }} == Issues == {{issue list|projects=mc}} == Gallery == World-type-custom.png|Example of a custom world created with a data pack. == See also == *[[Add-on]] *[[Tutorials/Installing a data pack]] *[[Tutorials/Creating a data pack]] *[[Resource Pack]] *[[Tutorials/Creating a resource pack]] == External links == * [https://misode.github.io/ misode.github.io] provides data pack generators == Navigation == {{Navbox Java Edition}} {{Navbox Java Edition technical|datapack}} [[Category:Data packs| ]] [[de:Datenpaket]] [[es:Paquete de datos]] [[fr:Pack de données]] [[ja:データパック]] [[ko:데이터 팩]] [[pl:Paczki danych]] [[pt:Pacote de dados]] [[ru:Набор данных]] [[th:ดาต้าแพ็ก]] [[zh:数据包]]