stewbeet 2.0.4__tar.gz → 2.0.6__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of stewbeet might be problematic. Click here for more details.

Files changed (138) hide show
  1. {stewbeet-2.0.4 → stewbeet-2.0.6}/PKG-INFO +2 -2
  2. {stewbeet-2.0.4 → stewbeet-2.0.6}/pyproject.toml +2 -2
  3. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/cli.py +5 -10
  4. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/core/constants.py +1 -1
  5. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/core/utils/sounds.py +5 -1
  6. stewbeet-2.0.6/stewbeet/dependencies/datapack/ItemIO.zip +0 -0
  7. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/custom_recipes/pulverizer.py +11 -10
  8. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/datapack/custom_blocks/__init__.py +19 -22
  9. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/datapack/loading/__init__.py +1 -5
  10. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/__init__.py +1 -1
  11. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/main.py +8 -9
  12. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/initialize/__init__.py +97 -96
  13. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/resource_pack/item_models/object.py +1 -5
  14. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/resource_pack/sounds/__init__.py +6 -7
  15. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/verify_definitions/__init__.py +15 -0
  16. stewbeet-2.0.6/stewbeet/utils.py +28 -0
  17. stewbeet-2.0.4/stewbeet/dependencies/datapack/ItemIO.zip +0 -0
  18. {stewbeet-2.0.4 → stewbeet-2.0.6}/.gitignore +0 -0
  19. {stewbeet-2.0.4 → stewbeet-2.0.6}/LICENSE +0 -0
  20. {stewbeet-2.0.4 → stewbeet-2.0.6}/README.md +0 -0
  21. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/__init__.py +0 -0
  22. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/__main__.py +0 -0
  23. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/continuous_delivery/__init__.py +0 -0
  24. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/continuous_delivery/cd_utils.py +0 -0
  25. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/continuous_delivery/github.py +0 -0
  26. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/continuous_delivery/modrinth.py +0 -0
  27. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/continuous_delivery/pmc.py +0 -0
  28. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/continuous_delivery/smithed.py +0 -0
  29. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/core/__init__.py +0 -0
  30. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/core/__memory__.py +0 -0
  31. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/core/definitions_helper/__init__.py +0 -0
  32. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/core/definitions_helper/completion.py +0 -0
  33. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/core/definitions_helper/equipments.py +0 -0
  34. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/core/definitions_helper/materials.py +0 -0
  35. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/core/definitions_helper/records.py +0 -0
  36. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/core/definitions_helper/smart_ore_generation.py +0 -0
  37. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/core/definitions_helper/text.py +0 -0
  38. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/core/ingredients.py +0 -0
  39. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/core/utils/io.py +0 -0
  40. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/__init__.py +0 -0
  41. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/bookshelf.py +0 -0
  42. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/bookshelf_config.json +0 -0
  43. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Bitwise.zip +0 -0
  44. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Block.zip +0 -0
  45. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Color.zip +0 -0
  46. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Dump.zip +0 -0
  47. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Environment.zip +0 -0
  48. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Generation.zip +0 -0
  49. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Health.zip +0 -0
  50. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Hitbox.zip +0 -0
  51. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Id.zip +0 -0
  52. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Interaction.zip +0 -0
  53. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Link.zip +0 -0
  54. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Log.zip +0 -0
  55. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Math.zip +0 -0
  56. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Move.zip +0 -0
  57. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Position.zip +0 -0
  58. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Random.zip +0 -0
  59. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Raycast.zip +0 -0
  60. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Schedule.zip +0 -0
  61. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Sidebar.zip +0 -0
  62. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Spline.zip +0 -0
  63. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf String.zip +0 -0
  64. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Time.zip +0 -0
  65. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Tree.zip +0 -0
  66. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Vector.zip +0 -0
  67. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf View.zip +0 -0
  68. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Bookshelf Xp.zip +0 -0
  69. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Common Signals.zip +0 -0
  70. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Furnace NBT Recipes.zip +0 -0
  71. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/SmartOreGeneration.zip +0 -0
  72. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Smithed Crafter.zip +0 -0
  73. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/datapack/Smithed Custom Block.zip +0 -0
  74. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/dependencies/resource_pack/Smithed Crafter.zip +0 -0
  75. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/archive/__init__.py +0 -0
  76. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/auto/headers/__init__.py +0 -0
  77. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/auto/headers/object.py +0 -0
  78. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/auto/lang_file/__init__.py +0 -0
  79. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/auto/lang_file/utils.py +0 -0
  80. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/compatibilities/neo_enchant/__init__.py +0 -0
  81. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/compatibilities/simpledrawer/__init__.py +0 -0
  82. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/compute_sha1/__init__.py +0 -0
  83. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/copy_to_destination/__init__.py +0 -0
  84. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/custom_recipes/__init__.py +0 -0
  85. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/custom_recipes/furnace.py +0 -0
  86. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/custom_recipes/smithed.py +0 -0
  87. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/custom_recipes/vanilla.py +0 -0
  88. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/datapack/loot_tables/__init__.py +0 -0
  89. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/finalyze/basic_datapack_structure/__init__.py +0 -0
  90. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/finalyze/check_unused_textures/__init__.py +0 -0
  91. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/finalyze/custom_blocks_ticking/__init__.py +0 -0
  92. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/finalyze/dependencies/__init__.py +0 -0
  93. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/furnace.png +0 -0
  94. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/heavy_workbench.png +0 -0
  95. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/invisible_item.png +0 -0
  96. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/invisible_item_release.png +0 -0
  97. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/minecraft_font.ttf +0 -0
  98. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/none.png +0 -0
  99. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/none_release.png +0 -0
  100. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/pulverizing.png +0 -0
  101. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/shaped_2x2.png +0 -0
  102. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/shaped_3x3.png +0 -0
  103. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/simple_case_no_border.png +0 -0
  104. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/wiki_information.png +0 -0
  105. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/wiki_ingredient_of_craft.png +0 -0
  106. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/wiki_ingredient_of_craft_template.png +0 -0
  107. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/assets/wiki_result_of_craft.png +0 -0
  108. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/book_components.py +0 -0
  109. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/book_optimizer.py +0 -0
  110. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/craft_content.py +0 -0
  111. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/image_utils.py +0 -0
  112. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/iso_renders.py +0 -0
  113. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/other_utils.py +0 -0
  114. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/page_font.py +0 -0
  115. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/shared_import.py +0 -0
  116. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/.gitignore +0 -0
  117. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/_README.md +0 -0
  118. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/furnace.png +0 -0
  119. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/heavy_workbench.png +0 -0
  120. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/invisible_item.png +0 -0
  121. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/invisible_item_release.png +0 -0
  122. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/minecraft_font.ttf +0 -0
  123. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/none.png +0 -0
  124. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/none_release.png +0 -0
  125. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/pulverizing.png +0 -0
  126. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/shaped_2x2.png +0 -0
  127. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/shaped_3x3.png +0 -0
  128. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/simple_case_no_border.png +0 -0
  129. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/wiki_information.png +0 -0
  130. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/wiki_ingredient_of_craft.png +0 -0
  131. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/wiki_ingredient_of_craft_template.png +0 -0
  132. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/templates/wiki_result_of_craft.png +0 -0
  133. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/ingame_manual/text_components.py +0 -0
  134. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/initialize/source_lore_font.py +0 -0
  135. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/merge_smithed_weld/__init__.py +0 -0
  136. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/merge_smithed_weld/weld.py +0 -0
  137. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/resource_pack/check_power_of_2/__init__.py +0 -0
  138. {stewbeet-2.0.4 → stewbeet-2.0.6}/stewbeet/plugins/resource_pack/item_models/__init__.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: stewbeet
