major rework, more documentation, configuration, and lots of fixes
This commit is contained in:
		
							parent
							
								
									e5a415ddd5
								
							
						
					
					
						commit
						c0ebe09a02
					
				
							
								
								
									
										21
									
								
								blockPropertyDocumentation.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								blockPropertyDocumentation.txt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | |||||||
|  | "material": | ||||||
|  | 
 | ||||||
|  | //controls what happens when a piston pushes this block | ||||||
|  | 
 | ||||||
|  | "blocksMovement" ~ boolean  | ||||||
|  | //this sets whether water can flow away this block if "collidable" is false, otherwise subtily changes how fluids look around it | ||||||
|  | 
 | ||||||
|  | "collidable" ~ boolean  | ||||||
|  | //this sets whether the block has collision. if false you (and monsters) can walk throught the block. | ||||||
|  | 
 | ||||||
|  | "burnable" ~ boolean | ||||||
|  | //does lava ignite the block | ||||||
|  | 
 | ||||||
|  | "burnChance" ~ int  | ||||||
|  | //how fast the block burns down (leaves 60, wood 5, flowers 100) if 0, block will never burn down. | ||||||
|  | 
 | ||||||
|  | "spreadChance" ~ int  | ||||||
|  | //how easily this block catches fire ( wood 5, leaves 30, flowers 60) if null, block can only be ignited by lava if burnable. | ||||||
|  | 
 | ||||||
