mirror of
https://github.com/magefree/mage.git
synced 2026-01-10 21:02:08 -08:00
Merge pull request #5502 from ZeldaZach/address_mage_stuff
Address Json Tests
This commit is contained in:
commit
8f0351896c
9 changed files with 139 additions and 99 deletions
|
|
@ -13,12 +13,14 @@ import org.apache.log4j.Logger;
|
|||
import org.junit.Ignore;
|
||||
import org.junit.Test;
|
||||
|
||||
import java.io.*;
|
||||
import java.nio.charset.StandardCharsets;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* @author JayDi85
|
||||
* @author JayDi85 & ZeldaZach
|
||||
*/
|
||||
public class ExportJsonGameplayDataTest {
|
||||
|
||||
|
|
@ -33,96 +35,103 @@ public class ExportJsonGameplayDataTest {
|
|||
List<Card> cards = new ArrayList<>();
|
||||
Collection<ExpansionSet> sets = Sets.getInstance().values();
|
||||
for (ExpansionSet set : sets) {
|
||||
if (!set.getCode().equals("GRN")) {
|
||||
//continue;
|
||||
}
|
||||
|
||||
for (ExpansionSet.SetCardInfo setInfo : set.getSetCardInfo()) {
|
||||
if (cards.size() >= 10) {
|
||||
//break;
|
||||
}
|
||||
cards.add(CardImpl.createCard(setInfo.getCardClass(), new CardSetInfo(setInfo.getName(), set.getCode(),
|
||||
setInfo.getCardNumber(), setInfo.getRarity(), setInfo.getGraphicInfo())));
|
||||
}
|
||||
}
|
||||
|
||||
JsonObject res = new JsonObject();
|
||||
JsonObject res = new JsonObject();
|
||||
|
||||
for (Card card : cards) {
|
||||
try {
|
||||
JsonObject resCard = new JsonObject();
|
||||
res.add(card.getName(), resCard);
|
||||
for (Card card : cards) {
|
||||
try {
|
||||
JsonObject resCard = new JsonObject();
|
||||
res.add(card.getName(), resCard);
|
||||
|
||||
JsonArray resAbilities = new JsonArray();
|
||||
resCard.add("abilities", resAbilities);
|
||||
for (Ability ability : card.getAbilities()) {
|
||||
JsonObject resAbility = new JsonObject();
|
||||
resAbilities.add(resAbility);
|
||||
|
||||
// basic
|
||||
resAbility.addProperty("cost", ability.getManaCosts().getText());
|
||||
resAbility.addProperty("name", ability.toString());
|
||||
resAbility.addProperty("class", ability.getClass().getSimpleName());
|
||||
//resAbility.addProperty("rule", ability.getRule());
|
||||
|
||||
// modes
|
||||
JsonArray resModes = new JsonArray();
|
||||
resAbility.add("modes", resModes);
|
||||
for (Mode mode : ability.getModes().values()) {
|
||||
JsonObject resMode = new JsonObject();
|
||||
resModes.add(resMode);
|
||||
JsonArray resAbilities = new JsonArray();
|
||||
resCard.add("abilities", resAbilities);
|
||||
for (Ability ability : card.getAbilities()) {
|
||||
JsonObject resAbility = new JsonObject();
|
||||
resAbilities.add(resAbility);
|
||||
|
||||
// basic
|
||||
//resMode.addProperty("name", mode.toString());
|
||||
resAbility.addProperty("cost", ability.getManaCosts().getText());
|
||||
resAbility.addProperty("name", ability.toString());
|
||||
resAbility.addProperty("class", ability.getClass().getSimpleName());
|
||||
//resAbility.addProperty("rule", ability.getRule());
|
||||
|
||||
// effects
|
||||
JsonArray resEffects = new JsonArray();
|
||||
resMode.add("effects", resEffects);
|
||||
for (Effect effect : mode.getEffects()) {
|
||||
JsonObject resEffect = new JsonObject();
|
||||
resEffects.add(resEffect);
|
||||
// modes
|
||||
JsonArray resModes = new JsonArray();
|
||||
resAbility.add("modes", resModes);
|
||||
for (Mode mode : ability.getModes().values()) {
|
||||
JsonObject resMode = new JsonObject();
|
||||
resModes.add(resMode);
|
||||
|
||||
resEffect.addProperty("class", effect.getClass().getSimpleName());
|
||||
resEffect.addProperty("outcome", effect.getOutcome().toString());
|
||||
resEffect.addProperty("text", effect.getText(mode));
|
||||
// basic
|
||||
//resMode.addProperty("name", mode.toString());
|
||||
|
||||
// effects
|
||||
JsonArray resEffects = new JsonArray();
|
||||
resMode.add("effects", resEffects);
|
||||
for (Effect effect : mode.getEffects()) {
|
||||
JsonObject resEffect = new JsonObject();
|
||||
resEffects.add(resEffect);
|
||||
|
||||
resEffect.addProperty("class", effect.getClass().getSimpleName());
|
||||
resEffect.addProperty("outcome", effect.getOutcome().toString());
|
||||
resEffect.addProperty("text", effect.getText(mode));
|
||||
}
|
||||
if (resEffects.size() == 0) {
|
||||
resMode.remove("effects");
|
||||
}
|
||||
|
||||
// targets
|
||||
JsonArray resTargets = new JsonArray();
|
||||
resMode.add("targets", resTargets);
|
||||
for (Target target : mode.getTargets()) {
|
||||
JsonObject resTarget = new JsonObject();
|
||||
resTargets.add(resTarget);
|
||||
|
||||
resTarget.addProperty("name", target.getTargetName());
|
||||
resTarget.addProperty("class", target.getClass().getSimpleName());
|
||||
resTarget.addProperty("min", target.getMinNumberOfTargets());
|
||||
resTarget.addProperty("max", target.getMaxNumberOfTargets());
|
||||
}
|
||||
if (resTargets.size() == 0) {
|
||||
resMode.remove("targets");
|
||||
}
|
||||
|
||||
if (resMode.get("effects") == null && resMode.get("targets") == null) {
|
||||
resModes.remove(resMode);
|
||||
}
|
||||
}
|
||||
if (resEffects.size() == 0) {
|
||||
resMode.remove("effects");
|
||||
}
|
||||
|
||||
// targets
|
||||
JsonArray resTargets = new JsonArray();
|
||||
resMode.add("targets", resTargets);
|
||||
for (Target target : mode.getTargets()) {
|
||||
JsonObject resTarget = new JsonObject();
|
||||
resTargets.add(resTarget);
|
||||
|
||||
resTarget.addProperty("name", target.getTargetName());
|
||||
resTarget.addProperty("class", target.getClass().getSimpleName());
|
||||
resTarget.addProperty("min", target.getMinNumberOfTargets());
|
||||
resTarget.addProperty("max", target.getMaxNumberOfTargets());
|
||||
}
|
||||
if (resTargets.size() == 0) {
|
||||
resMode.remove("targets");
|
||||
}
|
||||
|
||||
if (resMode.get("effects") == null && resMode.get("targets") == null) {
|
||||
resModes.remove(resMode);
|
||||
if (resModes.size() == 0) {
|
||||
resAbility.remove("modes");
|
||||
}
|
||||
}
|
||||
if (resModes.size() == 0) {
|
||||
resAbility.remove("modes");
|
||||
}
|
||||
} catch (Throwable e) {
|
||||
logger.error("Inner error for " + card.getName() + ": " + e.getMessage(), e);
|
||||
break;
|
||||
}
|
||||
} catch (Throwable e) {
|
||||
logger.error("Inner error for " + card.getName() + ": " + e.getMessage(), e);
|
||||
break;
|
||||
}
|
||||
|
||||
Gson gson = new GsonBuilder().setPrettyPrinting().create();
|
||||
|
||||
String filePath = System.getProperty("user.dir") + "/json/" + set.getCode() + ".json";
|
||||
File outputFile = new File(filePath);
|
||||
final boolean mkdirs = outputFile.getParentFile().mkdirs();
|
||||
|
||||
try (Writer writer =
|
||||
new BufferedWriter(
|
||||
new OutputStreamWriter(
|
||||
new FileOutputStream(outputFile, false), StandardCharsets.UTF_8
|
||||
)
|
||||
)
|
||||
) {
|
||||
writer.write(gson.toJson(res));
|
||||
System.out.println("Wrote " + set.getCode() + " to file");
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
Gson gson = new GsonBuilder()
|
||||
.setPrettyPrinting()
|
||||
.create();
|
||||
System.out.println(gson.toJson(res));
|
||||
}
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue