fdai7430
2 years ago
1 changed files with 28 additions and 47 deletions
@ -1,67 +1,48 @@ |
|||||
package org.bitbiome.commands; |
package org.bitbiome.commands; |
||||
|
|
||||
|
import java.util.ArrayList; |
||||
import java.util.Scanner; |
import java.util.Scanner; |
||||
|
|
||||
import org.bitbiome.classes.JsonParser; |
|
||||
import org.bitbiome.classes.TravelEngine; |
|
||||
import org.json.*; |
|
||||
|
import org.bitbiome.classes.*; |
||||
|
import org.bitbiome.entities.*; |
||||
|
|
||||
public class UseCommand implements CommandAPI { |
public class UseCommand implements CommandAPI { |
||||
@Override |
@Override |
||||
public void performCommand(Scanner scanner, boolean isRunning, String message, TravelEngine engine) { |
public void performCommand(Scanner scanner, boolean isRunning, String message, TravelEngine engine) { |
||||
System.out.println(getUseMessage(message.split(" ", 2)[1])); |
|
||||
|
System.out.println(getUseMessage(message.split(" ", 2)[1], engine)); |
||||
} |
} |
||||
|
|
||||
private String getUseMessage(String msg) { |
|
||||
|
private String getUseMessage(String msg, TravelEngine engine) { |
||||
|
Player player = engine.getPlayer(); |
||||
String message[] = msg.split(" on "); |
String message[] = msg.split(" on "); |
||||
String itemName = message[0]; |
String itemName = message[0]; |
||||
JSONObject item = getItem(itemName), target; |
|
||||
JsonParser p = new JsonParser(); |
|
||||
|
|
||||
if(item == null) |
|
||||
return "You don't have that item."; |
|
||||
if(item.getBoolean("attack")) |
|
||||
return "You can't attack with this."; |
|
||||
if(message.length == 1) |
|
||||
target = p.getJSONObject("playerconfig.json"); |
|
||||
else |
|
||||
target = getTarget(message[1]); |
|
||||
if(target == null) |
|
||||
return "That target is not available."; |
|
||||
return useItem(item, target); |
|
||||
|
ArrayList<Item> inv = player.getInventory(); |
||||
|
|
||||
|
for(int i = 0; i<inv.size(); i++) { |
||||
|
Item item = inv.get(i); |
||||
|
if(item.getName().equals(itemName)) { |
||||
|
if(item.doesDamage()) |
||||
|
return "You can't attack with this."; |
||||
|
if(message.length == 1) |
||||
|
return useItem(item, player); |
||||
|
String targetName = message[1]; |
||||
|
ArrayList<Mob> mobs = player.getLocation().getMobList(); |
||||
|
for(int j = 0; j<mobs.size(); j++) { |
||||
|
Mob mob = mobs.get(j); |
||||
|
if(mob.getName().equals(targetName)) |
||||
|
return useItem(item, mob); |
||||
|
} |
||||
|
return "That target is not available."; |
||||
|
} |
||||
|
} |
||||
|
return "That item is not in your inventory."; |
||||
} |
} |
||||
|
|
||||
private String useItem(JSONObject item, JSONObject target) { |
|
||||
|
private String useItem(Item item, Player target) { |
||||
return "You used " + item + " on " + target; |
return "You used " + item + " on " + target; |
||||
} |
} |
||||
|
|
||||
private JSONObject getItem(String item) { |
|
||||
JsonParser p = new JsonParser(); |
|
||||
JSONArray inventory = p.getJSONObject("playerconfig.json").getJSONArray("inventory"); |
|
||||
for(int i = 0; i < inventory.length(); i++) { |
|
||||
JSONObject currentItem = inventory.getJSONObject(i); |
|
||||
if(currentItem.getString("name").equals(item)) |
|
||||
return currentItem; |
|
||||
} |
|
||||
return null; |
|
||||
} |
|
||||
|
|
||||
private JSONObject getTarget(String target) { |
|
||||
JsonParser p = new JsonParser(); |
|
||||
String currentLocation = p.getJSONObject("playerconfig").getString("currentLocation"); |
|
||||
JSONArray locations = p.getJSONObject("gameconfig").getJSONArray("locations"); |
|
||||
for(int i = 0; i < locations.length(); i++) { |
|
||||
JSONObject location = locations.getJSONObject(i); |
|
||||
if(locations.getJSONObject(i).getString("name").equals(currentLocation)) { |
|
||||
JSONArray targets = location.getJSONArray("mobs"); |
|
||||
for(int j = 0; j < targets.length(); j++) { |
|
||||
JSONObject mob = targets.getJSONObject(j); |
|
||||
if(mob.getString("name").equals(target)) |
|
||||
return mob; |
|
||||
} |
|
||||
break; |
|
||||
} |
|
||||
} |
|
||||
return null; |
|
||||
|
private String useItem(Item item, Mob target) { |
||||
|
return "You used " + item + " on " + target; |
||||
} |
} |
||||
} |
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue