Initial work on the Sanguine Scientiem
Downloaded patchouli and, after lots of remorse, managed to get the beginnings of a guide.
This commit is contained in:
parent
fea894a2b2
commit
c159828248
13
build.gradle
13
build.gradle
|
@ -36,6 +36,8 @@ minecraft {
|
||||||
runs {
|
runs {
|
||||||
client {
|
client {
|
||||||
workingDirectory project.file('run')
|
workingDirectory project.file('run')
|
||||||
|
|
||||||
|
properties 'mixin.env.disableRefMap': 'true'
|
||||||
|
|
||||||
// Recommended logging data for a userdev environment
|
// Recommended logging data for a userdev environment
|
||||||
property 'forge.logging.markers', 'SCAN,REGISTRIES,REGISTRYDUMP'
|
property 'forge.logging.markers', 'SCAN,REGISTRIES,REGISTRYDUMP'
|
||||||
|
@ -52,6 +54,8 @@ minecraft {
|
||||||
|
|
||||||
server {
|
server {
|
||||||
workingDirectory project.file('run')
|
workingDirectory project.file('run')
|
||||||
|
|
||||||
|
properties 'mixin.env.disableRefMap': 'true'
|
||||||
|
|
||||||
// Recommended logging data for a userdev environment
|
// Recommended logging data for a userdev environment
|
||||||
property 'forge.logging.markers', 'SCAN,REGISTRIES,REGISTRYDUMP'
|
property 'forge.logging.markers', 'SCAN,REGISTRIES,REGISTRYDUMP'
|
||||||
|
@ -68,6 +72,8 @@ minecraft {
|
||||||
|
|
||||||
data {
|
data {
|
||||||
workingDirectory project.file('run')
|
workingDirectory project.file('run')
|
||||||
|
|
||||||
|
properties 'mixin.env.disableRefMap': 'true'
|
||||||
|
|
||||||
// Recommended logging data for a userdev environment
|
// Recommended logging data for a userdev environment
|
||||||
property 'forge.logging.markers', 'SCAN,REGISTRIES,REGISTRYDUMP'
|
property 'forge.logging.markers', 'SCAN,REGISTRIES,REGISTRYDUMP'
|
||||||
|
@ -90,6 +96,10 @@ repositories {
|
||||||
maven {
|
maven {
|
||||||
url "http://dvs1.progwml6.com/files/maven/"
|
url "http://dvs1.progwml6.com/files/maven/"
|
||||||
}
|
}
|
||||||
|
maven {
|
||||||
|
name = "The Loader"
|
||||||
|
url = "https://maven.blamejared.com"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
|
@ -105,6 +115,9 @@ dependencies {
|
||||||
|
|
||||||
compileOnly fg.deobf("mezz.jei:jei-1.16.2:7.1.3.19:api")
|
compileOnly fg.deobf("mezz.jei:jei-1.16.2:7.1.3.19:api")
|
||||||
runtimeOnly fg.deobf("mezz.jei:jei-1.16.2:7.1.3.19")
|
runtimeOnly fg.deobf("mezz.jei:jei-1.16.2:7.1.3.19")
|
||||||
|
|
||||||
|
compileOnly fg.deobf("vazkii.patchouli:Patchouli:${patchouli_version}:api")
|
||||||
|
runtimeOnly fg.deobf("vazkii.patchouli:Patchouli:${patchouli_version}")
|
||||||
// You may put jars on which you depend on in ./libs or you may define them like so..
|
// You may put jars on which you depend on in ./libs or you may define them like so..
|
||||||
// compile "some.group:artifact:version:classifier"
|
// compile "some.group:artifact:version:classifier"
|
||||||
// compile "some.group:artifact:version"
|
// compile "some.group:artifact:version"
|
||||||
|
|
|
@ -6,4 +6,5 @@ org.gradle.daemon=false
|
||||||
minecraft_version=1.16.3
|
minecraft_version=1.16.3
|
||||||
|
|
||||||
#Mod dependencies
|
#Mod dependencies
|
||||||
jei_version=7.6.0.49
|
jei_version=7.6.0.49
|
||||||
|
patchouli_version=1.16.2-47-SNAPSHOT
|
|
@ -16,6 +16,6 @@
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.MAIN_TYPE" value="net.minecraftforge.userdev.LaunchTesting"/>
|
<stringAttribute key="org.eclipse.jdt.launching.MAIN_TYPE" value="net.minecraftforge.userdev.LaunchTesting"/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.PROGRAM_ARGUMENTS" value=""/>
|
<stringAttribute key="org.eclipse.jdt.launching.PROGRAM_ARGUMENTS" value=""/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.PROJECT_ATTR" value="BloodMagic3"/>
|
<stringAttribute key="org.eclipse.jdt.launching.PROJECT_ATTR" value="BloodMagic3"/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.VM_ARGUMENTS" value="-Dforge.logging.console.level=debug -Dforge.logging.markers=SCAN,REGISTRIES,REGISTRYDUMP -XX:HeapDumpPath=MojangTricksIntelDriversForPerformance_javaw.exe_minecraft.exe.heapdump "-Dos.name=Windows 10" -Dos.version=10.0"/>
|
<stringAttribute key="org.eclipse.jdt.launching.VM_ARGUMENTS" value="-Dforge.logging.console.level=debug -Dmixin.env.disableRefMap=true -Dforge.logging.markers=SCAN,REGISTRIES,REGISTRYDUMP -XX:HeapDumpPath=MojangTricksIntelDriversForPerformance_javaw.exe_minecraft.exe.heapdump "-Dos.name=Windows 10" -Dos.version=10.0"/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.WORKING_DIRECTORY" value="C:\Users\Scott\Desktop\BloodMagic3\run"/>
|
<stringAttribute key="org.eclipse.jdt.launching.WORKING_DIRECTORY" value="C:\Users\Scott\Desktop\BloodMagic3\run"/>
|
||||||
</launchConfiguration>
|
</launchConfiguration>
|
||||||
|
|
|
@ -1,11 +1,5 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
<launchConfiguration type="org.eclipse.jdt.launching.localJavaApplication">
|
<launchConfiguration type="org.eclipse.jdt.launching.localJavaApplication">
|
||||||
<listAttribute key="org.eclipse.debug.core.MAPPED_RESOURCE_PATHS">
|
|
||||||
<listEntry value="/BloodMagic3"/>
|
|
||||||
</listAttribute>
|
|
||||||
<listAttribute key="org.eclipse.debug.core.MAPPED_RESOURCE_TYPES">
|
|
||||||
<listEntry value="4"/>
|
|
||||||
</listAttribute>
|
|
||||||
<mapAttribute key="org.eclipse.debug.core.environmentVariables">
|
<mapAttribute key="org.eclipse.debug.core.environmentVariables">
|
||||||
<mapEntry key="FORGE_GROUP" value="net.minecraftforge"/>
|
<mapEntry key="FORGE_GROUP" value="net.minecraftforge"/>
|
||||||
<mapEntry key="FORGE_VERSION" value="34.1.11"/>
|
<mapEntry key="FORGE_VERSION" value="34.1.11"/>
|
||||||
|
@ -15,13 +9,10 @@
|
||||||
<mapEntry key="MOD_CLASSES" value="bloodmagic%%C:\Users\Scott\Desktop\BloodMagic3\bin\main;bloodmagic%%C:\Users\Scott\Desktop\BloodMagic3\bin\main"/>
|
<mapEntry key="MOD_CLASSES" value="bloodmagic%%C:\Users\Scott\Desktop\BloodMagic3\bin\main;bloodmagic%%C:\Users\Scott\Desktop\BloodMagic3\bin\main"/>
|
||||||
<mapEntry key="target" value="fmluserdevdata"/>
|
<mapEntry key="target" value="fmluserdevdata"/>
|
||||||
</mapAttribute>
|
</mapAttribute>
|
||||||
<booleanAttribute key="org.eclipse.jdt.launching.ATTR_SHOW_CODEDETAILS_IN_EXCEPTION_MESSAGES" value="true"/>
|
|
||||||
<booleanAttribute key="org.eclipse.jdt.launching.ATTR_USE_CLASSPATH_ONLY_JAR" value="false"/>
|
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.CLASSPATH_PROVIDER" value="org.eclipse.buildship.core.classpathprovider"/>
|
<stringAttribute key="org.eclipse.jdt.launching.CLASSPATH_PROVIDER" value="org.eclipse.buildship.core.classpathprovider"/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.MAIN_TYPE" value="net.minecraftforge.userdev.LaunchTesting"/>
|
<stringAttribute key="org.eclipse.jdt.launching.MAIN_TYPE" value="net.minecraftforge.userdev.LaunchTesting"/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.MODULE_NAME" value="BloodMagic3"/>
|
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.PROGRAM_ARGUMENTS" value="--mod bloodmagic --all --output C:\Users\Scott\Desktop\BloodMagic3\src\generated\resources --existing C:\Users\Scott\Desktop\BloodMagic3\src\main\resources"/>
|
<stringAttribute key="org.eclipse.jdt.launching.PROGRAM_ARGUMENTS" value="--mod bloodmagic --all --output C:\Users\Scott\Desktop\BloodMagic3\src\generated\resources --existing C:\Users\Scott\Desktop\BloodMagic3\src\main\resources"/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.PROJECT_ATTR" value="BloodMagic3"/>
|
<stringAttribute key="org.eclipse.jdt.launching.PROJECT_ATTR" value="BloodMagic3"/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.VM_ARGUMENTS" value="-Dforge.logging.console.level=debug -Dforge.logging.markers=SCAN,REGISTRIES,REGISTRYDUMP"/>
|
<stringAttribute key="org.eclipse.jdt.launching.VM_ARGUMENTS" value="-Dforge.logging.console.level=debug -Dmixin.env.disableRefMap=true -Dforge.logging.markers=SCAN,REGISTRIES,REGISTRYDUMP"/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.WORKING_DIRECTORY" value="C:\Users\Scott\Desktop\BloodMagic3\run"/>
|
<stringAttribute key="org.eclipse.jdt.launching.WORKING_DIRECTORY" value="C:\Users\Scott\Desktop\BloodMagic3\run"/>
|
||||||
</launchConfiguration>
|
</launchConfiguration>
|
||||||
|
|
|
@ -1,11 +1,5 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
<launchConfiguration type="org.eclipse.jdt.launching.localJavaApplication">
|
<launchConfiguration type="org.eclipse.jdt.launching.localJavaApplication">
|
||||||
<listAttribute key="org.eclipse.debug.core.MAPPED_RESOURCE_PATHS">
|
|
||||||
<listEntry value="/BloodMagic3"/>
|
|
||||||
</listAttribute>
|
|
||||||
<listAttribute key="org.eclipse.debug.core.MAPPED_RESOURCE_TYPES">
|
|
||||||
<listEntry value="4"/>
|
|
||||||
</listAttribute>
|
|
||||||
<mapAttribute key="org.eclipse.debug.core.environmentVariables">
|
<mapAttribute key="org.eclipse.debug.core.environmentVariables">
|
||||||
<mapEntry key="FORGE_GROUP" value="net.minecraftforge"/>
|
<mapEntry key="FORGE_GROUP" value="net.minecraftforge"/>
|
||||||
<mapEntry key="FORGE_VERSION" value="34.1.11"/>
|
<mapEntry key="FORGE_VERSION" value="34.1.11"/>
|
||||||
|
@ -15,12 +9,10 @@
|
||||||
<mapEntry key="MOD_CLASSES" value="bloodmagic%%C:\Users\Scott\Desktop\BloodMagic3\bin\main;bloodmagic%%C:\Users\Scott\Desktop\BloodMagic3\bin\main"/>
|
<mapEntry key="MOD_CLASSES" value="bloodmagic%%C:\Users\Scott\Desktop\BloodMagic3\bin\main;bloodmagic%%C:\Users\Scott\Desktop\BloodMagic3\bin\main"/>
|
||||||
<mapEntry key="target" value="fmluserdevserver"/>
|
<mapEntry key="target" value="fmluserdevserver"/>
|
||||||
</mapAttribute>
|
</mapAttribute>
|
||||||
<booleanAttribute key="org.eclipse.jdt.launching.ATTR_SHOW_CODEDETAILS_IN_EXCEPTION_MESSAGES" value="true"/>
|
|
||||||
<booleanAttribute key="org.eclipse.jdt.launching.ATTR_USE_CLASSPATH_ONLY_JAR" value="false"/>
|
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.CLASSPATH_PROVIDER" value="org.eclipse.buildship.core.classpathprovider"/>
|
<stringAttribute key="org.eclipse.jdt.launching.CLASSPATH_PROVIDER" value="org.eclipse.buildship.core.classpathprovider"/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.MAIN_TYPE" value="net.minecraftforge.userdev.LaunchTesting"/>
|
<stringAttribute key="org.eclipse.jdt.launching.MAIN_TYPE" value="net.minecraftforge.userdev.LaunchTesting"/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.MODULE_NAME" value="BloodMagic3"/>
|
<stringAttribute key="org.eclipse.jdt.launching.PROGRAM_ARGUMENTS" value=""/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.PROJECT_ATTR" value="BloodMagic3"/>
|
<stringAttribute key="org.eclipse.jdt.launching.PROJECT_ATTR" value="BloodMagic3"/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.VM_ARGUMENTS" value="-Dforge.logging.console.level=debug -Dforge.logging.markers=SCAN,REGISTRIES,REGISTRYDUMP"/>
|
<stringAttribute key="org.eclipse.jdt.launching.VM_ARGUMENTS" value="-Dforge.logging.console.level=debug -Dmixin.env.disableRefMap=true -Dforge.logging.markers=SCAN,REGISTRIES,REGISTRYDUMP"/>
|
||||||
<stringAttribute key="org.eclipse.jdt.launching.WORKING_DIRECTORY" value="C:\Users\Scott\Desktop\BloodMagic3\run"/>
|
<stringAttribute key="org.eclipse.jdt.launching.WORKING_DIRECTORY" value="C:\Users\Scott\Desktop\BloodMagic3\run"/>
|
||||||
</launchConfiguration>
|
</launchConfiguration>
|
||||||
|
|
|
@ -18,7 +18,7 @@ e1a98bd53fca155e4bbb03c1e548341af0f84bd7 assets/bloodmagic/blockstates/masterrit
|
||||||
b03040d7a168653bf8df3600033b8fde2383db30 assets/bloodmagic/blockstates/selfsacrificerune.json
|
b03040d7a168653bf8df3600033b8fde2383db30 assets/bloodmagic/blockstates/selfsacrificerune.json
|
||||||
487ffdc02ab7b65aafcb932e3b5cf6ea0500b21d assets/bloodmagic/blockstates/speedrune.json
|
487ffdc02ab7b65aafcb932e3b5cf6ea0500b21d assets/bloodmagic/blockstates/speedrune.json
|
||||||
e6d9cf699667aaa47efff37b2b033895dee29c15 assets/bloodmagic/blockstates/waterritualstone.json
|
e6d9cf699667aaa47efff37b2b033895dee29c15 assets/bloodmagic/blockstates/waterritualstone.json
|
||||||
2fd83f690f0a9af248196620b528a4f9717962a1 assets/bloodmagic/lang/en_us.json
|
fb7a615c3c1cf62b3a9c4a3ef701d22e7b45108c assets/bloodmagic/lang/en_us.json
|
||||||
34445195b9f2459475cde53454bc8e37d32865d7 assets/bloodmagic/models/block/accelerationrune.json
|
34445195b9f2459475cde53454bc8e37d32865d7 assets/bloodmagic/models/block/accelerationrune.json
|
||||||
bcdbccc49d4509571be6988762ab87126275a4c8 assets/bloodmagic/models/block/airritualstone.json
|
bcdbccc49d4509571be6988762ab87126275a4c8 assets/bloodmagic/models/block/airritualstone.json
|
||||||
adf6c0b1e25451609486dc8c8cfbd9cf0f8c67f4 assets/bloodmagic/models/block/alchemicalreactionchamber.json
|
adf6c0b1e25451609486dc8c8cfbd9cf0f8c67f4 assets/bloodmagic/models/block/alchemicalreactionchamber.json
|
||||||
|
|
|
@ -25,6 +25,8 @@
|
||||||
"chat.bloodmagic.ritual.prevent": "The ritual is actively resisting you!",
|
"chat.bloodmagic.ritual.prevent": "The ritual is actively resisting you!",
|
||||||
"chat.bloodmagic.ritual.weak": "You feel a push, but are too weak to perform this ritual.",
|
"chat.bloodmagic.ritual.weak": "You feel a push, but are too weak to perform this ritual.",
|
||||||
"gui.bloodmagic.empty": "Empty",
|
"gui.bloodmagic.empty": "Empty",
|
||||||
|
"guide.bloodmagic.landing_text": "\"It is my dear hope that by holding this tome in your hands, I may impart the knowledge of the lost art that is Blood Magic\"$(br)$(o)- Magus Arcana$()",
|
||||||
|
"guide.bloodmagic.name": "Sanguine Scientiem",
|
||||||
"item.bloodmagic.activationcrystalawakened": "Awakened Activation Crystal",
|
"item.bloodmagic.activationcrystalawakened": "Awakened Activation Crystal",
|
||||||
"item.bloodmagic.activationcrystalcreative": "Creative Activation Crystal",
|
"item.bloodmagic.activationcrystalcreative": "Creative Activation Crystal",
|
||||||
"item.bloodmagic.activationcrystalweak": "Weak Activation Crystal",
|
"item.bloodmagic.activationcrystalweak": "Weak Activation Crystal",
|
||||||
|
|
|
@ -15,7 +15,9 @@ import com.google.common.collect.ImmutableSet;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.item.crafting.Ingredient;
|
import net.minecraft.item.crafting.Ingredient;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
import net.minecraftforge.fluids.FluidStack;
|
||||||
import wayoftime.bloodmagic.api.IBloodMagicRecipeRegistrar;
|
import wayoftime.bloodmagic.api.IBloodMagicRecipeRegistrar;
|
||||||
|
import wayoftime.bloodmagic.api.impl.recipe.RecipeARC;
|
||||||
import wayoftime.bloodmagic.api.impl.recipe.RecipeAlchemyArray;
|
import wayoftime.bloodmagic.api.impl.recipe.RecipeAlchemyArray;
|
||||||
import wayoftime.bloodmagic.api.impl.recipe.RecipeBloodAltar;
|
import wayoftime.bloodmagic.api.impl.recipe.RecipeBloodAltar;
|
||||||
import wayoftime.bloodmagic.api.impl.recipe.RecipeTartaricForge;
|
import wayoftime.bloodmagic.api.impl.recipe.RecipeTartaricForge;
|
||||||
|
@ -250,6 +252,40 @@ public class BloodMagicRecipeRegistrar implements IBloodMagicRecipeRegistrar
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public RecipeARC getARC(World world, @Nonnull ItemStack input, @Nonnull ItemStack arcToolInput, @Nonnull FluidStack inputFluid)
|
||||||
|
{
|
||||||
|
Preconditions.checkNotNull(input, "input cannot be null.");
|
||||||
|
Preconditions.checkNotNull(arcToolInput, "tool cannot be null.");
|
||||||
|
if (input.isEmpty() || arcToolInput.isEmpty())
|
||||||
|
return null;
|
||||||
|
|
||||||
|
List<RecipeARC> arcRecipes = world.getRecipeManager().getRecipesForType(BloodMagicRecipeType.ARC);
|
||||||
|
|
||||||
|
for (RecipeARC recipe : arcRecipes)
|
||||||
|
{
|
||||||
|
if (recipe.getInput().test(input) && recipe.getTool().test(arcToolInput))
|
||||||
|
{
|
||||||
|
if (recipe.getFluidIngredient() == null)
|
||||||
|
{
|
||||||
|
return recipe;
|
||||||
|
} else if (recipe.getFluidIngredient().test(inputFluid))
|
||||||
|
{
|
||||||
|
return recipe;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// if (input.isEmpty())
|
||||||
|
// return null;
|
||||||
|
//
|
||||||
|
// List<RecipeBloodAltar> altarRecipes = world.getRecipeManager().getRecipesForType(BloodMagicRecipeType.ALTAR);
|
||||||
|
//
|
||||||
|
// for (RecipeBloodAltar recipe : altarRecipes) if (recipe.getInput().test(input))
|
||||||
|
// return recipe;
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
// @Nullable
|
// @Nullable
|
||||||
// public RecipeAlchemyTable getAlchemyTable(@Nonnull List<ItemStack> input)
|
// public RecipeAlchemyTable getAlchemyTable(@Nonnull List<ItemStack> input)
|
||||||
// {
|
// {
|
||||||
|
|
|
@ -103,6 +103,8 @@ public class Constants
|
||||||
public static final String SOUL_FORGE_BURN = "burnTime";
|
public static final String SOUL_FORGE_BURN = "burnTime";
|
||||||
public static final String SOUL_FORGE_CONSUMED = "consumedSouls";
|
public static final String SOUL_FORGE_CONSUMED = "consumedSouls";
|
||||||
|
|
||||||
|
public static final String ARC_PROGRESS = "progress";
|
||||||
|
|
||||||
public static final String ROUTING_MASTER = "master";
|
public static final String ROUTING_MASTER = "master";
|
||||||
public static final String ROUTING_CONNECTION = "connections";
|
public static final String ROUTING_CONNECTION = "connections";
|
||||||
public static final String ROUTING_PRIORITY = "prioritiesPeople";
|
public static final String ROUTING_PRIORITY = "prioritiesPeople";
|
||||||
|
|
|
@ -65,11 +65,28 @@ public abstract class RecipeARC extends BloodMagicRecipe
|
||||||
return input;
|
return input;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nonnull
|
||||||
|
public final Ingredient getTool()
|
||||||
|
{
|
||||||
|
return arc_tool;
|
||||||
|
}
|
||||||
|
|
||||||
|
public final FluidStackIngredient getFluidIngredient()
|
||||||
|
{
|
||||||
|
return inputFluid;
|
||||||
|
}
|
||||||
|
|
||||||
|
public final FluidStack getFluidOutput()
|
||||||
|
{
|
||||||
|
return outputFluid;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final NonNullList<Ingredient> getIngredients()
|
public final NonNullList<Ingredient> getIngredients()
|
||||||
{
|
{
|
||||||
NonNullList<Ingredient> list = NonNullList.create();
|
NonNullList<Ingredient> list = NonNullList.create();
|
||||||
list.add(getInput());
|
list.add(getInput());
|
||||||
|
list.add(getTool());
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -136,6 +136,10 @@ public class GeneratorLanguage extends LanguageProvider
|
||||||
add("ritual.bloodmagic.altarBuilderRitual", "The Assembly of the High Altar");
|
add("ritual.bloodmagic.altarBuilderRitual", "The Assembly of the High Altar");
|
||||||
add("ritual.bloodmagic.portalRitual", "The Gate of the Fold");
|
add("ritual.bloodmagic.portalRitual", "The Gate of the Fold");
|
||||||
|
|
||||||
|
// Guide
|
||||||
|
add("guide.bloodmagic.name", "Sanguine Scientiem");
|
||||||
|
add("guide.bloodmagic.landing_text", "\"It is my dear hope that by holding this tome in your hands, I may impart the knowledge of the lost art that is Blood Magic\"$(br)$(o)- Magus Arcana$()");
|
||||||
|
|
||||||
// Block names
|
// Block names
|
||||||
addBlock(BloodMagicBlocks.BLANK_RUNE, "Blank Rune");
|
addBlock(BloodMagicBlocks.BLANK_RUNE, "Blank Rune");
|
||||||
addBlock(BloodMagicBlocks.SPEED_RUNE, "Speed Rune");
|
addBlock(BloodMagicBlocks.SPEED_RUNE, "Speed Rune");
|
||||||
|
|
|
@ -23,6 +23,8 @@ import net.minecraftforge.fluids.capability.IFluidHandlerItem;
|
||||||
import net.minecraftforge.fluids.capability.templates.FluidTank;
|
import net.minecraftforge.fluids.capability.templates.FluidTank;
|
||||||
import net.minecraftforge.items.ItemHandlerHelper;
|
import net.minecraftforge.items.ItemHandlerHelper;
|
||||||
import net.minecraftforge.registries.ObjectHolder;
|
import net.minecraftforge.registries.ObjectHolder;
|
||||||
|
import wayoftime.bloodmagic.api.impl.BloodMagicAPI;
|
||||||
|
import wayoftime.bloodmagic.api.impl.recipe.RecipeARC;
|
||||||
import wayoftime.bloodmagic.tile.contailer.ContainerAlchemicalReactionChamber;
|
import wayoftime.bloodmagic.tile.contailer.ContainerAlchemicalReactionChamber;
|
||||||
import wayoftime.bloodmagic.util.Constants;
|
import wayoftime.bloodmagic.util.Constants;
|
||||||
import wayoftime.bloodmagic.util.MultiSlotItemHandler;
|
import wayoftime.bloodmagic.util.MultiSlotItemHandler;
|
||||||
|
@ -42,7 +44,7 @@ public class TileAlchemicalReactionChamber extends TileInventory implements ITic
|
||||||
public FluidTank inputTank = new FluidTank(FluidAttributes.BUCKET_VOLUME * 20);
|
public FluidTank inputTank = new FluidTank(FluidAttributes.BUCKET_VOLUME * 20);
|
||||||
public FluidTank outputTank = new FluidTank(FluidAttributes.BUCKET_VOLUME * 20);
|
public FluidTank outputTank = new FluidTank(FluidAttributes.BUCKET_VOLUME * 20);
|
||||||
|
|
||||||
public int burnTime = 0;
|
public double currentProgress = 0;
|
||||||
|
|
||||||
public TileAlchemicalReactionChamber(TileEntityType<?> type)
|
public TileAlchemicalReactionChamber(TileEntityType<?> type)
|
||||||
{
|
{
|
||||||
|
@ -59,7 +61,7 @@ public class TileAlchemicalReactionChamber extends TileInventory implements ITic
|
||||||
{
|
{
|
||||||
super.deserialize(tag);
|
super.deserialize(tag);
|
||||||
|
|
||||||
burnTime = tag.getInt(Constants.NBT.SOUL_FORGE_BURN);
|
currentProgress = tag.getDouble(Constants.NBT.ARC_PROGRESS);
|
||||||
|
|
||||||
CompoundNBT inputTankTag = tag.getCompound("inputtank");
|
CompoundNBT inputTankTag = tag.getCompound("inputtank");
|
||||||
inputTank.readFromNBT(inputTankTag);
|
inputTank.readFromNBT(inputTankTag);
|
||||||
|
@ -73,7 +75,7 @@ public class TileAlchemicalReactionChamber extends TileInventory implements ITic
|
||||||
{
|
{
|
||||||
super.serialize(tag);
|
super.serialize(tag);
|
||||||
|
|
||||||
tag.putInt(Constants.NBT.SOUL_FORGE_BURN, burnTime);
|
tag.putDouble(Constants.NBT.ARC_PROGRESS, currentProgress);
|
||||||
|
|
||||||
CompoundNBT inputTankTag = new CompoundNBT();
|
CompoundNBT inputTankTag = new CompoundNBT();
|
||||||
inputTank.writeToNBT(inputTankTag);
|
inputTank.writeToNBT(inputTankTag);
|
||||||
|
@ -165,6 +167,15 @@ public class TileAlchemicalReactionChamber extends TileInventory implements ITic
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ItemStack inputStack = this.getStackInSlot(INPUT_SLOT);
|
||||||
|
ItemStack toolStack = this.getStackInSlot(ARC_TOOL_SLOT);
|
||||||
|
RecipeARC recipe = BloodMagicAPI.INSTANCE.getRecipeRegistrar().getARC(world, inputStack, toolStack, inputTank.getFluid());
|
||||||
|
if (recipe != null && outputSlotHandler.canTransferAllItemsToSlots(recipe.getAllListedOutputs(), true))
|
||||||
|
{
|
||||||
|
// We have enough fluid (if applicable) and the theoretical outputs can fit.
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
for (int i = 0; i < NUM_OUTPUTS; i++)
|
for (int i = 0; i < NUM_OUTPUTS; i++)
|
||||||
{
|
{
|
||||||
this.setInventorySlotContents(OUTPUT_SLOT + i, outputSlotHandler.getStackInSlot(i));
|
this.setInventorySlotContents(OUTPUT_SLOT + i, outputSlotHandler.getStackInSlot(i));
|
||||||
|
@ -173,47 +184,72 @@ public class TileAlchemicalReactionChamber extends TileInventory implements ITic
|
||||||
// FluidUtil.tryEmptyContainer(container, fluidDestination, maxAmount, player, doDrain)
|
// FluidUtil.tryEmptyContainer(container, fluidDestination, maxAmount, player, doDrain)
|
||||||
}
|
}
|
||||||
|
|
||||||
// private boolean canCraft(RecipeTartaricForge recipe)
|
private boolean canCraft(RecipeARC recipe, MultiSlotItemHandler outputSlotHandler)
|
||||||
// {
|
{
|
||||||
// if (recipe == null)
|
if (recipe == null)
|
||||||
// return false;
|
return false;
|
||||||
//
|
|
||||||
// ItemStack currentOutputStack = getStackInSlot(outputSlot);
|
if (outputSlotHandler.canTransferAllItemsToSlots(recipe.getAllListedOutputs(), true))
|
||||||
// if (recipe.getOutput().isEmpty())
|
{
|
||||||
// return false;
|
FluidStack outputStack = recipe.getFluidOutput();
|
||||||
// if (currentOutputStack.isEmpty())
|
return outputStack.isEmpty() ? true
|
||||||
// return true;
|
: outputTank.fill(outputStack, FluidAction.SIMULATE) >= outputStack.getAmount();
|
||||||
// if (!currentOutputStack.isItemEqual(recipe.getOutput()))
|
}
|
||||||
// return false;
|
|
||||||
// int result = currentOutputStack.getCount() + recipe.getOutput().getCount();
|
return false;
|
||||||
// return result <= getInventoryStackLimit() && result <= currentOutputStack.getMaxStackSize();
|
}
|
||||||
//
|
|
||||||
// }
|
public void craftItem(RecipeARC recipe, MultiSlotItemHandler outputSlotHandler)
|
||||||
//
|
{
|
||||||
// public void craftItem(RecipeTartaricForge recipe)
|
if (this.canCraft(recipe, outputSlotHandler))
|
||||||
// {
|
{
|
||||||
// if (this.canCraft(recipe))
|
outputSlotHandler.canTransferAllItemsToSlots(recipe.getAllOutputs(world.rand), false);
|
||||||
// {
|
outputTank.fill(recipe.getFluidOutput().copy(), FluidAction.EXECUTE);
|
||||||
// ItemStack currentOutputStack = getStackInSlot(outputSlot);
|
consumeInventory();
|
||||||
//
|
}
|
||||||
// List<ItemStack> inputList = new ArrayList<>();
|
}
|
||||||
// for (int i = 0; i < 4; i++) if (!getStackInSlot(i).isEmpty())
|
|
||||||
// inputList.add(getStackInSlot(i).copy());
|
public void consumeInventory()
|
||||||
//
|
{
|
||||||
// BloodMagicCraftedEvent.SoulForge event = new BloodMagicCraftedEvent.SoulForge(recipe.getOutput().copy(), inputList.toArray(new ItemStack[0]));
|
ItemStack inputStack = getStackInSlot(INPUT_SLOT);
|
||||||
// MinecraftForge.EVENT_BUS.post(event);
|
if (!inputStack.isEmpty())
|
||||||
//
|
{
|
||||||
// if (currentOutputStack.isEmpty())
|
if (inputStack.getItem().hasContainerItem(inputStack))
|
||||||
// {
|
{
|
||||||
// setInventorySlotContents(outputSlot, event.getOutput());
|
setInventorySlotContents(INPUT_SLOT, inputStack.getItem().getContainerItem(inputStack));
|
||||||
// } else if (ItemHandlerHelper.canItemStacksStack(currentOutputStack, event.getOutput()))
|
} else
|
||||||
// {
|
{
|
||||||
// currentOutputStack.grow(event.getOutput().getCount());
|
inputStack.shrink(1);
|
||||||
// }
|
if (inputStack.isEmpty())
|
||||||
//
|
{
|
||||||
// consumeInventory();
|
setInventorySlotContents(INPUT_SLOT, ItemStack.EMPTY);
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ItemStack toolStack = getStackInSlot(ARC_TOOL_SLOT);
|
||||||
|
if (!toolStack.isEmpty())
|
||||||
|
{
|
||||||
|
if (toolStack.isDamageable())
|
||||||
|
{
|
||||||
|
toolStack.setDamage(toolStack.getDamage() + 1);
|
||||||
|
if (toolStack.getDamage() >= toolStack.getMaxDamage())
|
||||||
|
{
|
||||||
|
setInventorySlotContents(ARC_TOOL_SLOT, ItemStack.EMPTY);
|
||||||
|
}
|
||||||
|
} else if (toolStack.getItem().hasContainerItem(toolStack))
|
||||||
|
{
|
||||||
|
setInventorySlotContents(ARC_TOOL_SLOT, toolStack.getItem().getContainerItem(inputStack));
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
toolStack.shrink(1);
|
||||||
|
if (toolStack.isEmpty())
|
||||||
|
{
|
||||||
|
setInventorySlotContents(ARC_TOOL_SLOT, ItemStack.EMPTY);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Container createMenu(int p_createMenu_1_, PlayerInventory p_createMenu_2_, PlayerEntity p_createMenu_3_)
|
public Container createMenu(int p_createMenu_1_, PlayerInventory p_createMenu_2_, PlayerEntity p_createMenu_3_)
|
||||||
|
|
|
@ -176,7 +176,6 @@ public class MultiSlotItemHandler implements IItemHandler
|
||||||
copyList[slot] = copy;
|
copyList[slot] = copy;
|
||||||
}
|
}
|
||||||
stack = ItemStack.EMPTY;
|
stack = ItemStack.EMPTY;
|
||||||
// System.out.println("Count: " + stack.getCount() + ", m: " + m);
|
|
||||||
|
|
||||||
break slots;
|
break slots;
|
||||||
} else
|
} else
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 30 KiB |
Binary file not shown.
After Width: | Height: | Size: 39 KiB |
Binary file not shown.
After Width: | Height: | Size: 27 KiB |
Binary file not shown.
After Width: | Height: | Size: 58 KiB |
Binary file not shown.
After Width: | Height: | Size: 48 KiB |
|
@ -0,0 +1,6 @@
|
||||||
|
{
|
||||||
|
"parent": "minecraft:item/handheld",
|
||||||
|
"textures": {
|
||||||
|
"layer0": "bloodmagic:item/sanguinebook"
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,9 @@
|
||||||
|
{
|
||||||
|
"name": "guide.bloodmagic.name",
|
||||||
|
"subtitle": "Alchemical Wizardry",
|
||||||
|
"landing_text": "guide.bloodmagic.landing_text",
|
||||||
|
"version": 1,
|
||||||
|
"creative_tab": "bloodmagictab",
|
||||||
|
"model": "bloodmagic:book",
|
||||||
|
"show_progress": true
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
{
|
||||||
|
"name": "Alchemy Arrays",
|
||||||
|
"description": "Alchemy Arrays are simple effects that originate from circles that are drawn on the ground using $(l:alchemyarray/arcaneash)Arcane Ashes.$(/l) While they are simple to build, they can be really useful in both early game and late game applications.",
|
||||||
|
"icon": "bloodmagic:arcaneashes",
|
||||||
|
"sortnum": 3
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
{
|
||||||
|
"name": "Blood Altars",
|
||||||
|
"description": "",
|
||||||
|
"icon": "bloodmagic:altar",
|
||||||
|
"sortnum": 2
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
{
|
||||||
|
"name": "Demon Will",
|
||||||
|
"description": "",
|
||||||
|
"icon": "bloodmagic:basemonstersoul",
|
||||||
|
"sortnum": 1
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
{
|
||||||
|
"name": "Sigils",
|
||||||
|
"description": "",
|
||||||
|
"icon": "bloodmagic:divinationsigil",
|
||||||
|
"sortnum": 4
|
||||||
|
}
|
|
@ -0,0 +1,30 @@
|
||||||
|
{
|
||||||
|
"name": "Alchemy Array Basics",
|
||||||
|
"icon": "bloodmagic:arcaneashes",
|
||||||
|
"category": "alchemyarray",
|
||||||
|
"pages": [
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": "$(item)Arcane Ashes$() is an item that is pivotal in the creation of Alchemy Arrays. $(item)Arcane Ashes$() can be crafted in the $(l:demonwill/soulforge)Hellfire Forge$(/l) using some early game items. The recipe can be found in JEI."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": "In order to create an Alchemy Array, right click the top of the ground with the $(item)Arcane Ashes$() (although any solid block face works) - this will consume 1 durability out of 20 from the $(item)Arcane Ashes$() and draw a simple Alchemy Array, that by itself has no effects.$(bl2)When you click on the Alchemy Array, it will consume a single item from the stack in your hand and hold it in the array. These items are then used to determine the Alchemy Array's effect."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "image",
|
||||||
|
"images": [
|
||||||
|
"bloodmagic:images/entries/alchemyarray/simple_array.png",
|
||||||
|
"bloodmagic:images/entries/alchemyarray/divination_array_1.png",
|
||||||
|
"bloodmagic:images/entries/alchemyarray/divination_array_2.png"
|
||||||
|
],
|
||||||
|
"title": "Alchemy Array",
|
||||||
|
"border": true,
|
||||||
|
"text": "Alchemy Array showing array with: no inputs; only the base item; both base and catalyst."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": "Each effect requires two items: a base and a catalyst. The base is the first item that you click the array with after it is drawn, and the catalyst is the second item. When you apply the input, the design of the array will change if it is valid, and the array will start activating once you apply the catalyst.$(br2)You can have arrays that range from $(l:alchemyarray/craftingarray)crafting arrays$(/l) to even teleportation arrays."
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,15 @@
|
||||||
|
{
|
||||||
|
"name": "Crafting with Arrays",
|
||||||
|
"icon": "bloodmagic:divinationsigil",
|
||||||
|
"category": "alchemyarray",
|
||||||
|
"pages": [
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": "$(1)Alchemy Arrays of Crafting$() are one of the simplest forms of array. These arrays inscribe the $(item)base item$() onto the $(item)catalyst$(), transforming them both into a useful item (after a small, pretty animation)."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": "While some of these resulting items can be crafted $(l:sigil/divination)using very simple ingredients$(/l), others require additional steps to create useful items."
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,15 @@
|
||||||
|
{
|
||||||
|
"name": "The Blood Altar",
|
||||||
|
"icon": "bloodmagic:altar",
|
||||||
|
"category": "altar",
|
||||||
|
"pages": [
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": ""
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,27 @@
|
||||||
|
{
|
||||||
|
"name": "Demon Will",
|
||||||
|
"icon": "bloodmagic:basemonstersoul",
|
||||||
|
"category": "demonwill",
|
||||||
|
"pages": [
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": "To get started with $(6)Blood Magic$() you need to gather a few $(item)Demon Wills$(). There are two ways to get Demon Will:$(br)$(li)Killing a mob that has been snared and is killed when white particle effects appear.$(li)By killing a hostile mob with a $(l:demonwill/sentientsword)$(item)Sentient Sword$(/l)$().$(br)Since you are just beginning to use the mod, you will not yet have a $(l:demonwill/sentientsword)$(item)Sentient Sword$(/l), and thus will need to use"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": "a $(l:demonwill/soulsnare)$(item)Soul Snare$(/l).$(br2)Demon Will is a recurring resource in $(6)Blood Magic$() that is used in crafting for several advanced blocks, such as the $(l:demonwill/soulforge)$(item)Hellfire Forge,$(/l) as well as items like the $(l:demonwill/sentientsword)$(item)Sentient Sword.$(/l)$(br2)In the lore of $(6)Blood Magic$(), $(1)Demon Will$() is the residual effect of when a demon imbues its will into the bodies of the dead."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "image",
|
||||||
|
"images": [
|
||||||
|
"bloodmagic:images/entries/demonwill/demonwill.png"
|
||||||
|
],
|
||||||
|
"title": "Demon Will",
|
||||||
|
"border": true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": "Once you have some Will, you can use it to craft useful tools in the $(item)Hellfire Forge$(). Also, it is suggested to gather two $(item)Demon Will$() items before coming back to base, since you need to have one in order to craft your first $(l:altar/bloodaltar)Blood Altar.$(/l)"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,15 @@
|
||||||
|
{
|
||||||
|
"name": "Your First Will2",
|
||||||
|
"icon": "bloodmagic:soulsnare",
|
||||||
|
"category": "demonwill",
|
||||||
|
"pages": [
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": "The $(item)Soul Snare$() is a fun thing with a fun name."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "crafting",
|
||||||
|
"recipe": "bloodmagic:soul_snare"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,15 @@
|
||||||
|
{
|
||||||
|
"name": "Hellfire Forge",
|
||||||
|
"icon": "bloodmagic:soulforge",
|
||||||
|
"category": "demonwill",
|
||||||
|
"pages": [
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": "The $(item)Soul Snare$() is a fun thing with a fun name."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "crafting",
|
||||||
|
"recipe": "bloodmagic:soul_forge"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,24 @@
|
||||||
|
{
|
||||||
|
"name": "Your First Will",
|
||||||
|
"icon": "bloodmagic:soulsnare",
|
||||||
|
"category": "demonwill",
|
||||||
|
"pages": [
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": "The $(item)Soul Snare$() is a fun thing with a fun name."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "crafting",
|
||||||
|
"recipe": "bloodmagic:soul_snare"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "image",
|
||||||
|
"images": [
|
||||||
|
"bloodmagic:images/entries/demonwill/soul_snare.png"
|
||||||
|
],
|
||||||
|
"title": "Snare on Skeleton",
|
||||||
|
"border": true,
|
||||||
|
"text": "A skeleton with white particles after hit by a snare."
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,11 @@
|
||||||
|
{
|
||||||
|
"name": "Divination Sigil",
|
||||||
|
"icon": "bloodmagic:divinationsigil",
|
||||||
|
"category": "sigil",
|
||||||
|
"pages": [
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"text": "$(item)Divination Sigil$()."
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
Loading…
Reference in a new issue