commit 9616bb49935b39c82f3cec5525b29e297e0d3442 Author: Glitchlabs Date: Mon Apr 27 22:57:58 2026 +0200 v1.0.0 diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..9e4b940 --- /dev/null +++ b/.gitignore @@ -0,0 +1,21 @@ +# MacOS DS_Store files +.DS_Store + +# Gradle cache folder +.gradle + +# Gradle build folder +build + +# IntelliJ +out/ +.idea +*.iml +# mpeltonen/sbt-idea plugin +.idea_modules/ + +# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml +hs_err_pid* + +# Common working directory +run diff --git a/build.gradle b/build.gradle new file mode 100644 index 0000000..9148150 --- /dev/null +++ b/build.gradle @@ -0,0 +1,167 @@ +plugins { + id 'java-library' + id 'maven-publish' + id 'idea' + id 'net.neoforged.moddev' version '2.0.141' +} + +version = mod_version +group = mod_group_id + +repositories { + mavenLocal() +} + +base { + archivesName = mod_id +} + +java.toolchain.languageVersion = JavaLanguageVersion.of(21) + +neoForge { + // Specify the version of NeoForge to use. + version = project.neo_version + + parchment { + mappingsVersion = project.parchment_mappings_version + minecraftVersion = project.parchment_minecraft_version + } + + // This line is optional. Access Transformers are automatically detected + // accessTransformers.add('src/main/resources/META-INF/accesstransformer.cfg') + + // Default run configurations. + // These can be tweaked, removed, or duplicated as needed. + runs { + client { + client() + + // Comma-separated list of namespaces to load gametests from. Empty = all namespaces. + systemProperty 'neoforge.enabledGameTestNamespaces', project.mod_id + } + + server { + server() + programArgument '--nogui' + systemProperty 'neoforge.enabledGameTestNamespaces', project.mod_id + } + + // This run config launches GameTestServer and runs all registered gametests, then exits. + // By default, the server will crash when no gametests are provided. + // The gametest system is also enabled by default for other run configs under the /test command. + gameTestServer { + type = "gameTestServer" + systemProperty 'neoforge.enabledGameTestNamespaces', project.mod_id + } + + data { + data() + + // example of overriding the workingDirectory set in configureEach above, uncomment if you want to use it + // gameDirectory = project.file('run-data') + + // Specify the modid for data generation, where to output the resulting resource, and where to look for existing resources. + programArguments.addAll '--mod', project.mod_id, '--all', '--output', file('src/generated/resources/').getAbsolutePath(), '--existing', file('src/main/resources/').getAbsolutePath() + } + + // applies to all the run configs above + configureEach { + // Recommended logging data for a userdev environment + // The markers can be added/remove as needed separated by commas. + // "SCAN": For mods scan. + // "REGISTRIES": For firing of registry events. + // "REGISTRYDUMP": For getting the contents of all registries. + systemProperty 'forge.logging.markers', 'REGISTRIES' + + // Recommended logging level for the console + // You can set various levels here. + // Please read: https://stackoverflow.com/questions/2031163/when-to-use-the-different-log-levels + logLevel = org.slf4j.event.Level.DEBUG + } + } + + mods { + // define mod <-> source bindings + // these are used to tell the game which sources are for which mod + // mostly optional in a single mod project + // but multi mod projects should define one per mod + "${mod_id}" { + sourceSet(sourceSets.main) + } + } +} + +// Include resources generated by data generators. +sourceSets.main.resources { srcDir 'src/generated/resources' } + + +dependencies { + // Example mod dependency with JEI + // The JEI API is declared for compile time use, while the full JEI artifact is used at runtime + // compileOnly "mezz.jei:jei-${mc_version}-common-api:${jei_version}" + // compileOnly "mezz.jei:jei-${mc_version}-forge-api:${jei_version}" + // runtimeOnly "mezz.jei:jei-${mc_version}-forge:${jei_version}" + + // Example mod dependency using a mod jar from ./libs with a flat dir repository + // This maps to ./libs/coolmod-${mc_version}-${coolmod_version}.jar + // The group id is ignored when searching -- in this case, it is "blank" + // implementation "blank:coolmod-${mc_version}:${coolmod_version}" + + // Example mod dependency using a file as dependency + // implementation files("libs/coolmod-${mc_version}-${coolmod_version}.jar") + + // Example project dependency using a sister or child project: + // implementation project(":myproject") + + // For more info: + // http://www.gradle.org/docs/current/userguide/artifact_dependencies_tutorial.html + // http://www.gradle.org/docs/current/userguide/dependency_management.html +} + +// This block of code expands all declared replace properties in the specified resource targets. +// A missing property will result in an error. Properties are expanded using ${} Groovy notation. +var generateModMetadata = tasks.register("generateModMetadata", ProcessResources) { + var replaceProperties = [minecraft_version : minecraft_version, + minecraft_version_range: minecraft_version_range, + neo_version : neo_version, + neo_version_range : neo_version_range, + loader_version_range : loader_version_range, + mod_id : mod_id, + mod_name : mod_name, + mod_license : mod_license, + mod_version : mod_version, + mod_authors : mod_authors, + mod_description : mod_description] + inputs.properties replaceProperties + expand replaceProperties + from "src/main/templates" + into "build/generated/sources/modMetadata" +} + +// Include the output of "generateModMetadata" as an input directory for the build +// this works with both building through Gradle and the IDE. +sourceSets.main.resources.srcDir generateModMetadata +// To avoid having to run "generateModMetadata" manually, make it run on every project reload +neoForge.ideSyncTask generateModMetadata + +// Example configuration to allow publishing using the maven-publish plugin +publishing { + publications { + register('mavenJava', MavenPublication) { + from components.java + } + } + repositories { + maven { + url "file://${project.projectDir}/repo" + } + } +} + +// IDEA no longer automatically downloads sources/javadoc jars for dependencies, so we need to explicitly enable the behavior. +idea { + module { + downloadSources = true + downloadJavadoc = true + } +} diff --git a/gradle.properties b/gradle.properties new file mode 100644 index 0000000..b84aaae --- /dev/null +++ b/gradle.properties @@ -0,0 +1,40 @@ +# Sets default memory used for gradle commands. Can be overridden by user or command line properties. +org.gradle.jvmargs=-Xmx2G +org.gradle.daemon=true +org.gradle.parallel=true +org.gradle.caching=true +org.gradle.configuration-cache=true +## Environment Properties +# You can find the latest versions here: https://projects.neoforged.net/neoforged/neoforge +# The Minecraft version must agree with the Neo version to get a valid artifact +minecraft_version=1.21.1 +# The Minecraft version range can use any release version of Minecraft as bounds. +# Snapshots, pre-releases, and release candidates are not guaranteed to sort properly +# as they do not follow standard versioning conventions. +minecraft_version_range=[1.21.1,1.22) +# The Neo version must agree with the Minecraft version to get a valid artifact +neo_version=21.1.228 +# The Neo version range can use any version of Neo as bounds +neo_version_range=[21,) +# The loader version range can only use the major version of FML as bounds +loader_version_range=[4,) +parchment_minecraft_version=1.21.11 +parchment_mappings_version=2025.12.20 +## Mod Properties +# The unique mod identifier for the mod. Must be lowercase in English locale. Must fit the regex [a-z][a-z0-9_]{1,63} +# Must match the String constant located in the main mod class annotated with @Mod. +mod_id=processed_obsidian +# The human-readable display name for the mod. +mod_name=Processed obsidian +# The license of the mod. Review your options at https://choosealicense.com/. All Rights Reserved is the default. +mod_license=All Rights Reserved +# The mod version. See https://semver.org/ +mod_version=1.0.0 +# The group ID for the mod. It is only important when publishing as an artifact to a Maven repository. +# This should match the base package used for the mod sources. +# See https://maven.apache.org/guides/mini/guide-naming-conventions.html +mod_group_id=ovh.glitchlabs +# The authors of the mod. This is a simple text string that is used for display purposes in the mod list. +mod_authors=Ian1337 +# The description of the mod. This is a simple multiline text string that is used for display purposes in the mod list. +mod_description= diff --git a/gradle/wrapper/gradle-wrapper.jar b/gradle/wrapper/gradle-wrapper.jar new file mode 100644 index 0000000..e644113 Binary files /dev/null and b/gradle/wrapper/gradle-wrapper.jar differ diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties new file mode 100644 index 0000000..a441313 --- /dev/null +++ b/gradle/wrapper/gradle-wrapper.properties @@ -0,0 +1,7 @@ +distributionBase=GRADLE_USER_HOME +distributionPath=wrapper/dists +distributionUrl=https\://services.gradle.org/distributions/gradle-8.8-bin.zip +networkTimeout=10000 +validateDistributionUrl=true +zipStoreBase=GRADLE_USER_HOME +zipStorePath=wrapper/dists diff --git a/gradlew b/gradlew new file mode 100755 index 0000000..b740cf1 --- /dev/null +++ b/gradlew @@ -0,0 +1,249 @@ +#!/bin/sh + +# +# Copyright © 2015-2021 the original authors. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# https://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# + +############################################################################## +# +# Gradle start up script for POSIX generated by Gradle. +# +# Important for running: +# +# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is +# noncompliant, but you have some other compliant shell such as ksh or +# bash, then to run this script, type that shell name before the whole +# command line, like: +# +# ksh Gradle +# +# Busybox and similar reduced shells will NOT work, because this script +# requires all of these POSIX shell features: +# * functions; +# * expansions «$var», «${var}», «${var:-default}», «${var+SET}», +# «${var#prefix}», «${var%suffix}», and «$( cmd )»; +# * compound commands having a testable exit status, especially «case»; +# * various built-in commands including «command», «set», and «ulimit». +# +# Important for patching: +# +# (2) This script targets any POSIX shell, so it avoids extensions provided +# by Bash, Ksh, etc; in particular arrays are avoided. +# +# The "traditional" practice of packing multiple parameters into a +# space-separated string is a well documented source of bugs and security +# problems, so this is (mostly) avoided, by progressively accumulating +# options in "$@", and eventually passing that to Java. +# +# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS, +# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly; +# see the in-line comments for details. +# +# There are tweaks for specific operating systems such as AIX, CygWin, +# Darwin, MinGW, and NonStop. +# +# (3) This script is generated from the Groovy template +# https://github.com/gradle/gradle/blob/HEAD/platforms/jvm/plugins-application/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt +# within the Gradle project. +# +# You can find Gradle at https://github.com/gradle/gradle/. +# +############################################################################## + +# Attempt to set APP_HOME + +# Resolve links: $0 may be a link +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 + +# This is normally unused +# shellcheck disable=SC2034 +APP_BASE_NAME=${0##*/} +# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036) +APP_HOME=$( cd "${APP_HOME:-./}" > /dev/null && pwd -P ) || exit + +# Use the maximum available, or set MAX_FD != -1 to use that value. +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 ;; #( + MSYS* | MINGW* ) msys=true ;; #( + NONSTOP* ) nonstop=true ;; +esac + +CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar + + +# Determine the Java command to use to start the JVM. +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 + else + JAVACMD=$JAVA_HOME/bin/java + fi + if [ ! -x "$JAVACMD" ] ; then + die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME + +Please set the JAVA_HOME variable in your environment to match the +location of your Java installation." + fi +else + JAVACMD=java + if ! command -v java >/dev/null 2>&1 + then + 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 +location of your Java installation." + fi +fi + +# Increase the maximum file descriptors if we can. +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=SC2039,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=SC2039,SC3045 + ulimit -n "$MAX_FD" || + warn "Could not set maximum file descriptor limit to $MAX_FD" + esac +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" || "$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 + 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 + # 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 +fi + + +# 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, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments, +# and any embedded shellness will be escaped. +# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be +# treated as '${Hostname}' itself on the command line. + +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 new file mode 100644 index 0000000..7101f8e --- /dev/null +++ b/gradlew.bat @@ -0,0 +1,92 @@ +@rem +@rem Copyright 2015 the original author or authors. +@rem +@rem Licensed under the Apache License, Version 2.0 (the "License"); +@rem you may not use this file except in compliance with the License. +@rem You may obtain a copy of the License at +@rem +@rem https://www.apache.org/licenses/LICENSE-2.0 +@rem +@rem Unless required by applicable law or agreed to in writing, software +@rem distributed under the License is distributed on an "AS IS" BASIS, +@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +@rem See the License for the specific language governing permissions and +@rem limitations under the License. +@rem + +@if "%DEBUG%"=="" @echo off +@rem ########################################################################## +@rem +@rem Gradle startup script for Windows +@rem +@rem ########################################################################## + +@rem Set local scope for the variables with windows NT shell +if "%OS%"=="Windows_NT" setlocal + +set DIRNAME=%~dp0 +if "%DIRNAME%"=="" set DIRNAME=. +@rem This is normally unused +set APP_BASE_NAME=%~n0 +set APP_HOME=%DIRNAME% + +@rem Resolve any "." and ".." in APP_HOME to make it shorter. +for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi + +@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" + +@rem Find java.exe +if defined JAVA_HOME goto findJavaFromJavaHome + +set JAVA_EXE=java.exe +%JAVA_EXE% -version >NUL 2>&1 +if %ERRORLEVEL% equ 0 goto execute + +echo. 1>&2 +echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2 +echo. 1>&2 +echo Please set the JAVA_HOME variable in your environment to match the 1>&2 +echo location of your Java installation. 1>&2 + +goto fail + +:findJavaFromJavaHome +set JAVA_HOME=%JAVA_HOME:"=% +set JAVA_EXE=%JAVA_HOME%/bin/java.exe + +if exist "%JAVA_EXE%" goto execute + +echo. 1>&2 +echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2 +echo. 1>&2 +echo Please set the JAVA_HOME variable in your environment to match the 1>&2 +echo location of your Java installation. 1>&2 + +goto fail + +:execute +@rem Setup the command line + +set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar + + +@rem Execute Gradle +"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* + +:end +@rem End local scope for the variables with windows NT shell +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! +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 + +:omega diff --git a/settings.gradle b/settings.gradle new file mode 100644 index 0000000..ada876e --- /dev/null +++ b/settings.gradle @@ -0,0 +1,11 @@ +pluginManagement { + repositories { + mavenLocal() + gradlePluginPortal() + maven { url = 'https://maven.neoforged.net/releases' } + } +} + +plugins { + id 'org.gradle.toolchains.foojay-resolver-convention' version '0.8.0' +} diff --git a/src/generated/resources/.cache/59eb3dbb5f86130e09b3c62d89b9525ee01cf52d b/src/generated/resources/.cache/59eb3dbb5f86130e09b3c62d89b9525ee01cf52d new file mode 100644 index 0000000..f0d403c --- /dev/null +++ b/src/generated/resources/.cache/59eb3dbb5f86130e09b3c62d89b9525ee01cf52d @@ -0,0 +1,6 @@ +// 1.21.1 2026-04-27T21:59:02.410882928 Loot Tables +f21b2a97e8470cfc3d7538d1b0d7096f5748b6e2 data/processed_obsidian/loot_table/blocks/cracked_obsidian_bricks.json +192ef7b15b8f072dda076e4d372d5cd97f350534 data/processed_obsidian/loot_table/blocks/cracked_obsidian_tiles.json +414e5336e6618894bd7ba5b96acadb2c73c1ca6c data/processed_obsidian/loot_table/blocks/obsidian_bricks.json +b4d935b7d05ed57eddf0fd99918848802e6c480b data/processed_obsidian/loot_table/blocks/obsidian_tiles.json +ab1bf0e279315d8fddae0bcdc0230cba796f3ae2 data/processed_obsidian/loot_table/blocks/polished_obsidian.json diff --git a/src/generated/resources/.cache/7f96c16204632dd642f805975137d690bf522e1c b/src/generated/resources/.cache/7f96c16204632dd642f805975137d690bf522e1c new file mode 100644 index 0000000..057b6b3 --- /dev/null +++ b/src/generated/resources/.cache/7f96c16204632dd642f805975137d690bf522e1c @@ -0,0 +1,16 @@ +// 1.21.1 2026-04-27T21:59:02.409476133 Block States: processed_obsidian +9bb3540d344f13b241649e506066c899757a51c3 assets/processed_obsidian/blockstates/cracked_obsidian_bricks.json +12cec9d85e4fa8a8b4b858cd693a5e84d4e2d66f assets/processed_obsidian/blockstates/cracked_obsidian_tiles.json +d65a588a6e6a4d76b19a0117bcdc056a4d0adcff assets/processed_obsidian/blockstates/obsidian_bricks.json +919053c3d999feaadddf18752759893b3ff59d0f assets/processed_obsidian/blockstates/obsidian_tiles.json +f3542d999e8f8d5d3e712fd1e8f118d14e267706 assets/processed_obsidian/blockstates/polished_obsidian.json +e7e5049c8fa4f3b8448072df2b4a314c2b4b25c3 assets/processed_obsidian/models/block/cracked_obsidian_bricks.json +0a0f072bda094f474fd7bb4f644fd9e5e68931b4 assets/processed_obsidian/models/block/cracked_obsidian_tiles.json +a2eab4caa2e5693465abee4ffaf2986af544bd55 assets/processed_obsidian/models/block/obsidian_bricks.json +3e998affb07ade0e5d9f68833e14f853a53ee3be assets/processed_obsidian/models/block/obsidian_tiles.json +09dfebea8337980c0a2f6c191f8fce40c8eb9b78 assets/processed_obsidian/models/block/polished_obsidian.json +389a1e7647cb6aa70b655da7288bb26b9c730e02 assets/processed_obsidian/models/item/cracked_obsidian_bricks.json +bb4de85ab06ca071f0e43ebc2f052b9a1a67e185 assets/processed_obsidian/models/item/cracked_obsidian_tiles.json +2addc681209cb4ce5b4ee177c59b60c5553c6af3 assets/processed_obsidian/models/item/obsidian_bricks.json +bf5b8f2d160f16a8a6c21877f975419168b995b2 assets/processed_obsidian/models/item/obsidian_tiles.json +2f8086bf61fe0688d8cb770ecfaee75bc7dadd01 assets/processed_obsidian/models/item/polished_obsidian.json diff --git a/src/generated/resources/.cache/be5720aac139ee197c55b68040cc95f687ab0aa2 b/src/generated/resources/.cache/be5720aac139ee197c55b68040cc95f687ab0aa2 new file mode 100644 index 0000000..bc3606b --- /dev/null +++ b/src/generated/resources/.cache/be5720aac139ee197c55b68040cc95f687ab0aa2 @@ -0,0 +1,2 @@ +// 1.21.1 2026-04-27T21:59:02.410668709 Item Models: processed_obsidian +e4b0a25a058313fe86e228b769ea1106b6f5bb56 assets/processed_obsidian/models/item/obsidian_dust.json diff --git a/src/generated/resources/.cache/f04eeeff5586946d40a4e5aa6e023601ec5a9e42 b/src/generated/resources/.cache/f04eeeff5586946d40a4e5aa6e023601ec5a9e42 new file mode 100644 index 0000000..84fbb2c --- /dev/null +++ b/src/generated/resources/.cache/f04eeeff5586946d40a4e5aa6e023601ec5a9e42 @@ -0,0 +1,3 @@ +// 1.21.1 2026-04-27T21:59:02.410419363 Tags for minecraft:block mod id processed_obsidian +b574cbc55e404661251d88d773cd79cc2d344983 data/minecraft/tags/block/mineable/pickaxe.json +b574cbc55e404661251d88d773cd79cc2d344983 data/minecraft/tags/block/needs_diamond_tool.json diff --git a/src/generated/resources/assets/processed_obsidian/blockstates/cracked_obsidian_bricks.json b/src/generated/resources/assets/processed_obsidian/blockstates/cracked_obsidian_bricks.json new file mode 100644 index 0000000..09c8d2d --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/blockstates/cracked_obsidian_bricks.json @@ -0,0 +1,7 @@ +{ + "variants": { + "": { + "model": "processed_obsidian:block/cracked_obsidian_bricks" + } + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/blockstates/cracked_obsidian_tiles.json b/src/generated/resources/assets/processed_obsidian/blockstates/cracked_obsidian_tiles.json new file mode 100644 index 0000000..5f13c9c --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/blockstates/cracked_obsidian_tiles.json @@ -0,0 +1,7 @@ +{ + "variants": { + "": { + "model": "processed_obsidian:block/cracked_obsidian_tiles" + } + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/blockstates/obsidian_bricks.json b/src/generated/resources/assets/processed_obsidian/blockstates/obsidian_bricks.json new file mode 100644 index 0000000..8e112c7 --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/blockstates/obsidian_bricks.json @@ -0,0 +1,7 @@ +{ + "variants": { + "": { + "model": "processed_obsidian:block/obsidian_bricks" + } + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/blockstates/obsidian_tiles.json b/src/generated/resources/assets/processed_obsidian/blockstates/obsidian_tiles.json new file mode 100644 index 0000000..c6734ad --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/blockstates/obsidian_tiles.json @@ -0,0 +1,7 @@ +{ + "variants": { + "": { + "model": "processed_obsidian:block/obsidian_tiles" + } + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/blockstates/polished_obsidian.json b/src/generated/resources/assets/processed_obsidian/blockstates/polished_obsidian.json new file mode 100644 index 0000000..fb60f0b --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/blockstates/polished_obsidian.json @@ -0,0 +1,7 @@ +{ + "variants": { + "": { + "model": "processed_obsidian:block/polished_obsidian" + } + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/models/block/cracked_obsidian_bricks.json b/src/generated/resources/assets/processed_obsidian/models/block/cracked_obsidian_bricks.json new file mode 100644 index 0000000..d484653 --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/models/block/cracked_obsidian_bricks.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:block/cube_all", + "textures": { + "all": "processed_obsidian:block/cracked_obsidian_bricks" + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/models/block/cracked_obsidian_tiles.json b/src/generated/resources/assets/processed_obsidian/models/block/cracked_obsidian_tiles.json new file mode 100644 index 0000000..e25766a --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/models/block/cracked_obsidian_tiles.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:block/cube_all", + "textures": { + "all": "processed_obsidian:block/cracked_obsidian_tiles" + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/models/block/obsidian_bricks.json b/src/generated/resources/assets/processed_obsidian/models/block/obsidian_bricks.json new file mode 100644 index 0000000..320519e --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/models/block/obsidian_bricks.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:block/cube_all", + "textures": { + "all": "processed_obsidian:block/obsidian_bricks" + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/models/block/obsidian_tiles.json b/src/generated/resources/assets/processed_obsidian/models/block/obsidian_tiles.json new file mode 100644 index 0000000..9cc4df7 --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/models/block/obsidian_tiles.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:block/cube_all", + "textures": { + "all": "processed_obsidian:block/obsidian_tiles" + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/models/block/polished_obsidian.json b/src/generated/resources/assets/processed_obsidian/models/block/polished_obsidian.json new file mode 100644 index 0000000..ce2965b --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/models/block/polished_obsidian.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:block/cube_all", + "textures": { + "all": "processed_obsidian:block/polished_obsidian" + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/models/item/cracked_obsidian_bricks.json b/src/generated/resources/assets/processed_obsidian/models/item/cracked_obsidian_bricks.json new file mode 100644 index 0000000..5125fec --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/models/item/cracked_obsidian_bricks.json @@ -0,0 +1,3 @@ +{ + "parent": "processed_obsidian:block/cracked_obsidian_bricks" +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/models/item/cracked_obsidian_tiles.json b/src/generated/resources/assets/processed_obsidian/models/item/cracked_obsidian_tiles.json new file mode 100644 index 0000000..20880d6 --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/models/item/cracked_obsidian_tiles.json @@ -0,0 +1,3 @@ +{ + "parent": "processed_obsidian:block/cracked_obsidian_tiles" +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/models/item/obsidian_bricks.json b/src/generated/resources/assets/processed_obsidian/models/item/obsidian_bricks.json new file mode 100644 index 0000000..df11f45 --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/models/item/obsidian_bricks.json @@ -0,0 +1,3 @@ +{ + "parent": "processed_obsidian:block/obsidian_bricks" +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/models/item/obsidian_dust.json b/src/generated/resources/assets/processed_obsidian/models/item/obsidian_dust.json new file mode 100644 index 0000000..df18e70 --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/models/item/obsidian_dust.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/generated", + "textures": { + "layer0": "processed_obsidian:item/obsidian_dust" + } +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/models/item/obsidian_tiles.json b/src/generated/resources/assets/processed_obsidian/models/item/obsidian_tiles.json new file mode 100644 index 0000000..56fdd7a --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/models/item/obsidian_tiles.json @@ -0,0 +1,3 @@ +{ + "parent": "processed_obsidian:block/obsidian_tiles" +} \ No newline at end of file diff --git a/src/generated/resources/assets/processed_obsidian/models/item/polished_obsidian.json b/src/generated/resources/assets/processed_obsidian/models/item/polished_obsidian.json new file mode 100644 index 0000000..78a0a5a --- /dev/null +++ b/src/generated/resources/assets/processed_obsidian/models/item/polished_obsidian.json @@ -0,0 +1,3 @@ +{ + "parent": "processed_obsidian:block/polished_obsidian" +} \ No newline at end of file diff --git a/src/generated/resources/data/minecraft/tags/block/mineable/pickaxe.json b/src/generated/resources/data/minecraft/tags/block/mineable/pickaxe.json new file mode 100644 index 0000000..a77eaff --- /dev/null +++ b/src/generated/resources/data/minecraft/tags/block/mineable/pickaxe.json @@ -0,0 +1,9 @@ +{ + "values": [ + "processed_obsidian:obsidian_tiles", + "processed_obsidian:cracked_obsidian_tiles", + "processed_obsidian:cracked_obsidian_bricks", + "processed_obsidian:obsidian_bricks", + "processed_obsidian:polished_obsidian" + ] +} \ No newline at end of file diff --git a/src/generated/resources/data/minecraft/tags/block/needs_diamond_tool.json b/src/generated/resources/data/minecraft/tags/block/needs_diamond_tool.json new file mode 100644 index 0000000..a77eaff --- /dev/null +++ b/src/generated/resources/data/minecraft/tags/block/needs_diamond_tool.json @@ -0,0 +1,9 @@ +{ + "values": [ + "processed_obsidian:obsidian_tiles", + "processed_obsidian:cracked_obsidian_tiles", + "processed_obsidian:cracked_obsidian_bricks", + "processed_obsidian:obsidian_bricks", + "processed_obsidian:polished_obsidian" + ] +} \ No newline at end of file diff --git a/src/generated/resources/data/processed_obsidian/loot_table/blocks/cracked_obsidian_bricks.json b/src/generated/resources/data/processed_obsidian/loot_table/blocks/cracked_obsidian_bricks.json new file mode 100644 index 0000000..2042c53 --- /dev/null +++ b/src/generated/resources/data/processed_obsidian/loot_table/blocks/cracked_obsidian_bricks.json @@ -0,0 +1,21 @@ +{ + "type": "minecraft:block", + "pools": [ + { + "bonus_rolls": 0.0, + "conditions": [ + { + "condition": "minecraft:survives_explosion" + } + ], + "entries": [ + { + "type": "minecraft:item", + "name": "processed_obsidian:cracked_obsidian_bricks" + } + ], + "rolls": 1.0 + } + ], + "random_sequence": "processed_obsidian:blocks/cracked_obsidian_bricks" +} \ No newline at end of file diff --git a/src/generated/resources/data/processed_obsidian/loot_table/blocks/cracked_obsidian_tiles.json b/src/generated/resources/data/processed_obsidian/loot_table/blocks/cracked_obsidian_tiles.json new file mode 100644 index 0000000..db11fb8 --- /dev/null +++ b/src/generated/resources/data/processed_obsidian/loot_table/blocks/cracked_obsidian_tiles.json @@ -0,0 +1,21 @@ +{ + "type": "minecraft:block", + "pools": [ + { + "bonus_rolls": 0.0, + "conditions": [ + { + "condition": "minecraft:survives_explosion" + } + ], + "entries": [ + { + "type": "minecraft:item", + "name": "processed_obsidian:cracked_obsidian_tiles" + } + ], + "rolls": 1.0 + } + ], + "random_sequence": "processed_obsidian:blocks/cracked_obsidian_tiles" +} \ No newline at end of file diff --git a/src/generated/resources/data/processed_obsidian/loot_table/blocks/obsidian_bricks.json b/src/generated/resources/data/processed_obsidian/loot_table/blocks/obsidian_bricks.json new file mode 100644 index 0000000..17e038c --- /dev/null +++ b/src/generated/resources/data/processed_obsidian/loot_table/blocks/obsidian_bricks.json @@ -0,0 +1,21 @@ +{ + "type": "minecraft:block", + "pools": [ + { + "bonus_rolls": 0.0, + "conditions": [ + { + "condition": "minecraft:survives_explosion" + } + ], + "entries": [ + { + "type": "minecraft:item", + "name": "processed_obsidian:obsidian_bricks" + } + ], + "rolls": 1.0 + } + ], + "random_sequence": "processed_obsidian:blocks/obsidian_bricks" +} \ No newline at end of file diff --git a/src/generated/resources/data/processed_obsidian/loot_table/blocks/obsidian_tiles.json b/src/generated/resources/data/processed_obsidian/loot_table/blocks/obsidian_tiles.json new file mode 100644 index 0000000..fe4f264 --- /dev/null +++ b/src/generated/resources/data/processed_obsidian/loot_table/blocks/obsidian_tiles.json @@ -0,0 +1,21 @@ +{ + "type": "minecraft:block", + "pools": [ + { + "bonus_rolls": 0.0, + "conditions": [ + { + "condition": "minecraft:survives_explosion" + } + ], + "entries": [ + { + "type": "minecraft:item", + "name": "processed_obsidian:obsidian_tiles" + } + ], + "rolls": 1.0 + } + ], + "random_sequence": "processed_obsidian:blocks/obsidian_tiles" +} \ No newline at end of file diff --git a/src/generated/resources/data/processed_obsidian/loot_table/blocks/polished_obsidian.json b/src/generated/resources/data/processed_obsidian/loot_table/blocks/polished_obsidian.json new file mode 100644 index 0000000..1048abc --- /dev/null +++ b/src/generated/resources/data/processed_obsidian/loot_table/blocks/polished_obsidian.json @@ -0,0 +1,21 @@ +{ + "type": "minecraft:block", + "pools": [ + { + "bonus_rolls": 0.0, + "conditions": [ + { + "condition": "minecraft:survives_explosion" + } + ], + "entries": [ + { + "type": "minecraft:item", + "name": "processed_obsidian:polished_obsidian" + } + ], + "rolls": 1.0 + } + ], + "random_sequence": "processed_obsidian:blocks/polished_obsidian" +} \ No newline at end of file diff --git a/src/main/java/ovh/glitchlabs/processed_obsidian/Processed_obsidian.java b/src/main/java/ovh/glitchlabs/processed_obsidian/Processed_obsidian.java new file mode 100644 index 0000000..dbb0b4c --- /dev/null +++ b/src/main/java/ovh/glitchlabs/processed_obsidian/Processed_obsidian.java @@ -0,0 +1,95 @@ +package ovh.glitchlabs.processed_obsidian; + +import com.mojang.logging.LogUtils; +import net.minecraft.client.Minecraft; +import net.minecraft.core.registries.BuiltInRegistries; +import net.minecraft.core.registries.Registries; +import net.minecraft.network.chat.Component; +import net.minecraft.world.food.FoodProperties; +import net.minecraft.world.item.BlockItem; +import net.minecraft.world.item.CreativeModeTab; +import net.minecraft.world.item.CreativeModeTabs; +import net.minecraft.world.item.Item; +import net.minecraft.world.level.block.Block; +import net.minecraft.world.level.block.Blocks; +import net.minecraft.world.level.block.state.BlockBehaviour; +import net.minecraft.world.level.material.MapColor; +import net.neoforged.api.distmarker.Dist; +import net.neoforged.bus.api.IEventBus; +import net.neoforged.bus.api.SubscribeEvent; +import net.neoforged.fml.ModContainer; +import net.neoforged.fml.common.EventBusSubscriber; +import net.neoforged.fml.common.Mod; +import net.neoforged.fml.config.ModConfig; +import net.neoforged.fml.event.lifecycle.FMLClientSetupEvent; +import net.neoforged.fml.event.lifecycle.FMLCommonSetupEvent; +import net.neoforged.neoforge.common.NeoForge; +import net.neoforged.neoforge.event.BuildCreativeModeTabContentsEvent; +import net.neoforged.neoforge.event.server.ServerStartingEvent; +import net.neoforged.neoforge.registries.DeferredBlock; +import net.neoforged.neoforge.registries.DeferredHolder; +import net.neoforged.neoforge.registries.DeferredItem; +import net.neoforged.neoforge.registries.DeferredRegister; +import org.slf4j.Logger; +import ovh.glitchlabs.processed_obsidian.blocks.ModBlocks; +import ovh.glitchlabs.processed_obsidian.items.ModItems; + +@Mod(Processed_obsidian.MODID) +public class Processed_obsidian { + public static final String MODID = "processed_obsidian"; + private static final Logger LOGGER = LogUtils.getLogger(); + + // The constructor for the mod class is the first code that is run when your mod is loaded. + // FML will recognize some parameter types like IEventBus or ModContainer and pass them in automatically. + public Processed_obsidian(IEventBus modEventBus, ModContainer modContainer) { + // Register the commonSetup method for modloading + modEventBus.addListener(this::commonSetup); + + // Register ourselves for server and other game events we are interested in. + // Note that this is necessary if and only if we want *this* class (Processed_obsidian) to respond directly to events. + // Do not add this line if there are no @SubscribeEvent-annotated functions in this class, like onServerStarting() below. + NeoForge.EVENT_BUS.register(this); + + ModBlocks.register(modEventBus); + ModItems.register(modEventBus); + + modEventBus.addListener(this::addCreative); + + } + + private void commonSetup(final FMLCommonSetupEvent event) { + + } + + private void addCreative(BuildCreativeModeTabContentsEvent event) { + if (event.getTabKey() == CreativeModeTabs.BUILDING_BLOCKS) { + event.accept(ModBlocks.CRACKED_OBSIDIAN_BRICKS.get()); + event.accept(ModBlocks.OBSIDIAN_BRICKS.get()); + event.accept(ModBlocks.OBSIDIAN_TILES.get()); + event.accept(ModBlocks.POLISHED_OBSIDIAN.get()); + event.accept(ModBlocks.CRACKED_OBSIDIAN_TILES.get()); + } + if (event.getTabKey() == CreativeModeTabs.INGREDIENTS) { + event.accept(ModItems.OBSIDIAN_DUST.get()); + } + } + + + + // You can use SubscribeEvent and let the Event Bus discover methods to call + @SubscribeEvent + public void onServerStarting(ServerStartingEvent event) { + // Do something when the server starts + LOGGER.info("HELLO from server starting"); + } + + // You can use EventBusSubscriber to automatically register all static methods in the class annotated with @SubscribeEvent + @EventBusSubscriber(modid = MODID, bus = EventBusSubscriber.Bus.MOD, value = Dist.CLIENT) + public static class ClientModEvents { + @SubscribeEvent + public static void onClientSetup(FMLClientSetupEvent event) { + // Some client setup code + LOGGER.info("MINECRAFT NAME >> {}", Minecraft.getInstance().getUser().getName()); + } + } +} diff --git a/src/main/java/ovh/glitchlabs/processed_obsidian/blocks/ModBlocks.java b/src/main/java/ovh/glitchlabs/processed_obsidian/blocks/ModBlocks.java new file mode 100644 index 0000000..ad3d0ba --- /dev/null +++ b/src/main/java/ovh/glitchlabs/processed_obsidian/blocks/ModBlocks.java @@ -0,0 +1,82 @@ +package ovh.glitchlabs.processed_obsidian.blocks; + +import net.minecraft.util.valueproviders.UniformInt; +import net.minecraft.world.item.BlockItem; +import net.minecraft.world.item.Item; +import net.minecraft.world.level.block.Block; +import net.minecraft.world.level.block.DropExperienceBlock; +import net.minecraft.world.level.block.SoundType; +import net.minecraft.world.level.block.state.BlockBehaviour; +import net.minecraft.world.level.block.state.properties.NoteBlockInstrument; +import net.minecraft.world.level.material.MapColor; +import net.neoforged.bus.api.IEventBus; +import net.neoforged.neoforge.registries.DeferredBlock; +import net.neoforged.neoforge.registries.DeferredRegister; +import ovh.glitchlabs.processed_obsidian.Processed_obsidian; +import ovh.glitchlabs.processed_obsidian.items.ModItems; + +import java.util.function.Supplier; + +public class ModBlocks { + public static final DeferredRegister.Blocks BLOCKS = + DeferredRegister.createBlocks(Processed_obsidian.MODID); + + public static final DeferredBlock OBSIDIAN_BRICKS = registerBlock("obsidian_bricks", + () -> new Block(BlockBehaviour.Properties.of() + .strength(50.0F) + .requiresCorrectToolForDrops() + .explosionResistance(1200.0F) + .instrument(NoteBlockInstrument.BASEDRUM) + .mapColor(MapColor.COLOR_BLACK) + )); + + public static final DeferredBlock CRACKED_OBSIDIAN_BRICKS = registerBlock("cracked_obsidian_bricks", + () -> new Block(BlockBehaviour.Properties.of() + .strength(50.0F) + .requiresCorrectToolForDrops() + .explosionResistance(1200.0F) + .instrument(NoteBlockInstrument.BASEDRUM) + .mapColor(MapColor.COLOR_BLACK) + )); + + public static final DeferredBlock OBSIDIAN_TILES = registerBlock("obsidian_tiles", + () -> new Block(BlockBehaviour.Properties.of() + .strength(50.0F) + .requiresCorrectToolForDrops() + .explosionResistance(1200.0F) + .instrument(NoteBlockInstrument.BASEDRUM) + .mapColor(MapColor.COLOR_BLACK) + )); + + public static final DeferredBlock CRACKED_OBSIDIAN_TILES = registerBlock("cracked_obsidian_tiles", + () -> new Block(BlockBehaviour.Properties.of() + .strength(50.0F) + .requiresCorrectToolForDrops() + .explosionResistance(1200.0F) + .instrument(NoteBlockInstrument.BASEDRUM) + .mapColor(MapColor.COLOR_BLACK) + )); + + public static final DeferredBlock POLISHED_OBSIDIAN = registerBlock("polished_obsidian", + () -> new Block(BlockBehaviour.Properties.of() + .strength(50.0F) + .requiresCorrectToolForDrops() + .explosionResistance(1200.0F) + .instrument(NoteBlockInstrument.BASEDRUM) + .mapColor(MapColor.COLOR_BLACK) + )); + + private static DeferredBlock registerBlock(String name, Supplier block) { + DeferredBlock toReturn = BLOCKS.register(name, block); + registerBlockItem(name, toReturn); + return toReturn; + } + + private static void registerBlockItem(String name, DeferredBlock block) { + ModItems.ITEMS.register(name, () -> new BlockItem(block.get(), new Item.Properties())); + } + + public static void register(IEventBus eventBus) { + BLOCKS.register(eventBus); + } +} diff --git a/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/DataGenerators.java b/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/DataGenerators.java new file mode 100644 index 0000000..02b2de7 --- /dev/null +++ b/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/DataGenerators.java @@ -0,0 +1,39 @@ +package ovh.glitchlabs.processed_obsidian.datagen; + +import net.minecraft.core.HolderLookup; +import net.minecraft.data.DataGenerator; +import net.minecraft.data.PackOutput; +import net.minecraft.data.loot.LootTableProvider; +import net.minecraft.world.level.storage.loot.parameters.LootContextParamSets; +import net.neoforged.bus.api.SubscribeEvent; +import net.neoforged.fml.common.EventBusSubscriber; +import net.neoforged.neoforge.common.data.BlockTagsProvider; +import net.neoforged.neoforge.common.data.ExistingFileHelper; +import net.neoforged.neoforge.data.event.GatherDataEvent; +import ovh.glitchlabs.processed_obsidian.Processed_obsidian; + +import java.util.Collections; +import java.util.List; +import java.util.concurrent.CompletableFuture; + +import java.util.concurrent.CompletableFuture; + +@EventBusSubscriber(modid = Processed_obsidian.MODID, bus = EventBusSubscriber.Bus.MOD) +public class DataGenerators { + @SubscribeEvent + public static void gatherData(GatherDataEvent event) { + DataGenerator generator = event.getGenerator(); + PackOutput packOutput = generator.getPackOutput(); + ExistingFileHelper existingFileHelper = event.getExistingFileHelper(); + CompletableFuture lookupProvider = event.getLookupProvider(); + + generator.addProvider(event.includeServer(), new LootTableProvider(packOutput, Collections.emptySet(), + List.of(new LootTableProvider.SubProviderEntry(ModBlockLootTableProvider::new, LootContextParamSets.BLOCK)), lookupProvider)); + + BlockTagsProvider blockTagsProvider = new ModBlockTagProvider(packOutput, lookupProvider, existingFileHelper); + generator.addProvider(event.includeServer(), blockTagsProvider); + + generator.addProvider(event.includeClient(), new ModItemModelProvider(packOutput, existingFileHelper)); + generator.addProvider(event.includeClient(), new ModBlockStateProvider(packOutput, existingFileHelper)); + } +} diff --git a/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/ModBlockLootTableProvider.java b/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/ModBlockLootTableProvider.java new file mode 100644 index 0000000..7cf31b6 --- /dev/null +++ b/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/ModBlockLootTableProvider.java @@ -0,0 +1,31 @@ +package ovh.glitchlabs.processed_obsidian.datagen; + +import net.minecraft.core.Holder; +import net.minecraft.core.HolderLookup; +import net.minecraft.data.loot.BlockLootSubProvider; +import net.minecraft.world.flag.FeatureFlags; +import net.minecraft.world.level.block.Block; +import ovh.glitchlabs.processed_obsidian.blocks.ModBlocks; + +import java.util.Set; + +public class ModBlockLootTableProvider extends BlockLootSubProvider { + protected ModBlockLootTableProvider(HolderLookup.Provider registries) { + super(Set.of(), FeatureFlags.REGISTRY.allFlags(), registries); + } + + @Override + protected void generate() { + dropSelf(ModBlocks.OBSIDIAN_BRICKS.get()); + dropSelf(ModBlocks.OBSIDIAN_TILES.get()); + dropSelf(ModBlocks.CRACKED_OBSIDIAN_BRICKS.get()); + dropSelf(ModBlocks.CRACKED_OBSIDIAN_TILES.get()); + dropSelf(ModBlocks.POLISHED_OBSIDIAN.get()); + + } + + @Override + protected Iterable getKnownBlocks() { + return ModBlocks.BLOCKS.getEntries().stream().map(Holder::value)::iterator; + } +} diff --git a/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/ModBlockStateProvider.java b/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/ModBlockStateProvider.java new file mode 100644 index 0000000..0af4e78 --- /dev/null +++ b/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/ModBlockStateProvider.java @@ -0,0 +1,27 @@ +package ovh.glitchlabs.processed_obsidian.datagen; + +import net.minecraft.data.PackOutput; +import net.neoforged.neoforge.client.model.generators.BlockStateProvider; +import net.neoforged.neoforge.common.data.ExistingFileHelper; +import net.neoforged.neoforge.registries.DeferredBlock; +import ovh.glitchlabs.processed_obsidian.Processed_obsidian; +import ovh.glitchlabs.processed_obsidian.blocks.ModBlocks; + +public class ModBlockStateProvider extends BlockStateProvider { + public ModBlockStateProvider(PackOutput output, ExistingFileHelper exFileHelper) { + super(output, Processed_obsidian.MODID, exFileHelper); + } + + @Override + protected void registerStatesAndModels() { + blockWithItem(ModBlocks.POLISHED_OBSIDIAN); + blockWithItem(ModBlocks.CRACKED_OBSIDIAN_BRICKS); + blockWithItem(ModBlocks.CRACKED_OBSIDIAN_TILES); + blockWithItem(ModBlocks.OBSIDIAN_BRICKS); + blockWithItem(ModBlocks.OBSIDIAN_TILES); + } + + private void blockWithItem(DeferredBlock deferredBlock) { + simpleBlockWithItem(deferredBlock.get(), cubeAll(deferredBlock.get())); + } +} \ No newline at end of file diff --git a/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/ModBlockTagProvider.java b/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/ModBlockTagProvider.java new file mode 100644 index 0000000..00d6aa1 --- /dev/null +++ b/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/ModBlockTagProvider.java @@ -0,0 +1,36 @@ +package ovh.glitchlabs.processed_obsidian.datagen; + +import net.minecraft.core.HolderLookup; +import net.minecraft.data.PackOutput; +import net.minecraft.tags.BlockTags; +import net.neoforged.neoforge.common.data.BlockTagsProvider; +import net.neoforged.neoforge.common.data.ExistingFileHelper; +import org.jetbrains.annotations.Nullable; +import ovh.glitchlabs.processed_obsidian.Processed_obsidian; +import ovh.glitchlabs.processed_obsidian.blocks.ModBlocks; + +import java.util.concurrent.CompletableFuture; + +public class ModBlockTagProvider extends BlockTagsProvider { + public ModBlockTagProvider(PackOutput output, CompletableFuture lookupProvider, @Nullable ExistingFileHelper existingFileHelper) { + super(output, lookupProvider, Processed_obsidian.MODID, existingFileHelper); + } + + @Override + protected void addTags(HolderLookup.Provider provider) { + tag(BlockTags.MINEABLE_WITH_PICKAXE) + .add(ModBlocks.OBSIDIAN_TILES.get()) + .add(ModBlocks.CRACKED_OBSIDIAN_TILES.get()) + .add(ModBlocks.CRACKED_OBSIDIAN_BRICKS.get()) + .add(ModBlocks.OBSIDIAN_BRICKS.get()) + .add(ModBlocks.POLISHED_OBSIDIAN.get()); + + tag(BlockTags.NEEDS_DIAMOND_TOOL) + .add(ModBlocks.OBSIDIAN_TILES.get()) + .add(ModBlocks.CRACKED_OBSIDIAN_TILES.get()) + .add(ModBlocks.CRACKED_OBSIDIAN_BRICKS.get()) + .add(ModBlocks.OBSIDIAN_BRICKS.get()) + .add(ModBlocks.POLISHED_OBSIDIAN.get()); + + } +} \ No newline at end of file diff --git a/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/ModItemModelProvider.java b/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/ModItemModelProvider.java new file mode 100644 index 0000000..00ea7bf --- /dev/null +++ b/src/main/java/ovh/glitchlabs/processed_obsidian/datagen/ModItemModelProvider.java @@ -0,0 +1,18 @@ +package ovh.glitchlabs.processed_obsidian.datagen; + +import net.minecraft.data.PackOutput; +import net.neoforged.neoforge.client.model.generators.ItemModelProvider; +import net.neoforged.neoforge.common.data.ExistingFileHelper; +import ovh.glitchlabs.processed_obsidian.Processed_obsidian; +import ovh.glitchlabs.processed_obsidian.items.ModItems; + +public class ModItemModelProvider extends ItemModelProvider { + public ModItemModelProvider(PackOutput output, ExistingFileHelper existingFileHelper) { + super(output, Processed_obsidian.MODID, existingFileHelper); + } + + @Override + protected void registerModels() { + basicItem(ModItems.OBSIDIAN_DUST.get()); + } +} \ No newline at end of file diff --git a/src/main/java/ovh/glitchlabs/processed_obsidian/items/ModItems.java b/src/main/java/ovh/glitchlabs/processed_obsidian/items/ModItems.java new file mode 100644 index 0000000..7268664 --- /dev/null +++ b/src/main/java/ovh/glitchlabs/processed_obsidian/items/ModItems.java @@ -0,0 +1,22 @@ +package ovh.glitchlabs.processed_obsidian.items; + +import net.minecraft.world.item.Item; +import net.minecraft.world.item.Rarity; +import net.neoforged.bus.api.IEventBus; +import net.neoforged.neoforge.registries.DeferredItem; +import net.neoforged.neoforge.registries.DeferredRegister; +import ovh.glitchlabs.processed_obsidian.Processed_obsidian; + +public class ModItems { + public static final DeferredRegister.Items ITEMS = DeferredRegister.createItems(Processed_obsidian.MODID); + + public static final DeferredItem OBSIDIAN_DUST = ITEMS.register("obsidian_dust", + () -> new Item(new Item.Properties() + .stacksTo(16) + .rarity(Rarity.RARE) + )); + + public static void register(IEventBus eventBus) { + ITEMS.register(eventBus); + } +} \ No newline at end of file diff --git a/src/main/resources/assets/processed_obsidian/lang/en_us.json b/src/main/resources/assets/processed_obsidian/lang/en_us.json new file mode 100644 index 0000000..218197d --- /dev/null +++ b/src/main/resources/assets/processed_obsidian/lang/en_us.json @@ -0,0 +1,9 @@ +{ + "block.processed_obsidian.cracked_obsidian_tiles": "Cracked Obsidian Tiles", + "block.processed_obsidian.obsidian_tiles": "Obsidian Tiles", + "block.processed_obsidian.polished_obsidian": "Polished Obsidian Tiles", + "block.processed_obsidian.obsidian_bricks": "Obsidian Bricks", + "block.processed_obsidian.cracked_obsidian_bricks": "Cracked Obsidian Bricks", + "item.processed_obsidian.obsidian_dust": "Obsidian Dust" + +} diff --git a/src/main/resources/assets/processed_obsidian/textures/block/cracked_obsidian_bricks.png b/src/main/resources/assets/processed_obsidian/textures/block/cracked_obsidian_bricks.png new file mode 100644 index 0000000..344ab8b Binary files /dev/null and b/src/main/resources/assets/processed_obsidian/textures/block/cracked_obsidian_bricks.png differ diff --git a/src/main/resources/assets/processed_obsidian/textures/block/cracked_obsidian_tiles.png b/src/main/resources/assets/processed_obsidian/textures/block/cracked_obsidian_tiles.png new file mode 100644 index 0000000..a192e1e Binary files /dev/null and b/src/main/resources/assets/processed_obsidian/textures/block/cracked_obsidian_tiles.png differ diff --git a/src/main/resources/assets/processed_obsidian/textures/block/obsidian_bricks.png b/src/main/resources/assets/processed_obsidian/textures/block/obsidian_bricks.png new file mode 100644 index 0000000..35c1750 Binary files /dev/null and b/src/main/resources/assets/processed_obsidian/textures/block/obsidian_bricks.png differ diff --git a/src/main/resources/assets/processed_obsidian/textures/block/obsidian_tiles.png b/src/main/resources/assets/processed_obsidian/textures/block/obsidian_tiles.png new file mode 100644 index 0000000..ce3b3ac Binary files /dev/null and b/src/main/resources/assets/processed_obsidian/textures/block/obsidian_tiles.png differ diff --git a/src/main/resources/assets/processed_obsidian/textures/block/polished_obsidian.png b/src/main/resources/assets/processed_obsidian/textures/block/polished_obsidian.png new file mode 100644 index 0000000..f871598 Binary files /dev/null and b/src/main/resources/assets/processed_obsidian/textures/block/polished_obsidian.png differ diff --git a/src/main/resources/assets/processed_obsidian/textures/item/obsidian_dust.png b/src/main/resources/assets/processed_obsidian/textures/item/obsidian_dust.png new file mode 100644 index 0000000..bc5e60d Binary files /dev/null and b/src/main/resources/assets/processed_obsidian/textures/item/obsidian_dust.png differ diff --git a/src/main/resources/data/processed_obsidian/recipe/cracked_obsidian_bricks.json b/src/main/resources/data/processed_obsidian/recipe/cracked_obsidian_bricks.json new file mode 100644 index 0000000..32d53e7 --- /dev/null +++ b/src/main/resources/data/processed_obsidian/recipe/cracked_obsidian_bricks.json @@ -0,0 +1,13 @@ +{ + "type": "minecraft:blasting", + "group": "processed_obsidian", + "category": "blocks", + "cookingtime": 200, + "experience": 0.1, + "ingredient": { + "item": "processed_obsidian:obsidian_bricks" + }, + "result": { + "id": "processed_obsidian:cracked_obsidian_bricks" + } +} \ No newline at end of file diff --git a/src/main/resources/data/processed_obsidian/recipe/cracked_obsidian_tiles.json b/src/main/resources/data/processed_obsidian/recipe/cracked_obsidian_tiles.json new file mode 100644 index 0000000..1251938 --- /dev/null +++ b/src/main/resources/data/processed_obsidian/recipe/cracked_obsidian_tiles.json @@ -0,0 +1,13 @@ +{ + "type": "minecraft:blasting", + "group": "processed_obsidian", + "category": "blocks", + "cookingtime": 200, + "experience": 0.1, + "ingredient": { + "item": "processed_obsidian:obsidian_tiles" + }, + "result": { + "id": "processed_obsidian:cracked_obsidian_tiles" + } +} \ No newline at end of file diff --git a/src/main/resources/data/processed_obsidian/recipe/obisdian_dust.json b/src/main/resources/data/processed_obsidian/recipe/obisdian_dust.json new file mode 100644 index 0000000..8fc4075 --- /dev/null +++ b/src/main/resources/data/processed_obsidian/recipe/obisdian_dust.json @@ -0,0 +1,14 @@ +{ + "type": "minecraft:crafting_shapeless", + "group": "processed_obsidian", + "category": "building", + "ingredients": [ + { + "item": "minecraft:obsidian" + } + ], + "result": { + "id": "processed_obsidian:obsidian_dust", + "count": 9 + } +} \ No newline at end of file diff --git a/src/main/resources/data/processed_obsidian/recipe/obsidian.json b/src/main/resources/data/processed_obsidian/recipe/obsidian.json new file mode 100644 index 0000000..a806aa2 --- /dev/null +++ b/src/main/resources/data/processed_obsidian/recipe/obsidian.json @@ -0,0 +1,19 @@ +{ + "type": "minecraft:crafting_shaped", + "group": "processed_obsidian", + "category": "building", + "pattern": [ + "OOO", + "OOO", + "OOO" + ], + "key": { + "O": { + "item": "processed_obsidian:obsidian_dust" + } + }, + "result": { + "id": "minecraft:obsidian", + "count": 1 + } +} \ No newline at end of file diff --git a/src/main/resources/data/processed_obsidian/recipe/obsidian_bricks.json b/src/main/resources/data/processed_obsidian/recipe/obsidian_bricks.json new file mode 100644 index 0000000..3a4b531 --- /dev/null +++ b/src/main/resources/data/processed_obsidian/recipe/obsidian_bricks.json @@ -0,0 +1,13 @@ +{ + "type": "minecraft:blasting", + "group": "processed_obsidian", + "category": "blocks", + "cookingtime": 200, + "experience": 0.3, + "ingredient": { + "item": "processed_obsidian:obsidian_dust" + }, + "result": { + "id": "processed_obsidian:obsidian_bricks" + } +} \ No newline at end of file diff --git a/src/main/resources/data/processed_obsidian/recipe/obsidian_tiles.json b/src/main/resources/data/processed_obsidian/recipe/obsidian_tiles.json new file mode 100644 index 0000000..4bfb2af --- /dev/null +++ b/src/main/resources/data/processed_obsidian/recipe/obsidian_tiles.json @@ -0,0 +1,18 @@ +{ + "type": "minecraft:crafting_shaped", + "group": "processed_obsidian", + "category": "building", + "key": { + "S": { + "item": "processed_obsidian:obsidian_bricks" + } + }, + "pattern": [ + "SS", + "SS" + ], + "result": { + "count": 4, + "id": "processed_obsidian:obsidian_tiles" + } +} \ No newline at end of file diff --git a/src/main/resources/data/processed_obsidian/recipe/polished_obsidian.json b/src/main/resources/data/processed_obsidian/recipe/polished_obsidian.json new file mode 100644 index 0000000..414435e --- /dev/null +++ b/src/main/resources/data/processed_obsidian/recipe/polished_obsidian.json @@ -0,0 +1,18 @@ +{ + "type": "minecraft:crafting_shaped", + "group": "processed_obsidian", + "category": "building", + "key": { + "S": { + "item": "minecraft:obsidian" + } + }, + "pattern": [ + "SS", + "SS" + ], + "result": { + "count": 4, + "id": "processed_obsidian:polished_obsidian" + } +} \ No newline at end of file diff --git a/src/main/resources/processed_obsidian.mixins.json b/src/main/resources/processed_obsidian.mixins.json new file mode 100644 index 0000000..2186dbd --- /dev/null +++ b/src/main/resources/processed_obsidian.mixins.json @@ -0,0 +1,16 @@ +{ + "required": true, + "minVersion": "0.8", + "package": "ovh.glitchlabs.processed_obsidian.mixin", + "compatibilityLevel": "JAVA_21", + "mixins": [ + ], + "client": [ + ], + "injectors": { + "defaultRequire": 1 + }, + "overwrites": { + "requireAnnotations": true + } +} diff --git a/src/main/templates/META-INF/neoforge.mods.toml b/src/main/templates/META-INF/neoforge.mods.toml new file mode 100644 index 0000000..e385860 --- /dev/null +++ b/src/main/templates/META-INF/neoforge.mods.toml @@ -0,0 +1,79 @@ +# This is an example mods.toml file. It contains the data relating to the loading mods. +# There are several mandatory fields (#mandatory), and many more that are optional (#optional). +# The overall format is standard TOML format, v0.5.0. +# Note that there are a couple of TOML lists in this file. +# Find more information on toml format here: https://github.com/toml-lang/toml +# The name of the mod loader type to load - for regular FML @Mod mods it should be javafml +modLoader = "javafml" #mandatory +# A version range to match for said mod loader - for regular FML @Mod it will be the the FML version. This is currently 47. +loaderVersion = "${loader_version_range}" #mandatory +# The license for you mod. This is mandatory metadata and allows for easier comprehension of your redistributive properties. +# Review your options at https://choosealicense.com/. All rights reserved is the default copyright stance, and is thus the default here. +license = "${mod_license}" +# A URL to refer people to when problems occur with this mod +#issueTrackerURL="https://change.me.to.your.issue.tracker.example.invalid/" #optional +# A list of mods - how many allowed here is determined by the individual mod loader +[[mods]] #mandatory +# The modid of the mod +modId = "${mod_id}" #mandatory +# The version number of the mod +version = "${mod_version}" #mandatory +# A display name for the mod +displayName = "${mod_name}" #mandatory +# A URL to query for updates for this mod. See the JSON update specification https://docs.neoforge.net/docs/misc/updatechecker/ +#updateJSONURL="https://change.me.example.invalid/updates.json" #optional +# A URL for the "homepage" for this mod, displayed in the mod UI +displayURL = "https://www.glitchlabs.ovh" #optional +# A file name (in the root of the mod JAR) containing a logo for display +#logoFile="processed_obsidian.png" #optional +# A text field displayed in the mod UI +#credits="" #optional +# A text field displayed in the mod UI +authors = "${mod_authors}" #optional + +# The description text for the mod (multi line!) (#mandatory) +description = '''${mod_description}''' + +# The [[mixins]] block allows you to declare your mixin config to FML so that it gets loaded. +[[mixins]] +config = "${mod_id}.mixins.json" + +# The [[accessTransformers]] block allows you to declare where your AT file is. +# If this block is omitted, a fallback attempt will be made to load an AT from META-INF/accesstransformer.cfg +#[[accessTransformers]] +#file="META-INF/accesstransformer.cfg" + +# The coremods config file path is not configurable and is always loaded from META-INF/coremods.json + +# A dependency - use the . to indicate dependency for a specific modid. Dependencies are optional. +[[dependencies."${mod_id}"]] #optional +# the modid of the dependency +modId = "neoforge" #mandatory +# The type of the dependency. Can be one of "required", "optional", "incompatible" or "discouraged" (case insensitive). +# 'required' requires the mod to exist, 'optional' does not +# 'incompatible' will prevent the game from loading when the mod exists, and 'discouraged' will show a warning +type = "required" #mandatory +# Optional field describing why the dependency is required or why it is incompatible +# reason="..." +# The version range of the dependency +versionRange = "${neo_version_range}" #mandatory +# An ordering relationship for the dependency. +# BEFORE - This mod is loaded BEFORE the dependency +# AFTER - This mod is loaded AFTER the dependency +ordering = "NONE" +# Side this dependency is applied on - BOTH, CLIENT, or SERVER +side = "BOTH" +# Here's another dependency +[[dependencies."${mod_id}"]] +modId = "minecraft" +type = "required" +# This version range declares a minimum of the current minecraft version up to but not including the next major version +versionRange = "${minecraft_version_range}" +ordering = "NONE" +side = "BOTH" + +# Features are specific properties of the game environment, that you may want to declare you require. This example declares +# that your mod requires GL version 3.2 or higher. Other features will be added. They are side aware so declaring this won't +# stop your mod loading on the server for example. +#[features."${mod_id}"] +#openGLVersion="[3.2,)"