From 80a45b4ccc4a4659cd05af830c8c1527d6b018b8 Mon Sep 17 00:00:00 2001 From: covers1624 Date: Mon, 16 Oct 2023 23:53:58 +1030 Subject: [PATCH] Port to 1.20.1 Mostly complete. --- build.gradle | 26 +- build.properties | 8 +- gradle/wrapper/gradle-wrapper.jar | Bin 59821 -> 62076 bytes gradle/wrapper/gradle-wrapper.properties | 3 +- gradlew | 276 ++++++++------ gradlew.bat | 15 +- settings.gradle | 11 + .../282910bf22b00ad347f56cc1dfb6815b78e846d9 | 56 ++- .../3cae2902f4522543fae07a36318d5ed427f71d39 | 2 +- ... 53c252d47159caa2725cf9322152d4faa8adddc2} | 2 +- .../enderstorage/models/item/ender_pouch.json | 347 +++++++++++++++++- .../item/ender_pouch_button_left_black.json | 6 + .../item/ender_pouch_button_left_blue.json | 6 + .../item/ender_pouch_button_left_brown.json | 6 + .../item/ender_pouch_button_left_cyan.json | 6 + .../item/ender_pouch_button_left_gray.json | 6 + .../item/ender_pouch_button_left_green.json | 6 + .../ender_pouch_button_left_light_blue.json | 6 + .../ender_pouch_button_left_light_gray.json | 6 + .../item/ender_pouch_button_left_lime.json | 6 + .../item/ender_pouch_button_left_magenta.json | 6 + .../item/ender_pouch_button_left_orange.json | 6 + .../item/ender_pouch_button_left_pink.json | 6 + .../item/ender_pouch_button_left_purple.json | 6 + .../item/ender_pouch_button_left_red.json | 6 + .../item/ender_pouch_button_left_white.json | 6 + .../item/ender_pouch_button_left_yellow.json | 6 + .../item/ender_pouch_button_middle_black.json | 6 + .../item/ender_pouch_button_middle_blue.json | 6 + .../item/ender_pouch_button_middle_brown.json | 6 + .../item/ender_pouch_button_middle_cyan.json | 6 + .../item/ender_pouch_button_middle_gray.json | 6 + .../item/ender_pouch_button_middle_green.json | 6 + .../ender_pouch_button_middle_light_blue.json | 6 + .../ender_pouch_button_middle_light_gray.json | 6 + .../item/ender_pouch_button_middle_lime.json | 6 + .../ender_pouch_button_middle_magenta.json | 6 + .../ender_pouch_button_middle_orange.json | 6 + .../item/ender_pouch_button_middle_pink.json | 6 + .../ender_pouch_button_middle_purple.json | 6 + .../item/ender_pouch_button_middle_red.json | 6 + .../item/ender_pouch_button_middle_white.json | 6 + .../ender_pouch_button_middle_yellow.json | 6 + .../item/ender_pouch_button_right_black.json | 6 + .../item/ender_pouch_button_right_blue.json | 6 + .../item/ender_pouch_button_right_brown.json | 6 + .../item/ender_pouch_button_right_cyan.json | 6 + .../item/ender_pouch_button_right_gray.json | 6 + .../item/ender_pouch_button_right_green.json | 6 + .../ender_pouch_button_right_light_blue.json | 6 + .../ender_pouch_button_right_light_gray.json | 6 + .../item/ender_pouch_button_right_lime.json | 6 + .../ender_pouch_button_right_magenta.json | 6 + .../item/ender_pouch_button_right_orange.json | 6 + .../item/ender_pouch_button_right_pink.json | 6 + .../item/ender_pouch_button_right_purple.json | 6 + .../item/ender_pouch_button_right_red.json | 6 + .../item/ender_pouch_button_right_white.json | 6 + .../item/ender_pouch_button_right_yellow.json | 6 + .../models/item/ender_pouch_closed.json | 6 + .../models/item/ender_pouch_open.json | 6 + .../models/item/ender_pouch_owned_closed.json | 6 + .../models/item/ender_pouch_owned_open.json | 6 + .../enderstorage/block/BlockEnderStorage.java | 6 +- .../enderstorage/client/EnderPouchBakery.java | 73 ---- .../enderstorage/client/Shaders.java | 2 +- .../client/gui/GuiEnderItemStorage.java | 30 +- .../client/render/RenderCustomEndPortal.java | 17 +- .../render/item/EnderChestItemRender.java | 5 +- .../render/item/EnderTankItemRender.java | 5 +- .../render/tile/RenderTileEnderChest.java | 4 +- .../enderstorage/init/ClientInit.java | 51 ++- .../enderstorage/init/DataGenerators.java | 71 +++- .../init/EnderStorageModContent.java | 16 +- .../enderstorage/item/ItemEnderPouch.java | 15 +- .../enderstorage/item/ItemEnderStorage.java | 4 +- .../enderstorage/recipe/CreateRecipe.java | 5 +- .../enderstorage/recipe/ReColourRecipe.java | 5 +- .../enderstorage/recipe/RecipeBase.java | 11 +- .../enderstorage/tile/TileEnderChest.java | 4 +- .../enderstorage/tile/TileEnderTank.java | 6 +- src/main/resources/META-INF/mods.toml | 2 +- .../pouch/buttons/left/black.png | Bin .../pouch/buttons/left/blue.png | Bin .../pouch/buttons/left/brown.png | Bin .../pouch/buttons/left/cyan.png | Bin .../pouch/buttons/left/gray.png | Bin .../pouch/buttons/left/green.png | Bin .../pouch/buttons/left/light_blue.png | Bin .../pouch/buttons/left/light_gray.png | Bin .../pouch/buttons/left/lime.png | Bin .../pouch/buttons/left/magenta.png | Bin .../pouch/buttons/left/orange.png | Bin .../pouch/buttons/left/pink.png | Bin .../pouch/buttons/left/purple.png | Bin .../pouch/buttons/left/red.png | Bin .../pouch/buttons/left/white.png | Bin .../pouch/buttons/left/yellow.png | Bin .../pouch/buttons/middle/black.png | Bin .../pouch/buttons/middle/blue.png | Bin .../pouch/buttons/middle/brown.png | Bin .../pouch/buttons/middle/cyan.png | Bin .../pouch/buttons/middle/gray.png | Bin .../pouch/buttons/middle/green.png | Bin .../pouch/buttons/middle/light_blue.png | Bin .../pouch/buttons/middle/light_gray.png | Bin .../pouch/buttons/middle/lime.png | Bin .../pouch/buttons/middle/magenta.png | Bin .../pouch/buttons/middle/orange.png | Bin .../pouch/buttons/middle/pink.png | Bin .../pouch/buttons/middle/purple.png | Bin .../pouch/buttons/middle/red.png | Bin .../pouch/buttons/middle/white.png | Bin .../pouch/buttons/middle/yellow.png | Bin .../pouch/buttons/right/black.png | Bin .../pouch/buttons/right/blue.png | Bin .../pouch/buttons/right/brown.png | Bin .../pouch/buttons/right/cyan.png | Bin .../pouch/buttons/right/gray.png | Bin .../pouch/buttons/right/green.png | Bin .../pouch/buttons/right/light_blue.png | Bin .../pouch/buttons/right/light_gray.png | Bin .../pouch/buttons/right/lime.png | Bin .../pouch/buttons/right/magenta.png | Bin .../pouch/buttons/right/orange.png | Bin .../pouch/buttons/right/pink.png | Bin .../pouch/buttons/right/purple.png | Bin .../pouch/buttons/right/red.png | Bin .../pouch/buttons/right/white.png | Bin .../pouch/buttons/right/yellow.png | Bin .../textures/{items => item}/pouch/closed.png | Bin .../textures/{items => item}/pouch/open.png | Bin .../{items => item}/pouch/owned_closed.png | Bin .../{items => item}/pouch/owned_open.png | Bin 134 files changed, 1088 insertions(+), 302 deletions(-) create mode 100644 settings.gradle rename src/main/generated/.cache/{75bcd4dba6ca7d365462b0ec45e291d1056349c4 => 53c252d47159caa2725cf9322152d4faa8adddc2} (51%) create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_black.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_blue.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_brown.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_cyan.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_gray.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_green.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_light_blue.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_light_gray.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_lime.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_magenta.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_orange.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_pink.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_purple.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_red.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_white.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_yellow.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_black.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_blue.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_brown.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_cyan.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_gray.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_green.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_light_blue.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_light_gray.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_lime.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_magenta.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_orange.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_pink.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_purple.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_red.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_white.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_yellow.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_black.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_blue.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_brown.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_cyan.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_gray.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_green.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_light_blue.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_light_gray.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_lime.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_magenta.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_orange.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_pink.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_purple.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_red.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_white.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_yellow.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_closed.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_open.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_owned_closed.json create mode 100644 src/main/generated/assets/enderstorage/models/item/ender_pouch_owned_open.json delete mode 100644 src/main/java/codechicken/enderstorage/client/EnderPouchBakery.java rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/black.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/blue.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/brown.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/cyan.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/gray.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/green.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/light_blue.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/light_gray.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/lime.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/magenta.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/orange.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/pink.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/purple.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/red.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/white.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/left/yellow.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/black.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/blue.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/brown.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/cyan.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/gray.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/green.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/light_blue.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/light_gray.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/lime.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/magenta.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/orange.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/pink.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/purple.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/red.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/white.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/middle/yellow.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/black.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/blue.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/brown.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/cyan.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/gray.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/green.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/light_blue.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/light_gray.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/lime.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/magenta.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/orange.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/pink.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/purple.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/red.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/white.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/buttons/right/yellow.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/closed.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/open.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/owned_closed.png (100%) rename src/main/resources/assets/enderstorage/textures/{items => item}/pouch/owned_open.png (100%) diff --git a/build.gradle b/build.gradle index 7426b48..6beb1a8 100644 --- a/build.gradle +++ b/build.gradle @@ -1,27 +1,15 @@ -buildscript { - repositories { - mavenLocal() - mavenCentral() - maven { url "https://maven.minecraftforge.net/" } - } - dependencies { - classpath 'net.minecraftforge.gradle:ForgeGradle:5.1.+' - } -} - plugins { id 'java' id 'maven-publish' id "net.covers1624.signing" version '1.1.4' + id 'net.neoforged.gradle' version '[6.0.18,6.2)' } -apply plugin: 'net.minecraftforge.gradle' +java.toolchain.languageVersion = JavaLanguageVersion.of(17) group = "codechicken" archivesBaseName = "EnderStorage" -java.toolchain.languageVersion = JavaLanguageVersion.of(17) - sourceSets.main.resources.srcDirs += "src/main/generated" file('build.properties').withReader { @@ -77,12 +65,12 @@ minecraft { repositories { mavenLocal() maven { url = "https://chickenbones.net/maven" } - maven { url = "https://dvs1.progwml6.com/files/maven" } + maven { url = "https://maven.blamejared.com/" } } dependencies { - minecraft "net.minecraftforge:forge:${config.mc_version}-${config.forge_version}" - implementation fg.deobf("codechicken:CodeChickenLib:${config.mc_version}-${config.ccl_version}:universal") + minecraft "net.neoforged:forge:${config.mc_version}-${config.forge_version}" + implementation fg.deobf("codechicken:CodeChickenLib:1.19.2-${config.ccl_version}:universal") implementation fg.deobf("mezz.jei:jei-${config.mc_version}-forge:${config.jei_version}") } @@ -116,7 +104,7 @@ processResources { jar { finalizedBy 'reobfJar' - classifier = 'universal' + archiveClassifier = 'universal' manifest { attributes 'Specification-Title': archivesBaseName attributes 'Specification-Vendor': 'covers1624' @@ -132,7 +120,7 @@ jar { task srcJar(type: Jar) { build.dependsOn it from sourceSets.main.allSource - classifier = 'sources' + archiveClassifier = 'sources' from file("LICENSE.txt") } diff --git a/build.properties b/build.properties index 54f70c5..0251d70 100644 --- a/build.properties +++ b/build.properties @@ -1,6 +1,6 @@ -mc_version=1.19.2 -forge_version=43.1.1 +mc_version=1.20.1 +forge_version=47.1.65 ccl_version=4.3.0.+ ccl_version_max=5.0.0 -jei_version=11.2.0.246 -mod_version=2.10.1 +jei_version=15.2.0.27 +mod_version=2.11.0 diff --git a/gradle/wrapper/gradle-wrapper.jar b/gradle/wrapper/gradle-wrapper.jar index 41d9927a4d4fb3f96a785543079b8df6723c946b..c1962a79e29d3e0ab67b14947c167a862655af9b 100644 GIT binary patch delta 40199 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 delta 37942 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 \(.*\)$'` - if expr "$link" : '/.*' > /dev/null; then - PRG="$link" - else - PRG=`dirname "$PRG"`"/$link" - fi +app_path=$0 + +# Need this for daisy-chained symlinks. +while + APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path + [ -h "$app_path" ] +do + ls=$( ls -ld "$app_path" ) + link=${ls#*' -> '} + case $link in #( + /*) app_path=$link ;; #( + *) app_path=$APP_HOME$link ;; + esac done -SAVED="`pwd`" -cd "`dirname \"$PRG\"`/" >/dev/null -APP_HOME="`pwd -P`" -cd "$SAVED" >/dev/null -APP_NAME="Gradle" -APP_BASE_NAME=`basename "$0"` - -# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. -DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' +# This is normally unused +# shellcheck disable=SC2034 +APP_BASE_NAME=${0##*/} +APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit # Use the maximum available, or set MAX_FD != -1 to use that value. -MAX_FD="maximum" +MAX_FD=maximum warn () { echo "$*" -} +} >&2 die () { echo echo "$*" echo exit 1 -} +} >&2 # OS specific support (must be 'true' or 'false'). cygwin=false msys=false darwin=false nonstop=false -case "`uname`" in - CYGWIN* ) - cygwin=true - ;; - Darwin* ) - darwin=true - ;; - MINGW* ) - msys=true - ;; - NONSTOP* ) - nonstop=true - ;; +case "$( uname )" in #( + CYGWIN* ) cygwin=true ;; #( + Darwin* ) darwin=true ;; #( + MSYS* | MINGW* ) msys=true ;; #( + NONSTOP* ) nonstop=true ;; esac CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar @@ -87,9 +118,9 @@ CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar if [ -n "$JAVA_HOME" ] ; then if [ -x "$JAVA_HOME/jre/sh/java" ] ; then # IBM's JDK on AIX uses strange locations for the executables - JAVACMD="$JAVA_HOME/jre/sh/java" + JAVACMD=$JAVA_HOME/jre/sh/java else - JAVACMD="$JAVA_HOME/bin/java" + JAVACMD=$JAVA_HOME/bin/java fi if [ ! -x "$JAVACMD" ] ; then die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME @@ -98,7 +129,7 @@ Please set the JAVA_HOME variable in your environment to match the location of your Java installation." fi else - JAVACMD="java" + JAVACMD=java which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. Please set the JAVA_HOME variable in your environment to match the @@ -106,80 +137,109 @@ location of your Java installation." fi # Increase the maximum file descriptors if we can. -if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then - MAX_FD_LIMIT=`ulimit -H -n` - if [ $? -eq 0 ] ; then - if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then - MAX_FD="$MAX_FD_LIMIT" - fi - ulimit -n $MAX_FD - if [ $? -ne 0 ] ; then - warn "Could not set maximum file descriptor limit: $MAX_FD" - fi - else - warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" - fi +if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then + case $MAX_FD in #( + max*) + # In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked. + # shellcheck disable=SC3045 + MAX_FD=$( ulimit -H -n ) || + warn "Could not query maximum file descriptor limit" + esac + case $MAX_FD in #( + '' | soft) :;; #( + *) + # In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked. + # shellcheck disable=SC3045 + ulimit -n "$MAX_FD" || + warn "Could not set maximum file descriptor limit to $MAX_FD" + esac fi -# For Darwin, add options to specify how the application appears in the dock -if $darwin; then - GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" -fi +# Collect all arguments for the java command, stacking in reverse order: +# * args from the command line +# * the main class name +# * -classpath +# * -D...appname settings +# * --module-path (only if needed) +# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables. # For Cygwin or MSYS, switch paths to Windows format before running java -if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then - APP_HOME=`cygpath --path --mixed "$APP_HOME"` - CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` - - JAVACMD=`cygpath --unix "$JAVACMD"` - - # We build the pattern for arguments to be converted via cygpath - ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` - SEP="" - for dir in $ROOTDIRSRAW ; do - ROOTDIRS="$ROOTDIRS$SEP$dir" - SEP="|" - done - OURCYGPATTERN="(^($ROOTDIRS))" - # Add a user-defined pattern to the cygpath arguments - if [ "$GRADLE_CYGPATTERN" != "" ] ; then - OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" - fi +if "$cygwin" || "$msys" ; then + APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) + CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) + + JAVACMD=$( cygpath --unix "$JAVACMD" ) + # Now convert the arguments - kludge to limit ourselves to /bin/sh - i=0 - for arg in "$@" ; do - CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` - CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option - - if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition - eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` - else - eval `echo args$i`="\"$arg\"" + for arg do + if + case $arg in #( + -*) false ;; # don't mess with options #( + /?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath + [ -e "$t" ] ;; #( + *) false ;; + esac + then + arg=$( cygpath --path --ignore --mixed "$arg" ) fi - i=`expr $i + 1` + # Roll the args list around exactly as many times as the number of + # args, so each arg winds up back in the position where it started, but + # possibly modified. + # + # NB: a `for` loop captures its iteration list before it begins, so + # changing the positional parameters here affects neither the number of + # iterations, nor the values presented in `arg`. + shift # remove old arg + set -- "$@" "$arg" # push replacement arg done - case $i in - 0) set -- ;; - 1) set -- "$args0" ;; - 2) set -- "$args0" "$args1" ;; - 3) set -- "$args0" "$args1" "$args2" ;; - 4) set -- "$args0" "$args1" "$args2" "$args3" ;; - 5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; - 6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; - 7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; - 8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; - 9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; - esac fi -# Escape application args -save () { - for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done - echo " " -} -APP_ARGS=`save "$@"` -# Collect all arguments for the java command, following the shell quoting and substitution rules -eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS" +# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' + +# Collect all arguments for the java command; +# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of +# shell script including quotes and variable substitutions, so put them in +# double quotes to make sure that they get re-expanded; and +# * put everything else in single quotes, so that it's not re-expanded. + +set -- \ + "-Dorg.gradle.appname=$APP_BASE_NAME" \ + -classpath "$CLASSPATH" \ + org.gradle.wrapper.GradleWrapperMain \ + "$@" + +# Stop when "xargs" is not available. +if ! command -v xargs >/dev/null 2>&1 +then + die "xargs is not available" +fi + +# Use "xargs" to parse quoted args. +# +# With -n1 it outputs one arg per line, with the quotes and backslashes removed. +# +# In Bash we could simply go: +# +# readarray ARGS < <( xargs -n1 <<<"$var" ) && +# set -- "${ARGS[@]}" "$@" +# +# but POSIX shell has neither arrays nor command substitution, so instead we +# post-process each arg (as a line of input to sed) to backslash-escape any +# character that might be a shell metacharacter, then use eval to reverse +# that process (while maintaining the separation between arguments), and wrap +# the whole thing up as a single "set" statement. +# +# This will of course break if any of these variables contains a newline or +# an unmatched quote. +# + +eval "set -- $( + printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" | + xargs -n1 | + sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' | + tr '\n' ' ' + )" '"$@"' exec "$JAVACMD" "$@" diff --git a/gradlew.bat b/gradlew.bat index 107acd3..93e3f59 100644 --- a/gradlew.bat +++ b/gradlew.bat @@ -14,7 +14,7 @@ @rem limitations under the License. @rem -@if "%DEBUG%" == "" @echo off +@if "%DEBUG%"=="" @echo off @rem ########################################################################## @rem @rem Gradle startup script for Windows @@ -25,7 +25,8 @@ if "%OS%"=="Windows_NT" setlocal set DIRNAME=%~dp0 -if "%DIRNAME%" == "" set DIRNAME=. +if "%DIRNAME%"=="" set DIRNAME=. +@rem This is normally unused set APP_BASE_NAME=%~n0 set APP_HOME=%DIRNAME% @@ -40,7 +41,7 @@ if defined JAVA_HOME goto findJavaFromJavaHome set JAVA_EXE=java.exe %JAVA_EXE% -version >NUL 2>&1 -if "%ERRORLEVEL%" == "0" goto execute +if %ERRORLEVEL% equ 0 goto execute echo. echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. @@ -75,13 +76,15 @@ set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar :end @rem End local scope for the variables with windows NT shell -if "%ERRORLEVEL%"=="0" goto mainEnd +if %ERRORLEVEL% equ 0 goto mainEnd :fail rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of rem the _cmd.exe /c_ return code! -if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 -exit /b 1 +set EXIT_CODE=%ERRORLEVEL% +if %EXIT_CODE% equ 0 set EXIT_CODE=1 +if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE% +exit /b %EXIT_CODE% :mainEnd if "%OS%"=="Windows_NT" endlocal diff --git a/settings.gradle b/settings.gradle new file mode 100644 index 0000000..7c4df18 --- /dev/null +++ b/settings.gradle @@ -0,0 +1,11 @@ +pluginManagement { + repositories { + gradlePluginPortal() + maven { + name = 'NeoForged' + url = 'https://maven.neoforged.net/releases' + } + } +} + +rootProject.name = 'EnderStorage' diff --git a/src/main/generated/.cache/282910bf22b00ad347f56cc1dfb6815b78e846d9 b/src/main/generated/.cache/282910bf22b00ad347f56cc1dfb6815b78e846d9 index ca13641..22af882 100644 --- a/src/main/generated/.cache/282910bf22b00ad347f56cc1dfb6815b78e846d9 +++ b/src/main/generated/.cache/282910bf22b00ad347f56cc1dfb6815b78e846d9 @@ -1,4 +1,56 @@ -// 1.19.2 2022-08-25T19:11:42.399211076 EnderStorage Item models +// 1.20.1 2023-09-08T23:52:29.3559643 EnderStorage Item models a163c9ce1e63e428f3fa804b66e491b455f18540 assets/enderstorage/models/item/ender_chest.json -a163c9ce1e63e428f3fa804b66e491b455f18540 assets/enderstorage/models/item/ender_pouch.json +e56e5f4371f82507db4f3edcd5514ff7a7c9b91c assets/enderstorage/models/item/ender_pouch.json +d85340997885467c20e49061f74a4858f9a276fd assets/enderstorage/models/item/ender_pouch_button_left_black.json +7e07a5bb75528acb4596870d5e8420545f848888 assets/enderstorage/models/item/ender_pouch_button_left_blue.json +9ba8d58cfa07266d7f941829cd29bcdc1f889f2e assets/enderstorage/models/item/ender_pouch_button_left_brown.json +ae29c7450647265a9c7f0ff07baf06e573df3e1b assets/enderstorage/models/item/ender_pouch_button_left_cyan.json +0bae0abe6a19fe6426e06fce6f635a339f292aea assets/enderstorage/models/item/ender_pouch_button_left_gray.json +68508de7b1433a03590fb48052aa939e9d7ef7ba assets/enderstorage/models/item/ender_pouch_button_left_green.json +fb37cc876ba2daa64181107a1b5fc88636f5b25e assets/enderstorage/models/item/ender_pouch_button_left_light_blue.json +e56b61acf5f109eccc0247dd30b6ea6aa5425169 assets/enderstorage/models/item/ender_pouch_button_left_light_gray.json +df4aa3277de16aa9229055405a710049d5147948 assets/enderstorage/models/item/ender_pouch_button_left_lime.json +0b05fbcaba35bdbd11705d3a911304f42cc08a7c assets/enderstorage/models/item/ender_pouch_button_left_magenta.json +cf155a4b5328e7e985529648d6c3ca7cf96cc5c3 assets/enderstorage/models/item/ender_pouch_button_left_orange.json +e709c3b2417e069e48566b1a400212c35e726d38 assets/enderstorage/models/item/ender_pouch_button_left_pink.json +c94ae073ceb74495d10bc64f3790b141f686d069 assets/enderstorage/models/item/ender_pouch_button_left_purple.json +f20570ea965c501e0c2db1b4b21897768e1ea98d assets/enderstorage/models/item/ender_pouch_button_left_red.json +4fa420edf72a3e76a0e4f9372459ce22a046c213 assets/enderstorage/models/item/ender_pouch_button_left_white.json +4a627837eaf71af214d24040529be7b5ca9f52ab assets/enderstorage/models/item/ender_pouch_button_left_yellow.json +a36cb8e8e50a95d480130bf089afa14f06dfd431 assets/enderstorage/models/item/ender_pouch_button_middle_black.json +c1e6ab2e28ba662c73dcd83b1da11fdb2d1b5188 assets/enderstorage/models/item/ender_pouch_button_middle_blue.json +c5e4fe646dbb3f3686b2b4c62bc74f538e888c96 assets/enderstorage/models/item/ender_pouch_button_middle_brown.json +84ed513eb12f71f7b33aa4b1ab2b0a41f9a311fc assets/enderstorage/models/item/ender_pouch_button_middle_cyan.json +24e35f004fdd1f5734492f291b77b61c52496164 assets/enderstorage/models/item/ender_pouch_button_middle_gray.json +8936ae49cad86d81719abef9790c42c46d678704 assets/enderstorage/models/item/ender_pouch_button_middle_green.json +cbf4cde1d31296215d534fcd1deb01dc1cb3706a assets/enderstorage/models/item/ender_pouch_button_middle_light_blue.json +135c1b09d882c711e41b711432fbd2b24c9062eb assets/enderstorage/models/item/ender_pouch_button_middle_light_gray.json +d6ef6c867d7a6d608088f0b26b78ffcb29797612 assets/enderstorage/models/item/ender_pouch_button_middle_lime.json +e3a0dc7d67cba57b5c6cd45ab6cc188d45272763 assets/enderstorage/models/item/ender_pouch_button_middle_magenta.json +24eb1f3eb178c1cd5619d11480b65b1b61948505 assets/enderstorage/models/item/ender_pouch_button_middle_orange.json +ce49f986c5261fd959c5f4893059afe4db439528 assets/enderstorage/models/item/ender_pouch_button_middle_pink.json +96a75d37944398a89cf903011dff73b007778a88 assets/enderstorage/models/item/ender_pouch_button_middle_purple.json +1542a7dad4f290fd2e6b0b96b00aa12c499e82f5 assets/enderstorage/models/item/ender_pouch_button_middle_red.json +6bef062d2143f22b7c755844764883bcf30a9b71 assets/enderstorage/models/item/ender_pouch_button_middle_white.json +7707574198d4a2c1fe2396e05bc235bd06f8694e assets/enderstorage/models/item/ender_pouch_button_middle_yellow.json +53f3ca761620deb019264957b577b6ddcb63ec0b assets/enderstorage/models/item/ender_pouch_button_right_black.json +5367df26aa79aac9de1eb31bf0e4194e953baa3f assets/enderstorage/models/item/ender_pouch_button_right_blue.json +c670f1dfb94a097b4d1ba73defe77665182e7704 assets/enderstorage/models/item/ender_pouch_button_right_brown.json +0d9172c44aead9f4a453ef04da1f441e8d9c8056 assets/enderstorage/models/item/ender_pouch_button_right_cyan.json +2f57fa614a12c1b40666472fb17e435907ca07f9 assets/enderstorage/models/item/ender_pouch_button_right_gray.json +2fca4fee9aff00230c15150cb5a6a87dde46c7db assets/enderstorage/models/item/ender_pouch_button_right_green.json +1a1b9f0868fecc4b4f272bd3bef9c2a469f23497 assets/enderstorage/models/item/ender_pouch_button_right_light_blue.json +2507c0a4b464eca8a7d281a8b2b2fa5459d8ea4b assets/enderstorage/models/item/ender_pouch_button_right_light_gray.json +822d51cd201234893046880c06e2cca45935b14d assets/enderstorage/models/item/ender_pouch_button_right_lime.json +091b55afb1f5622d46b99fe7004b173bf717eafa assets/enderstorage/models/item/ender_pouch_button_right_magenta.json +5eb9d6f12300b44ac14cd038afe8c9ab2faf1355 assets/enderstorage/models/item/ender_pouch_button_right_orange.json +825a4fc6b7a6106104f42d0aeb692761484a422d assets/enderstorage/models/item/ender_pouch_button_right_pink.json +a5ad7b32224d2bd0ddfd87d1ec054c4f32ab2010 assets/enderstorage/models/item/ender_pouch_button_right_purple.json +480c7b301c1d83feb74235d85a5537c48aaeb7a7 assets/enderstorage/models/item/ender_pouch_button_right_red.json +c23266a51bb6eb50d6ee13cb45658690466b7b29 assets/enderstorage/models/item/ender_pouch_button_right_white.json +44b16aafa3e4588c3fb1f07f9aa9179685ff8bb9 assets/enderstorage/models/item/ender_pouch_button_right_yellow.json +37965b95c13cb39b499b7925c76a2fbbeee31bce assets/enderstorage/models/item/ender_pouch_closed.json +4f79a4c9572e3d1f01b41505c777038ea2c72b85 assets/enderstorage/models/item/ender_pouch_open.json +bca93d7cdab91d358aa60130acba6f555663a3b2 assets/enderstorage/models/item/ender_pouch_owned_closed.json +9cc9edaa2b3e3572f77a34d3ec878c8e0ebd4f75 assets/enderstorage/models/item/ender_pouch_owned_open.json a163c9ce1e63e428f3fa804b66e491b455f18540 assets/enderstorage/models/item/ender_tank.json diff --git a/src/main/generated/.cache/3cae2902f4522543fae07a36318d5ed427f71d39 b/src/main/generated/.cache/3cae2902f4522543fae07a36318d5ed427f71d39 index 63f5949..17f7ce8 100644 --- a/src/main/generated/.cache/3cae2902f4522543fae07a36318d5ed427f71d39 +++ b/src/main/generated/.cache/3cae2902f4522543fae07a36318d5ed427f71d39 @@ -1,4 +1,4 @@ -// 1.19.2 2022-08-25T19:11:42.398014174 EnderStorage BlockStates +// 1.20.1 2023-09-08T20:40:41.873187702 EnderStorage BlockStates 31ae921e4029b7a18bfc63f7cee5e5bf4ce92828 assets/enderstorage/blockstates/ender_chest.json 31ae921e4029b7a18bfc63f7cee5e5bf4ce92828 assets/enderstorage/blockstates/ender_tank.json f105c225def5c2a406cab5c02f6b08774a37e9de assets/enderstorage/models/block/dummy.json diff --git a/src/main/generated/.cache/75bcd4dba6ca7d365462b0ec45e291d1056349c4 b/src/main/generated/.cache/53c252d47159caa2725cf9322152d4faa8adddc2 similarity index 51% rename from src/main/generated/.cache/75bcd4dba6ca7d365462b0ec45e291d1056349c4 rename to src/main/generated/.cache/53c252d47159caa2725cf9322152d4faa8adddc2 index 9e04473..5359baf 100644 --- a/src/main/generated/.cache/75bcd4dba6ca7d365462b0ec45e291d1056349c4 +++ b/src/main/generated/.cache/53c252d47159caa2725cf9322152d4faa8adddc2 @@ -1,2 +1,2 @@ -// 1.19.2 2022-08-25T19:11:42.399052525 Tags for minecraft:block +// 1.20.1 2023-09-08T20:40:41.873013063 Tags for minecraft:block mod id enderstorage 5b2130f55986594660c630dadb50eede58d67c12 data/minecraft/tags/blocks/mineable/pickaxe.json diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch.json index 1bcbb31..6659e91 100644 --- a/src/main/generated/assets/enderstorage/models/item/ender_pouch.json +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch.json @@ -1,3 +1,348 @@ { - "parent": "minecraft:item/generated" + "parent": "minecraft:item/generated", + "children": { + "bag": { + "parent": "minecraft:item/generated", + "overrides": [ + { + "model": "enderstorage:item/ender_pouch_closed", + "predicate": { + "enderstorage:open": 0.0, + "enderstorage:owned": 0.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_open", + "predicate": { + "enderstorage:open": 1.0, + "enderstorage:owned": 0.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_owned_closed", + "predicate": { + "enderstorage:open": 0.0, + "enderstorage:owned": 1.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_owned_open", + "predicate": { + "enderstorage:open": 1.0, + "enderstorage:owned": 1.0 + } + } + ] + }, + "left": { + "parent": "minecraft:item/generated", + "overrides": [ + { + "model": "enderstorage:item/ender_pouch_button_left_white", + "predicate": { + "enderstorage:left": 0.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_orange", + "predicate": { + "enderstorage:left": 1.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_magenta", + "predicate": { + "enderstorage:left": 2.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_light_blue", + "predicate": { + "enderstorage:left": 3.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_yellow", + "predicate": { + "enderstorage:left": 4.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_lime", + "predicate": { + "enderstorage:left": 5.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_pink", + "predicate": { + "enderstorage:left": 6.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_gray", + "predicate": { + "enderstorage:left": 7.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_light_gray", + "predicate": { + "enderstorage:left": 8.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_cyan", + "predicate": { + "enderstorage:left": 9.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_purple", + "predicate": { + "enderstorage:left": 10.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_blue", + "predicate": { + "enderstorage:left": 11.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_brown", + "predicate": { + "enderstorage:left": 12.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_green", + "predicate": { + "enderstorage:left": 13.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_red", + "predicate": { + "enderstorage:left": 14.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_left_black", + "predicate": { + "enderstorage:left": 15.0 + } + } + ] + }, + "middle": { + "parent": "minecraft:item/generated", + "overrides": [ + { + "model": "enderstorage:item/ender_pouch_button_middle_white", + "predicate": { + "enderstorage:middle": 0.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_orange", + "predicate": { + "enderstorage:middle": 1.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_magenta", + "predicate": { + "enderstorage:middle": 2.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_light_blue", + "predicate": { + "enderstorage:middle": 3.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_yellow", + "predicate": { + "enderstorage:middle": 4.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_lime", + "predicate": { + "enderstorage:middle": 5.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_pink", + "predicate": { + "enderstorage:middle": 6.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_gray", + "predicate": { + "enderstorage:middle": 7.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_light_gray", + "predicate": { + "enderstorage:middle": 8.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_cyan", + "predicate": { + "enderstorage:middle": 9.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_purple", + "predicate": { + "enderstorage:middle": 10.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_blue", + "predicate": { + "enderstorage:middle": 11.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_brown", + "predicate": { + "enderstorage:middle": 12.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_green", + "predicate": { + "enderstorage:middle": 13.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_red", + "predicate": { + "enderstorage:middle": 14.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_middle_black", + "predicate": { + "enderstorage:middle": 15.0 + } + } + ] + }, + "right": { + "parent": "minecraft:item/generated", + "overrides": [ + { + "model": "enderstorage:item/ender_pouch_button_right_white", + "predicate": { + "enderstorage:right": 0.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_orange", + "predicate": { + "enderstorage:right": 1.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_magenta", + "predicate": { + "enderstorage:right": 2.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_light_blue", + "predicate": { + "enderstorage:right": 3.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_yellow", + "predicate": { + "enderstorage:right": 4.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_lime", + "predicate": { + "enderstorage:right": 5.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_pink", + "predicate": { + "enderstorage:right": 6.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_gray", + "predicate": { + "enderstorage:right": 7.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_light_gray", + "predicate": { + "enderstorage:right": 8.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_cyan", + "predicate": { + "enderstorage:right": 9.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_purple", + "predicate": { + "enderstorage:right": 10.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_blue", + "predicate": { + "enderstorage:right": 11.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_brown", + "predicate": { + "enderstorage:right": 12.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_green", + "predicate": { + "enderstorage:right": 13.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_red", + "predicate": { + "enderstorage:right": 14.0 + } + }, + { + "model": "enderstorage:item/ender_pouch_button_right_black", + "predicate": { + "enderstorage:right": 15.0 + } + } + ] + } + }, + "item_render_order": [ + "bag", + "left", + "middle", + "right" + ], + "loader": "codechickenlib:item_composite" } \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_black.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_black.json new file mode 100644 index 0000000..7a8801b --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_black.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/black" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_blue.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_blue.json new file mode 100644 index 0000000..85493b6 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_blue.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/blue" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_brown.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_brown.json new file mode 100644 index 0000000..30718e1 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_brown.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/brown" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_cyan.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_cyan.json new file mode 100644 index 0000000..3906ce4 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_cyan.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/cyan" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_gray.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_gray.json new file mode 100644 index 0000000..62265ef --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_gray.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/gray" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_green.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_green.json new file mode 100644 index 0000000..16a49b1 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_green.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/green" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_light_blue.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_light_blue.json new file mode 100644 index 0000000..e95da72 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_light_blue.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/light_blue" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_light_gray.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_light_gray.json new file mode 100644 index 0000000..9a9f624 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_light_gray.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/light_gray" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_lime.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_lime.json new file mode 100644 index 0000000..e37cf6f --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_lime.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/lime" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_magenta.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_magenta.json new file mode 100644 index 0000000..d241ca2 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_magenta.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/magenta" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_orange.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_orange.json new file mode 100644 index 0000000..f4b32f9 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_orange.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/orange" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_pink.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_pink.json new file mode 100644 index 0000000..470cfe9 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_pink.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/pink" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_purple.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_purple.json new file mode 100644 index 0000000..4984fa5 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_purple.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/purple" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_red.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_red.json new file mode 100644 index 0000000..4d4d4b0 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_red.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/red" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_white.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_white.json new file mode 100644 index 0000000..3077430 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_white.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/white" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_yellow.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_yellow.json new file mode 100644 index 0000000..9d156e4 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_left_yellow.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/left/yellow" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_black.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_black.json new file mode 100644 index 0000000..02e9a8d --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_black.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/black" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_blue.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_blue.json new file mode 100644 index 0000000..91a9de7 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_blue.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/blue" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_brown.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_brown.json new file mode 100644 index 0000000..925aff7 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_brown.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/brown" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_cyan.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_cyan.json new file mode 100644 index 0000000..0b408a7 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_cyan.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/cyan" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_gray.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_gray.json new file mode 100644 index 0000000..663f6d7 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_gray.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/gray" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_green.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_green.json new file mode 100644 index 0000000..ca2f709 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_green.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/green" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_light_blue.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_light_blue.json new file mode 100644 index 0000000..13b8baf --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_light_blue.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/light_blue" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_light_gray.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_light_gray.json new file mode 100644 index 0000000..2abbd93 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_light_gray.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/light_gray" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_lime.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_lime.json new file mode 100644 index 0000000..f538e96 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_lime.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/lime" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_magenta.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_magenta.json new file mode 100644 index 0000000..94ce6bd --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_magenta.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/magenta" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_orange.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_orange.json new file mode 100644 index 0000000..596ee77 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_orange.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/orange" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_pink.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_pink.json new file mode 100644 index 0000000..8f7ce3d --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_pink.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/pink" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_purple.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_purple.json new file mode 100644 index 0000000..77c46c6 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_purple.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/purple" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_red.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_red.json new file mode 100644 index 0000000..de62f5c --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_red.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/red" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_white.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_white.json new file mode 100644 index 0000000..5c10158 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_white.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/white" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_yellow.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_yellow.json new file mode 100644 index 0000000..40fa95e --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_middle_yellow.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/middle/yellow" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_black.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_black.json new file mode 100644 index 0000000..da55dc5 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_black.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/black" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_blue.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_blue.json new file mode 100644 index 0000000..ccf9acf --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_blue.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/blue" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_brown.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_brown.json new file mode 100644 index 0000000..b9a6869 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_brown.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/brown" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_cyan.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_cyan.json new file mode 100644 index 0000000..61b4476 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_cyan.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/cyan" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_gray.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_gray.json new file mode 100644 index 0000000..42ebca1 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_gray.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/gray" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_green.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_green.json new file mode 100644 index 0000000..510fb87 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_green.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/green" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_light_blue.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_light_blue.json new file mode 100644 index 0000000..7aa977e --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_light_blue.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/light_blue" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_light_gray.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_light_gray.json new file mode 100644 index 0000000..b1602bf --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_light_gray.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/light_gray" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_lime.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_lime.json new file mode 100644 index 0000000..0c17688 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_lime.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/lime" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_magenta.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_magenta.json new file mode 100644 index 0000000..18640cc --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_magenta.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/magenta" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_orange.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_orange.json new file mode 100644 index 0000000..22efede --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_orange.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/orange" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_pink.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_pink.json new file mode 100644 index 0000000..49cf908 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_pink.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/pink" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_purple.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_purple.json new file mode 100644 index 0000000..c7e8257 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_purple.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/purple" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_red.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_red.json new file mode 100644 index 0000000..ffa572b --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_red.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/red" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_white.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_white.json new file mode 100644 index 0000000..bf34892 --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_white.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/white" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_yellow.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_yellow.json new file mode 100644 index 0000000..c85fc6d --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_button_right_yellow.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/buttons/right/yellow" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_closed.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_closed.json new file mode 100644 index 0000000..2c6414f --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_closed.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/closed" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_open.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_open.json new file mode 100644 index 0000000..4ec969e --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_open.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/open" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_owned_closed.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_owned_closed.json new file mode 100644 index 0000000..2b178aa --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_owned_closed.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/owned_closed" + } +} \ No newline at end of file diff --git a/src/main/generated/assets/enderstorage/models/item/ender_pouch_owned_open.json b/src/main/generated/assets/enderstorage/models/item/ender_pouch_owned_open.json new file mode 100644 index 0000000..567b73c --- /dev/null +++ b/src/main/generated/assets/enderstorage/models/item/ender_pouch_owned_open.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "enderstorage:item/pouch/owned_open" + } +} \ No newline at end of file diff --git a/src/main/java/codechicken/enderstorage/block/BlockEnderStorage.java b/src/main/java/codechicken/enderstorage/block/BlockEnderStorage.java index bd05cff..c63bda0 100644 --- a/src/main/java/codechicken/enderstorage/block/BlockEnderStorage.java +++ b/src/main/java/codechicken/enderstorage/block/BlockEnderStorage.java @@ -4,8 +4,8 @@ import codechicken.enderstorage.config.EnderStorageConfig; import codechicken.enderstorage.tile.TileFrequencyOwner; import codechicken.lib.colour.EnumColour; -import codechicken.lib.raytracer.SubHitBlockHitResult; import codechicken.lib.raytracer.RayTracer; +import codechicken.lib.raytracer.SubHitBlockHitResult; import codechicken.lib.util.ItemUtils; import net.minecraft.core.BlockPos; import net.minecraft.core.Direction; @@ -22,7 +22,7 @@ import net.minecraft.world.level.block.state.BlockBehaviour; import net.minecraft.world.level.block.state.BlockState; import net.minecraft.world.level.material.FluidState; -import net.minecraft.world.level.storage.loot.LootContext; +import net.minecraft.world.level.storage.loot.LootParams; import net.minecraft.world.level.storage.loot.parameters.LootContextParams; import net.minecraft.world.phys.BlockHitResult; import net.minecraft.world.phys.HitResult; @@ -58,7 +58,7 @@ public void playerDestroy(Level worldIn, Player player, BlockPos pos, BlockState } @Override - public List getDrops(BlockState state, LootContext.Builder builder) { + public List getDrops(BlockState state, LootParams.Builder builder) { List drops = new ArrayList<>(); TileFrequencyOwner tile = (TileFrequencyOwner) builder.getOptionalParameter(LootContextParams.BLOCK_ENTITY); if (tile != null) { diff --git a/src/main/java/codechicken/enderstorage/client/EnderPouchBakery.java b/src/main/java/codechicken/enderstorage/client/EnderPouchBakery.java deleted file mode 100644 index 3d158fa..0000000 --- a/src/main/java/codechicken/enderstorage/client/EnderPouchBakery.java +++ /dev/null @@ -1,73 +0,0 @@ -package codechicken.enderstorage.client; - -import codechicken.enderstorage.api.Frequency; -import codechicken.enderstorage.manager.EnderStorageManager; -import codechicken.enderstorage.storage.EnderItemStorage; -import codechicken.lib.colour.EnumColour; -import codechicken.lib.model.ItemQuadBakery; -import codechicken.lib.model.bakedmodels.ModelProperties.PerspectiveProperties; -import codechicken.lib.model.bakery.generation.IItemBakery; -import codechicken.lib.texture.AtlasRegistrar; -import codechicken.lib.texture.IIconRegister; -import net.minecraft.client.renderer.block.model.BakedQuad; -import net.minecraft.client.renderer.texture.TextureAtlasSprite; -import net.minecraft.core.Direction; -import net.minecraft.world.item.ItemStack; - -import java.util.ArrayList; -import java.util.List; - -/** - * Created by covers1624 on 17/02/2017. - */ -public class EnderPouchBakery implements IItemBakery, IIconRegister { - - public static final EnderPouchBakery INSTANCE = new EnderPouchBakery(); - - // [Ownded(0/1)][Open(0/1)] - public static TextureAtlasSprite[][] BAG_TEXTURES; - // [Button(0/1/2)(l/m/r)][Colour(EnumColour.ordinal)] - public static TextureAtlasSprite[][] COLOUR_TEXTURES; - - @Override - public List bakeItemQuads(Direction face, ItemStack stack) { - List quads = new ArrayList<>(); - if (face == null) { - Frequency frequency = Frequency.readFromStack(stack); - boolean open = EnderStorageManager.instance(true).getStorage(frequency, EnderItemStorage.TYPE).openCount() > 0; - TextureAtlasSprite bagTexture = BAG_TEXTURES[frequency.hasOwner() ? 1 : 0][open ? 1 : 0]; - TextureAtlasSprite leftButton = COLOUR_TEXTURES[0][frequency.getLeft().getWoolMeta()]; - TextureAtlasSprite middleButton = COLOUR_TEXTURES[1][frequency.getMiddle().getWoolMeta()]; - TextureAtlasSprite rightButton = COLOUR_TEXTURES[2][frequency.getRight().getWoolMeta()]; - quads.addAll(ItemQuadBakery.bakeItem(bagTexture, leftButton, middleButton, rightButton)); - } - return quads; - } - - @Override - public PerspectiveProperties getModelProperties(ItemStack stack) { - return PerspectiveProperties.DEFAULT_ITEM; - } - - @Override - public void registerIcons(AtlasRegistrar registrar) { - String POUCH_PREFIX = "enderstorage:items/pouch/"; - String BUTTONS_PREFIX = POUCH_PREFIX + "buttons/"; - String[] position_prefixes = { "left/", "middle/", "right/" }; - - BAG_TEXTURES = new TextureAtlasSprite[2][2]; - COLOUR_TEXTURES = new TextureAtlasSprite[3][16]; - - registrar.registerSprite(POUCH_PREFIX + "closed", e -> BAG_TEXTURES[0][0] = e); - registrar.registerSprite(POUCH_PREFIX + "open", e -> BAG_TEXTURES[0][1] = e); - registrar.registerSprite(POUCH_PREFIX + "owned_closed", e -> BAG_TEXTURES[1][0] = e); - registrar.registerSprite(POUCH_PREFIX + "owned_open", e -> BAG_TEXTURES[1][1] = e); - for (int i = 0; i < 3; i++) { - int finalI = i; - for (EnumColour colour : EnumColour.values()) { - registrar.registerSprite(BUTTONS_PREFIX + position_prefixes[i] + colour.getSerializedName(), e -> COLOUR_TEXTURES[finalI][colour.ordinal()] = e); - } - } - - } -} diff --git a/src/main/java/codechicken/enderstorage/client/Shaders.java b/src/main/java/codechicken/enderstorage/client/Shaders.java index 7ac92d6..6087cc8 100644 --- a/src/main/java/codechicken/enderstorage/client/Shaders.java +++ b/src/main/java/codechicken/enderstorage/client/Shaders.java @@ -30,7 +30,7 @@ public static void init() { } private static void onRegisterShaders(RegisterShadersEvent event) { - event.registerShader(CCShaderInstance.create(event.getResourceManager(), new ResourceLocation(MOD_ID, "starfield"), DefaultVertexFormat.POSITION), e -> { + event.registerShader(CCShaderInstance.create(event.getResourceProvider(), new ResourceLocation(MOD_ID, "starfield"), DefaultVertexFormat.POSITION), e -> { starfieldShader = (CCShaderInstance) e; starfieldTime = starfieldShader.getUniform("Time"); starfieldYaw = starfieldShader.getUniform("Yaw"); diff --git a/src/main/java/codechicken/enderstorage/client/gui/GuiEnderItemStorage.java b/src/main/java/codechicken/enderstorage/client/gui/GuiEnderItemStorage.java index 9e26ff7..fd7a44a 100644 --- a/src/main/java/codechicken/enderstorage/client/gui/GuiEnderItemStorage.java +++ b/src/main/java/codechicken/enderstorage/client/gui/GuiEnderItemStorage.java @@ -3,6 +3,7 @@ import codechicken.enderstorage.container.ContainerEnderItemStorage; import com.mojang.blaze3d.systems.RenderSystem; import com.mojang.blaze3d.vertex.PoseStack; +import net.minecraft.client.gui.GuiGraphics; import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen; import net.minecraft.client.renderer.GameRenderer; import net.minecraft.network.chat.Component; @@ -13,7 +14,6 @@ public class GuiEnderItemStorage extends AbstractContainerScreen Shaders.starfieldShader)) .setTextureState(new RenderStateShard.TextureStateShard(TheEndPortalRenderer.END_PORTAL_LOCATION, false, false)) @@ -51,4 +52,18 @@ public void render(Matrix4 mat, MultiBufferSource source) { cons.vertex(surfaceX2, surfaceY, surfaceZ2).endVertex(); cons.vertex(surfaceX2, surfaceY, surfaceZ1).endVertex(); } + + public void render(PoseStack pStack, MultiBufferSource source) { + LocalPlayer localPlayer = Minecraft.getInstance().player; + + Shaders.starfieldTime.glUniform1f((float) ClientUtils.getRenderTime()); + Shaders.starfieldYaw.glUniform1f((float) (localPlayer.getYRot() * MathHelper.torad)); + Shaders.starfieldPitch.glUniform1f((float) -(localPlayer.getXRot() * MathHelper.torad)); + + VertexConsumer cons = source.getBuffer(STARFIELD_TYPE); + cons.vertex(pStack.last().pose(), (float) surfaceX1, (float) surfaceY, (float) surfaceZ1).endVertex(); + cons.vertex(pStack.last().pose(), (float) surfaceX1, (float) surfaceY, (float) surfaceZ2).endVertex(); + cons.vertex(pStack.last().pose(), (float) surfaceX2, (float) surfaceY, (float) surfaceZ2).endVertex(); + cons.vertex(pStack.last().pose(), (float) surfaceX2, (float) surfaceY, (float) surfaceZ1).endVertex(); + } } diff --git a/src/main/java/codechicken/enderstorage/client/render/item/EnderChestItemRender.java b/src/main/java/codechicken/enderstorage/client/render/item/EnderChestItemRender.java index c8fe941..ea598bd 100644 --- a/src/main/java/codechicken/enderstorage/client/render/item/EnderChestItemRender.java +++ b/src/main/java/codechicken/enderstorage/client/render/item/EnderChestItemRender.java @@ -8,8 +8,7 @@ import codechicken.lib.util.TransformUtils; import com.mojang.blaze3d.vertex.PoseStack; import net.minecraft.client.renderer.MultiBufferSource; -import net.minecraft.client.renderer.block.model.ItemTransforms.TransformType; -import net.minecraft.client.resources.model.ModelState; +import net.minecraft.world.item.ItemDisplayContext; import net.minecraft.world.item.ItemStack; /** @@ -20,7 +19,7 @@ public class EnderChestItemRender implements IItemRenderer { private final RenderTileEnderChest tileRender = new RenderTileEnderChest(null); @Override - public void renderItem(ItemStack stack, TransformType transformType, PoseStack poseStack, MultiBufferSource source, int packedLight, int packedOverlay) { + public void renderItem(ItemStack stack, ItemDisplayContext context, PoseStack poseStack, MultiBufferSource source, int packedLight, int packedOverlay) { CCRenderState ccrs = CCRenderState.instance(); ccrs.reset(); Frequency freq = Frequency.readFromStack(stack); diff --git a/src/main/java/codechicken/enderstorage/client/render/item/EnderTankItemRender.java b/src/main/java/codechicken/enderstorage/client/render/item/EnderTankItemRender.java index bc917e3..8b3a980 100644 --- a/src/main/java/codechicken/enderstorage/client/render/item/EnderTankItemRender.java +++ b/src/main/java/codechicken/enderstorage/client/render/item/EnderTankItemRender.java @@ -11,8 +11,7 @@ import codechicken.lib.vec.Matrix4; import com.mojang.blaze3d.vertex.PoseStack; import net.minecraft.client.renderer.MultiBufferSource; -import net.minecraft.client.renderer.block.model.ItemTransforms.TransformType; -import net.minecraft.client.resources.model.ModelState; +import net.minecraft.world.item.ItemDisplayContext; import net.minecraft.world.item.ItemStack; import net.minecraftforge.fluids.FluidStack; @@ -22,7 +21,7 @@ public class EnderTankItemRender implements IItemRenderer { @Override - public void renderItem(ItemStack stack, TransformType transformType, PoseStack poseStack, MultiBufferSource source, int packedLight, int packedOverlay) { + public void renderItem(ItemStack stack, ItemDisplayContext context, PoseStack poseStack, MultiBufferSource source, int packedLight, int packedOverlay) { CCRenderState ccrs = CCRenderState.instance(); ccrs.reset(); ccrs.brightness = packedLight; diff --git a/src/main/java/codechicken/enderstorage/client/render/tile/RenderTileEnderChest.java b/src/main/java/codechicken/enderstorage/client/render/tile/RenderTileEnderChest.java index 474036e..e5b3242 100644 --- a/src/main/java/codechicken/enderstorage/client/render/tile/RenderTileEnderChest.java +++ b/src/main/java/codechicken/enderstorage/client/render/tile/RenderTileEnderChest.java @@ -17,7 +17,6 @@ import codechicken.lib.vec.uv.UVTranslation; import com.mojang.blaze3d.vertex.PoseStack; import com.mojang.blaze3d.vertex.VertexConsumer; -import com.mojang.math.Quaternion; import net.minecraft.client.model.geom.ModelPart; import net.minecraft.client.model.geom.PartPose; import net.minecraft.client.model.geom.builders.CubeListBuilder; @@ -29,6 +28,7 @@ import net.minecraft.client.renderer.blockentity.BlockEntityRenderer; import net.minecraft.client.renderer.blockentity.BlockEntityRendererProvider; import net.minecraft.resources.ResourceLocation; +import org.joml.Quaternionf; /** * Created by covers1624 on 4/12/2016. @@ -83,7 +83,7 @@ public void renderChest(CCRenderState ccrs, PoseStack pose, MultiBufferSource so pose.translate(0, 1.0, 1.0); pose.scale(1.0F, -1.0F, -1.0F); pose.translate(0.5, 0.5, 0.5); - pose.mulPose(new Quaternion(0, rotation * 90, 0, true)); + pose.mulPose(new Quaternionf().rotateXYZ(0, (float) (rotation * 90F * MathHelper.torad), 0)); pose.translate(-0.5, -0.5, -0.5); VertexConsumer chestCons = source.getBuffer(chestType); lid.xRot = lidAngle; diff --git a/src/main/java/codechicken/enderstorage/init/ClientInit.java b/src/main/java/codechicken/enderstorage/init/ClientInit.java index c422976..924d930 100644 --- a/src/main/java/codechicken/enderstorage/init/ClientInit.java +++ b/src/main/java/codechicken/enderstorage/init/ClientInit.java @@ -1,7 +1,6 @@ package codechicken.enderstorage.init; import codechicken.enderstorage.api.Frequency; -import codechicken.enderstorage.client.EnderPouchBakery; import codechicken.enderstorage.client.Shaders; import codechicken.enderstorage.client.gui.GuiEnderItemStorage; import codechicken.enderstorage.client.render.entity.TankLayerRenderer; @@ -13,19 +12,22 @@ import codechicken.enderstorage.manager.EnderStorageManager; import codechicken.enderstorage.storage.EnderItemStorage; import codechicken.lib.model.ModelRegistryHelper; -import codechicken.lib.model.bakery.CCBakeryModel; -import codechicken.lib.model.bakery.ModelBakery; -import codechicken.lib.texture.SpriteRegistryHelper; import net.covers1624.quack.util.CrashLock; import net.minecraft.client.gui.screens.MenuScreens; import net.minecraft.client.renderer.blockentity.BlockEntityRenderers; import net.minecraft.client.renderer.entity.LivingEntityRenderer; +import net.minecraft.client.renderer.item.ClampedItemPropertyFunction; +import net.minecraft.client.renderer.item.ItemProperties; import net.minecraft.client.resources.model.ModelResourceLocation; +import net.minecraft.resources.ResourceLocation; import net.minecraftforge.client.event.EntityRenderersEvent; +import net.minecraftforge.client.event.ModelEvent; +import net.minecraftforge.client.event.RegisterColorHandlersEvent; import net.minecraftforge.eventbus.api.IEventBus; import net.minecraftforge.fml.event.lifecycle.FMLClientSetupEvent; import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext; +import static codechicken.enderstorage.EnderStorage.MOD_ID; import static codechicken.enderstorage.init.EnderStorageModContent.*; /** @@ -35,15 +37,12 @@ public class ClientInit { private static final CrashLock LOCK = new CrashLock("Already Initialized."); - public static final SpriteRegistryHelper spriteHelper = new SpriteRegistryHelper(); public static final ModelRegistryHelper modelHelper = new ModelRegistryHelper(); public static void init() { LOCK.lock(); IEventBus bus = FMLJavaModLoadingContext.get().getModEventBus(); - spriteHelper.addIIconRegister(EnderPouchBakery.INSTANCE); - bus.addListener(ClientInit::onRegisterRenderers); bus.addListener(ClientInit::onAddRenderLayers); bus.addListener(ClientInit::onClientSetupEvent); @@ -69,15 +68,39 @@ private static void onAddRenderLayers(EntityRenderersEvent.AddLayers event) { private static void onClientSetupEvent(FMLClientSetupEvent event) { MenuScreens.register(ENDER_ITEM_STORAGE.get(), GuiEnderItemStorage::new); - ModelResourceLocation invLocation = new ModelResourceLocation(ENDER_POUCH.getId(), "inventory"); - modelHelper.register(invLocation, new CCBakeryModel()); - ModelBakery.registerItemKeyGenerator(ENDER_POUCH.get(), stack -> { - Frequency frequency = Frequency.readFromStack(stack); - boolean open = EnderStorageManager.instance(true).getStorage(frequency, EnderItemStorage.TYPE).openCount() > 0; - return ModelBakery.defaultItemKeyGenerator.generateKey(stack) + "|" + frequency.toModelLoc() + "|" + open; - }); + event.enqueueWork(ClientInit::registerPredicates); modelHelper.register(new ModelResourceLocation(ENDER_CHEST_ITEM.getId(), "inventory"), new EnderChestItemRender()); modelHelper.register(new ModelResourceLocation(ENDER_TANK_ITEM.getId(), "inventory"), new EnderTankItemRender()); } + + private static void registerPredicates() { + ItemProperties.register( + ENDER_POUCH.get(), + new ResourceLocation(MOD_ID, "owned"), + (ClampedItemPropertyFunction) (pStack, pLevel, pEntity, pSeed) -> Frequency.readFromStack(pStack).hasOwner() ? 1 : 0 + ); + ItemProperties.register( + ENDER_POUCH.get(), + new ResourceLocation(MOD_ID, "open"), + (ClampedItemPropertyFunction) (pStack, pLevel, pEntity, pSeed) -> EnderStorageManager.instance(true).getStorage(Frequency.readFromStack(pStack), EnderItemStorage.TYPE).openCount() + ); + ItemProperties.register( + ENDER_POUCH.get(), + new ResourceLocation(MOD_ID, "left"), + (pStack, pLevel, pEntity, pSeed) -> Frequency.readFromStack(pStack).getLeft().ordinal() + ); + ItemProperties.register( + ENDER_POUCH.get(), + new ResourceLocation(MOD_ID, "middle"), + (pStack, pLevel, pEntity, pSeed) -> Frequency.readFromStack(pStack).getMiddle().ordinal() + ); + ItemProperties.register( + ENDER_POUCH.get(), + new ResourceLocation(MOD_ID, "right"), + (pStack, pLevel, pEntity, pSeed) -> Frequency.readFromStack(pStack).getRight().ordinal() + ); + } + + } diff --git a/src/main/java/codechicken/enderstorage/init/DataGenerators.java b/src/main/java/codechicken/enderstorage/init/DataGenerators.java index 7ca81f4..217835c 100644 --- a/src/main/java/codechicken/enderstorage/init/DataGenerators.java +++ b/src/main/java/codechicken/enderstorage/init/DataGenerators.java @@ -1,11 +1,14 @@ package codechicken.enderstorage.init; +import codechicken.lib.colour.EnumColour; import codechicken.lib.datagen.ItemModelProvider; +import net.minecraft.core.HolderLookup; import net.minecraft.data.DataGenerator; -import net.minecraft.data.tags.BlockTagsProvider; +import net.minecraft.data.PackOutput; import net.minecraft.tags.BlockTags; import net.minecraftforge.client.model.generators.BlockStateProvider; import net.minecraftforge.client.model.generators.ModelFile; +import net.minecraftforge.common.data.BlockTagsProvider; import net.minecraftforge.common.data.ExistingFileHelper; import net.minecraftforge.data.event.GatherDataEvent; import net.minecraftforge.eventbus.api.SubscribeEvent; @@ -13,6 +16,7 @@ import org.jetbrains.annotations.Nullable; import javax.annotation.Nonnull; +import java.util.concurrent.CompletableFuture; import static codechicken.enderstorage.EnderStorage.MOD_ID; import static codechicken.enderstorage.init.EnderStorageModContent.*; @@ -26,23 +30,66 @@ public class DataGenerators { @SubscribeEvent public static void gatherDataGenerators(GatherDataEvent event) { DataGenerator gen = event.getGenerator(); + PackOutput output = gen.getPackOutput(); ExistingFileHelper files = event.getExistingFileHelper(); - gen.addProvider(event.includeClient(), new BlockStates(gen, files)); - gen.addProvider(event.includeClient(), new ItemModels(gen, files)); - gen.addProvider(event.includeServer(), new BlockTagGen(gen, files)); + CompletableFuture lookupProvider = event.getLookupProvider(); + + gen.addProvider(event.includeClient(), new BlockStates(output, files)); + gen.addProvider(event.includeClient(), new ItemModels(output, files)); + gen.addProvider(event.includeServer(), new BlockTagGen(output, lookupProvider, files)); } private static class ItemModels extends ItemModelProvider { - public ItemModels(DataGenerator generator, ExistingFileHelper existingFileHelper) { - super(generator, MOD_ID, existingFileHelper); + public ItemModels(PackOutput output, ExistingFileHelper existingFileHelper) { + super(output, MOD_ID, existingFileHelper); } @Override protected void registerModels() { generated(ENDER_CHEST_ITEM).noTexture(); generated(ENDER_TANK_ITEM).noTexture(); - generated(ENDER_POUCH).noTexture(); + + CompositeLoaderBuilder bag = generated(ENDER_POUCH) + .noTexture() + .customLoader(CompositeLoaderBuilder::ccl) + .nested("bag", e -> { + e.parent(GENERATED).noTexture(); + e.override(o -> { + o.predicate(modLoc("open"), 0); + o.predicate(modLoc("owned"), 0); + o.model("ender_pouch_closed", m -> m.parent(GENERATED).texture("layer0", modLoc("item/pouch/closed"))); + }); + e.override(o -> { + o.predicate(modLoc("open"), 1); + o.predicate(modLoc("owned"), 0); + o.model("ender_pouch_open", m -> m.parent(GENERATED).texture("layer0", modLoc("item/pouch/open"))); + }); + e.override(o -> { + o.predicate(modLoc("open"), 0); + o.predicate(modLoc("owned"), 1); + o.model("ender_pouch_owned_closed", m -> m.parent(GENERATED).texture("layer0", modLoc("item/pouch/owned_closed"))); + }); + e.override(o -> { + o.predicate(modLoc("open"), 1); + o.predicate(modLoc("owned"), 1); + o.model("ender_pouch_owned_open", m -> m.parent(GENERATED).texture("layer0", modLoc("item/pouch/owned_open"))); + }); + }); + for (String side : new String[] { "left", "middle", "right" }) { + bag.nested(side, e -> { + e.parent(GENERATED).noTexture(); + for (EnumColour colour : EnumColour.values()) { + String col = colour.getSerializedName(); + e.override(o -> { + o.predicate(modLoc(side), colour.ordinal()); + o.model("ender_pouch_button_" + side + "_" + col, m -> { + m.parent(GENERATED).texture(modLoc("item/pouch/buttons/" + side + "/" + col)); + }); + }); + } + }); + } } @Override @@ -53,8 +100,8 @@ public String getName() { private static class BlockStates extends BlockStateProvider { - public BlockStates(DataGenerator gen, ExistingFileHelper exFileHelper) { - super(gen, MOD_ID, exFileHelper); + public BlockStates(PackOutput output, ExistingFileHelper exFileHelper) { + super(output, MOD_ID, exFileHelper); } @Nonnull @@ -75,12 +122,12 @@ protected void registerStatesAndModels() { private static class BlockTagGen extends BlockTagsProvider { - public BlockTagGen(DataGenerator gen, @Nullable ExistingFileHelper existingFileHelper) { - super(gen, MOD_ID, existingFileHelper); + public BlockTagGen(PackOutput output, CompletableFuture lookupProvider, @Nullable ExistingFileHelper existingFileHelper) { + super(output, lookupProvider, MOD_ID, existingFileHelper); } @Override - protected void addTags() { + protected void addTags(HolderLookup.Provider pProvider) { tag(BlockTags.MINEABLE_WITH_PICKAXE) .add(ENDER_CHEST_BLOCK.get()) .add(ENDER_TANK_BLOCK.get()); diff --git a/src/main/java/codechicken/enderstorage/init/EnderStorageModContent.java b/src/main/java/codechicken/enderstorage/init/EnderStorageModContent.java index fffc5da..8db4120 100644 --- a/src/main/java/codechicken/enderstorage/init/EnderStorageModContent.java +++ b/src/main/java/codechicken/enderstorage/init/EnderStorageModContent.java @@ -12,12 +12,14 @@ import codechicken.lib.inventory.container.ICCLContainerType; import net.covers1624.quack.util.CrashLock; import net.minecraft.world.inventory.MenuType; +import net.minecraft.world.item.CreativeModeTabs; import net.minecraft.world.item.Item; import net.minecraft.world.item.crafting.RecipeSerializer; import net.minecraft.world.level.block.Block; import net.minecraft.world.level.block.entity.BlockEntityType; import net.minecraft.world.level.block.state.BlockBehaviour; -import net.minecraft.world.level.material.Material; +import net.minecraft.world.level.material.MapColor; +import net.minecraftforge.event.BuildCreativeModeTabContentsEvent; import net.minecraftforge.eventbus.api.IEventBus; import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext; import net.minecraftforge.registries.DeferredRegister; @@ -38,7 +40,8 @@ public class EnderStorageModContent { private static final DeferredRegister> MENU_TYPES = DeferredRegister.create(ForgeRegistries.MENU_TYPES, MOD_ID); private static final DeferredRegister> RECIPE_SERIALIZERS = DeferredRegister.create(ForgeRegistries.RECIPE_SERIALIZERS, MOD_ID); - private static final BlockBehaviour.Properties blockProps = Block.Properties.of(Material.STONE) + private static final BlockBehaviour.Properties blockProps = Block.Properties.of() + .mapColor(MapColor.STONE) .strength(20, 100); public static final RegistryObject ENDER_CHEST_BLOCK = BLOCKS.register("ender_chest", () -> new BlockEnderChest(blockProps)); public static final RegistryObject ENDER_TANK_BLOCK = BLOCKS.register("ender_tank", () -> new BlockEnderTank(blockProps)); @@ -74,5 +77,14 @@ public static void init() { BLOCK_ENTITY_TYPES.register(bus); MENU_TYPES.register(bus); RECIPE_SERIALIZERS.register(bus); + bus.addListener(EnderStorageModContent::onCreativeTabBuild); + } + + private static void onCreativeTabBuild(BuildCreativeModeTabContentsEvent event) { + if (event.getTabKey() == CreativeModeTabs.BUILDING_BLOCKS) { + event.accept(ENDER_POUCH); + event.accept(ENDER_CHEST_BLOCK); + event.accept(ENDER_TANK_BLOCK); + } } } diff --git a/src/main/java/codechicken/enderstorage/item/ItemEnderPouch.java b/src/main/java/codechicken/enderstorage/item/ItemEnderPouch.java index d9322db..7aa45af 100644 --- a/src/main/java/codechicken/enderstorage/item/ItemEnderPouch.java +++ b/src/main/java/codechicken/enderstorage/item/ItemEnderPouch.java @@ -1,38 +1,31 @@ package codechicken.enderstorage.item; import codechicken.enderstorage.api.Frequency; -import codechicken.enderstorage.client.EnderPouchBakery; import codechicken.enderstorage.config.EnderStorageConfig; import codechicken.enderstorage.manager.EnderStorageManager; import codechicken.enderstorage.storage.EnderItemStorage; import codechicken.enderstorage.tile.TileEnderChest; -import codechicken.lib.model.bakery.IBakeryProvider; -import codechicken.lib.model.bakery.generation.IBakery; import net.minecraft.network.chat.Component; import net.minecraft.server.level.ServerPlayer; import net.minecraft.world.InteractionHand; import net.minecraft.world.InteractionResult; import net.minecraft.world.InteractionResultHolder; import net.minecraft.world.entity.player.Player; -import net.minecraft.world.item.CreativeModeTab; import net.minecraft.world.item.Item; import net.minecraft.world.item.ItemStack; import net.minecraft.world.item.TooltipFlag; import net.minecraft.world.item.context.UseOnContext; import net.minecraft.world.level.Level; import net.minecraft.world.level.block.entity.BlockEntity; -import net.minecraftforge.api.distmarker.Dist; -import net.minecraftforge.api.distmarker.OnlyIn; import javax.annotation.Nullable; import java.util.List; -public class ItemEnderPouch extends Item implements IBakeryProvider { +public class ItemEnderPouch extends Item { public ItemEnderPouch() { super(new Item.Properties() .stacksTo(1) - .tab(CreativeModeTab.TAB_TRANSPORTATION) ); } @@ -78,10 +71,4 @@ public InteractionResultHolder use(Level world, Player player, Intera } return new InteractionResultHolder<>(InteractionResult.SUCCESS, stack); } - - @Override - @OnlyIn (Dist.CLIENT) - public IBakery getBakery() { - return EnderPouchBakery.INSTANCE; - } } diff --git a/src/main/java/codechicken/enderstorage/item/ItemEnderStorage.java b/src/main/java/codechicken/enderstorage/item/ItemEnderStorage.java index ff50014..f1ffccb 100644 --- a/src/main/java/codechicken/enderstorage/item/ItemEnderStorage.java +++ b/src/main/java/codechicken/enderstorage/item/ItemEnderStorage.java @@ -19,9 +19,7 @@ public class ItemEnderStorage extends BlockItem { public ItemEnderStorage(Block block) { - super(block, new Properties() - .tab(CreativeModeTab.TAB_TRANSPORTATION) - ); + super(block, new Properties()); } public Frequency getFreq(ItemStack stack) { diff --git a/src/main/java/codechicken/enderstorage/recipe/CreateRecipe.java b/src/main/java/codechicken/enderstorage/recipe/CreateRecipe.java index f366a4f..654c919 100644 --- a/src/main/java/codechicken/enderstorage/recipe/CreateRecipe.java +++ b/src/main/java/codechicken/enderstorage/recipe/CreateRecipe.java @@ -5,6 +5,7 @@ import codechicken.lib.colour.EnumColour; import com.google.gson.JsonObject; import net.minecraft.core.NonNullList; +import net.minecraft.core.RegistryAccess; import net.minecraft.network.FriendlyByteBuf; import net.minecraft.resources.ResourceLocation; import net.minecraft.util.GsonHelper; @@ -29,7 +30,7 @@ public CreateRecipe(ResourceLocation id, String group, @Nonnull ItemStack result @Nonnull @Override - public ItemStack assemble(CraftingContainer inv) { + public ItemStack assemble(CraftingContainer inv, RegistryAccess pRegistryAccess) { EnumColour colour = EnumColour.WHITE; finish: for (int x = 0; x < 3; x++) { @@ -45,7 +46,7 @@ public ItemStack assemble(CraftingContainer inv) { } } Frequency frequency = new Frequency(colour, colour, colour); - return frequency.writeToStack(super.assemble(inv)); + return frequency.writeToStack(super.assemble(inv, pRegistryAccess)); } @Override diff --git a/src/main/java/codechicken/enderstorage/recipe/ReColourRecipe.java b/src/main/java/codechicken/enderstorage/recipe/ReColourRecipe.java index 1ef9a21..228ff92 100644 --- a/src/main/java/codechicken/enderstorage/recipe/ReColourRecipe.java +++ b/src/main/java/codechicken/enderstorage/recipe/ReColourRecipe.java @@ -6,6 +6,7 @@ import com.google.gson.JsonElement; import com.google.gson.JsonObject; import net.minecraft.core.NonNullList; +import net.minecraft.core.RegistryAccess; import net.minecraft.network.FriendlyByteBuf; import net.minecraft.resources.ResourceLocation; import net.minecraft.util.GsonHelper; @@ -32,7 +33,7 @@ public ReColourRecipe(ResourceLocation id, String group, @Nonnull ItemStack resu } @Override - public ItemStack assemble(CraftingContainer inv) { + public ItemStack assemble(CraftingContainer inv, RegistryAccess pRegistryAccess) { int foundRow = 0; Frequency currFreq = new Frequency(); for (int row = 1; row < 3; row++) {//Grab the input frequency, and store it's row. @@ -63,7 +64,7 @@ public ItemStack assemble(CraftingContainer inv) { currFreq.setMiddle(colours[1]); currFreq.setRight(colours[2]); - return currFreq.writeToStack(super.assemble(inv)); + return currFreq.writeToStack(super.assemble(inv, pRegistryAccess)); } @Override diff --git a/src/main/java/codechicken/enderstorage/recipe/RecipeBase.java b/src/main/java/codechicken/enderstorage/recipe/RecipeBase.java index 0aec863..2501e2d 100644 --- a/src/main/java/codechicken/enderstorage/recipe/RecipeBase.java +++ b/src/main/java/codechicken/enderstorage/recipe/RecipeBase.java @@ -1,9 +1,11 @@ package codechicken.enderstorage.recipe; import net.minecraft.core.NonNullList; +import net.minecraft.core.RegistryAccess; import net.minecraft.resources.ResourceLocation; import net.minecraft.world.inventory.CraftingContainer; import net.minecraft.world.item.ItemStack; +import net.minecraft.world.item.crafting.CraftingBookCategory; import net.minecraft.world.item.crafting.CraftingRecipe; import net.minecraft.world.item.crafting.Ingredient; import net.minecraft.world.level.Level; @@ -48,7 +50,7 @@ public boolean matches(CraftingContainer inv, Level worldIn) { } @Override - public ItemStack assemble(CraftingContainer inv) { + public ItemStack assemble(CraftingContainer inv, RegistryAccess pRegistryAccess) { return output.copy(); } @@ -73,7 +75,7 @@ public String getGroup() { } @Override - public ItemStack getResultItem() { + public ItemStack getResultItem(RegistryAccess pRegistryAccess) { return output; } @@ -86,4 +88,9 @@ public int getRecipeWidth() { public int getRecipeHeight() { return 3; } + + @Override + public CraftingBookCategory category() { + return CraftingBookCategory.MISC; + } } diff --git a/src/main/java/codechicken/enderstorage/tile/TileEnderChest.java b/src/main/java/codechicken/enderstorage/tile/TileEnderChest.java index 141a4fa..acd3f52 100644 --- a/src/main/java/codechicken/enderstorage/tile/TileEnderChest.java +++ b/src/main/java/codechicken/enderstorage/tile/TileEnderChest.java @@ -19,8 +19,8 @@ import net.minecraft.world.entity.player.Player; import net.minecraft.world.level.block.state.BlockState; import net.minecraftforge.common.capabilities.Capability; +import net.minecraftforge.common.capabilities.ForgeCapabilities; import net.minecraftforge.common.util.LazyOptional; -import net.minecraftforge.items.CapabilityItemHandler; import net.minecraftforge.items.IItemHandler; import net.minecraftforge.items.ItemHandlerHelper; import net.minecraftforge.items.wrapper.InvWrapper; @@ -152,7 +152,7 @@ public int comparatorInput() { @Nonnull @Override public LazyOptional getCapability(@Nonnull Capability cap, @Nullable Direction side) { - if (!remove && cap == CapabilityItemHandler.ITEM_HANDLER_CAPABILITY) { + if (!remove && cap == ForgeCapabilities.ITEM_HANDLER) { return itemHandler.cast(); } return super.getCapability(cap, side); diff --git a/src/main/java/codechicken/enderstorage/tile/TileEnderTank.java b/src/main/java/codechicken/enderstorage/tile/TileEnderTank.java index 22bc933..c00404f 100644 --- a/src/main/java/codechicken/enderstorage/tile/TileEnderTank.java +++ b/src/main/java/codechicken/enderstorage/tile/TileEnderTank.java @@ -20,11 +20,11 @@ import net.minecraft.world.level.Level; import net.minecraft.world.level.block.state.BlockState; import net.minecraftforge.common.capabilities.Capability; +import net.minecraftforge.common.capabilities.ForgeCapabilities; import net.minecraftforge.common.util.LazyOptional; import net.minecraftforge.fluids.FluidStack; import net.minecraftforge.fluids.FluidUtil; import net.minecraftforge.fluids.IFluidTank; -import net.minecraftforge.fluids.capability.CapabilityFluidHandler; import net.minecraftforge.fluids.capability.IFluidHandler; import net.minecraftforge.fluids.capability.templates.EmptyFluidHandler; @@ -71,7 +71,7 @@ public void onNeighborChange(BlockPos from) { private void ejectLiquid() { IFluidHandler source = getStorage(); for (Direction side : Direction.BY_3D_DATA) { - IFluidHandler dest = capCache.getCapabilityOr(CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY, side, EmptyFluidHandler.INSTANCE); + IFluidHandler dest = capCache.getCapabilityOr(ForgeCapabilities.FLUID_HANDLER, side, EmptyFluidHandler.INSTANCE); FluidStack drain = source.drain(100, IFluidHandler.FluidAction.SIMULATE); if (!drain.isEmpty()) { int qty = dest.fill(drain, IFluidHandler.FluidAction.EXECUTE); @@ -197,7 +197,7 @@ public int comparatorInput() { @Nonnull @Override public LazyOptional getCapability(@Nonnull Capability cap, @Nullable Direction side) { - if (!remove && cap == CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY) { + if (!remove && cap == ForgeCapabilities.FLUID_HANDLER) { return fluidHandler.cast(); } return super.getCapability(cap, side); diff --git a/src/main/resources/META-INF/mods.toml b/src/main/resources/META-INF/mods.toml index 7a6acd5..7b6424d 100644 --- a/src/main/resources/META-INF/mods.toml +++ b/src/main/resources/META-INF/mods.toml @@ -26,7 +26,7 @@ Stores your stuff in the END! [[dependencies.enderstorage]] modId="minecraft" mandatory=true - versionRange="[1.19.2]" + versionRange="[1.20.1]" ordering="NONE" side="BOTH" [[dependencies.enderstorage]] diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/black.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/black.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/black.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/black.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/blue.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/blue.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/blue.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/blue.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/brown.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/brown.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/brown.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/brown.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/cyan.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/cyan.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/cyan.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/cyan.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/gray.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/gray.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/gray.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/gray.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/green.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/green.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/green.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/green.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/light_blue.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/light_blue.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/light_blue.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/light_blue.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/light_gray.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/light_gray.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/light_gray.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/light_gray.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/lime.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/lime.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/lime.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/lime.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/magenta.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/magenta.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/magenta.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/magenta.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/orange.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/orange.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/orange.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/orange.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/pink.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/pink.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/pink.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/pink.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/purple.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/purple.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/purple.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/purple.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/red.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/red.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/red.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/red.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/white.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/white.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/white.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/white.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/yellow.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/yellow.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/left/yellow.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/left/yellow.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/black.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/black.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/black.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/black.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/blue.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/blue.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/blue.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/blue.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/brown.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/brown.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/brown.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/brown.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/cyan.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/cyan.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/cyan.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/cyan.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/gray.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/gray.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/gray.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/gray.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/green.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/green.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/green.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/green.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/light_blue.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/light_blue.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/light_blue.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/light_blue.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/light_gray.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/light_gray.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/light_gray.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/light_gray.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/lime.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/lime.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/lime.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/lime.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/magenta.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/magenta.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/magenta.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/magenta.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/orange.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/orange.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/orange.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/orange.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/pink.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/pink.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/pink.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/pink.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/purple.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/purple.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/purple.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/purple.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/red.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/red.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/red.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/red.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/white.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/white.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/white.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/white.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/yellow.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/yellow.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/middle/yellow.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/middle/yellow.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/black.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/black.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/black.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/black.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/blue.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/blue.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/blue.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/blue.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/brown.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/brown.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/brown.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/brown.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/cyan.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/cyan.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/cyan.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/cyan.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/gray.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/gray.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/gray.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/gray.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/green.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/green.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/green.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/green.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/light_blue.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/light_blue.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/light_blue.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/light_blue.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/light_gray.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/light_gray.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/light_gray.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/light_gray.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/lime.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/lime.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/lime.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/lime.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/magenta.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/magenta.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/magenta.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/magenta.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/orange.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/orange.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/orange.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/orange.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/pink.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/pink.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/pink.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/pink.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/purple.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/purple.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/purple.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/purple.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/red.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/red.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/red.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/red.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/white.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/white.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/white.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/white.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/yellow.png b/src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/yellow.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/buttons/right/yellow.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/buttons/right/yellow.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/closed.png b/src/main/resources/assets/enderstorage/textures/item/pouch/closed.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/closed.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/closed.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/open.png b/src/main/resources/assets/enderstorage/textures/item/pouch/open.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/open.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/open.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/owned_closed.png b/src/main/resources/assets/enderstorage/textures/item/pouch/owned_closed.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/owned_closed.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/owned_closed.png diff --git a/src/main/resources/assets/enderstorage/textures/items/pouch/owned_open.png b/src/main/resources/assets/enderstorage/textures/item/pouch/owned_open.png similarity index 100% rename from src/main/resources/assets/enderstorage/textures/items/pouch/owned_open.png rename to src/main/resources/assets/enderstorage/textures/item/pouch/owned_open.png