Merge pull request #2455 from Styxo/master

Fixed gen-card to work after reorg
This commit is contained in:
LevelX2 2016-10-11 22:59:15 +02:00 committed by GitHub
commit 51f2d991ac
2 changed files with 138 additions and 147 deletions

View file

@ -25,7 +25,7 @@
* authors and should not be interpreted as representing official policies, either expressed * authors and should not be interpreted as representing official policies, either expressed
* or implied, of BetaSteward_at_googlemail.com. * or implied, of BetaSteward_at_googlemail.com.
*/ */
package mage.sets.[=$set=]; package mage.cards.[=$cardNameFirstLetter=];
import java.util.UUID;[= import java.util.UUID;[=
if ($power || $power eq 0) { if ($power || $power eq 0) {
@ -33,8 +33,8 @@ if ($power || $power eq 0) {
} }
=][=$abilitiesImports=] =][=$abilitiesImports=]
import mage.cards.CardImpl; import mage.cards.CardImpl;
import mage.cards.CardSetInfo;
import mage.constants.CardType; import mage.constants.CardType;
import mage.constants.Rarity;
/** /**
* *
@ -42,9 +42,9 @@ import mage.constants.Rarity;
*/ */
public class [=$className=] extends CardImpl { public class [=$className=] extends CardImpl {
public [=$className=](UUID ownerId) { public [=$className=](UUID ownerId, CardSetInfo setInfo) {
super(ownerId, [=$cardNumber=], "[=$name=]", Rarity.[=$rarity=], new CardType[]{[=$type=]}, "[=$manaCost=]"); super(ownerId, setInfo, new CardType[]{[=$type=]}, "[=$manaCost=]");
this.expansionSetCode = "[=$expansionSetCode=]";[=$subType=][=$colors=][= [=$subType=][=$colors=][=
if ($power || $power eq 0) { if ($power || $power eq 0) {
$OUT .= "\n this.power = new MageInt($power);"; $OUT .= "\n this.power = new MageInt($power);";
$OUT .= "\n this.toughness = new MageInt($toughness);"; $OUT .= "\n this.toughness = new MageInt($toughness);";

View file

@ -12,7 +12,6 @@ my $setsFile = 'mtg-sets-data.txt';
my $knownSetsFile = 'known-sets.txt'; my $knownSetsFile = 'known-sets.txt';
my $keywordsFile = 'keywords.txt'; my $keywordsFile = 'keywords.txt';
my %cards; my %cards;
my %sets; my %sets;
my %knownSets; my %knownSets;
@ -21,7 +20,7 @@ my %keywords;
sub toCamelCase { sub toCamelCase {
my $string = $_[0]; my $string = $_[0];
$string =~ s/\b([\w']+)\b/ucfirst($1)/ge; $string =~ s/\b([\w']+)\b/ucfirst($1)/ge;
$string =~ s/[-,\s\']//g; $string =~ s/[-,\s\':]//g;
$string; $string;
} }
@ -102,57 +101,71 @@ if (!exists $cards{$cardName}) {
} }
# Check if card is already implemented # Check if card is already implemented
foreach my $setName (keys %{$cards{$cardName}}) { my $fileName = "../Mage.Sets/src/mage/cards/".substr($cardName, 0, 1)."/".toCamelCase($cardName).".java";
if (exists $knownSets{$setName}) {
my $fileName = "../Mage.Sets/src/mage/sets/" . $knownSets{$setName} . "/" . toCamelCase($cardName) . ".java";
print "gvim $fileName\n";
my $fileName2 = $fileName;
$fileName2 =~ s/\//\\/img;
print "gvim $fileName2\n";
if(-e $fileName) { if(-e $fileName) {
die "$cardName is already implemented (set found in: $setName).\n"; die "$cardName is already implemented.\n";
}
}
} }
# Generate the cards # Generate lines to corresponding sets
my $simpleOnly = $ARGV[1] || 'false';
my $template = Text::Template->new(TYPE => 'FILE', SOURCE => 'cardClass.tmpl', DELIMITERS => [ '[=', '=]' ]);
my $templateExtended = Text::Template->new(TYPE => 'FILE', SOURCE => 'cardExtendedClass.tmpl', DELIMITERS => [ '[=', '=]' ]);
my %vars; my %vars;
$vars{'author'} = $author;
$vars{'name'} = $cardName;
$vars{'className'} = toCamelCase($cardName); $vars{'className'} = toCamelCase($cardName);
$vars{'cardNameFirstLetter'} = lc substr($cardName, 0, 1);
my @card;
if ($simpleOnly ne 'true') {
print "Files generated:\n";
}
my $baseRarity = '';
foreach my $setName (keys %{$cards{$cardName}}) { foreach my $setName (keys %{$cards{$cardName}}) {
if (exists $knownSets{$setName}) { my $setFileName = "../Mage.Sets/src/mage/sets/".toCamelCase($setName).".java";
my $fileName = "../Mage.Sets/src/mage/sets/" . $knownSets{$setName} . "/" . toCamelCase($cardName) . ".java"; @card = @{${cards{$cardName}{$setName}}};
print "gvim $fileName\n"; my $line = "\tcards.add(new SetCardInfo(\"".$card[0]."\", ".$card[2].", Rarity.".$raritiesConversion{$card[3]}.", mage.cards.".$vars{'cardNameFirstLetter'}.".".$vars{'className'}.".class));\n";
my $fileName2 = $fileName;
$fileName2 =~ s/\//\\/img; @ARGV = ($setFileName);
print "gvim $fileName2\n"; $^I = '.bak';
my $last;
my $lastName;
my $currName;
while (<>) {
if ($_ !~ m/cards.add/) {
if (defined($last)) {
print $last;
}
# print card line as last
if (defined($currName) && ($cardName cmp $currName) > 0) {
print $line;
undef $currName;
}
$last = $_;
print $last if eof;
next;
}
($lastName) = $last =~ m/"(.*?)"/;
($currName) = $_ =~ m/"(.*?)"/;
print $last;
$last = $_;
# print card line as first
if (!defined($lastName) && defined($currName) && ($currName cmp $cardName) > 0) {
print $line;
}
# print card line in the middle
if (defined($lastName) && defined($currName) && ($cardName cmp $lastName) > 0 && ($currName cmp $cardName) > 0) {
print $line;
}
}
unlink $setFileName.".bak";
print "$setFileName\n";
}
# Generate the the card
my $result; my $result;
my $template = Text::Template->new(TYPE => 'FILE', SOURCE => 'cardClass.tmpl', DELIMITERS => [ '[=', '=]' ]);
$vars{'set'} = $knownSets{$setName}; $vars{'author'} = $author;
$vars{'expansionSetCode'} = $sets{$setName}; $vars{'manaCost'} = fixCost($card[4]);
$vars{'cardNumber'} = $cards{$cardName}{$setName}[2]; $vars{'power'} = $card[6];
$vars{'rarity'} = $raritiesConversion{$cards{$cardName}{$setName}[3]}; $vars{'toughness'} = $card[7];
if (!$baseRarity) {
$baseRarity = $cards{$cardName}{$setName}[3];
$vars{'manaCost'} = fixCost($cards{$cardName}{$setName}[4]);
$vars{'power'} = $cards{$cardName}{$setName}[6];
$vars{'toughness'} = $cards{$cardName}{$setName}[7];
my @types; my @types;
$vars{'subType'} = ''; $vars{'subType'} = '';
my $type = $cards{$cardName}{$setName}[5]; my $type = $card[5];
while ($type =~ m/([a-zA-Z]+)( )*/g) { while ($type =~ m/([a-zA-Z]+)( )*/g) {
if (exists($cardTypes{$1})) { if (exists($cardTypes{$1})) {
push(@types, $cardTypes{$1}); push(@types, $cardTypes{$1});
@ -169,7 +182,7 @@ foreach my $setName (keys %{$cards{$cardName}}) {
$vars{'abilitiesImports'} = ''; $vars{'abilitiesImports'} = '';
$vars{'abilities'} = ''; $vars{'abilities'} = '';
my @abilities = split('\$', $cards{$cardName}{$setName}[8]); my @abilities = split('\$', $card[8]);
foreach my $ability (@abilities) { foreach my $ability (@abilities) {
$ability =~ s/ <i>.+?<\/i>//g; $ability =~ s/ <i>.+?<\/i>//g;
@ -208,14 +221,9 @@ foreach my $setName (keys %{$cards{$cardName}}) {
$vars{'abilities'} .= "\n this.addAbility(new " . $kw . 'Ability(this, new ManaCostsImpl("' . fixCost($1) . '")));'; $vars{'abilities'} .= "\n this.addAbility(new " . $kw . 'Ability(this, new ManaCostsImpl("' . fixCost($1) . '")));';
$vars{'abilitiesImports'} .= "\nimport mage.abilities.costs.mana.ManaCostsImpl;"; $vars{'abilitiesImports'} .= "\nimport mage.abilities.costs.mana.ManaCostsImpl;";
} }
$vars{'abilitiesImports'} .= "\nimport mage.abilities.keyword." . $kw . "Ability;"; $vars{'abilitiesImports'} .= "\nimport mage.abilities.keyword." . $kw . "Ability;";
} else { } else {
$vars{'abilities'} .= "\n // $kwUnchanged"; $vars{'abilities'} .= "\n // $kwUnchanged";
if ($simpleOnly eq 'true') {
exit 0;
}
} }
} }
} }
@ -223,33 +231,16 @@ foreach my $setName (keys %{$cards{$cardName}}) {
if (!$notKeyWord) { if (!$notKeyWord) {
$vars{'abilities'} .= "\n // $ability"; $vars{'abilities'} .= "\n // $ability";
if ($simpleOnly eq 'true') {
exit 0;
}
} }
} }
if ($vars{'abilities'}) { if ($vars{'abilities'}) {
$vars{'abilities'} = "\n" . $vars{'abilities'}; $vars{'abilities'} = "\n" . $vars{'abilities'};
} }
$vars{'baseSet'} = $vars{'set'};
$vars{'baseClassName'} = $vars{'className'};
$result = $template->fill_in(HASH => \%vars); $result = $template->fill_in(HASH => \%vars);
} else {
$vars{'rarityExtended'} = '';
if ($baseRarity ne $cards{$cardName}{$setName}[3]) {
$vars{'rarityExtended'} = "\n this.rarity = Rarity.$raritiesConversion{$cards{$cardName}{$setName}[3]};";
}
$result = $templateExtended->fill_in(HASH => \%vars);
}
open CARD, "> $fileName"; open CARD, "> $fileName";
print CARD $result; print CARD $result;
close CARD; close CARD;
print "$vars{'set'}.$vars{'className'}\n"; print "$fileName\n";
} else {
print "Set not found in known sets: $setName\n";
}
}