3
- Version: 2.0.4
3
+ Version: 2.0.6
4
4
  Summary: Beet Framework made to help generating advanced Minecraft datapack contents
5
5
  Project-URL: Homepage, https://github.com/Stoupy51/stewbeet
6
6
  Project-URL: Issues, https://github.com/Stoupy51/stewbeet/issues
@@ -18,7 +18,7 @@ Requires-Dist: model-resolver>=1.8.0
18
18
  Requires-Dist: mutagen>=1.47.0
19
19
  Requires-Dist: pyperclip>=1.8.0
20
20
  Requires-Dist: smithed>=0.19.0
21
- Requires-Dist: stouputils>=1.3.13
21
+ Requires-Dist: stouputils>=1.3.15
22
22
  Description-Content-Type: text/markdown
23
23
 
24
24
 
@@ -5,7 +5,7 @@ build-backend = "hatchling.build"
5
5
 
6
6
  [project]
7
7
  name = "stewbeet"
8
- version = "2.0.4"
8
+ version = "2.0.6"
9
9
  description = "Beet Framework made to help generating advanced Minecraft datapack contents"
10
10
  readme = "README.md"
11
11
  license = "MIT"
@@ -16,7 +16,7 @@ classifiers = [
16
16
  "Operating System :: OS Independent",
17
17
  ]