|  | "breakByHand" ~ boolean | ||||||
|  | //this sets whether the block drops when brocken without tool. | ||||||
| @ -18,8 +18,14 @@ dependencies { | |||||||
| 	minecraft "com.mojang:minecraft:${project.minecraft_version}" | 	minecraft "com.mojang:minecraft:${project.minecraft_version}" | ||||||
| 	mappings "net.fabricmc:yarn:${project.yarn_mappings}:v2" | 	mappings "net.fabricmc:yarn:${project.yarn_mappings}:v2" | ||||||
| 	modImplementation "net.fabricmc:fabric-loader:${project.loader_version}" | 	modImplementation "net.fabricmc:fabric-loader:${project.loader_version}" | ||||||
| 
 | 	implementation 'com.google.code.findbugs:jsr305:3.0.2' | ||||||
| 	modImplementation "net.fabricmc.fabric-api:fabric-api:${project.fabric_api_version}" | 	modImplementation "net.fabricmc.fabric-api:fabric-api:${project.fabric_api_version}" | ||||||
|  | 
 | ||||||
|  | 	modCompile "me.sargunvohra.mcmods:autoconfig1u:2.0" | ||||||
|  | 	include "me.sargunvohra.mcmods:autoconfig1u:2.0" | ||||||
|  | 	modApi "me.shedaniel.cloth:config-2:2.13.1" | ||||||
|  | 	include "me.shedaniel.cloth:config-2:2.13.1" | ||||||
|  | 	modImplementation "io.github.prospector:modmenu:1.10.0+build.28" | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| processResources { | processResources { | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ yarn_mappings       = 1.15.2+build.15 | |||||||
| loader_version      = 0.8.2+build.194 | loader_version      = 0.8.2+build.194 | ||||||
| 
 | 
 | ||||||
| #Mod properties | #Mod properties | ||||||
| mod_version         = 0.7.0 | mod_version         = 0.8.0 | ||||||
| maven_group         = quimufu.simple_creator | maven_group         = quimufu.simple_creator | ||||||
| archives_base_name  = simple_creator | archives_base_name  = simple_creator | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										462
									
								
								materialsDocumentation.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										462
									
								
								materialsDocumentation.txt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,462 @@ | |||||||
|  | Some materials have certain effects, apart from their properties. | ||||||
|  |     They have effect on how noteblocks sound when the block is below: | ||||||
|  |         material -> soundtype | ||||||
|  |         --------------------- | ||||||
|  |         stone -> basedrum | ||||||
|  |         sand -> snare | ||||||
|  |         glass -> hat | ||||||
|  |         wood -> bass | ||||||
|  |         others -> harp | ||||||
|  |     The "water" material should cause crashes (or at least errors in connection with the frostwalker enchantment. (untested) | ||||||
|  |     Some materials prevent the block being broken by water, even if the other conditions are met: | ||||||
|  |         portal | ||||||
|  |         structure_void | ||||||
|  |         underwater_plant | ||||||
|  |         seagrass | ||||||
|  |     The "ice" material negates the stronger downward flow next to solid blocks. i.e. for waterfalls: block ~ air | ||||||
|  |     Some materials are broken faster by sword. This can also be achieved via tag "leaves". | ||||||
|  |         plant | ||||||
|  |         replaceable_plant | ||||||
|  |         unused_plant | ||||||
|  |         pumpkin | ||||||
|  |     Some materials let the block when mined with an axe be broken faster: | ||||||
|  |         wood | ||||||
|  |         plant | ||||||
|  |         replaceable_plant | ||||||
|  |         bamboo | ||||||
|  |     Some materials let the block when mined with an Pickaxe be broken faster and drop loot: | ||||||
|  |         metal | ||||||
|  |         anvil | ||||||
|  |         stone | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | All materials with their settings: | ||||||
|  | "air" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: true | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "structure_void" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: true | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "portal" | ||||||
|  | pistonBehavior: "block" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "carpet" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: true | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "plant" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "underwater_plant" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "replaceable_plant" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: true | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: true | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "seagrass" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: true | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "water" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: true | ||||||
|  | replaceable: true | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "bubble_column" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: true | ||||||
|  | replaceable: true | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "lava" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: true | ||||||
|  | replaceable: true | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "snow" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: false | ||||||
|  | breakByHand: false | ||||||
|  | liquid: false | ||||||
|  | replaceable: true | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "fire" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: true | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "part" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: false | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "cobweb" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: false | ||||||
|  | breakByHand: false | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "redstone_lamp" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "clay" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "earth" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "organic" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "packed_ice" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "sand" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "sponge" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "shulker_box" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "wood" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: true | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "bamboo_sapling" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: false | ||||||
|  | burnable: true | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "bamboo" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: true | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "wool" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: true | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "tnt" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: true | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "leaves" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: true | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "glass" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "ice" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "cactus" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: false | ||||||
|  | 
 | ||||||
|  | "stone" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: false | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "metal" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: false | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "snow_block" | ||||||
|  | pistonBehavior: "normal" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: false | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "anvil" | ||||||
|  | pistonBehavior: "block" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: false | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "barrier" | ||||||
|  | pistonBehavior: "block" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: false | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "piston" | ||||||
|  | pistonBehavior: "block" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "unused_plant" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "pumpkin" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "egg" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "cake" | ||||||
|  | pistonBehavior: "destroy" | ||||||
|  | blocksMovement: true | ||||||
|  | burnable: false | ||||||
|  | breakByHand: true | ||||||
|  | liquid: false | ||||||
|  | replaceable: false | ||||||
|  | solid: true | ||||||
|  | blocksLight: true | ||||||
|  | 
 | ||||||
|  | "pistonBehavior": | ||||||
|  | normal, | ||||||
|  | destroy, | ||||||
|  | block, | ||||||
|  | ignore, | ||||||
|  | push_only | ||||||
| @ -4,9 +4,7 @@ import com.google.common.collect.Maps; | |||||||
| import com.google.gson.Gson; | import com.google.gson.Gson; | ||||||
| import com.google.gson.GsonBuilder; | import com.google.gson.GsonBuilder; | ||||||
| import com.google.gson.JsonObject; | import com.google.gson.JsonObject; | ||||||
| import net.minecraft.block.Block; | import net.minecraft.block.*; | ||||||
| import net.minecraft.block.Material; |  | ||||||
| import net.minecraft.block.MaterialColor; |  | ||||||
| import net.minecraft.block.piston.PistonBehavior; | import net.minecraft.block.piston.PistonBehavior; | ||||||
| import net.minecraft.item.BlockItem; | import net.minecraft.item.BlockItem; | ||||||
| import net.minecraft.item.Item; | import net.minecraft.item.Item; | ||||||
| @ -49,86 +47,223 @@ public class BlockResourceLoader extends GenericManualResourceLoader<Pair<Block, | |||||||
|     @Override |     @Override | ||||||
|     protected Pair<Block, Item> deserialize(Pair<Identifier, JsonObject> e) { |     protected Pair<Block, Item> deserialize(Pair<Identifier, JsonObject> e) { | ||||||
|         JsonObject jo = e.getRight(); |         JsonObject jo = e.getRight(); | ||||||
| 
 |  | ||||||
|         PistonBehavior pistonBehavior; |  | ||||||
|         boolean blocksMovement; |  | ||||||
|         boolean burnable; |  | ||||||
|         boolean breakByHand; |  | ||||||
|         boolean liquid; |  | ||||||
|         boolean replaceable; |  | ||||||
|         boolean solid; |  | ||||||
|         MaterialColor color; |  | ||||||
|         boolean blocksLight; |  | ||||||
|         Material material; |         Material material; | ||||||
|         String materialStr = JsonHelper.getString(jo, "material", "stone"); |         if(JsonHelper.hasString(jo, "material")){ | ||||||
|         material = getMaterial(materialStr); |             String materialString = JsonHelper.getString(jo, "material"); | ||||||
|  |             material = getMaterial(materialString); | ||||||
|  |         } else if (JsonHelper.getObject(jo,"material", null)!=null){ | ||||||
|  |             // get material information | ||||||
|  |             JsonObject jmo = JsonHelper.getObject(jo, "material"); | ||||||
|  |             MaterialSettingsPojo mspj = GSON.fromJson(jmo, MaterialSettingsPojo.class); | ||||||
|  |             //build material | ||||||
|  |             material = getSettings(mspj); | ||||||
|  |         } else { | ||||||
|  |             material = Material.EARTH; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // get block information | ||||||
|  |         BlockSettingsPojo bspj = GSON.fromJson(jo, BlockSettingsPojo.class); | ||||||
|  | 
 | ||||||
|  |         // move block information in Block.Settings (!!hacky!!) | ||||||
|  |         Block.Settings bs = getSettings(material, bspj); | ||||||
|  | 
 | ||||||
|  |         // parse item group | ||||||
|  |         String group = JsonHelper.getString(jo, "itemGroup", "misc"); | ||||||
|  |         ItemGroup g = ItemResourceLoader.findGroup(group); | ||||||
|  |         //create block and corresponding item | ||||||
|  |         Block resB = new Block(bs); | ||||||
|  |         Item resI = new BlockItem(resB, new Item.Settings().group(g)); | ||||||
|  | 
 | ||||||
|  |         FireBlock fireBlock = (FireBlock) Blocks.FIRE; | ||||||
|  | 
 | ||||||
|  |         int burnChance = JsonHelper.getInt(jo,"burnChance", -1); | ||||||
|  |         int spreadChance = JsonHelper.getInt(jo,"spreadChance", -1); | ||||||
|  |         if(burnChance!=-1 && spreadChance!=-1){ | ||||||
|  |             //spreadChance and burnChance are the wrong way around in yarn | ||||||
|  |             fireBlock.registerFlammableBlock(resB, spreadChance, burnChance); | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         // construct block information |         return new Pair<>(resB, resI); | ||||||
|         BlockSoundGroup soundGroup; |     } | ||||||
|         Identifier dropTableId; |  | ||||||
|         boolean collidable; |  | ||||||
|         int luminance; |  | ||||||
|         float resistance; |  | ||||||
|         float hardness; |  | ||||||
|         float slipperiness; |  | ||||||
|         float slowDownMultiplier; |  | ||||||
|         float jumpVelocityMultiplier; |  | ||||||
|         boolean opaque; |  | ||||||
| 
 | 
 | ||||||
|         String soundGroupStr = JsonHelper.getString(jo, "soundGroup", "stone"); |     private Material getSettings(MaterialSettingsPojo mspj) { | ||||||
|         soundGroup = getSoundGroup(soundGroupStr); |         return new Material( | ||||||
|         String dropTableIdStr = JsonHelper.getString(jo, "dropTableId", null); |                 MaterialColor.PINK, | ||||||
|         dropTableId = getDropTableId(dropTableIdStr); |                 mspj.liquid, | ||||||
|         collidable = JsonHelper.getBoolean(jo, "collidable", true); |                 mspj.solid, | ||||||
|         luminance = JsonHelper.getInt(jo, "lightLevel", 0); |                 mspj.blocksMovement, | ||||||
|         resistance = JsonHelper.getFloat(jo, "explosionResistance", 6.0F); |                 mspj.blocksLight, | ||||||
|         hardness = JsonHelper.getFloat(jo, "hardness", 1.5F); |                 mspj.breakByHand, | ||||||
|         slipperiness = JsonHelper.getFloat(jo, "slipperiness", 0.6F); |                 mspj.burnable, | ||||||
|         slowDownMultiplier = JsonHelper.getFloat(jo, "slowDownMultiplier", 1.0F); |                 mspj.replaceable, | ||||||
|         jumpVelocityMultiplier = JsonHelper.getFloat(jo, "jumpVelocityMultiplier", 1.0F); |                 getPistonBehavior(mspj.pistonBehavior)); | ||||||
|         opaque = JsonHelper.getBoolean(jo, "opaque", true); |  | ||||||
| 
 | 
 | ||||||
|         // save block information in Block.Settings (!!hacky!!) |     } | ||||||
|  | 
 | ||||||
|  |     private PistonBehavior getPistonBehavior(String pistonBehavior) { | ||||||
|  |         switch (pistonBehavior.toUpperCase()) { | ||||||
|  |             case "NORMAL": | ||||||
|  |                 return PistonBehavior.NORMAL; | ||||||
|  |             case "DESTROY": | ||||||
|  |                 return PistonBehavior.DESTROY; | ||||||
|  |             case "BLOCK": | ||||||
|  |                 return PistonBehavior.BLOCK; | ||||||
|  |             case "IGNORE": | ||||||
|  |                 return PistonBehavior.IGNORE; | ||||||
|  |             case "PUSH_ONLY": | ||||||
|  |                 return PistonBehavior.PUSH_ONLY; | ||||||
|  |             default: | ||||||
|  |                 log(Level.WARN, "Piston Behavior " + pistonBehavior + " not found, using normal"); | ||||||
|  |                 return PistonBehavior.NORMAL; | ||||||
|  | 
 | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private MaterialColor getMaterialColor(String color) { | ||||||
|  |         switch (color.toUpperCase()) { | ||||||
|  |             case "AIR": | ||||||
|  |                 return MaterialColor.AIR; | ||||||
|  |             case "GRASS": | ||||||
|  |                 return MaterialColor.GRASS; | ||||||
|  |             case "SAND": | ||||||
|  |                 return MaterialColor.SAND; | ||||||
|  |             case "WEB": | ||||||
|  |                 return MaterialColor.WEB; | ||||||
|  |             case "LAVA": | ||||||
|  |                 return MaterialColor.LAVA; | ||||||
|  |             case "ICE": | ||||||
|  |                 return MaterialColor.ICE; | ||||||
|  |             case "IRON": | ||||||
|  |                 return MaterialColor.IRON; | ||||||
|  |             case "FOLIAGE": | ||||||
|  |                 return MaterialColor.FOLIAGE; | ||||||
|  |             case "WHITE": | ||||||
|  |                 return MaterialColor.WHITE; | ||||||
|  |             case "CLAY": | ||||||
|  |                 return MaterialColor.CLAY; | ||||||
|  |             case "DIRT": | ||||||
|  |                 return MaterialColor.DIRT; | ||||||
|  |             case "STONE": | ||||||
|  |                 return MaterialColor.STONE; | ||||||
|  |             case "WATER": | ||||||
|  |                 return MaterialColor.WATER; | ||||||
|  |             case "WOOD": | ||||||
|  |                 return MaterialColor.WOOD; | ||||||
|  |             case "QUARTZ": | ||||||
|  |                 return MaterialColor.QUARTZ; | ||||||
|  |             case "ORANGE": | ||||||
|  |                 return MaterialColor.ORANGE; | ||||||
|  |             case "MAGENTA": | ||||||
|  |                 return MaterialColor.MAGENTA; | ||||||
|  |             case "LIGHT_BLUE": | ||||||
|  |                 return MaterialColor.LIGHT_BLUE; | ||||||
|  |             case "YELLOW": | ||||||
|  |                 return MaterialColor.YELLOW; | ||||||
|  |             case "LIME": | ||||||
|  |                 return MaterialColor.LIME; | ||||||
|  |             case "PINK": | ||||||
|  |                 return MaterialColor.PINK; | ||||||
|  |             case "GRAY": | ||||||
|  |                 return MaterialColor.GRAY; | ||||||
|  |             case "LIGHT_GRAY": | ||||||
|  |                 return MaterialColor.LIGHT_GRAY; | ||||||
|  |             case "CYAN": | ||||||
|  |                 return MaterialColor.CYAN; | ||||||
|  |             case "PURPLE": | ||||||
|  |                 return MaterialColor.PURPLE; | ||||||
|  |             case "BLUE": | ||||||
|  |                 return MaterialColor.BLUE; | ||||||
|  |             case "BROWN": | ||||||
|  |                 return MaterialColor.BROWN; | ||||||
|  |             case "GREEN": | ||||||
|  |                 return MaterialColor.GREEN; | ||||||
|  |             case "RED": | ||||||
|  |                 return MaterialColor.RED; | ||||||
|  |             case "BLACK": | ||||||
|  |                 return MaterialColor.BLACK; | ||||||
|  |             case "GOLD": | ||||||
|  |                 return MaterialColor.GOLD; | ||||||
|  |             case "DIAMOND": | ||||||
|  |                 return MaterialColor.DIAMOND; | ||||||
|  |             case "LAPIS": | ||||||
|  |                 return MaterialColor.LAPIS; | ||||||
|  |             case "EMERALD": | ||||||
|  |                 return MaterialColor.EMERALD; | ||||||
|  |             case "SPRUCE": | ||||||
|  |                 return MaterialColor.SPRUCE; | ||||||
|  |             case "NETHER": | ||||||
|  |                 return MaterialColor.NETHER; | ||||||
|  |             case "WHITE_TERRACOTTA": | ||||||
|  |                 return MaterialColor.WHITE_TERRACOTTA; | ||||||
|  |             case "ORANGE_TERRACOTTA": | ||||||
|  |                 return MaterialColor.ORANGE_TERRACOTTA; | ||||||
|  |             case "MAGENTA_TERRACOTTA": | ||||||
|  |                 return MaterialColor.MAGENTA_TERRACOTTA; | ||||||
|  |             case "LIGHT_BLUE_TERRACOTTA": | ||||||
|  |                 return MaterialColor.LIGHT_BLUE_TERRACOTTA; | ||||||
|  |             case "YELLOW_TERRACOTTA": | ||||||
|  |                 return MaterialColor.YELLOW_TERRACOTTA; | ||||||
|  |             case "LIME_TERRACOTTA": | ||||||
|  |                 return MaterialColor.LIME_TERRACOTTA; | ||||||
|  |             case "PINK_TERRACOTTA": | ||||||
|  |                 return MaterialColor.PINK_TERRACOTTA; | ||||||
|  |             case "GRAY_TERRACOTTA": | ||||||
|  |                 return MaterialColor.GRAY_TERRACOTTA; | ||||||
|  |             case "LIGHT_GRAY_TERRACOTTA": | ||||||
|  |                 return MaterialColor.LIGHT_GRAY_TERRACOTTA; | ||||||
|  |             case "CYAN_TERRACOTTA": | ||||||
|  |                 return MaterialColor.CYAN_TERRACOTTA; | ||||||
|  |             case "PURPLE_TERRACOTTA": | ||||||
|  |                 return MaterialColor.PURPLE_TERRACOTTA; | ||||||
|  |             case "BLUE_TERRACOTTA": | ||||||
|  |                 return MaterialColor.BLUE_TERRACOTTA; | ||||||
|  |             case "BROWN_TERRACOTTA": | ||||||
|  |                 return MaterialColor.BROWN_TERRACOTTA; | ||||||
|  |             case "GREEN_TERRACOTTA": | ||||||
|  |                 return MaterialColor.GREEN_TERRACOTTA; | ||||||
|  |             case "RED_TERRACOTTA": | ||||||
|  |                 return MaterialColor.RED_TERRACOTTA; | ||||||
|  |             case "BLACK_TERRACOTTA": | ||||||
|  |                 return MaterialColor.BLACK_TERRACOTTA; | ||||||
|  |             default: | ||||||
|  |                 log(Level.WARN, "MapColor " + color + " not found, using pink"); | ||||||
|  |                 return MaterialColor.PINK; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private Block.Settings getSettings(Material material, BlockSettingsPojo bspj) { | ||||||
|         Block.Settings bs = Block.Settings.of(material, material.getColor()); |         Block.Settings bs = Block.Settings.of(material, material.getColor()); | ||||||
|         Field[] fields = Block.Settings.class.getDeclaredFields(); |         Field[] fields = Block.Settings.class.getDeclaredFields(); | ||||||
|         try { |         try { | ||||||
|             fields[0].setAccessible(true); |             fields[0].setAccessible(true); | ||||||
|             fields[0].set(bs, material); |             fields[0].set(bs, material); | ||||||
|             fields[1].setAccessible(true); |             fields[1].setAccessible(true); | ||||||
|             fields[1].set(bs, material.getColor()); |             fields[1].set(bs, getMaterialColor(bspj.mapColor)); | ||||||
|             fields[2].setAccessible(true); |             fields[2].setAccessible(true); | ||||||
|             fields[2].setBoolean(bs, collidable); |             fields[2].setBoolean(bs, bspj.collidable); | ||||||
|             fields[3].setAccessible(true); |             fields[3].setAccessible(true); | ||||||
|             fields[3].set(bs, soundGroup); |             fields[3].set(bs, getSoundGroup(bspj.soundGroup)); | ||||||
|             fields[4].setAccessible(true); |             fields[4].setAccessible(true); | ||||||
|             fields[4].setInt(bs, luminance); |             fields[4].setInt(bs, bspj.lightLevel); | ||||||
|             fields[5].setAccessible(true); |             fields[5].setAccessible(true); | ||||||
|             fields[5].setFloat(bs, resistance); |             fields[5].setFloat(bs, bspj.explosionResistance); | ||||||
|             fields[6].setAccessible(true); |             fields[6].setAccessible(true); | ||||||
|             fields[6].setFloat(bs, hardness); |             fields[6].setFloat(bs, bspj.hardness); | ||||||
|             fields[8].setAccessible(true); |             fields[8].setAccessible(true); | ||||||
|             fields[8].setFloat(bs, slipperiness); |             fields[8].setFloat(bs, bspj.slipperiness); | ||||||
|             fields[9].setAccessible(true); |             fields[9].setAccessible(true); | ||||||
|             fields[9].setFloat(bs, slowDownMultiplier); |             fields[9].setFloat(bs, bspj.slowDownMultiplier); | ||||||
|             fields[10].setAccessible(true); |             fields[10].setAccessible(true); | ||||||
|             fields[10].setFloat(bs, jumpVelocityMultiplier); |             fields[10].setFloat(bs, bspj.jumpVelocityMultiplier); | ||||||
|             fields[11].setAccessible(true); |             fields[11].setAccessible(true); | ||||||
|             fields[11].set(bs, dropTableId); |             fields[11].set(bs, getDropTableId(bspj.dropTableId)); | ||||||
|             fields[12].setAccessible(true); |             fields[12].setAccessible(true); | ||||||
|             fields[12].setBoolean(bs, opaque); |             fields[12].setBoolean(bs, bspj.opaque); | ||||||
|         } catch (IllegalAccessException ex) { |         } catch (IllegalAccessException ex) { | ||||||
|             ex.printStackTrace(); |             ex.printStackTrace(); | ||||||
|         } |         } | ||||||
| 
 |         return bs; | ||||||
|         // parse item group |  | ||||||
|         String group = JsonHelper.getString(jo, "group", "misc"); |  | ||||||
|         ItemGroup g = ItemResourceLoader.findGroup(group); |  | ||||||
|         //create block and corresponding item |  | ||||||
|         Block resB = new Block(bs); |  | ||||||
|         Item resI = new BlockItem(resB, new Item.Settings().group(g)); |  | ||||||
| 
 |  | ||||||
|         return new Pair<>(resB, resI); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private Identifier getDropTableId(String s) { |     private Identifier getDropTableId(String s) { | ||||||
|  | |||||||
							
								
								
									
										15
									
								
								src/main/java/quimufu/simple_creator/BlockSettingsPojo.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								src/main/java/quimufu/simple_creator/BlockSettingsPojo.java
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,15 @@ | |||||||
|  | package quimufu.simple_creator; | ||||||
|  | 
 | ||||||
|  | public class BlockSettingsPojo { | ||||||
|  |     public String soundGroup = "stone"; | ||||||
|  |     public String dropTableId = null; | ||||||
|  |     public boolean collidable = true; | ||||||
|  |     public int lightLevel = 0; | ||||||
|  |     public float explosionResistance = 6.0F; | ||||||
|  |     public float hardness = 1.5F; | ||||||
|  |     public float slipperiness = 0.6F; | ||||||
|  |     public float slowDownMultiplier = 1.0F; | ||||||
|  |     public float jumpVelocityMultiplier = 1.0F; | ||||||
|  |     public boolean opaque = true; | ||||||
|  |     String mapColor = "stone"; | ||||||
|  | } | ||||||
| @ -1,124 +0,0 @@ | |||||||
| /*package quimufu.simple_creator; |  | ||||||
| 
 |  | ||||||
| import net.minecraft.block.Block; |  | ||||||
| import net.minecraft.block.Material; |  | ||||||
| import net.minecraft.block.MaterialColor; |  | ||||||
| import net.minecraft.sound.BlockSoundGroup; |  | ||||||
| import net.minecraft.util.Identifier; |  | ||||||
| 
 |  | ||||||
| public class FlexibleBlockSettings extends Block { |  | ||||||
| 
 |  | ||||||
|     public Material getMaterial() { |  | ||||||
|         return material; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public BlockSoundGroup getSoundGroup() { |  | ||||||
|         return soundGroup; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Override |  | ||||||
|     public Identifier getDropTableId() { |  | ||||||
|         return dropTableId; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void setDropTableId(Identifier dropTableId) { |  | ||||||
|         this.dropTableId = dropTableId; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public boolean isCollidable() { |  | ||||||
|         return collidable; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void setCollidable(boolean collidable) { |  | ||||||
|         this.collidable = collidable; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public int getLuminance() { |  | ||||||
|         return luminance; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void setLuminance(int luminance) { |  | ||||||
|         this.luminance = luminance; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public float getResistance() { |  | ||||||
|         return resistance; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void setResistance(float resistance) { |  | ||||||
|         this.resistance = resistance; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public float getHardness() { |  | ||||||
|         return hardness; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void setHardness(float hardness) { |  | ||||||
|         this.hardness = hardness; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Override |  | ||||||
|     public float getSlipperiness() { |  | ||||||
|         return slipperiness; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void setSlipperiness(float slipperiness) { |  | ||||||
|         this.slipperiness = slipperiness; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public float getSlowDownMultiplier() { |  | ||||||
|         return slowDownMultiplier; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void setSlowDownMultiplier(float slowDownMultiplier) { |  | ||||||
|         this.slowDownMultiplier = slowDownMultiplier; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Override |  | ||||||
|     public float getJumpVelocityMultiplier() { |  | ||||||
|         return jumpVelocityMultiplier; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void setJumpVelocityMultiplier(float jumpVelocityMultiplier) { |  | ||||||
|         this.jumpVelocityMultiplier = jumpVelocityMultiplier; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public boolean isOpaque() { |  | ||||||
|         return opaque; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void setOpaque(boolean opaque) { |  | ||||||
|         this.opaque = opaque; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public MaterialColor getMaterialColor() { |  | ||||||
|         return materialColor; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void setMaterialColor(MaterialColor materialColor) { |  | ||||||
|         this.materialColor = materialColor; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public boolean isRandomTicks() { |  | ||||||
|         return randomTicks; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void setRandomTicks(boolean randomTicks) { |  | ||||||
|         this.randomTicks = randomTicks; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public boolean isDynamicBounds() { |  | ||||||
|         return dynamicBounds; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public void setDynamicBounds(boolean dynamicBounds) { |  | ||||||
|         this.dynamicBounds = dynamicBounds; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|     public FlexibleBlockSettings() { |  | ||||||
|         super(Settings.of(Material.AIR)); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| */ |  | ||||||
| @ -1,33 +0,0 @@ | |||||||
| package quimufu.simple_creator; |  | ||||||
| 
 |  | ||||||
| import net.minecraft.block.Material; |  | ||||||
| import net.minecraft.block.MaterialColor; |  | ||||||
| import net.minecraft.block.piston.PistonBehavior; |  | ||||||
| 
 |  | ||||||
| public class FlexibleMaterialBuilder extends Material.Builder { |  | ||||||
| 
 |  | ||||||
|     public FlexibleMaterialBuilder(MaterialColor color) { |  | ||||||
|         super(color); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Override |  | ||||||
|     public Material.Builder blocksPistons() { |  | ||||||
|         return super.blocksPistons(); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Override |  | ||||||
|     public Material.Builder burnable() { |  | ||||||
|         return super.burnable(); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Override |  | ||||||
|     public Material.Builder destroyedByPiston() { |  | ||||||
|         return super.destroyedByPiston(); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Override |  | ||||||
|     public Material.Builder requiresTool() { |  | ||||||
|         return super.requiresTool(); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
| @ -1,8 +1,11 @@ | |||||||
| package quimufu.simple_creator; | package quimufu.simple_creator; | ||||||
| 
 | 
 | ||||||
| import com.google.common.collect.Lists; | import com.google.common.collect.Lists; | ||||||
|  | import com.google.common.collect.Maps; | ||||||
| import com.google.gson.Gson; | import com.google.gson.Gson; | ||||||
| import com.google.gson.JsonObject; | import com.google.gson.JsonObject; | ||||||
|  | import com.google.gson.JsonParseException; | ||||||
|  | import me.sargunvohra.mcmods.autoconfig1u.AutoConfig; | ||||||
| import net.fabricmc.fabric.impl.resource.loader.ModResourcePackCreator; | import net.fabricmc.fabric.impl.resource.loader.ModResourcePackCreator; | ||||||
| import net.minecraft.resource.*; | import net.minecraft.resource.*; | ||||||
| import net.minecraft.util.Identifier; | import net.minecraft.util.Identifier; | ||||||
| @ -12,15 +15,14 @@ import org.apache.logging.log4j.Level; | |||||||
| 
 | 
 | ||||||
| import java.io.*; | import java.io.*; | ||||||
| import java.nio.charset.StandardCharsets; | import java.nio.charset.StandardCharsets; | ||||||
| import java.util.ArrayList; | import java.util.*; | ||||||
| import java.util.Collection; |  | ||||||
| import java.util.List; |  | ||||||
| 
 | 
 | ||||||
| import static quimufu.simple_creator.SimpleCreatorMod.log; | import static quimufu.simple_creator.SimpleCreatorMod.log; | ||||||
| 
 | 
 | ||||||
| public abstract class GenericManualResourceLoader<T> { | public abstract class GenericManualResourceLoader<T> { | ||||||
|     private Gson GSON; |     private Gson GSON; | ||||||
|     private String dataType; |     private String dataType; | ||||||
|  |     private SimpleCreatorConfig config; | ||||||
| 
 | 
 | ||||||
|     GenericManualResourceLoader(Gson gson, String dt) { |     GenericManualResourceLoader(Gson gson, String dt) { | ||||||
|         GSON = gson; |         GSON = gson; | ||||||
| @ -47,9 +49,11 @@ public abstract class GenericManualResourceLoader<T> { | |||||||
|     protected abstract void save(Identifier id, T item); |     protected abstract void save(Identifier id, T item); | ||||||
| 
 | 
 | ||||||
|     public void load() { |     public void load() { | ||||||
|  |         config = AutoConfig.getConfigHolder(SimpleCreatorConfig.class).getConfig(); | ||||||
|         ResourcePackManager<ResourcePackProfile> resourcePackManager = new ResourcePackManager<>(ResourcePackProfile::new); |         ResourcePackManager<ResourcePackProfile> resourcePackManager = new ResourcePackManager<>(ResourcePackProfile::new); | ||||||
|         resourcePackManager.registerProvider(new VanillaDataPackProvider()); |         resourcePackManager.registerProvider(new VanillaDataPackProvider()); | ||||||
|         resourcePackManager.registerProvider(new FileResourcePackProvider(new File("./datapacks"))); |         resourcePackManager.registerProvider(new FileResourcePackProvider(new File("./datapacks"))); | ||||||
|  |         if (config.enableTestThings) | ||||||
|             resourcePackManager.registerProvider(new ModResourcePackCreator(ResourceType.SERVER_DATA)); |             resourcePackManager.registerProvider(new ModResourcePackCreator(ResourceType.SERVER_DATA)); | ||||||
|         resourcePackManager.scanPacks(); |         resourcePackManager.scanPacks(); | ||||||
|         List<ResourcePackProfile> ep = Lists.newArrayList(resourcePackManager.getEnabledProfiles()); |         List<ResourcePackProfile> ep = Lists.newArrayList(resourcePackManager.getEnabledProfiles()); | ||||||
| @ -62,26 +66,42 @@ public abstract class GenericManualResourceLoader<T> { | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         ArrayList<Pair<Identifier, JsonObject>> itemJsonList = new ArrayList<>(); |         ArrayList<Pair<Identifier, JsonObject>> itemJsonList = new ArrayList<>(); | ||||||
|  |         HashMap<Identifier, JsonObject> itemJsonMap = Maps.newHashMap(); | ||||||
|         for (ResourcePackProfile rpp : resourcePackManager.getEnabledProfiles()) { |         for (ResourcePackProfile rpp : resourcePackManager.getEnabledProfiles()) { | ||||||
|             ResourcePack rp = rpp.createResourcePack(); |             ResourcePack rp = rpp.createResourcePack(); | ||||||
|             log(Level.INFO, "Loading ResourcePack " + rp.getName()); |             log(Level.INFO, "Loading ResourcePack " + rp.getName()); | ||||||
|             for (String ns : rp.getNamespaces(ResourceType.SERVER_DATA)) { |             for (String ns : rp.getNamespaces(ResourceType.SERVER_DATA)) { | ||||||
|                 log(Level.INFO, "Loading namespace " + ns); |                 log(Level.INFO, "Loading namespace " + ns); | ||||||
|                 Collection<Identifier> ressurces = rp.findResources(ResourceType.SERVER_DATA, ns, dataType, 5, s -> s.endsWith(".json")); |                 Collection<Identifier> resources = rp.findResources(ResourceType.SERVER_DATA, ns, dataType, 5, s -> s.endsWith(".json")); | ||||||
|                 for (Identifier id : ressurces) { |                 for (Identifier id : resources) { | ||||||
|  |                     if (config.extendedLogging) | ||||||
|  |                         log(Level.INFO, "found: " + id.toString() + " in Pack: " + rp.getName()); | ||||||
|                     Identifier idNice = new Identifier(id.getNamespace(), getName(id)); |                     Identifier idNice = new Identifier(id.getNamespace(), getName(id)); | ||||||
|                     try { |                     try { | ||||||
|                         InputStream is = rp.open(ResourceType.SERVER_DATA, id); |                         InputStream is = rp.open(ResourceType.SERVER_DATA, id); | ||||||
|                         Reader r = new BufferedReader(new InputStreamReader(is, StandardCharsets.UTF_8)); |                         Reader r = new BufferedReader(new InputStreamReader(is, StandardCharsets.UTF_8)); | ||||||
|                         JsonObject jo = JsonHelper.deserialize(GSON, r, JsonObject.class); |                         JsonObject jo = JsonHelper.deserialize(GSON, r, JsonObject.class); | ||||||
|                         if (jo != null) |                         if (jo != null) | ||||||
|                             itemJsonList.add(new Pair<>(idNice, jo)); |                             if (jo.entrySet().isEmpty()) { | ||||||
|  |                                 itemJsonMap.remove(idNice); | ||||||
|  |                                 if (config.extendedLogging) | ||||||
|  |                                     log(Level.INFO, "deleting " + idNice + " because of an empty override in " + rp.getName()); | ||||||
|  |                             } else { | ||||||
|  |                                 itemJsonMap.put(idNice, jo); | ||||||
|  |                                 if (config.extendedLogging) | ||||||
|  |                                     log(Level.INFO, "adding " + idNice + " from " + rp.getName()); | ||||||
|  |                             } | ||||||
|                     } catch (IOException e) { |                     } catch (IOException e) { | ||||||
|                         e.printStackTrace(); |                         log(Level.ERROR, "error loading " + id + " " + e.getMessage()); | ||||||
|  |                     } catch (JsonParseException e) { | ||||||
|  |                         log(Level.ERROR, "error parsing json for " + id + " " + e.getMessage()); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         for (Map.Entry<Identifier, JsonObject> e : itemJsonMap.entrySet()) { | ||||||
|  |             itemJsonList.add(new Pair<>(e.getKey(), e.getValue())); | ||||||
|  |         } | ||||||
|         loadItems(itemJsonList); |         loadItems(itemJsonList); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -0,0 +1,15 @@ | |||||||
|  | package quimufu.simple_creator; | ||||||
|  | 
 | ||||||
|  | import net.minecraft.block.MaterialColor; | ||||||
|  | import net.minecraft.block.piston.PistonBehavior; | ||||||
|  | 
 | ||||||
|  | public class MaterialSettingsPojo { | ||||||
|  |     String pistonBehavior = "normal"; | ||||||
|  |     boolean blocksMovement = true; | ||||||
|  |     boolean burnable = false; | ||||||
|  |     boolean breakByHand = true; | ||||||
|  |     boolean liquid = false; | ||||||
|  |     boolean replaceable = false; | ||||||
|  |     boolean solid = true; | ||||||
|  |     boolean blocksLight = true; | ||||||
|  | } | ||||||
| @ -0,0 +1,10 @@ | |||||||
|  | package quimufu.simple_creator; | ||||||
|  | 
 | ||||||
|  | import me.sargunvohra.mcmods.autoconfig1u.ConfigData; | ||||||
|  | import me.sargunvohra.mcmods.autoconfig1u.annotation.Config; | ||||||
|  | 
 | ||||||
|  | @Config(name = "simple_creator") | ||||||
|  | public class SimpleCreatorConfig  implements ConfigData { | ||||||
|  |     public boolean enableTestThings = false; | ||||||
|  |     public boolean extendedLogging = false; | ||||||
|  | } | ||||||
| @ -1,11 +1,17 @@ | |||||||
| package quimufu.simple_creator; | package quimufu.simple_creator; | ||||||
| 
 | 
 | ||||||
|  | import me.sargunvohra.mcmods.autoconfig1u.AutoConfig; | ||||||
|  | import me.sargunvohra.mcmods.autoconfig1u.ConfigHolder; | ||||||
|  | import me.sargunvohra.mcmods.autoconfig1u.serializer.GsonConfigSerializer; | ||||||
| import net.fabricmc.api.ModInitializer; | import net.fabricmc.api.ModInitializer; | ||||||
| 
 |  | ||||||
| import org.apache.logging.log4j.Level; | import org.apache.logging.log4j.Level; | ||||||
| import org.apache.logging.log4j.LogManager; | import org.apache.logging.log4j.LogManager; | ||||||
| import org.apache.logging.log4j.Logger; | import org.apache.logging.log4j.Logger; | ||||||
| 
 | 
 | ||||||
|  | //import net.minecraft.block.Material; | ||||||
|  | 
 | ||||||
|  | //import java.lang.reflect.Field; | ||||||
|  | 
 | ||||||
| public class SimpleCreatorMod implements ModInitializer { | public class SimpleCreatorMod implements ModInitializer { | ||||||
| 
 | 
 | ||||||
|     public static Logger LOGGER = LogManager.getLogger(); |     public static Logger LOGGER = LogManager.getLogger(); | ||||||
| @ -18,6 +24,28 @@ public class SimpleCreatorMod implements ModInitializer { | |||||||
|     @Override |     @Override | ||||||
|     public void onInitialize() { |     public void onInitialize() { | ||||||
|         log(Level.INFO, "Initializing"); |         log(Level.INFO, "Initializing"); | ||||||
|  |         AutoConfig.register(SimpleCreatorConfig.class, GsonConfigSerializer::new); | ||||||
|  | //        for(Material m : Material.class.getEnumConstants()){ | ||||||
|  | //            log(Level.INFO,  String.valueOf(m.getColor().color)); | ||||||
|  | //        } | ||||||
|  | //        for (Field f : Material.class.getDeclaredFields()) { | ||||||
|  | //            log(Level.INFO, f.getName()); | ||||||
|  | //            try { | ||||||
|  | //                Material m = ((Material) f.get(Material.class)); | ||||||
|  | //                log(Level.INFO, "pistonBehavior: " + m.getPistonBehavior().name()); | ||||||
|  | //                log(Level.INFO, "blocksMovement: " + m.blocksMovement()); | ||||||
|  | //                log(Level.INFO, "burnable: " + m.isBurnable()); | ||||||
|  | //                log(Level.INFO, "breakByHand: " + m.canBreakByHand()); | ||||||
|  | //                log(Level.INFO, "liquid: " + m.isLiquid()); | ||||||
|  | //                log(Level.INFO, "replaceable: " + m.isReplaceable()); | ||||||
|  | //                log(Level.INFO, "solid: " + m.isSolid()); | ||||||
|  | //                log(Level.INFO, "blocksLight: " + m.blocksLight()); | ||||||
|  | //                log(Level.INFO, ""); | ||||||
|  | //                log(Level.INFO, ""); | ||||||
|  | // | ||||||
|  | //            } catch (IllegalAccessException ignored) { | ||||||
|  | //            } | ||||||
|  | //        } | ||||||
|         irl.load(); |         irl.load(); | ||||||
|         brl.load(); |         brl.load(); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -0,0 +1,24 @@ | |||||||
|  | package quimufu.simple_creator; | ||||||
|  | 
 | ||||||
|  | import io.github.prospector.modmenu.api.ConfigScreenFactory; | ||||||
|  | import io.github.prospector.modmenu.api.ModMenuApi; | ||||||
|  | import me.sargunvohra.mcmods.autoconfig1u.AutoConfig; | ||||||
|  | import net.minecraft.client.gui.screen.Screen; | ||||||
|  | 
 | ||||||
|  | public class SimpleCreatorModMenuIntegration implements ModMenuApi { | ||||||
|  |     @Override | ||||||
|  |     public String getModId() { | ||||||
|  |         return SimpleCreatorMod.MOD_ID; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public ConfigScreenFactory<?> getModConfigScreenFactory() { | ||||||
|  |         return this::getScreen; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private Screen getScreen(Screen parent) { | ||||||
|  |         return AutoConfig.getConfigScreen(SimpleCreatorConfig.class, parent).get(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -1,3 +1,6 @@ | |||||||
| { | { | ||||||
|   "item.simple_creator.test_item": "Forbidden Fruit" |   "text.autoconfig.simple_creator.title": "Simple Item/Block Creator Settings", | ||||||
|  |   "text.autoconfig.simple_creator.option.enableTestThings": "Enable a test item and block", | ||||||
|  |   "item.simple_creator.test_item": "Forbidden Fruit", | ||||||
|  |   "block.simple_creator.test_block": "Fast jumpy wooly diamond-dropping block of Eternal Fire" | ||||||
| } | } | ||||||
| @ -1,9 +1,11 @@ | |||||||
| { | { | ||||||
|   "material": "LAVA", |   "material": "ice", | ||||||
|   "mapColor" : |   "mapColor": "yellow", | ||||||
|   "soundGroup": "wool", |  | ||||||
|   "dropTableId": "minecraft:blocks/diamond_ore", |  | ||||||
|   "collidable": true, |   "collidable": true, | ||||||
|  |   "soundGroup": "wool", | ||||||
|  |   "burnChance": 0, | ||||||
|  |   "spreadChance": 100, | ||||||
|  |   "dropTableId": "minecraft:blocks/diamond_ore", | ||||||
|   "lightLevel": 1, |   "lightLevel": 1, | ||||||
|   "explosionResistance": 5.0, |   "explosionResistance": 5.0, | ||||||
|   "hardness": 0.5, |   "hardness": 0.5, | ||||||
| @ -11,5 +13,5 @@ | |||||||
|   "slowDownMultiplier": 2.0, |   "slowDownMultiplier": 2.0, | ||||||
|   "jumpVelocityMultiplier": 2.0, |   "jumpVelocityMultiplier": 2.0, | ||||||
|   "opaque": true, |   "opaque": true, | ||||||
|   "group": "food" |   "itemGroup": "food" | ||||||
| } | } | ||||||
| @ -17,7 +17,10 @@ | |||||||
|       "quimufu.simple_creator.SimpleCreatorMod" |       "quimufu.simple_creator.SimpleCreatorMod" | ||||||
|     ], |     ], | ||||||
|     "client": [], |     "client": [], | ||||||
|     "server": [] |     "server": [], | ||||||
|  |     "modmenu": [ | ||||||
|  |       "quimufu.simple_creator.SimpleCreatorModMenuIntegration" | ||||||
|  |     ] | ||||||
|   }, |   }, | ||||||
|   "mixins": [], |   "mixins": [], | ||||||
|   "depends": { |   "depends": { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user