Added Project and .gitignore
This commit is contained in:
36
.classpath
Executable file
36
.classpath
Executable file
@@ -0,0 +1,36 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<classpath>
|
||||||
|
<classpathentry kind="src" output="target/classes" path="src/main/java">
|
||||||
|
<attributes>
|
||||||
|
<attribute name="optional" value="true"/>
|
||||||
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
|
</attributes>
|
||||||
|
</classpathentry>
|
||||||
|
<classpathentry excluding="**" kind="src" output="target/classes" path="src/main/resources">
|
||||||
|
<attributes>
|
||||||
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
|
</attributes>
|
||||||
|
</classpathentry>
|
||||||
|
<classpathentry kind="src" output="target/test-classes" path="src/test/java">
|
||||||
|
<attributes>
|
||||||
|
<attribute name="optional" value="true"/>
|
||||||
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
|
</attributes>
|
||||||
|
</classpathentry>
|
||||||
|
<classpathentry excluding="**" kind="src" output="target/test-classes" path="src/test/resources">
|
||||||
|
<attributes>
|
||||||
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
|
</attributes>
|
||||||
|
</classpathentry>
|
||||||
|
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.8">
|
||||||
|
<attributes>
|
||||||
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
|
</attributes>
|
||||||
|
</classpathentry>
|
||||||
|
<classpathentry kind="con" path="org.eclipse.m2e.MAVEN2_CLASSPATH_CONTAINER">
|
||||||
|
<attributes>
|
||||||
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
|
</attributes>
|
||||||
|
</classpathentry>
|
||||||
|
<classpathentry kind="output" path="target/classes"/>
|
||||||
|
</classpath>
|
||||||
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
target/
|
||||||
23
.project
Executable file
23
.project
Executable file
@@ -0,0 +1,23 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<projectDescription>
|
||||||
|
<name>CustomCrafting</name>
|
||||||
|
<comment></comment>
|
||||||
|
<projects>
|
||||||
|
</projects>
|
||||||
|
<buildSpec>
|
||||||
|
<buildCommand>
|
||||||
|
<name>org.eclipse.jdt.core.javabuilder</name>
|
||||||
|
<arguments>
|
||||||
|
</arguments>
|
||||||
|
</buildCommand>
|
||||||
|
<buildCommand>
|
||||||
|
<name>org.eclipse.m2e.core.maven2Builder</name>
|
||||||
|
<arguments>
|
||||||
|
</arguments>
|
||||||
|
</buildCommand>
|
||||||
|
</buildSpec>
|
||||||
|
<natures>
|
||||||
|
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||||
|
<nature>org.eclipse.m2e.core.maven2Nature</nature>
|
||||||
|
</natures>
|
||||||
|
</projectDescription>
|
||||||
5
.settings/org.eclipse.jdt.core.prefs
Executable file
5
.settings/org.eclipse.jdt.core.prefs
Executable file
@@ -0,0 +1,5 @@
|
|||||||
|
eclipse.preferences.version=1
|
||||||
|
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8
|
||||||
|
org.eclipse.jdt.core.compiler.compliance=1.8
|
||||||
|
org.eclipse.jdt.core.compiler.problem.forbiddenReference=warning
|
||||||
|
org.eclipse.jdt.core.compiler.source=1.8
|
||||||
4
.settings/org.eclipse.m2e.core.prefs
Executable file
4
.settings/org.eclipse.m2e.core.prefs
Executable file
@@ -0,0 +1,4 @@
|
|||||||
|
activeProfiles=
|
||||||
|
eclipse.preferences.version=1
|
||||||
|
resolveWorkspaceProjects=true
|
||||||
|
version=1
|
||||||
55
pom.xml
Executable file
55
pom.xml
Executable file
@@ -0,0 +1,55 @@
|
|||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
<groupId>org.forkzone.mc</groupId>
|
||||||
|
<artifactId>CustomCrafting</artifactId>
|
||||||
|
<packaging>jar</packaging>
|
||||||
|
<version>0.0.2-ALPHA</version>
|
||||||
|
<name>CustomCrafting</name>
|
||||||
|
<url></url>
|
||||||
|
<build>
|
||||||
|
<sourceDirectory>${basedir}/src/main/java</sourceDirectory>
|
||||||
|
<resources>
|
||||||
|
<resource>
|
||||||
|
<targetPath>.</targetPath>
|
||||||
|
<filtering>true</filtering>
|
||||||
|
<directory>${basedir}/src/main/resources/</directory>
|
||||||
|
<includes>
|
||||||
|
<include>plugin.yml</include>
|
||||||
|
</includes>
|
||||||
|
</resource>
|
||||||
|
<resource>
|
||||||
|
<targetPath>.</targetPath>
|
||||||
|
<filtering>false</filtering>
|
||||||
|
<directory>${basedir}/src/main/resources/</directory>
|
||||||
|
<excludes>
|
||||||
|
<exclude>plugin.yml</exclude>
|
||||||
|
</excludes>
|
||||||
|
</resource>
|
||||||
|
</resources>
|
||||||
|
<plugins>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-compiler-plugin</artifactId>
|
||||||
|
<configuration>
|
||||||
|
<source>1.8</source>
|
||||||
|
<target>1.8</target>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</build>
|
||||||
|
<repositories>
|
||||||
|
<repository>
|
||||||
|
<id>spigot-repo</id>
|
||||||
|
<url>https://hub.spigotmc.org/nexus/content/repositories/snapshots/</url>
|
||||||
|
</repository>
|
||||||
|
</repositories>
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.bukkit</groupId>
|
||||||
|
<artifactId>bukkit</artifactId>
|
||||||
|
<version>1.12.2-R0.1-SNAPSHOT</version><!--change this value depending on the version or use LATEST-->
|
||||||
|
<type>jar</type>
|
||||||
|
<scope>provided</scope>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
</project>
|
||||||
223
src/main/java/org/forkzone/mc/customcrafting/CustomCrafting.java
Executable file
223
src/main/java/org/forkzone/mc/customcrafting/CustomCrafting.java
Executable file
@@ -0,0 +1,223 @@
|
|||||||
|
package org.forkzone.mc.customcrafting;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.NamespacedKey;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.ShapedRecipe;
|
||||||
|
import org.bukkit.inventory.ShapelessRecipe;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
|
||||||
|
public final class CustomCrafting extends JavaPlugin
|
||||||
|
{
|
||||||
|
private static final String PREFIX = "[CustomCrafting] ";
|
||||||
|
//ArrayList<NamespacedKey> recipeList = new ArrayList<NamespacedKey>();
|
||||||
|
|
||||||
|
private String[][][] getShapeArray(String shape)
|
||||||
|
{
|
||||||
|
String[][][] shape_array = new String[3][3][2];
|
||||||
|
String[] buffer = shape.split(";");
|
||||||
|
|
||||||
|
for(int i = 0; i < buffer.length; ++i)
|
||||||
|
{
|
||||||
|
String[] buffer_ = buffer[i].split(",");
|
||||||
|
for(int j = 0; j < buffer_.length; ++j)
|
||||||
|
{
|
||||||
|
String[] buffer__ = buffer_[j].split(":");
|
||||||
|
|
||||||
|
shape_array[i][j][0] = buffer__[0].toUpperCase();
|
||||||
|
shape_array[i][j][1] = buffer__.length > 1 ? buffer__[1] : "0";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return shape_array;
|
||||||
|
}
|
||||||
|
|
||||||
|
private String[][] getShapeArraySL(String shape)
|
||||||
|
{
|
||||||
|
ArrayList<String[]> shape_array = new ArrayList<String[]>();
|
||||||
|
|
||||||
|
String[] buffer = shape.split(",");
|
||||||
|
for(String buffer_ : buffer)
|
||||||
|
{
|
||||||
|
shape_array.add(getItemArray(buffer_));
|
||||||
|
}
|
||||||
|
|
||||||
|
return shape_array.toArray(new String[shape_array.size()][3]);
|
||||||
|
}
|
||||||
|
|
||||||
|
private String[] getItemArray(String item)
|
||||||
|
{
|
||||||
|
String[] item_array = new String[3];
|
||||||
|
String[] buffer_item = item.split("#");
|
||||||
|
|
||||||
|
String[] buffer_item_ = buffer_item[0].split(":");
|
||||||
|
item_array[0] = buffer_item_[0].toUpperCase();
|
||||||
|
item_array[1] = buffer_item_.length > 1 ? buffer_item_[1] : "0";
|
||||||
|
item_array[2] = buffer_item.length > 1 ? buffer_item[1] : "1";
|
||||||
|
|
||||||
|
return item_array;
|
||||||
|
}
|
||||||
|
|
||||||
|
private int toInt(String string)
|
||||||
|
{
|
||||||
|
return Integer.parseInt(string);
|
||||||
|
}
|
||||||
|
|
||||||
|
private short toShort(String string)
|
||||||
|
{
|
||||||
|
return Short.parseShort(string);
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
|
private void addNewRecipe(NamespacedKey name, String shape, String item, boolean shapeless)
|
||||||
|
{
|
||||||
|
String[] item_array = getItemArray(item);
|
||||||
|
if(Material.getMaterial(item_array[0]) == null)
|
||||||
|
{
|
||||||
|
getLogger().warning("Could not add \"" + name.getKey() + "\"");
|
||||||
|
getLogger().warning("Unknown: " + item_array[0]);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else if(shapeless)
|
||||||
|
{
|
||||||
|
String[][] shape_array = getShapeArraySL(shape);
|
||||||
|
ShapelessRecipe recipe = new ShapelessRecipe(name, new ItemStack(Material.getMaterial(item_array[0]), toInt(item_array[2]), toShort(item_array[1])));
|
||||||
|
|
||||||
|
for(String[] ingredient_array : shape_array)
|
||||||
|
{
|
||||||
|
recipe.addIngredient(toInt(ingredient_array[2]), Material.getMaterial(ingredient_array[0]), toInt(ingredient_array[1]));
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!Bukkit.getServer().addRecipe(recipe))
|
||||||
|
getLogger().warning("Something went wrong!");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
String[][][] shape_array = getShapeArray(shape);
|
||||||
|
|
||||||
|
ShapedRecipe recipe = new ShapedRecipe(name, new ItemStack(Material.getMaterial(item_array[0]), toInt(item_array[2]), toShort(item_array[1])));
|
||||||
|
|
||||||
|
Map<String, Character> map = new HashMap<String, Character>();
|
||||||
|
|
||||||
|
int counter = 0;
|
||||||
|
|
||||||
|
String[] recipe_shape = new String[3];
|
||||||
|
|
||||||
|
for(int i = 0; i < shape_array.length; ++i)
|
||||||
|
{
|
||||||
|
recipe_shape[i] = "";
|
||||||
|
for(int j = 0; j < shape_array[i].length; ++j)
|
||||||
|
{
|
||||||
|
if(!map.containsKey(shape_array[i][j][0] + ":" + shape_array[i][j][1]))
|
||||||
|
{
|
||||||
|
if(shape_array[i][j][0].equalsIgnoreCase(" ") || shape_array[i][j][0].equalsIgnoreCase("0") || shape_array[i][j][0].equalsIgnoreCase("air"))
|
||||||
|
map.put(shape_array[i][j][0] + ":" + shape_array[i][j][1], ' ');
|
||||||
|
else
|
||||||
|
{
|
||||||
|
map.put(shape_array[i][j][0] + ":" + shape_array[i][j][1], (char)('a' + counter));
|
||||||
|
++counter;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
recipe_shape[i] += map.get(shape_array[i][j][0] + ":" + shape_array[i][j][1]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
recipe.shape(recipe_shape);
|
||||||
|
|
||||||
|
for (Map.Entry<String, Character> entry : map.entrySet())
|
||||||
|
{
|
||||||
|
if(!entry.getValue().equals(' '))
|
||||||
|
{
|
||||||
|
String[] buffer = entry.getKey().split(":");
|
||||||
|
recipe.setIngredient(entry.getValue(), Material.getMaterial(buffer[0]), toInt(buffer[1]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!Bukkit.getServer().addRecipe(recipe))
|
||||||
|
getLogger().warning("Something went wrong!");
|
||||||
|
}
|
||||||
|
getLogger().info("Add Recipe \"" + name.getKey() + "\"");
|
||||||
|
}
|
||||||
|
|
||||||
|
private void readConfigAndAddRecipe()
|
||||||
|
{
|
||||||
|
for(String key : getConfig().getConfigurationSection("recipes").getKeys(false))
|
||||||
|
{
|
||||||
|
NamespacedKey nkey = new NamespacedKey(this, key);
|
||||||
|
//recipeList.add(nkey);
|
||||||
|
addNewRecipe(nkey, getConfig().getString("recipes." + key + ".shape"), getConfig().getString("recipes." + key + ".item"), getConfig().getBoolean("recipes." + key + ".shapeless"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void removeRecipe()
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
Iterator<Recipe> iter = Bukkit.getServer().recipeIterator();
|
||||||
|
while(iter.hasNext())
|
||||||
|
{
|
||||||
|
Recipe r = iter.next();
|
||||||
|
if(r != null && r instanceof ShapedRecipe)
|
||||||
|
{
|
||||||
|
if(recipeList.contains(((ShapedRecipe) r).getKey()))
|
||||||
|
iter.remove();
|
||||||
|
}
|
||||||
|
else if(r != null && r instanceof ShapelessRecipe)
|
||||||
|
{
|
||||||
|
if(recipeList.contains(((ShapelessRecipe) r).getKey()))
|
||||||
|
iter.remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
recipeList.clear();
|
||||||
|
*/
|
||||||
|
Bukkit.getServer().resetRecipes();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
saveDefaultConfig();
|
||||||
|
reloadConfig();
|
||||||
|
readConfigAndAddRecipe();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
removeRecipe();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args)
|
||||||
|
{
|
||||||
|
if(cmd.getName().equalsIgnoreCase("customcrafting"))
|
||||||
|
{
|
||||||
|
if(args.length == 1 && args[0].equalsIgnoreCase("reload") && sender.hasPermission("customcrafting.reload"))
|
||||||
|
{
|
||||||
|
reloadConfig();
|
||||||
|
removeRecipe();
|
||||||
|
readConfigAndAddRecipe();
|
||||||
|
sender.sendMessage(PREFIX + "reloaded!");
|
||||||
|
}
|
||||||
|
else if(sender.hasPermission("customcrafting.infolite") || sender.hasPermission("customcrafting.info"))
|
||||||
|
{
|
||||||
|
sender.sendMessage(PREFIX + "Plugin Information");
|
||||||
|
sender.sendMessage(PREFIX + "Name: " + getDescription().getName());
|
||||||
|
sender.sendMessage(PREFIX + "Author: " + String.join(", ", getDescription().getAuthors()));
|
||||||
|
if(sender.hasPermission("customcrafting.info"))
|
||||||
|
{
|
||||||
|
sender.sendMessage(PREFIX + "Version: " + getDescription().getVersion());
|
||||||
|
sender.sendMessage(PREFIX + "Arguments: reload");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
13
src/main/resources/config.yml
Executable file
13
src/main/resources/config.yml
Executable file
@@ -0,0 +1,13 @@
|
|||||||
|
recipes:
|
||||||
|
dirtyDiamond:
|
||||||
|
shapeless: false
|
||||||
|
shape: "dirt,dirt,dirt;dirt,coal,dirt;dirt,dirt,dirt"
|
||||||
|
item: "diamond:0#1"
|
||||||
|
quarzblocktoitem:
|
||||||
|
shapeless: true
|
||||||
|
shape: "quartz_block:-1#1"
|
||||||
|
item: "quartz:0#4"
|
||||||
|
notchapple:
|
||||||
|
shapeless: false
|
||||||
|
shape: "gold_block,gold_block,gold_block;gold_block,apple,gold_block;gold_block,gold_block,gold_block"
|
||||||
|
item: "golden_apple:1"
|
||||||
27
src/main/resources/plugin.yml
Executable file
27
src/main/resources/plugin.yml
Executable file
@@ -0,0 +1,27 @@
|
|||||||
|
name: CustomCrafting
|
||||||
|
main: org.forkzone.mc.customcrafting.CustomCrafting
|
||||||
|
version: "${project.version}"
|
||||||
|
description: Add possibility to add custom crafting receipts to the game.
|
||||||
|
author: basman93
|
||||||
|
commands:
|
||||||
|
customcrafting:
|
||||||
|
description: Shows the plugin version or reloads it
|
||||||
|
usage: /<command> [arguments]
|
||||||
|
permission: customcrafting.infolite
|
||||||
|
aliases: cc
|
||||||
|
permissions:
|
||||||
|
customcrafting.*:
|
||||||
|
description: Gives access to all CustomCrafting commands
|
||||||
|
children:
|
||||||
|
customcrafting.info: true
|
||||||
|
customcrafting.infolite: true
|
||||||
|
customcrafting.reload: true
|
||||||
|
customcrafting.info:
|
||||||
|
description: Allows to see the full information of this plugin
|
||||||
|
children:
|
||||||
|
customcrafting.infolite: true
|
||||||
|
customcrafting.infolite:
|
||||||
|
description: Allows to see the reduced information of this plugin
|
||||||
|
default: true
|
||||||
|
customcrafting.reload:
|
||||||
|
description: Allows to reload the plugin
|
||||||
Reference in New Issue
Block a user