mirror of
https://github.com/correl/mage.git
synced 2025-01-13 11:01:58 +00:00
Merge pull request #2455 from Styxo/master
Fixed gen-card to work after reorg
This commit is contained in:
commit
51f2d991ac
2 changed files with 138 additions and 147 deletions
|
@ -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);";
|
||||||
|
|
|
@ -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";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue