mirror of
https://github.com/Relintai/mtg-forge-ios.git
synced 2025-01-13 05:41:14 +01:00
29260c205d
git-svn-id: http://svn.slightlymagic.net/forge/trunk@35700 269b9781-a132-4a9b-9d4e-f004f1b56b58
217 lines
9.3 KiB
Python
Executable File
217 lines
9.3 KiB
Python
Executable File
#!/usr/bin/env python
|
|
|
|
############IMPLEMENTATION FOLLOWS############
|
|
import os,sys,fnmatch
|
|
import re
|
|
|
|
pathToMtgData = os.path.join(sys.path[0], "mtg-data.txt")
|
|
|
|
class Card:
|
|
def __init__(self, name):
|
|
self.name = name
|
|
self.cost = ""
|
|
self.types = ""
|
|
self.pt = ""
|
|
self.oracle = []
|
|
self.sets = ""
|
|
|
|
def initKeywords():
|
|
keyWords.append('Cascade')
|
|
keyWords.append('Convoke')
|
|
keyWords.append('Deathtouch')
|
|
keyWords.append('Defender')
|
|
keyWords.append('Delve')
|
|
keyWords.append('Desertwalk')
|
|
keyWords.append('Double Strike')
|
|
keyWords.append('Epic')
|
|
keyWords.append('Exalted')
|
|
keyWords.append('Fear')
|
|
keyWords.append('First Strike')
|
|
keyWords.append('Flanking')
|
|
keyWords.append('Flash')
|
|
keyWords.append('Flying')
|
|
keyWords.append('Forestwalk')
|
|
keyWords.append('Haste')
|
|
keyWords.append('Hexproof')
|
|
keyWords.append('Hideaway')
|
|
keyWords.append('Horsemanship')
|
|
keyWords.append('Indestructible')
|
|
keyWords.append('Infect')
|
|
keyWords.append('Intimidate')
|
|
keyWords.append('Islandwalk')
|
|
keyWords.append('Lifelink')
|
|
keyWords.append('Living Weapon')
|
|
keyWords.append('Mountainwalk')
|
|
keyWords.append('Persist')
|
|
keyWords.append('Phasing')
|
|
keyWords.append('Plainswalk')
|
|
keyWords.append('Provoke')
|
|
keyWords.append('Reach')
|
|
keyWords.append('Rebound')
|
|
keyWords.append('Shadow')
|
|
keyWords.append('Shroud')
|
|
keyWords.append('Soulbond')
|
|
keyWords.append('Storm')
|
|
keyWords.append('Sunburst')
|
|
keyWords.append('Swampwalk')
|
|
keyWords.append('Trample')
|
|
keyWords.append('Unblockable')
|
|
keyWords.append('Undying')
|
|
keyWords.append('Vigilance')
|
|
keyWords.append('Wither')
|
|
|
|
|
|
def handleKeyords(line,keywords):
|
|
# split line by spaces to see if first token matches a keyword
|
|
line = line.rstrip();
|
|
p = re.compile( '\s\(.*\)$')
|
|
line = p.sub('',line)
|
|
allKeywords = True
|
|
if line.find('Enchant') != -1 :
|
|
print 'K:'+line
|
|
return allKeywords
|
|
else :
|
|
# Multiple keywords could be comma seperated in mtgdata
|
|
words=line.split(', ')
|
|
for token in words :
|
|
if token.title() in keywords :
|
|
print 'K:'+token.title()
|
|
else :
|
|
allKeywords = False
|
|
|
|
return allKeywords
|
|
|
|
if not os.path.exists(pathToMtgData) :
|
|
print("This script requires the text version of Arch's mtg-data to be present.You can download it from slightlymagic.net's forum and either place the text version next to this script or edit this script and provide the path to the file at the top.")
|
|
print("Press Enter to exit")
|
|
raw_input("")
|
|
sys.exit()
|
|
|
|
keyWords = []
|
|
mtgDataCards = {}
|
|
setCodes = []
|
|
tmpName = ""
|
|
line = ""
|
|
|
|
# initialize sets supported by Forge
|
|
initKeywords()
|
|
#Parse mtg-data
|
|
mtgdata = open(pathToMtgData,"r")
|
|
line = mtgdata.readline()
|
|
# Read set codes at top of file
|
|
while line != "\n" and line != "":
|
|
setCodes.append(line[0:3])
|
|
line = mtgdata.readline()
|
|
# loop over remaining file parsing cards
|
|
while line:
|
|
# Ignore blank lines
|
|
while line == "\n" and line != "":
|
|
line = mtgdata.readline()
|
|
# process card data
|
|
linesFound = 0
|
|
foundCost = False
|
|
foundType = False
|
|
foundPT = False
|
|
isPlaneswalker = False
|
|
oracleText = ""
|
|
prevLine = ""
|
|
while line != "\n" and line != "":
|
|
linesFound += 1
|
|
tmpLine = line
|
|
tmpLine = tmpLine.rstrip()
|
|
# First line is always the name
|
|
if linesFound == 1 :
|
|
mtgName = tmpLine
|
|
cardName = tmpLine.replace('AE', 'Ae')
|
|
card = Card(cardName)
|
|
# Second line is either cost or type
|
|
elif not foundCost :
|
|
if line[0] == '{' :
|
|
tmpLine = tmpLine.replace('}{',' ')
|
|
tmpLine = tmpLine.replace('{','')
|
|
tmpLine = tmpLine.replace('}','')
|
|
tmpLine = tmpLine.replace('/','')
|
|
card.cost = tmpLine
|
|
else :
|
|
card.cost = "no cost"
|
|
tmpLine = tmpLine.replace(' - ',' ');
|
|
card.types = tmpLine
|
|
foundType = True
|
|
foundCost = True
|
|
elif not foundType :
|
|
tmpLine = tmpLine.replace(' - ',' ');
|
|
card.types = tmpLine
|
|
foundType = True
|
|
elif not foundPT :
|
|
card.pt = tmpLine
|
|
foundPT = True
|
|
else :
|
|
if prevLine != '' : card.oracle.append(prevLine)
|
|
prevLine = tmpLine.replace(mtgName,'CARDNAME')
|
|
# if card is not creature, set foundPT to true
|
|
if foundType and not foundPT :
|
|
if card.types.find('Creature') == -1 and card.types.find('Planeswalker') == -1 and card.types.find('Vanguard') == -1 : foundPT = True
|
|
line = mtgdata.readline()
|
|
# found blank line or end of file so store last line as set info
|
|
card.sets = prevLine.rstrip()
|
|
# store Card object in hash table
|
|
mtgDataCards[cardName] = card
|
|
|
|
inputName = raw_input("Enter Card Name: ")
|
|
inputName = inputName.rstrip()
|
|
while inputName != 'quit' :
|
|
if mtgDataCards.keys().count(inputName) != 0 :
|
|
cardData = mtgDataCards[inputName]
|
|
cleanName = cardData.name.lower()
|
|
cleanName = cleanName.replace("'",'')
|
|
cleanName = cleanName.replace(',','')
|
|
cleanName = cleanName.replace(' ','_')
|
|
cleanName = cleanName.replace('-','_')
|
|
print '\nName:'+cardData.name
|
|
print 'ManaCost:'+cardData.cost
|
|
print 'Types:'+cardData.types
|
|
if cardData.types.find('Creature') != -1 :
|
|
print 'PT:'+cardData.pt
|
|
elif cardData.types.find('Planeswalker') != -1 :
|
|
print 'Loyalty:'+cardData.pt
|
|
elif cardData.types.find('Vanguard') != -1 :
|
|
vangModifier = cardData.pt.replace('Hand ','')
|
|
vangModifier = vangModifier.replace(', life ','/')
|
|
print 'HandLifeModifier:'+vangModifier
|
|
|
|
for text in cardData.oracle :
|
|
# do some prescripting
|
|
tokens = line.split(' ');
|
|
if text.find("When CARDNAME enters the battlefield") != -1 :
|
|
print "\n"+text
|
|
print "<Trigger Script Start>"
|
|
print 'T:Mode$ ChangesZone | Origin$ Any | Destination$ Battlefield | ValidCard$ Card.Self | Execute$ <TriggerFunc> | TriggerDescription$ '+text
|
|
print 'SVar:<TriggerFunc>:AB$ <Added Triggered Ability HERE>'
|
|
print "<Trigger Script End>\n"
|
|
elif text.find("When CARDNAME leaves the battlefield") != -1 :
|
|
print "\n"+text
|
|
print "<Trigger Script Start>"
|
|
print 'T:Mode$ ChangesZone | Origin$ Battlefield | Destination$ Any | ValidCard$ Card.Self | Execute$ <TriggerFunc> | TriggerDescription$ '+text
|
|
print 'SVar:<TriggerFunc>:AB$ <Added Triggered Ability HERE>'
|
|
print "<Trigger Script End>\n"
|
|
elif text.find("Unleash") != -1 :
|
|
print 'K:ETBReplacement:Other:Unleash:Optional'
|
|
print 'SVar:Unleash:DB$ PutCounter | Defined$ Self | CounterType$ P1P1 | CounterNum$ 1 | SpellDescription$ Unleash (You may have this creature enter the battlefield with a +1/+1 counter on it. It can\'t block as long as it has a +1/+1 counter on it.)'
|
|
print 'S:Mode$ Continuous | Affected$ Card.Self | AddHiddenKeyword$ HIDDEN CARDNAME can\'t block. | CheckSVar$ X | SVarCompare$ GE1 | References$ X'
|
|
print 'SVar:X:Count$NumCounters.P1P1'
|
|
else :
|
|
if handleKeyords(text,keyWords) == False:
|
|
print text
|
|
#print "\n"
|
|
if cardData.types.find('Scheme') != -1 :
|
|
print 'SVar:Picture:https://downloads.cardforge.org/images/cards/HOP/'+cardData.name+'.jpg'
|
|
elif cardData.types.find('Vanguard') != -1 :
|
|
print 'SVar:Picture:https://downloads.cardforge.org/images/cards/VAN/'+cardData.name+'.full.jpg'
|
|
else :
|
|
print 'SVar:Picture:http://www.wizards.com/global/images/magic/general/'+cleanName+'.jpg'
|
|
print '\n'
|
|
else :
|
|
print inputName+' not found\n'
|
|
inputName = raw_input("Enter Card Name: ")
|
|
inputName = inputName.rstrip()
|