Skip to content

Commit

Permalink
The great Resource Pack Merge (Gamemode4Dev#918)
Browse files Browse the repository at this point in the history
* Resources for Machine Blocks (Gamemode4Dev#56)

Adds font-magic needed to make machine names look fancy in the future.

* Machine blocks V1

* machine changes part 2

* Fix some typos (Gamemode4Dev#57)

- probably fixes the warnings, hopefully doesn't break anything

* update script and bismutite_lump

* hopper minecart items

* actual textures for the blocks

* Fix translate tags with the packager (Gamemode4Dev#59)

* Add Container GUIs (Gamemode4Dev#61)

Adds Texture GUIs for Machine Blocks Machines.
Textures by Hozz

* Fix Corrupted Image

* Update to 1.19 (Gamemode4Dev#63)

* Fix TP anchors, update beet

* Update to 1.19

* Auto Crafter GUI (Gamemode4Dev#65)

auto crafter gui should now look correct, but the CC container image is used as a placeholder

* Add auto crafter texture, and update optifine copy

* fix TP Jammer's name

* update phantom model

* Pack format and required atlases

-Increments pack format to 1.19.3 version,
-Adds atlas sources to properly load textures not in `items` or `blocks` directories

* Update pack.png (Gamemode4Dev#68)

Replaces old pack.png with Custom Crafter

* Add shrieking textures to Orb of Ankou (Gamemode4Dev#67)

Adds textures and a CMD path for the shrieking soul and shard

* Update pack_format and other versions

* Update GUI Font Magic for 1.19.4 (Gamemode4Dev#69)

- uses JP's perfect TTF font
  - names are now exactly center align
  - non-latin alphanumeric characters should work now (not tested)
- simplified the GUI name requirement
  - no more \u00a0 for spaces in container names

* Update to 1.20

* Move apple trees and scuba assets to module-folder

* Move CMD-controlling item models to base

* Load RPs into beet and output final to /out

* Model config validation

Adds a model_data field to meta, which allows for nested configs to inherit properties from their parent for ease of defining similar items

* Each module generates minecraft-model overrides for itself

* Model config `item` may be a list

Allows for modules which wish to use the same integer value for multiple different items: ie shamir tools

* Start generating model overrides with original file

* Add and remove configured model data to global registry

* Assign new CMD values

* Attempt to use same cmd first

* Allow config for custom override predicates

* Transition existing processes to service object

* Process config options late, allowin for programatic generation

* Functional config validation and error reporting on inherited model_data

* Move index retrieval/assignment to class methods

* Simplify filter function syntax

* Basics of auto-model generation (templating)

* textures defaults to reference

* Outputs registry after build

NOTE: uses the wrapped output style used in PlayerheadManagement, though that has not been merged as of yet

* Refactor some RP files into new spec

* Bugfix to model validation

* Github action fails if new CMD needs to be issued

* Fix CMD assignment/reassignment

* Logger revamp

* BROKEN: Attempt fix for vanilla override merging

* Fix vanilla model override merging

* Migrate many simple textures to their parent datapack

* Migrate more complex module textures

* Last uncomplex item config

* (to be redone) template_options pydantic models

* Reconfigure for extendable transform functions

* Transform designed for item_display calculations

* "block" model template

* Templates are classes, and textures can be specified by name

* template/transform combo for the common CC-like models

... class inheritance ended up working really nicely here.

* Cache registry during build

* Disassembler model move

* Custom templates support transforms

First attempt at LT models using the new item_display transform

* dev pipeline fully defined in beet-dev.yaml

* Rewrite of textures field for list and dict support

* Optional pydantic fields processed in order

* Fix liquid tanks block and item models

* Ender hoppers without minecart

* Auto crafting models

* Ench Extractors models

* Teleportation anchors models

* Update block_compressors to use display entities

* block_compressors model data config

* Update tinkering_compressors to display entities

* tinkering_compressors model data

* Migrate remaining unused directional ender_hoppers models

NOTE: item_displays actually allow for the remodelling of the player head item, even when shown with the "head" model variant. This removes the need for the stone-button model used previously

* Forming press models

* Smelteries models

NOTE: This uses the expandability function of the item model templates, although it would be roughly as easy to implement programmatically in a generator plugin

* Tnt landmines entity models

* Leftover model cleanup

* Fix custom crafters relocators with display entity change

* Relocator models

* Trapped sign models

* Metallurgy bands and lumps

* Metallurgy tool shamir models

This improperly handles shared CMD registration, and is solely to get the models more-or-less working in game

* Support different models for items sharing a CMD value

New example syntax in apple_trees, to be cleaned up in the following commit

* Clean up example config

* Metallurgy shamir textures complete

* Move template class to Pydantic, for configurable tempaltes

* Refactor TemplateOptions for multiple model creation

* Shamir models, but correctly this time

* Glob pattern support for allocations

* Remove old metallurgy models

* Remove sky dimension textures/models

* Start of advancement icon models

* Continuation of advancement icons

* Fix old-format scuba gear models

* Final advancement icons

* Clean up old advancement models

* Restore end_fishing custom tuned sword offsets

* Merge config cleanup

* Basics of Mecha Transformer rule

* Pass jsonfiles through Mecha manually

* Better Diagnostics when manually parsing jsonfiles

Adds a transformer name to the unique key used when registering a fake ComplilationUnit, to avoid overwriting previous rule's results

* Basic nbt transformations

* Port spreadsheet values to registry, pt 1

* Move shamir bands to the same CMD/Reference as shamir tools

* Port metallurgy spreadsheet values to registry, pt2

* Alphabetize and correct lingering shamir indexes

* Remove redundant metallurgy band model config

* Rename shamir references to `shamir/foo` to reflect multi-texture nature

* Use mecha rules in source packs: animi-boots_of_ostra

* Add rule for substitutions into `data modify ... value`

* Use mecha rules in source files: calling_bell-enchant_extractors

* Reconfig end fishing to share tool/armor CMD between different item types

* Rename end fishing textures to start at 1

* Ensure vanilla overrides are added in ascending CMD order

* Update ender_hoppers to use item displays. Use mecha rules in source files

* Use mecha rules in source files: enderman_support_class-lightning_in_a_bottle

* Extend jsonfile mecha rules into overlays

* Use mecha rules in source files: liquid_minecarts-note_block_interface

* Update orb_of_ankou model references - shards and essences are shared ref

* Use mecha rules in source files : particles_pack-ziprails (the rest)

* Remaining migration cleanup/bugfixes

* Restore texture existance checks

* Add beet.contrib.optifine

* CMD reference lookup for optifine CIT .properties

* Migrate simple CIT textures

* Remove public-server only optifine textures

* End fishing optifine armor

* Zauber cauldrons optifine textures

* Fix animated zauber textures

* Shamirs generate optifine armor config files

NOTE: during this commit a significant bug with file merging was discovered. It does not currently function completely as a result

* Migrate metallurgy armor optifine animations

* Optifine custom-entity-models

This is a dumb simple migration of optifine CEM models. In the future, if more than one pack wishes to use the same entity, some clever beet merge rules could be written to make it work in our monorepo

* item_display machines set to full brightness

* Font-powered custom guis

* Cleanup last old RP files

* Setup RP as a module, with its own beet.yaml instructions

* Use beet autoload to ensure merge policies apply during broadcast merges

* Remove optifine metallurgy armor .properties - they are generated by the plugin

* Repair optifine cit spyglass and trident item retextures

* Resource pack plays nice with beet-dev

* Update beet-release.yaml

* Add babelbox for translations

* Port existing (outdated) translations to new spreadsheets

* Fix `beet readme-gen` to work and also only load the metadata

* Allow CMD prefix to be configured

* Framework for "interrupted" broadcast

* [Broken] Hash-based update detector

* Completed hash-based update detector

Ensures builds are fully deterministic/reproducible so zipfile hashes can reliably be used to detect changes to a module.

* Run libraries through new patch system

* Rename plugin to `update_checker`

* Rename plugin to `worker` and run libraries and RP through new update checking

* Better organize new plugins, add repro-zipfile dependancy

* Descriptions for libraries, prevents addition of version number to mcmeta

* Move folder to `resource_pack` and finish patch tracking

* Add missing rename

* Skip writing RP version to datapack init functions

* Use mecha.contrib.json_files to get better diagnostics from LootTable processing

* Move json rules to class mixin

* Exclude block/fluid tag predicates from `tag` processing (easy way out)

* Allow proper parsing of newlines (like used in Guidebook)

* ill-formed nbt produces pretty diagnostic

* Translation key linting

* Add missing translations to babelbox shreadsheets

* Add warnings for unused translations

* Missing potion_liquids translations

* OOA Translations [babelbox makes nonfunctional atm]

* Add extra entries to item model files to return to the vanilla model on unused CMD values

* `generated` template supports creating the same model for multiple items

* Generate trapped signs model_data via plugin. Add simple hanging sign texture

* Update bolt to function

* Patch cache-less build

* Clear leftover item models

* Update beet to fix babelbox unicode loading

* Update mecha to fix orb_of_ankou build

* Copy vanilla model data first to prevent cross-build errors

* Restore CMD model padding

* Fix metallurgy shields and texture linting

* Various warning cleanup

* Github action debug

* Update translations.csv

* Revert "Github action debug"

This reverts commit b489e57.

* Remove old tunnel bores placement, and its ascioated translation

* Add unripe golden apple texture

Texture credit: Hozz

Co-Authored-By: hozz8528 <[email protected]>

* Edit RP dev pack description

* Save beet-dev generated config in tempfile to fix watch

* Fix `beet dev -w`

* Repair `beet readme-gen` cli command with new config method

* Update zauber translations

* Migrate zauber armor textures

* Migrate zauber crystal textures

* Migrate zauber soulution textures

* Migrate zauber magicol CMD

* Migrate new zauber advancements

* Zauber Cauldron custom model.

Model and Textures by @kyrkis

Co-Authored-By: kyrius <[email protected]>

* Fallback translations include "Lingering" and "Splash" for potions

* Update zauber_cauldrons_paint_biome.json

* Update beet-dev.yaml

* Begin incorporation of guidebook textures

* Add copies of legacy guidebook gm4 items

* Guidebooks have arrows

Textures by @kyrkis

Co-Authored-By: kyrius <[email protected]>

* New Orb of Ankou Textures

Image credit: Hozz

Co-Authored-By: hozz8528 <[email protected]>

* Namespace custom crafter reference - avoids error with unusual autocrafter guidebook inclusion

* CLI option for auto-updating babelbox translations from source fallback.

Intended for auto-propagating guidebook translations

* Repair some config issues

* Load test files during `beet dev` pipeline

* Correct metallurgy advancement icon config

* Mecha logging filter to limit single line length.

* Allow backfilling of unset translation keys

* Transfer guidebook translations into translations.csv

* Misc translation inconsistencies 1

* Misc translation inconsistencies 2

* Misc translation inconsistencies 3

* Fix github test action by adding RP plugins

Test build does not include complex beet tooling for update detection and patch number increments. Since tests dont check the update behavior currently this is acceptable, but may need to bae changed in the future

* Correct guidebook translation tag format

* Misc translation inconsistencies 4

* Fix Gamemode4Dev#932

* Skip mecha linting in beet-test.yaml

* Misc translation inconsistencies 5

* Fix function tag leaks from worker-based update checker

* Use new pack.copy() from beet v0.104.0

* config option for translation linter ignores

* Guidebook auto-generates advancement icons using module logos

* Guidebook item reference in all the places

* Texture gm4 root advancement

* Various cleanup

* Beet 0.104.1 fixes Unicode in beet.yaml on windows

* Update commands.py

* Prevent "worker reload" warning message on beet-release

* Optional `model_data.yaml` file for storing long config outside of beet.yaml

* Fix zauber cauldrons KeyError

* Fix RP worker merge

* Redundant `ignore` config

* Stably sort player heads skin cache

* Abstract dynamic config builder

* Separate RP and DP pack formats

* Correct ender hoppers cart display entity height

* New bat model for optifine ooa floating-shard

Co-Authored-By: hozz8528 <[email protected]>

* Incorporate 43811f3fd52c910c2c4df590baf548fdc80cdf3b from deprecated rp repo.

Co-Authored-By: Misode <[email protected]>

* Update some texture credits

* Advancement icon has white border and background

* Don't returning sort instead of inplace sort on skin_cache

* Ignore inexplicable pydantic validator typing errors

---------

Co-authored-by: BluePsychoRanger <[email protected]>
Co-authored-by: JP12 <[email protected]>
Co-authored-by: ToffeeMax <[email protected]>
Co-authored-by: kyrkis <[email protected]>
Co-authored-by: Misode <[email protected]>
Co-authored-by: hozz8528 <[email protected]>
  • Loading branch information
7 people authored Mar 9, 2024
1 parent 5f07d34 commit 2b4c9bd
Show file tree
Hide file tree
Showing 1,967 changed files with 26,926 additions and 1,433 deletions.
11 changes: 11 additions & 0 deletions base/assets/gm4/font/container_gui.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
{
"providers": [
{
"type": "space",
"advances": {
"\uf824": 3,
"\uf808": -10
}
}
]
}
18 changes: 18 additions & 0 deletions base/assets/gm4/font/default.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
{
"providers": [
{
"type": "space",
"advances": {
" ": 4,
"\u200c": 0
}
},
{
"type": "ttf",
"file": "gm4:minecraft.ttf",
"shift": [0,-0.5],
"size": 13,
"oversample": 7
}
]
}
18 changes: 18 additions & 0 deletions base/assets/gm4/font/half_invert.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
{
"providers": [
{
"type": "space",
"advances": {
" ": -2,
"\u200c": 0
}
},
{
"type": "ttf",
"file": "gm4:minecraft.ttf",
"shift": [0, -32768],
"size": -6.5,
"oversample": 1.0
}
]
}
Binary file added base/assets/gm4/font/minecraft.ttf
Binary file not shown.
18 changes: 18 additions & 0 deletions base/assets/gm4/font/offscreen.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
{
"providers": [
{
"type": "space",
"advances": {
" ": 4,
"\u200c": 0
}
},
{
"type": "ttf",
"file": "gm4:minecraft.ttf",
"shift": [0, -32768],
"size": 13,
"oversample": 1.0
}
]
}
3 changes: 3 additions & 0 deletions base/assets/gm4/lang/en_us.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"gm4.second": "%2$s"
}
143 changes: 143 additions & 0 deletions base/assets/gm4/models/block/cube_with_plate.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,143 @@
{
"parent": "minecraft:block/cube",
"elements": [
{
"name": "plate",
"from": [
1.0,
16.0,
1.0
],
"to": [
15.0,
17.0,
15.0
],
"faces": {
"north": {
"texture": "#plate",
"uv": [
1.0,
0.0,
15.0,
1.0
]
},
"east": {
"texture": "#plate",
"uv": [
1.0,
0.0,
15.0,
1.0
]
},
"south": {
"texture": "#plate",
"uv": [
1.0,
0.0,
15.0,
1.0
]
},
"west": {
"texture": "#plate",
"uv": [
1.0,
0.0,
15.0,
1.0
]
},
"up": {
"texture": "#plate",
"uv": [
1.0,
1.0,
15.0,
15.0
]
},
"down": {
"texture": "#plate",
"uv": [
1.0,
1.0,
15.0,
15.0
]
}
}
},
{
"name": "cube",
"from": [
0.0,
0.0,
0.0
],
"to": [
16.0,
16.0,
16.0
],
"faces": {
"north": {
"texture": "#front",
"uv": [
0.0,
0.0,
16.0,
16.0
]
},
"east": {
"texture": "#side",
"uv": [
0.0,
0.0,
16.0,
16.0
]
},
"south": {
"texture": "#side",
"uv": [
0.0,
0.0,
16.0,
16.0
]
},
"west": {
"texture": "#side",
"uv": [
0.0,
0.0,
16.0,
16.0
]
},
"up": {
"texture": "#top",
"uv": [
0.0,
0.0,
16.0,
16.0
]
},
"down": {
"texture": "#bottom",
"uv": [
0.0,
0.0,
16.0,
16.0
]
}
}
}
]
}
73 changes: 73 additions & 0 deletions base/assets/gm4/models/block/plate.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
{
"elements": [
{
"name": "plate",
"from": [
1.0,
16.0,
1.0
],
"to": [
15.0,
17.0,
15.0
],
"faces": {
"north": {
"texture": "#top",
"uv": [
1.0,
0.0,
15.0,
1.0
]
},
"east": {
"texture": "#top",
"uv": [
1.0,
0.0,
15.0,
1.0
]
},
"south": {
"texture": "#top",
"uv": [
1.0,
0.0,
15.0,
1.0
]
},
"west": {
"texture": "#top",
"uv": [
1.0,
0.0,
15.0,
1.0
]
},
"up": {
"texture": "#top",
"uv": [
1.0,
1.0,
15.0,
15.0
]
},
"down": {
"texture": "#top",
"uv": [
1.0,
1.0,
15.0,
15.0
]
}
}
}
]
}
Binary file added base/assets/gm4/textures/gui/advancement/root.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added base/assets/gm4/textures/item/empty.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
14 changes: 14 additions & 0 deletions base/assets/minecraft/atlases/blocks.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
{
"sources": [
{
"type": "directory",
"source": "gui",
"prefix": "gui/"
},
{
"type": "directory",
"source": "entity",
"prefix": "entity/"
}
]
}
1 change: 1 addition & 0 deletions base/assets/minecraft/optifine/emissive.properties
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
suffix.emissive=_e
3 changes: 3 additions & 0 deletions base/assets/translations.csv
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
key,en_us
advancement.gm4.root.title,"Gamemode 4",
advancement.gm4.root.description,"Semi-funny blurb about GM4",
16 changes: 16 additions & 0 deletions base/beet.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,16 @@ data_pack:
load:
data: data

resource_pack:
load:
assets: assets

require:
- gm4.plugins.resource_pack

pipeline:
- beet.contrib.babelbox
- gm4.plugins.resource_pack.build
- gm4.plugins.versioning.base

meta:
Expand All @@ -14,3 +23,10 @@ meta:
extra_version_injections:
advancements:
- 'gm4:intro_song/play_song'
model_data:
- item: command_block
reference: gm4:gui/advancement/root
template: generated
babelbox:
load: assets/translations.csv
namespace: gm4_translations
48 changes: 45 additions & 3 deletions beet-dev.yaml
Original file line number Diff line number Diff line change
@@ -1,10 +1,52 @@
ignore:
- gm4/skin_cache.json

pipeline:
- gm4.plugins.list_modules
- gm4.plugins.manifest.create
- gm4.plugins.resource_pack.setup
- broadcast: null
extend: beet.yaml
require:
- gm4.plugins.output
- gm4.plugins.player_heads
- gm4.plugins.resource_pack
- beet.contrib.model_merging
- beet.contrib.optifine
- beet.contrib.babelbox
- gm4_guidebook.generate_guidebooks.load_page_data
- gm4_guidebook.generate_guidebooks.load_custom_recipes
- gm4.plugins.test.load_tests
pipeline:
- gm4.plugins.write_mcmeta
meta:
gm4_dev: True
mecha:
formatting:
layout: preserve
nbt_compact: True
cmd_compact: True
babelbox:
load:
- assets/translations.csv
- translations.csv
namespace: gm4_translations
unicode_escape: True
dialect: excel
model_merging:
predicate_order: [custom_model_data]
- extend: beet.yaml
directory: resource_pack
pipeline:
- resource_pack.dev_description
- gm4.plugins.resource_pack.pad_model_overrides
- gm4.plugins.resource_pack.link_resource_pack
- gm4.plugins.output.resource_pack
- gm4.plugins.resource_pack.dump_registry
- gm4.plugins.finished

meta:
autosave:
link: false
gm4_dev: True

ignore:
- gm4/skin_cache.json
- gm4/modeldata_registry.json
Loading

0 comments on commit 2b4c9bd

Please sign in to comment.