18
18
  dependencies = [
19
- "stouputils>=1.3.13",
19
+ "stouputils>=1.3.15",
20
20
  "model_resolver>=1.8.0",
21
21
  "beet>=0.110.1",
22
22
  "bolt>=0.49.1",
@@ -6,11 +6,12 @@ import shutil
6
6
  import subprocess
7
7
  import sys
8
8
 
9
- from beet import ProjectConfig, load_config, locate_config
9
+ from beet import ProjectConfig
10
10
  from box import Box
11
11
  from stouputils.decorators import LogLevels, handle_error
12
- from stouputils.io import clean_path
13
- from stouputils.print import error, info
12
+ from stouputils.print import info
13
+
14
+ from .utils import get_project_config
14
15
 
15
16
 
16
17
  @handle_error(message="Error while running 'stewbeet'")
@@ -18,13 +19,7 @@ def main():
18
19
  second_arg: str = sys.argv[1] if len(sys.argv) == 2 else ""
19
20
 
20
21
  # Try to find and load the beet configuration file
21
- cfg: ProjectConfig | None = None
22
- if config_path := locate_config(os.getcwd(), parents=True):
23
- cfg = load_config(filename=config_path)
24
- if cfg:
25
- os.chdir(config_path.parent)
26
- if not cfg:
27
- error(f"No beet config file found in the current directory '{clean_path(os.getcwd())}'")
22
+ cfg: ProjectConfig | None = get_project_config()
28
23
 
29
24
  # Check if the command is "clean" or "rebuild"
30
25
  if second_arg in ["clean", "rebuild"]:
@@ -94,7 +94,7 @@ OFFICIAL_LIBS: dict[str, dict] = {
94
94
  "smithed.crafter": {"version":[0, 7, 0], "name":"Smithed Crafter", "url":"https://wiki.smithed.dev/libraries/crafter/", "is_used": False},
95
95
  "furnace_nbt_recipes": {"version":[1, 9, 0], "name":"Furnace NBT Recipes", "url":"https://github.com/Stoupy51/FurnaceNbtRecipes", "is_used": False},
96
96
  "smart_ore_generation": {"version":[1, 7, 1], "name":"SmartOreGeneration", "url":"https://github.com/Stoupy51/SmartOreGeneration", "is_used": False},
97
- "itemio": {"version":[1, 3, 3], "name":"ItemIO", "url":"https://github.com/edayot/ItemIO", "is_used": False},
97
+ "itemio": {"version":[1, 4, 0], "name":"ItemIO", "url":"https://github.com/edayot/ItemIO", "is_used": False},
98
98
  **BOOKSHELF_MODULES,
99
99
  }
100
100
 
@@ -33,8 +33,12 @@ def add_sound(ctx: Context, sounds: Sound | dict[str, Sound], name: str, ns: str
33
33
  ctx.assets[ns].sounds[path] = sound
34
34
 
35
35
  # Create a new sound config
36
+ # Use subtitle from the first sound if available, otherwise use the sound name
37
+ first_sound = next(iter(sounds.values()))
38
+ subtitle = first_sound.subtitle if first_sound.subtitle else name.split("/")[-1]
39
+
36
40
  new_config: JsonDict = {name: {
37
- "subtitle": name.split("/")[-1],
41
+ "subtitle": subtitle,
38
42
  "sounds": [
39
43
  {
40
44
  "name": f"{ns}:{path}",
@@ -3,11 +3,10 @@
3
3
  import json
4
4
  from typing import Any
5
5
 
6
- from beet import Recipe
7
6
  from stouputils.decorators import simple_cache
8
- from stouputils.io import super_json_dump
9
7
 
10
8
  from ...core.__memory__ import Mem
9
+ from ...core.constants import PULVERIZING
11
10
  from ...core.ingredients import (
12
11
  get_item_from_ingredient,
13
12
  ingr_repr,
@@ -44,22 +43,24 @@ class PulverizerRecipeHandler:
44
43
  str: The generated recipe command.
45
44
  """
46
45
  ingredient: dict[str, Any] = item_to_id_ingr_repr(recipe["ingredient"])
47
- result: dict[str, Any] = item_to_id_ingr_repr(get_item_from_ingredient(Mem.ctx.meta, recipe["result"])) if recipe.get("result") else ingr_repr(item, Mem.ctx.project_id)
46
+ result: dict[str, Any] = item_to_id_ingr_repr(get_item_from_ingredient(recipe["result"])) if recipe.get("result") else ingr_repr(item, Mem.ctx.project_id)
48
47
 
49
48
  line: str = "execute if score #found simplenergy.data matches 0 store result score #found simplenergy.data if data storage simplenergy:main pulverizer.input"
50
49
  line += json.dumps(ingredient)
51
- line += f" run loot replace entity @s contents loot {loot_table_from_ingredient(Mem.ctx.meta, result, recipe['result_count'])}"
52
- return line + "\n"
50
+ line += f" run loot replace entity @s contents loot {loot_table_from_ingredient(result, recipe['result_count'])}"
51
+ return line
53
52
 
54
53
  def generate_recipes(self) -> None:
55
- """Generate all pulverizer recipes."""
54
+ """ Generate all pulverizer recipes. """
56
55
  for item, data in Mem.definitions.items():
57
56
  crafts: list[dict[str, Any]] = list(data.get("result_of_crafting", []))
58
57
  crafts += list(data.get("used_for_crafting", []))
59
58
 
60
59
  for recipe in crafts:
61
- if recipe["type"] == "pulverizing":
62
- write_function(self.SIMPLENERGY_PULVERIZER_PATH,
63
- self.simplenergy_pulverizer_recipe(recipe, item))
64
- Mem.ctx.data["simplenergy:tags/function/calls/pulverizer_recipes"] = Recipe(super_json_dump({"values": [f"{Mem.ctx.project_id}:calls/simplenergy/pulverizer_recipes"]}))
60
+ if recipe["type"] == PULVERIZING:
61
+ write_function(
62
+ self.SIMPLENERGY_PULVERIZER_PATH,
63
+ self.simplenergy_pulverizer_recipe(recipe, item),
64
+ tags=["simplenergy:calls/pulverizer_recipes"],
65
+ )
65
66
 
@@ -46,8 +46,10 @@ def beet_default(ctx: Context):
46
46
  # Predicates
47
47
  FACING = ["north", "east", "south", "west"]
48
48
  for face in FACING:
49
- adv = {"condition":"minecraft:location_check","predicate":{"block":{"state":{"facing":face}}}}
50
- ctx.data[ns].predicates[f"facing/{face}"] = Predicate(super_json_dump(adv))
49
+ pred = {"condition":"minecraft:location_check","predicate":{"block":{"state":{"facing":face}}}}
50
+ pred_obj = Predicate(pred)
51
+ pred_obj.encoder = super_json_dump
52
+ ctx.data[ns].predicates[f"facing/{face}"] = pred_obj
51
53
 
52
54
  # Get rotation function
53
55
  write_function(f"{ns}:custom_blocks/get_rotation",
@@ -80,19 +82,6 @@ execute if score #rotation {ns}.data matches 0 if predicate {ns}:facing/west run
80
82
  # Custom block
81
83
  if data.get(VANILLA_BLOCK):
82
84
 
83
- # Add additional data to the custom blocks
84
- if data.get("id") == CUSTOM_BLOCK_VANILLA:
85
- data["container"] = [
86
- {"slot":0,"item":{"id":"minecraft:stone","count":1,"components":{"minecraft:custom_data":{"smithed":{"block":{"id":f"{ctx.project_id}:{item}","from":ctx.project_id}}}}}}
87
- ]
88
-
89
- # Hide the container tooltip
90
- if not data.get("tooltip_display"):
91
- data["tooltip_display"] = {"hidden_components": []}
92
- elif not data["tooltip_display"].get("hidden_components"):
93
- data["tooltip_display"]["hidden_components"] = []
94
- data["tooltip_display"]["hidden_components"].append("minecraft:container")
95
-
96
85
  # Get the vanilla block data
97
86
  block = data[VANILLA_BLOCK]
98
87
  block_id = block["id"]
@@ -329,7 +318,9 @@ execute store result entity @s Item.count byte 1 run scoreboard players get #ite
329
318
 
330
319
  # Create predicate
331
320
  pred = {"condition": "minecraft:location_check", "predicate": {"block": {"blocks": f"#{ns}:{VANILLA_BLOCKS_TAG}"}}}
332
- ctx.data[ns].predicates["check_vanilla_blocks"] = Predicate(super_json_dump(pred))
321
+ pred_obj = Predicate(pred)
322
+ pred_obj.encoder = super_json_dump
323
+ ctx.data[ns].predicates["check_vanilla_blocks"] = pred_obj
333
324
 
334
325
  # Create advanced predicate
335
326
  advanced_predicate = {"condition": "minecraft:any_of", "terms": []}
@@ -342,7 +333,9 @@ execute store result entity @s Item.count byte 1 run scoreboard players get #ite
342
333
  "predicate": { "nbt": f"{{Tags:[\"{ns}.vanilla.{block_underscore}\"]}}", "location": { "block": { "blocks": block }}}
343
334
  }
344
335
  advanced_predicate["terms"].append(pred)
345
- ctx.data[ns].predicates["advanced_check_vanilla_blocks"] = Predicate(super_json_dump(advanced_predicate))
336
+ pred_obj = Predicate(advanced_predicate)
337
+ pred_obj.encoder = super_json_dump
338
+ ctx.data[ns].predicates["advanced_check_vanilla_blocks"] = pred_obj
346
339
 
347
340
  # Write a destroy check every 2 ticks, every second, and every 5 seconds
348
341
  ore_block = VANILLA_BLOCK_FOR_ORES["id"].replace(':', '_')
@@ -407,15 +400,19 @@ execute as @e[tag={ns}.custom_block,dx=0,dy=0,dz=0] at @s run function {ns}:cust
407
400
  max_level = 0
408
401
  )
409
402
  adv["rewards"]["function"] = f"{ns}:custom_blocks/_player_head/search_{item}"
410
- ctx.data[ns].advancements[f"custom_block_head/{item}"] = Advancement(super_json_dump(adv))
403
+ adv_obj = Advancement(adv)
404
+ adv_obj.encoder = super_json_dump
405
+ ctx.data[ns].advancements[f"custom_block_head/{item}"] = adv_obj
411
406
 
412
407
  # Make search function
413
408
  content = "# Search where the head has been placed\n"
414
409
  mid_x, mid_y, mid_z = [x // 2 for x in CUSTOM_BLOCK_HEAD_CUBE_RADIUS]
415
- for x in range(-mid_x, mid_x + 1):
416
- for y in range(-mid_y, mid_y + 1):
417
- for z in range(-mid_z, mid_z + 1):
418
- content += f"execute positioned ~{x} ~{y} ~{z} if data block ~ ~ ~ components.\"minecraft:custom_data\".{ns}.{item} run function {ns}:custom_blocks/{item}/place_main\n"
410
+ content += f"""
411
+ for x in range({-mid_x}, {mid_x + 1}):
412
+ for y in range({-mid_y}, {mid_y + 1}):
413
+ for z in range({-mid_z}, {mid_z + 1}):
414
+ execute positioned ~x ~y ~z if data block ~ ~ ~ components.\"minecraft:custom_data\".{ns}.{item} run function {ns}:custom_blocks/{item}/place_main
415
+ """
419
416
  content += f"\n# Advancement\nadvancement revoke @s only {ns}:custom_block_head/{item}\n\n"
420
417
  write_function(f"{ns}:custom_blocks/_player_head/search_{item}", content)
421
418
 
@@ -2,7 +2,6 @@
2
2
  # ruff: noqa: E501
3
3
  # Imports
4
4
  from beet import Context
5
- from beet.core.utils import JsonDict
6
5
  from stouputils.decorators import measure_time
7
6
  from stouputils.io import super_json_dump
8
7
  from stouputils.print import progress
@@ -31,9 +30,6 @@ def beet_default(ctx: Context):
31
30
  assert ctx.project_id, "Project ID is not set. Please set it in the project configuration."
32
31
  assert ctx.project_version.count(".") == 2, "Project version must be in the format 'major.minor.patch'."
33
32
 
34
- # Get configuration from context meta
35
- stewbeet: JsonDict = ctx.meta.get("stewbeet", {})
36
-
37
33
  # Get basic project information
38
34
  major, minor, patch = ctx.project_version.split(".")
39
35
 
@@ -98,7 +94,7 @@ execute unless score #{ctx.project_id}.loaded load.status matches 1 run function
98
94
  items_storage += f"data modify storage {ctx.project_id}:items all.{item} set value " + super_json_dump(mc_data, max_level = 0)
99
95
 
100
96
  # Write the loading tellraw and score, along with the final dataset
101
- project_name = stewbeet.get('project_name', ctx.project_id)
97
+ project_name = ctx.project_name or ctx.project_id
102
98
  write_load_file(
103
99
  f"""
104
100
  # Confirm load
@@ -6,7 +6,7 @@ from stouputils.decorators import measure_time
6
6
  from stouputils.print import progress, warning
7
7
 
8
8
  from ...core.__memory__ import Mem
9
- from .main import main as manual_main
9
+ from .main import manual_main
10
10
  from .shared_import import SharedMemory
11
11
 
12
12
 
@@ -84,8 +84,7 @@ from .shared_import import (
84
84
  def deepcopy(x):
85
85
  return json.loads(json.dumps(x))
86
86
 
87
- @measure_time(info, "Added manual to the definitions")
88
- def main():
87
+ def manual_main():
89
88
  # Copy everything in the manual assets folder to the templates folder
90
89
  os.makedirs(TEMPLATES_PATH, exist_ok = True)
91
90
  shutil.copytree(MANUAL_ASSETS_PATH + "assets", TEMPLATES_PATH, dirs_exist_ok = True)
@@ -102,7 +101,7 @@ def main():
102
101
 
103
102
  def routine():
104
103
  manual_config: JsonDict = Mem.ctx.meta.get("stewbeet",{}).get("manual", {})
105
- manual_debug: str = manual_config.get("manual_debug", "")
104
+ json_dump_path: str = manual_config.get("json_dump_path", "")
106
105
  manual_name: str = manual_config.get("name", "")
107
106
  if not manual_name:
108
107
  manual_name = f"{Mem.ctx.project_name} Manual"
@@ -162,8 +161,8 @@ def routine():
162
161
 
163
162
  # If the manual cache is enabled and we have a cache file, load it
164
163
  cache_pages: bool = manual_config.get("cache_pages", False)
165
- if cache_pages and manual_debug and os.path.exists(manual_debug) and os.path.exists(f"{SharedMemory.cache_path}/font/manual.json"):
166
- with super_open(manual_debug, "r") as f:
164
+ if cache_pages and json_dump_path and os.path.exists(json_dump_path) and os.path.exists(f"{SharedMemory.cache_path}/font/manual.json"):
165
+ with super_open(json_dump_path, "r") as f:
167
166
  book_content = json.load(f)
168
167
 
169
168
  # Else, generate all
@@ -630,11 +629,11 @@ def routine():
630
629
  f.write(super_json_dump(fonts))
631
630
 
632
631
  # Debug book_content
633
- manual_debug: str = manual_config.get("json_dump_path", "")
634
- if manual_debug:
635
- with super_open(manual_debug, "w") as f:
632
+ json_dump_path: str = manual_config.get("json_dump_path", "")
633
+ if json_dump_path:
634
+ with super_open(json_dump_path, "w") as f:
636
635
  f.write(super_json_dump(book_content))
637
- debug(f"Debug book_content at '{relative_path(manual_debug)}'")
636
+ debug(f"Debug book_content at '{relative_path(json_dump_path)}'")
638
637
 
639
638
 
640
639
  # Copy the font provider and the generated textures to the resource pack
@@ -1,96 +1,97 @@
1
-
2
- # Imports
3
- import os
4
- from pathlib import Path
5
-
6
- from beet import Context, Pack
7
- from beet.core.utils import JsonDict, TextComponent
8
- from box import Box
9
- from stouputils import relative_path
10
- from stouputils.decorators import measure_time
11
- from stouputils.io import super_json_dump
12
- from stouputils.print import progress, warning
13
-
14
- from ...core import Mem
15
- from .source_lore_font import make_source_lore_font
16
-
17
-
18
- # Main entry point
19
- @measure_time(progress, message="Execution time of 'stewbeet.plugins.initialize'")
20
- def beet_default(ctx: Context):
21
-
22
- # Assertions
23
- assert ctx.project_id, "Project ID must be set in the project configuration."
24
-
25
- # Store the Box object in ctx for access throughout the codebase
26
- meta_box: Box = Box(ctx.meta, default_box=True, default_box_attr={})
27
- object.__setattr__(ctx, "meta", meta_box) # Bypass FrozenInstanceError
28
- Mem.ctx = ctx
29
-
30
- # Preprocess project description
31
- project_description: TextComponent = Mem.ctx.meta.stewbeet.project_description
32
- if not project_description or project_description == "auto":
33
- # Use project name, version, and author to create a default description
34
- Mem.ctx.meta.stewbeet.project_description = f"{ctx.project_name} [{ctx.project_version}] by {ctx.project_author}"
35
-
36
- # Preprocess source lore
37
- source_lore: TextComponent = Mem.ctx.meta.stewbeet.source_lore
38
- if not source_lore or source_lore == "auto":
39
- Mem.ctx.meta.stewbeet.source_lore = [{"text":"ICON"},{"text":f" {ctx.project_name}","italic":True,"color":"blue"}]
40
- make_source_lore_font(Mem.ctx.meta.stewbeet.source_lore)
41
-
42
- # Preprocess manual name
43
- manual_name: TextComponent = Mem.ctx.meta.stewbeet.manual.name
44
- if not manual_name:
45
- Mem.ctx.meta.stewbeet.manual.name = f"{ctx.project_name} Manual"
46
-
47
- # Convert paths to relative ones
48
- object.__setattr__(ctx, "output_directory", relative_path(Mem.ctx.output_directory))
49
-
50
- # Helper function to setup pack.mcmeta
51
- def setup_pack_mcmeta(pack: Pack, pack_format: int):
52
- existing_mcmeta = pack.mcmeta.data or {}
53
- pack_mcmeta: JsonDict = {"pack": {}}
54
- pack_mcmeta.update(existing_mcmeta)
55
- pack_mcmeta["pack"].update(existing_mcmeta.get("pack", {}))
56
- pack_mcmeta["pack"]["pack_format"] = pack_format
57
- pack_mcmeta["pack"]["description"] = Mem.ctx.meta.stewbeet.project_description
58
- pack_mcmeta["id"] = Mem.ctx.project_id
59
- pack.mcmeta.data = pack_mcmeta
60
- pack.mcmeta.encoder = super_json_dump
61
-
62
- # Setup pack.mcmeta for both packs
63
- setup_pack_mcmeta(ctx.data, ctx.data.pack_format)
64
- setup_pack_mcmeta(ctx.assets, ctx.assets.pack_format)
65
-
66
- # Convert texture names if needed (from old legacy system)
67
- textures_folder = Mem.ctx.meta.stewbeet.get("textures_folder")
68
- if textures_folder and Path(textures_folder).exists():
69
- REPLACEMENTS = {
70
- "_off": "",
71
- "_down": "_bottom",
72
- "_up": "_top",
73
- "_north": "_front",
74
- "_south": "_back",
75
- "_west": "_left",
76
- "_east": "_right",
77
- }
78
-
79
- # Get all texture files
80
- texture_files = [f for f in os.listdir(textures_folder) if f.endswith(('.png', '.jpg', '.jpeg', ".mcmeta"))]
81
-
82
- for file in texture_files:
83
- new_name = file.lower()
84
- for k, v in REPLACEMENTS.items():
85
- if k in file:
86
- new_name = new_name.replace(k, v)
87
-
88
- if new_name != file:
89
- old_path = Path(textures_folder) / file
90
- new_path = Path(textures_folder) / new_name
91
- if old_path.exists() and not new_path.exists():
92
- os.rename(old_path, new_path)
93
- warning(f"Renamed texture {file} to {new_name}")
94
-
95
- pass
96
-
1
+
2
+ # Imports
3
+ import os
4
+ from pathlib import Path
5
+
6
+ from beet import Context, Pack
7
+ from beet.core.utils import JsonDict, TextComponent
8
+ from box import Box
9
+ from stouputils import relative_path
10
+ from stouputils.decorators import measure_time
11
+ from stouputils.io import super_json_dump
12
+ from stouputils.print import warning
13
+
14
+ from ...core import Mem
15
+ from .source_lore_font import make_source_lore_font
16
+
17
+
18
+ # Main entry point
19
+ @measure_time(message="Total execution time")
20
+ def beet_default(ctx: Context):
21
+
22
+ # Assertions
23
+ assert ctx.project_id, "Project ID must be set in the project configuration."
24
+
25
+ # Store the Box object in ctx for access throughout the codebase
26
+ meta_box: Box = Box(ctx.meta, default_box=True, default_box_attr={})
27
+ object.__setattr__(ctx, "meta", meta_box) # Bypass FrozenInstanceError
28
+ Mem.ctx = ctx
29
+
30
+ # Preprocess project description
31
+ project_description: TextComponent = Mem.ctx.meta.stewbeet.project_description
32
+ if not project_description or project_description == "auto":
33
+ # Use project name, version, and author to create a default description
34
+ Mem.ctx.meta.stewbeet.project_description = f"{ctx.project_name} [{ctx.project_version}] by {ctx.project_author}"
35
+
36
+ # Preprocess source lore
37
+ source_lore: TextComponent = Mem.ctx.meta.stewbeet.source_lore
38
+ if not source_lore or source_lore == "auto":
39
+ Mem.ctx.meta.stewbeet.source_lore = [{"text":"ICON"},{"text":f" {ctx.project_name}","italic":True,"color":"blue"}]
40
+ make_source_lore_font(Mem.ctx.meta.stewbeet.source_lore)
41
+
42
+ # Preprocess manual name
43
+ manual_name: TextComponent = Mem.ctx.meta.stewbeet.manual.name
44
+ if not manual_name:
45
+ Mem.ctx.meta.stewbeet.manual.name = f"{ctx.project_name} Manual"
46
+
47
+ # Convert paths to relative ones
48
+ object.__setattr__(ctx, "output_directory", relative_path(Mem.ctx.output_directory))
49
+
50
+ # Helper function to setup pack.mcmeta
51
+ def setup_pack_mcmeta(pack: Pack, pack_format: int):
52
+ existing_mcmeta = pack.mcmeta.data or {}
53
+ pack_mcmeta: JsonDict = {"pack": {}}
54
+ pack_mcmeta.update(existing_mcmeta)
55
+ pack_mcmeta["pack"].update(existing_mcmeta.get("pack", {}))
56
+ pack_mcmeta["pack"]["pack_format"] = pack_format
57
+ pack_mcmeta["pack"]["description"] = Mem.ctx.meta.stewbeet.project_description
58
+ pack_mcmeta["id"] = Mem.ctx.project_id
59
+ pack.mcmeta.data = pack_mcmeta
60
+ pack.mcmeta.encoder = super_json_dump
61
+
62
+ # Setup pack.mcmeta for both packs
63
+ setup_pack_mcmeta(ctx.data, ctx.data.pack_format)
64
+ setup_pack_mcmeta(ctx.assets, ctx.assets.pack_format)
65
+
66
+ # Convert texture names if needed (from old legacy system)
67
+ textures_folder = Mem.ctx.meta.stewbeet.get("textures_folder")
68
+ if textures_folder and Path(textures_folder).exists():
69
+ REPLACEMENTS = {
70
+ "_off": "",
71
+ "_down": "_bottom",
72
+ "_up": "_top",
73
+ "_north": "_front",
74
+ "_south": "_back",
75
+ "_west": "_left",
76
+ "_east": "_right",
77
+ }
78
+
79
+ # Get all texture files
80
+ texture_files = [f for f in os.listdir(textures_folder) if f.endswith(('.png', '.jpg', '.jpeg', ".mcmeta"))]
81
+
82
+ for file in texture_files:
83
+ new_name = file.lower()
84
+ for k, v in REPLACEMENTS.items():
85
+ if k in file:
86
+ new_name = new_name.replace(k, v)
87
+
88
+ if new_name != file:
89
+ old_path = Path(textures_folder) / file
90
+ new_path = Path(textures_folder) / new_name
91
+ if old_path.exists() and not new_path.exists():
92
+ os.rename(old_path, new_path)
93
+ warning(f"Renamed texture {file} to {new_name}")
94
+
95
+ # Yield message to indicate successful build
96
+ yield
97
+
@@ -114,11 +114,9 @@ class AutoModel:
114
114
 
115
115
  # Get powered states (if any)
116
116
  powered = [""]
117
- on_textures = []
118
117
  for texture_name in self.source_textures:
119
118
  if texture_name.startswith(self.item_name) and texture_name.endswith("_on.png"):
120
119
  powered = ["", "_on"]
121
- on_textures.append(texture_name)
122
120
 
123
121
  # Debug
124
122
  if False:
@@ -127,7 +125,6 @@ class AutoModel:
127
125
  print(f"Block or item: {self.block_or_item}")
128
126
  print(f"Overrides: {overrides}")
129
127
  print(f"Powered states: {powered}")
130
- print(f"On textures: {on_textures}")
131
128
 
132
129
  # Generate its model file(s)
133
130
  for on_off in powered:
@@ -144,7 +141,6 @@ class AutoModel:
144
141
  if self.block_or_item == "block":
145
142
  # Get parent
146
143
  content = {"parent": "block/cube_all", "textures": {}}
147
-
148
144
  # Check in which variants state we are
149
145
  variants_without_on = [x for x in variants if "_on" not in x]
150
146
  if len(variants_without_on) == 1:
@@ -269,7 +265,7 @@ class AutoModel:
269
265
 
270
266
  # Add overrides
271
267
  for key, value in overrides.items():
272
- content[key] = value
268
+ content[key] = value.copy() if isinstance(value, dict) else value
273
269
 
274
270
  # If powered, check if the on state is in the variants and add it
275
271
  if on_off == "_on":
@@ -45,9 +45,8 @@ def beet_default(ctx: Context):
45
45
  sounds_names: list[str] = [sound for sound in all_files if sound.endswith(".ogg")]
46
46
  if not sounds_names:
47
47
  return
48
-
49
48
  # Dictionary to group sound variants
50
- sound_groups: dict[str, list[str]] = defaultdict(list)
49
+ sound_groups: dict[str, list[tuple[str, str]]] = defaultdict(list)
51
50
 
52
51
  def handle_sound(sound: str) -> None:
53
52
  """ Process a single sound file.
@@ -78,14 +77,14 @@ def beet_default(ctx: Context):
78
77
  sounds: dict[str, Sound] = {}
79
78
 
80
79
  # Process each variant
81
- for variant in sorted(variants):
80
+ for variant_rel_sound in sorted(variants):
82
81
  # Get variant name without extension
83
- variant_name: str = os.path.splitext(variant)[0]
82
+ variant_name: str = os.path.splitext(variant_rel_sound)[0]
84
83
 
85
84
  # Create Sound object for this variant
86
- sounds[variant_name] = Sound(
87
- source_path=clean_path(f"{sounds_folder}/{variant}"),
88
- subtitle=base_name.split("/")[-1]
85
+ sounds[variant_name.lower().replace(" ","_")] = Sound(
86
+ source_path=clean_path(f"{sounds_folder}/{variant_rel_sound}"),
87
+ subtitle=variant_name
89
88
  )
90
89
 
91
90
  # Add all variants to the sound system
@@ -214,3 +214,18 @@ def beet_default(ctx: Context) -> None:
214
214
  else:
215
215
  info("No errors found in the definitions during verification")
216
216
 
217
+
218
+ for item, data in Mem.definitions.items():
219
+ # Add additional data to the custom blocks
220
+ if data.get("id") == CUSTOM_BLOCK_VANILLA:
221
+ data["container"] = [
222
+ {"slot":0,"item":{"id":"minecraft:stone","count":1,"components":{"minecraft:custom_data":{"smithed":{"block":{"id":f"{ctx.project_id}:{item}","from":ctx.project_id}}}}}}
223
+ ]
224
+
225
+ # Hide the container tooltip
226
+ if not data.get("tooltip_display"):
227
+ data["tooltip_display"] = {"hidden_components": []}
228
+ elif not data["tooltip_display"].get("hidden_components"):
229
+ data["tooltip_display"]["hidden_components"] = []
230
+ data["tooltip_display"]["hidden_components"].append("minecraft:container")
231
+
@@ -0,0 +1,28 @@
1
+
2
+
3
+ # Imports
4
+ import os
5
+
6
+ from beet import ProjectConfig, load_config, locate_config
7
+ from stouputils.io import clean_path
8
+ from stouputils.print import error
9
+
10
+
11
+ # Try to find and load the beet configuration file
12
+ def get_project_config(directory: str = os.getcwd()) -> ProjectConfig | None:
13
+ """ Get the project configuration from the current directory.
14
+
15
+ If no configuration file is found, it returns None and prints an error message.
16
+
17
+ Args:
18
+ directory (str): The directory to search for the configuration file. Defaults to the current working directory.
19
+ """
20
+ cfg: ProjectConfig | None = None
21
+ if config_path := locate_config(directory, parents=True):
22
+ cfg = load_config(filename=config_path)
23
+ if cfg:
24
+ os.chdir(config_path.parent)
25
+ if not cfg:
26
+ error(f"No beet config file found in the current directory '{clean_path(directory)}'")
27
+ return cfg
28
+
File without changes
File without changes
File without changes
File without changes
File without changes