From The Mana World
(→‎[FIXED] Cannot run script: Current state of my script fixes)
m (Jesusalva moved page Talk:Item Reference to Legacy talk:Item Reference: Legacy namespace prevails)
 
(5 intermediate revisions by 4 users not shown)
Line 1: Line 1:
==Continuing script maintenance==
Script failed attempting to resurrect, but I'm not sure how I feel about the item categories created.
==Multiple Links to same page==
It appears from here that this page links to the Legacy Items with the same information on it.  I don't know if it is necessary or not.  The same goes from the Legacy Items page, in that it links to itself in its list. [[User:DeadManWalking|DeadManWalking]] ([[User talk:DeadManWalking|talk]]) 17:06, 19 July 2017 (EDT)
==Archives==
==Archives==


Line 26: Line 33:
I have tried to understand the script so I can solve it myself, but I do not really understand the logic of what the code is trying to do or the logic of python’s error message. It seems I need to learn more scripting and python as well. ✎ [[User:Kess|Kess]]<sup>[[User talk:Kess|☽]]</sup> 10:48, 7 November 2008 (CET)
I have tried to understand the script so I can solve it myself, but I do not really understand the logic of what the code is trying to do or the logic of python’s error message. It seems I need to learn more scripting and python as well. ✎ [[User:Kess|Kess]]<sup>[[User talk:Kess|☽]]</sup> 10:48, 7 November 2008 (CET)
: I have solved this part, just needed to take the time to understand the script and update/fix the relevant parts. I will update the item pages in a few days time when I have ironed out some ‘small’ issues like dyed items and rarity. At that time I think I’ll make another archive of this talk page as well. ✎ [[User:Kess|Kess]]<sup>[[User talk:Kess|☽]]</sup> 19:50, 10 November 2008 (CET)
: I have solved this part, just needed to take the time to understand the script and update/fix the relevant parts. I will update the item pages in a few days time when I have ironed out some ‘small’ issues like dyed items and rarity. At that time I think I’ll make another archive of this talk page as well. ✎ [[User:Kess|Kess]]<sup>[[User talk:Kess|☽]]</sup> 19:50, 10 November 2008 (CET)
:: I do not have this time currently. The latest state of the script is available here: [[User talk:Kess/Sandbox]], with output as shown here: [[User:Kess/Sandbox]]. Feel free to use it or skip it. I might get back to this next year. Depends on where my priorities will lie.
:: I do not have this time currently. The latest state of the script is available here: [[User talk:Kess/Sandbox]], with output as shown here: [[User:Kess/Sandbox]]. Feel free to use it or skip it. I might get back to this next year. Depends on where my priorities will lie. ✎ [[User:Kess|Kess]]<sup>[[User talk:Kess|☽]]</sup> 15:26, 18 November 2008 (CET)


== How to create this page ==
== How to create this page ==
Line 97: Line 104:
]
]


imagesused = {}
imagesused = set()


class whatever: pass
class whatever: pass
Line 145: Line 152:
                 parentry = a
                 parentry = a
         elif mode == 3: #reading param
         elif mode == 3: #reading param
             if (a == " ") or (a == ",") or (a == ";"):
             if a in (" ", ",", ";"):
                 script[scriptentry].append(parentry)
                 script[scriptentry].append(parentry)
                 parentry = ""
                 parentry = ""
                 if (a == ';'):  
                 if a == ';':  
                     mode = 0
                     mode = 0
                     scriptentry = ""
                     scriptentry = ""
Line 171: Line 178:
     objects = []
     objects = []
     for line in file:
     for line in file:
         s = line[0:line.find('//')].strip().replace('\t','')
         s = line[:line.find('//')].strip().replace('\t','')
         if s:
         if s:
             #Replace commas inbetween {} with |, so we can use split
             #Replace commas inbetween {} with |, so we can use split
Line 191: Line 198:
                     log.append("FOUND COMMENT LINE: %s" % str(values))
                     log.append("FOUND COMMENT LINE: %s" % str(values))
                 continue
                 continue
             if (len(values) != 20):
             if len(values) != 20:
                 log.append("item_db: Warning, item-line with ID %s has %d values instead of 19" % (values[0], len(values)))
                 log.append("item_db: Warning, item-line with ID %s has %d values instead of 19" % (values[0], len(values)))
                 if debug:
                 if debug:
                     log.append("  line was %s" % str(values))
                     log.append("  line was %s" % str(values))
                 while (len(values) < 20):
                 while len(values) < 20:
                     values.append('')
                     values.append('')
                 while (len(values) > 20):
                 while len(values) > 20:
                     values.pop()
                     values.pop()
             o = whatever()
             o = whatever()
Line 240: Line 247:
     index = 0
     index = 0
     debug = 0
     debug = 0
     while s[index:].find(pre) >= 0:
     while pre in s[index:]:
         index += s[index:].find(pre) + len(pre)
         index += s[index:].find(pre) + len(pre)
         curitem = {}
         curitem = {}
Line 253: Line 260:
                 start = termstart
                 start = termstart


             if (start < termstart):
             if start < termstart:
                 curitem[attr] = s[start:end]
                 curitem[attr] = s[start:end]


         for a in intattrs:
         for a in intattrs:
             try:
             try:
                 if curitem.has_key(a): curitem[a] = int(curitem[a])
                 if a in curitem: curitem[a] = int(curitem[a])
             except:
             except:
                 log.append("Item-ID %s: Cannot convert integer attribute %s to an integer. Value: '%s'" % (curitem["id"], a, curitem[a]))
                 log.append("Item-ID %s: Cannot convert integer attribute %s to an integer. Value: '%s'" % (curitem["id"], a, curitem[a]))
Line 273: Line 280:


def addclientinformation(items,citems):
def addclientinformation(items,citems):
    global imageurls
    global imagesused
     for i in items:
     for i in items:
         if citems.has_key(i.id):
         if i.id in citems:
             i.imagename=citems[i.id]["image"]
             i.imagename=citems[i.id]["image"]
             url=i.imagename[0].upper() + i.imagename[1:]
             url=i.imagename[0].upper() + i.imagename[1:]
             i.imgurl = "[[Image:"+ url + "]]"
             i.imgurl = "[[Image:"+ url + "]]"
             imagesused[ citems[i.id]["image"]] = 1
             imagesused.add( citems[i.id]["image"])
             i.description = citems[i.id]["description"]
             i.description = citems[i.id]["description"]
             i.clientname = citems[i.id]["name"]
             i.clientname = citems[i.id]["name"]
Line 293: Line 298:
## Returns sorted lists of items by itemtype
## Returns sorted lists of items by itemtype
def gettypedir(items):
def gettypedir(items):
     items.sort(lambda x,y: (x.price+x.sell) - (y.price+y.sell))
     items.sort(key=lambda x: x.price+x.sell)


     typedir = whatever()
     typedir = whatever()
Line 304: Line 309:
     typedir.other = []
     typedir.other = []
     for item in items:
     for item in items:
         if (item.imgurl.strip() or item.clientname.strip()):
         if item.imgurl.strip() or item.clientname.strip():
             #if item.id == 537: log.append('"%s", "%s"' % (item.imgurl, item.name)
             #if item.id == 537: log.append('"%s", "%s"' % (item.imgurl, item.name)
             if (item.atk > 0):
             if item.atk > 0:
                 if item.defense == 0: typedir.weapons.append(item)
                 if item.defense == 0: typedir.weapons.append(item)
                 else: typedir.combos.append(item)
                 else: typedir.combos.append(item)
             elif (item.defense > 0): typedir.armor.append(item)
             elif item.defense > 0: typedir.armor.append(item)
             elif item.usescript.has_key("itemheal"):  
             elif "itemheal" in item.usescript:
                 if item.usescript["itemheal"][0] > item.usescript["itemheal"][1]:  
                 if item.usescript["itemheal"][0] > item.usescript["itemheal"][1]:
                     typedir.healthy.append(item)
                     typedir.healthy.append(item)
                 else:
                 else:
                     typedir.inspiring.append(item)
                     typedir.inspiring.append(item)
             elif item.usescript.has_key("sc_start"):
             elif "sc_start" in item.usescript:
                 typedir.status.append(item)
                 typedir.status.append(item)
             else: typedir.other.append(item)
             else: typedir.other.append(item)


     typedir.weapons.sort(lambda x,y: x.atk - y.atk)
     typedir.weapons.sort(key=lambda x: x.atk)
     typedir.armor.sort(lambda x,y: x.defense - y.defense)
     typedir.armor.sort(key=lambda x: x.defense)
     typedir.combos.sort(lambda x,y: (x.defense+x.atk) - (y.defense+y.atk))
     typedir.combos.sort(key=lambda x: x.defense+x.atk)


     typedir.healthy.sort(lambda x,y: int(x.usescript["itemheal"][0]) - int(y.usescript["itemheal"][0]))
     typedir.healthy.sort(key=lambda x: int(x.usescript["itemheal"][0]))
     typedir.inspiring.sort(lambda x,y: int(x.usescript["itemheal"][1]) - int(y.usescript["itemheal"][1]))
     typedir.inspiring.sort(key=lambda x: int(x.usescript["itemheal"][1]))
     #typedir.other.sort(lambda x,y: (x.price+x.sell) - (y.price+y.sell))
     #typedir.other.sort(key=lambda x: x.price+x.sell)
     typedir.status.sort(lambda x,y: (x.price+x.sell) - (y.price+y.sell))
     typedir.status.sort(key=lambda x: x.price+x.sell)


     return typedir
     return typedir
Line 337: Line 342:
     global log
     global log
     if len(log) > 0:
     if len(log) > 0:
         sys.stdout.write('\n---------------------------------------\n')
         print '\n---------------------------------------'
     for line in log:
     for line in log:
         sys.stdout.write(line+'\n')
         print line




Line 351: Line 356:
      
      
def printhealitems(items,title):
def printhealitems(items,title):
     sys.stdout.write('==%s==\n' % title)
     print '==%s==' % title
     sys.stdout.write('{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"\n')
     print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"'
     # Print labels
     # Print labels
     for title in health_titles:
     for title in health_titles:
         sys.stdout.write('! style="background:#efdead;" | %s\n' % title)
         print '! style="background:#efdead;" | %s' % title
          
          
     for i in items:
     for i in items:
         sys.stdout.write('|-\n')
         print '|-'
         sys.stdout.write('| align="center" | %s\n' % i.imgurl)
         print '| align="center" | %s' % i.imgurl
         #sys.stdout.write('| %s\n' % i.jname.replace('_',' '))
         #print '| %s' % i.jname.replace('_',' ')
         sys.stdout.write('| %s\n' % i.clientname)
         print '| %s' % i.clientname
         sys.stdout.write( getidstring(i.id) )
         sys.stdout.write( getidstring(i.id) )
         sys.stdout.write('| align="center" | %d\n' % i.usescript["itemheal"][0])
         print '| align="center" | %d' % i.usescript["itemheal"][0]
         sys.stdout.write('| align="center" | %d\n' % i.usescript["itemheal"][1])
         print '| align="center" | %d' % i.usescript["itemheal"][1]
         sys.stdout.write( getmoneystring(i.price,i.sell) )
         sys.stdout.write( getmoneystring(i.price,i.sell) )
         sys.stdout.write('| align="center!" | %d\n' % i.weight)
         print '| align="center!" | %d' % i.weight
         sys.stdout.write('| %s\n' % i.description)
         print '| %s' % i.description
     sys.stdout.write('|}\n\n')
     print '|}\n'
              
              
def printstatusitems(items,title):
def printstatusitems(items,title):
     sys.stdout.write('==%s==\n' % title)
     print '==%s==\n' % title)
     sys.stdout.write('{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"\n')
     print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"\n')
     # Print labels
     # Print labels
     for title in status_titles:
     for title in status_titles:
         sys.stdout.write('! style="background:#efdead;" | %s\n' % title)
         print '! style="background:#efdead;" | %s' % title
          
          
     for i in items:
     for i in items:
         sys.stdout.write('|-\n')
         print '|-'
         sys.stdout.write('| align="center" | %s\n' % i.imgurl)
         print '| align="center" | %s' % i.imgurl
         #sys.stdout.write('| %s\n' % i.jname.replace('_',' '))
         #print '| %s' % i.jname.replace('_',' ')
         sys.stdout.write('| %s\n' % i.clientname)
         print '| %s' % i.clientname
         sys.stdout.write( getidstring(i.id) )
         sys.stdout.write( getidstring(i.id) )
         sys.stdout.write('| align="center" | %s\n' % i.usescript["sc_start"][0])
         print '| align="center" | %s' % i.usescript["sc_start"][0]
         sys.stdout.write('| align="center" | %s\n' % i.usescript["sc_start"][1])
         print '| align="center" | %s' % i.usescript["sc_start"][1]
         sys.stdout.write('| align="center" | %s\n' % i.usescript["sc_start"][2])
         print '| align="center" | %s' % i.usescript["sc_start"][2]
         sys.stdout.write( getmoneystring(i.price,i.sell) )
         sys.stdout.write( getmoneystring(i.price,i.sell) )
         sys.stdout.write('| align="center!" | %d\n' % i.weight)
         print '| align="center!" | %d' % i.weight
         sys.stdout.write('| %s\n' % i.description)
         print '| %s' % i.description
     sys.stdout.write('|}\n\n')
     print '|}\n'
              
              


def printweaponitems(items, title):
def printweaponitems(items, title):
     sys.stdout.write('==%s==\n' % title)
     print '==%s==\n' % title)
     sys.stdout.write('{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"\n')
     print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"\n')
     # Print labels
     # Print labels
     for title in weapon_titles:
     for title in weapon_titles:
         sys.stdout.write('! style="background:#efdead;" | %s\n' % title)
         print '! style="background:#efdead;" | %s\n' % title)


     for i in items:
     for i in items:
         sys.stdout.write('|-\n')
         print '|-'
         sys.stdout.write('| align="center" | %s\n' % i.imgurl)
         print '| align="center" | %s' % i.imgurl
         #sys.stdout.write('| %s\n' % i.jname.replace('_',' '))
         #print '| %s' % i.jname.replace('_',' ')
         sys.stdout.write('| %s\n' % i.clientname)
         print '| %s' % i.clientname
         sys.stdout.write( getidstring(i.id) )
         sys.stdout.write( getidstring(i.id) )
         sys.stdout.write('| align="center" | %d (%d)\n' % (i.atk,i.range))
         print '| align="center" | %d (%d)' % (i.atk,i.range)
         sys.stdout.write( getmoneystring(i.price,i.sell) )
         sys.stdout.write( getmoneystring(i.price,i.sell) )
         sys.stdout.write('| align="center!" | %d\n' % i.weight)
         print '| align="center!" | %d' % i.weight
         sys.stdout.write('| %s\n' % i.description)
         print '| %s' % i.description
     sys.stdout.write('|}\n\n')
     print '|}\n'
      
      
def printarmoritems(items, title):
def printarmoritems(items, title):
     sys.stdout.write('==%s==\n' % title)
     print '==%s==' % title
     sys.stdout.write('{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"\n')
     print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"'
     sys.stdout.write('! style="background:#efdead;" | Image\n')
     print '! style="background:#efdead;" | Image'
     sys.stdout.write('! style="background:#efdead;" | Name\n')
     print '! style="background:#efdead;" | Name'
     sys.stdout.write('! style="background:#efdead;" | ID\n')
     print '! style="background:#efdead;" | ID'
     sys.stdout.write('! style="background:#efdead;" | Defense\n')
     print '! style="background:#efdead;" | Defense'
     sys.stdout.write('! style="background:#efdead;" | Price<br>BUY/Sell\n')
     print '! style="background:#efdead;" | Price<br>BUY/Sell'
     sys.stdout.write('! style="background:#efdead;" | Description\n')
     print '! style="background:#efdead;" | Description'
     for i in items:
     for i in items:
         sys.stdout.write('|-\n')
         print '|-'
         sys.stdout.write('| align="center" | %s\n' % i.imgurl)
         print '| align="center" | %s' % i.imgurl
         #sys.stdout.write('| %s\n' % i.jname.replace('_',' '))
         #print '| %s' % i.jname.replace('_',' ')
         sys.stdout.write('| %s\n' % i.clientname)
         print '| %s' % i.clientname
         sys.stdout.write( getidstring(i.id) )
         sys.stdout.write( getidstring(i.id) )
         sys.stdout.write('| align="center" | %d\n' % i.defense)
         print '| align="center" | %d' % i.defense
         sys.stdout.write( getmoneystring(i.price,i.sell) )
         sys.stdout.write( getmoneystring(i.price,i.sell) )
         sys.stdout.write('| %s\n' % i.description)
         print '| %s' % i.description
     sys.stdout.write('|}\n\n')
     print '|}\n'


def printcomboitems(items, title):
def printcomboitems(items, title):
     sys.stdout.write('==%s==\n' % title)
     print '==%s==' % title
     sys.stdout.write('{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"\n')
     print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"'
     sys.stdout.write('! style="background:#efdead;" | Image\n')
     print '! style="background:#efdead;" | Image'
     sys.stdout.write('! style="background:#efdead;" | Name\n')
     print '! style="background:#efdead;" | Name'
     sys.stdout.write('! style="background:#efdead;" | ID\n')
     print '! style="background:#efdead;" | ID'
     sys.stdout.write('! style="background:#efdead;" | Damage<br>(Range)\n')
     print '! style="background:#efdead;" | Damage<br>(Range)'
     sys.stdout.write('! style="background:#efdead;" | Defense\n')
     print '! style="background:#efdead;" | Defense'
     sys.stdout.write('! style="background:#efdead;" | Price<br>BUY/Sell\n')
     print '! style="background:#efdead;" | Price<br>BUY/Sell'
     sys.stdout.write('! style="background:#efdead;" | Description\n')
     print '! style="background:#efdead;" | Description'
     for i in items:
     for i in items:
         sys.stdout.write('|-\n')
         print '|-'
         sys.stdout.write('| align="center" | %s\n' % i.imgurl)
         print '| align="center" | %s' % i.imgurl
         #sys.stdout.write('| %s\n' % i.jname.replace('_',' '))
         #print '| %s' % i.jname.replace('_',' ')
         sys.stdout.write('| %s\n' % i.clientname)
         print '| %s' % i.clientname
         sys.stdout.write( getidstring(i.id) )
         sys.stdout.write( getidstring(i.id) )
         sys.stdout.write('| align="center" | %d (%d)\n' % (i.atk,i.range))
         print '| align="center" | %d (%d)' % (i.atk,i.range)
         sys.stdout.write('| align="center" | %d\n' % i.defense)
         print '| align="center" | %d' % i.defense
         sys.stdout.write( getmoneystring(i.price,i.sell) )
         sys.stdout.write( getmoneystring(i.price,i.sell) )
         sys.stdout.write('| %s\n' % i.description)
         print '| %s' % i.description
     sys.stdout.write('|}\n\n')
     print '|}\n'


def getpropertystring(item):
def getpropertystring(item):
Line 467: Line 472:


def printotheritems(items, title):
def printotheritems(items, title):
     sys.stdout.write('==%s==\n' % title)
     print '==%s==' % title
     sys.stdout.write('{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"\n')
     print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"'
     sys.stdout.write('! style="background:#efdead;" | Image\n')
     print '! style="background:#efdead;" | Image'
     sys.stdout.write('! style="background:#efdead;" | Name\n')
     print '! style="background:#efdead;" | Name'
     sys.stdout.write('! style="background:#efdead;" | ID\n')
     print '! style="background:#efdead;" | ID'
     #sys.stdout.write('! style="background:#efdead;" | Type\n')
     #print '! style="background:#efdead;" | Type'
     #sys.stdout.write('! style="background:#efdead;" | Properties\n')
     #print '! style="background:#efdead;" | Properties'
     sys.stdout.write('! style="background:#efdead;" | Price<br>BUY/Sell\n')
     print '! style="background:#efdead;" | Price<br>BUY/Sell'
     sys.stdout.write('! style="background:#efdead;" | Description\n')
     print '! style="background:#efdead;" | Description'
     for i in items:
     for i in items:
         sys.stdout.write('|-\n')
         print '|-'
         sys.stdout.write('| align="center" | %s\n' % i.imgurl)
         print '| align="center" | %s' % i.imgurl
         #sys.stdout.write('| %s\n' % i.jname.replace('_',' '))
         #print '| %s' % i.jname.replace('_',' ')
         sys.stdout.write('| %s\n' % i.clientname)
         print '| %s' % i.clientname
         sys.stdout.write( getidstring(i.id) )
         sys.stdout.write( getidstring(i.id) )
         #sys.stdout.write('| align="center" | %d\n' % i.type)
         #print '| align="center" | %d' % i.type
         #sys.stdout.write('| align="center" | %s\n' % getpropertystring(i))
         #print '| align="center" | %s' % getpropertystring(i)
         sys.stdout.write( getmoneystring(i.price,i.sell) )
         sys.stdout.write( getmoneystring(i.price,i.sell) )
         sys.stdout.write('| %s\n' % i.description)
         print '| %s' % i.description
     sys.stdout.write('|}\n\n')
     print '|}\n'






def printunuseditems(title):
def printunuseditems(title):
    global imageurls
    global imagesused
     ids = []
     ids = []
     for i in range(1,len(imageurls)):
     for i in range(1,len(imageurls)):
         if not imagesused.has_key(i):
         if i not in imagesused:
             ids.append(i)
             ids.append(i)
     if len(ids):
     if len(ids):
         sys.stdout.write('==%s==\n' % title)
         print '==%s==' % title
         sys.stdout.write('{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"\n')
         print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"'
         sys.stdout.write('| ')
         print '|',
         for i in ids:
         for i in ids:
             sys.stdout.write(imageurls[i] + ' ')
             print imageurls[i],
         sys.stdout.write('\n|}\n\n')
         print '\n|}\n'


      
      
Line 512: Line 515:


try:
try:
     if (len(sys.argv) == 1):
     if len(sys.argv) == 1:
         item_db = "item_db.txt"
         item_db = "item_db.txt"
         item_xml = "items.xml"
         item_xml = "items.xml"
     elif (len(sys.argv) == 3):
     elif len(sys.argv) == 3:
         item_db = sys.argv[1]
         item_db = sys.argv[1]
         item_xml = sys.argv[2]
         item_xml = sys.argv[2]
Line 521: Line 524:
         item_db = ''
         item_db = ''
         item_xml = ''
         item_xml = ''
         sys.stdout.write("Wrong number of arguments\n")
         print "Wrong number of arguments"


     if item_db and (not os.path.isfile(item_db)):
     if item_db and not os.path.isfile(item_db):
         sys.stdout.write("File does not exist: %s\n" % item_db)
         print "File does not exist: %s" % item_db
         item_db = ''
         item_db = ''
     if item_xml and (not os.path.isfile(item_xml)):
     if item_xml and not os.path.isfile(item_xml):
         sys.stdout.write("File does not exist: %s\n" % item_xml)
         print "File does not exist: %s" % item_xml
         item_db = ''
         item_db = ''
      
      
     if not (item_db and item_xml):
     if not (item_db and item_xml):
         sys.stdout.write("\nUSAGE:\n")
         print "\nUSAGE:"
         sys.stdout.write("dbtowiki without any arguments will use item_db.txt and items.xml in the current directory.\n")
         print "dbtowiki without any arguments will use item_db.txt and items.xml in the current directory."
         sys.stdout.write("to specify custom files, call: dbtowiki <item_db> <item_xml>\n")
         print "to specify custom files, call: dbtowiki <item_db> <item_xml>"
         exit(-1);
         exit(-1);
     else:
     else:
Line 555: Line 558:


         if checkimagesonwiki:
         if checkimagesonwiki:
             sys.stdout.write("Checking for images on wiki: \n")
             print "Checking for images on wiki: "
             images = []
             images = []
             for item in typedir.healthy:
             for item in typedir.healthy:
Line 577: Line 580:
                     'Image:%s"' % fixedimagename
                     'Image:%s"' % fixedimagename
                 if debug:
                 if debug:
                     sys.stdout.write("CHECKING URL: %s\n" % curlstring)
                     print "CHECKING URL: %s" % curlstring
                 p=popen2.Popen4(curlstring)  
                 p=popen2.Popen4(curlstring)  
                 # this could hang if there is a lot of output!
                 # this could hang if there is a lot of output!
                 returncode = p.wait() # wait for the process to finish
                 returncode = p.wait() # wait for the process to finish
                 if debug:
                 if debug:
                     sys.stdout.write("Process finished with %d\n" % returncode)
                     print "Process finished with %d" % returncode
                 page = p.fromchild.read()
                 page = p.fromchild.read()
                  
                  
                 if debug >= 3:
                 if debug >= 3:
                     sys.stdout.write("Read: %s\n" % page)
                     print "Read: %s" % page


                 if page.find("No file by this name exists") != -1:
                 if "No file by this name exists" in page:
                     need_to_upload.append((imagename, description))
                     need_to_upload.append((imagename, description))
                     if debug:
                     if debug:
                         sys.stdout.write("NEED TO UPLOAD: %s\n" %  
                         print "NEED TO UPLOAD: %s" % need_to_upload[-1]
                                        str(need_to_upload[-1]))
              
              
              
              
Line 599: Line 601:
                 curlstring = 'curl -d "wpName=%s&wpPassword=%s&wpLoginattempt=Log+in" -c cookie-jar "http://wiki.themanaworld.org/index.php?title=Special:Userlogin&action=submitlogin&type=login"'% (wikiuser, wikipassword)
                 curlstring = 'curl -d "wpName=%s&wpPassword=%s&wpLoginattempt=Log+in" -c cookie-jar "http://wiki.themanaworld.org/index.php?title=Special:Userlogin&action=submitlogin&type=login"'% (wikiuser, wikipassword)


                 sys.stdout.write("Logging in as %s, your password can be seen "
                 print "Logging in as %s, your password can be seen " \
                                 "in `ps ax`, also this is using http://... "
                                 "in `ps ax`, also this is using http://... " \
                                 "so be warned!\n" % wikiuser)
                                 "so be warned!" % wikiuser
                 p=popen2.Popen4(curlstring)  
                 p=popen2.Popen4(curlstring)  
                 # this could hang if there is a lot of output!
                 # this could hang if there is a lot of output!
Line 607: Line 609:
                 data = p.fromchild.read()
                 data = p.fromchild.read()
                 if debug >= 1:
                 if debug >= 1:
                     sys.stdout.write("Read: %s\n" % data)
                     print "Read: %s" % data


                 if data.find("Login error") != -1:
                 if "Login error" in data:
                     sys.stdout.write("Login failed\n")
                     print "Login failed"


                 if debug:
                 if debug:
                     sys.stdout.write("Process finished with %d\n" % returncode)
                     print "Process finished with %d" % returncode


                 sys.stdout.write("Now it is time to upload: %s" %  
                 sys.stdout.write("Now it is time to upload: %s" %  
                                 str(need_to_upload))
                                 need_to_upload)


                 for imagename, description in need_to_upload:
                 for imagename, description in need_to_upload:
                     if debug:
                     if debug:
                         sys.stdout.write("Uploading image: %s\n" % imagename)
                         print "Uploading image: %s" % imagename


                     curlstring='curl -b cookie-jar -F "wpUploadFile=@%s/%s" -F "filename=%s" -F "wpDestFile=%s" -F "wpUploadDescription=%s" -F "wpUpload=Upload file" "http://wiki.themanaworld.org/index.php?title=Special:Upload"' % (image_path, imagename, imagename, imagename, description)
                     curlstring='curl -b cookie-jar -F "wpUploadFile=@%s/%s" -F "filename=%s" -F "wpDestFile=%s" -F "wpUploadDescription=%s" -F "wpUpload=Upload file" "http://wiki.themanaworld.org/index.php?title=Special:Upload"' % (image_path, imagename, imagename, imagename, description)
Line 628: Line 630:
                     data = p.fromchild.read()
                     data = p.fromchild.read()
                     if debug >= 1:
                     if debug >= 1:
                         sys.stdout.write("Read: %s\n" % data)
                         print "Read: %s" % data


                     if debug:
                     if debug:
                         sys.stdout.write("Process finished with %d\n" %  
                         print "Process finished with %d" % returncode
                                        returncode)


                     sys.stdout.write("Uploaded: %s, %s\n" % (imagename,
                     print "Uploaded: %s, %s" % (imagename, description))
                                                            description))
                      
                      


         printunuseditems("Still unknown")
         printunuseditems("Still unknown")


         sys.stdout.write("\n\n")
         print "\n"


finally:
finally:

Latest revision as of 02:08, 22 January 2020

Continuing script maintenance

Script failed attempting to resurrect, but I'm not sure how I feel about the item categories created.


Multiple Links to same page

It appears from here that this page links to the Legacy Items with the same information on it. I don't know if it is necessary or not. The same goes from the Legacy Items page, in that it links to itself in its list. DeadManWalking (talk) 17:06, 19 July 2017 (EDT)

Archives

Archives of outdated information from this talk page are here:

Problems

itemdbtowiki does not take enough arguments

In the future, itemdbtowiki should be modified to take some extra arguments from the command line, such as 'image_path', 'checkimagesonwiki', and perhaps the username and password.

[FIXED] Cannot run script

Output:

Item-ID -1: Cannot convert integer attribute type to an integer. Value: 'hairsprite'
.
.
.
Item-ID 1213: Cannot convert integer attribute type to an integer. Value: 'generic'
Traceback (most recent call last):
  File "./itemdbtowiki.py", line 531, in <module>
    citems = parsexmlitems(f);
  File "./itemdbtowiki.py", line 252, in parsexmlitems
    items[curitem['id']] = curitem
KeyError: 'id'

I have tried to understand the script so I can solve it myself, but I do not really understand the logic of what the code is trying to do or the logic of python’s error message. It seems I need to learn more scripting and python as well. ✎ Kess☽ 10:48, 7 November 2008 (CET)

I have solved this part, just needed to take the time to understand the script and update/fix the relevant parts. I will update the item pages in a few days time when I have ironed out some ‘small’ issues like dyed items and rarity. At that time I think I’ll make another archive of this talk page as well. ✎ Kess☽ 19:50, 10 November 2008 (CET)
I do not have this time currently. The latest state of the script is available here: User talk:Kess/Sandbox, with output as shown here: User:Kess/Sandbox. Feel free to use it or skip it. I might get back to this next year. Depends on where my priorities will lie. ✎ Kess☽ 15:26, 18 November 2008 (CET)

How to create this page

I have completed the new new script to recreate this page, please leave me a note if you find any problems. It is now capable of uploading new images to the wiki! --Hype0 02:42, 3 September 2007 (CEST)

You can run itemdbtowiki to generate the wiki page. The usage is:

itemdbtowiki <item_db.txt> <items.xml> > wikipage.txt

If run without any arguments, it'll look for item_db.txt and items.xml in the current directory.

To upload new images to the wiki automatically, 'checkimagesonwiki' in the file to 1 and set a corresponding valid 'wikiuser' and 'wikipassword' as well as set the 'image_path' to be correct (these are all parameters at the start of the script.)

Warning: if you choose to upload images, authentication will be done in plaintext, which is exactly what happens if you log in over http:// anyway... just thought you might like a reminder.

Python-Tools

itemdbtowiki

#!/usr/bin/python
#Licensed under GNU General Public License

import sys, os, popen2;
import xml.parsers.expat

debug=0
checkimagesonwiki=0
#wikiuser="Hype0"
#wikipassword="password"
image_path="/usr/home/dex/src/themanaworld/tmw/trunk/data/graphics/items"

health_titles = ["Image","Name","ID","HP Bonus","SP Bonus",
                 "Price<BR />BUY/Sell","Weight","Description"]
status_titles = ["Image","Name","ID","Spell name","Parameter 1","Parameter 2",
                 "Price<BR />BUY/Sell","Weight","Description"]
weapon_titles = [" Image","Name","ID","Damage<BR />(Range)",
                 "Price<BR />BUY/Sell","Weight","Description"]
armor_titles = ["Image", "Name", "ID", "Defense", 
              "Price<BR />BUY/Sell", "Weight","Description"]
other_titles = ["Image","Name","ID","Price<BR />BUY/Sell",
                "Weight","Description "]


imageurls = [
# The index represents the imageID from the items.xml of the client.
    "",  #    0
    "http://img52.imageshack.us/img52/3072/423xc.png",         #   42
    "http://img187.imageshack.us/img187/2963/434dc.png",       #   43
    "http://img125.imageshack.us/img125/4331/442fm.png",       #   44
    "http://img260.imageshack.us/img260/6627/456rj.png",       #   45
    "http://img211.imageshack.us/img211/9089/469fy.png",       #   46
    "http://img219.imageshack.us/img219/1188/479yz.png",       #   47
    "http://img232.imageshack.us/img232/3517/489oa.png",       #   48
    "http://img291.imageshack.us/img291/8643/491eg.png",       #   49
    "http://img157.imageshack.us/img157/1425/502hg.png",       #   50
    "http://img293.imageshack.us/img293/4524/514dn.png",       #   51
    "http://img42.imageshack.us/img42/7271/523hc.png",         #   52
    "http://img187.imageshack.us/img187/5241/535fk.png",       #   53
    "http://img125.imageshack.us/img125/8093/543yr.png",       #   54
    "http://img260.imageshack.us/img260/1315/554bt.png",       #   55
    "http://img211.imageshack.us/img211/9687/564wu.png",       #   56
    "http://img219.imageshack.us/img219/6842/571wz.png",       #   57
    "http://img232.imageshack.us/img232/9236/582ue.png",       #   58
    "http://img291.imageshack.us/img291/435/598ni.png",        #   59
    "http://img157.imageshack.us/img157/1323/605pt.png",       #   60
    "http://img293.imageshack.us/img293/1371/618fu.png",       #   61
    "http://img42.imageshack.us/img42/69/625mj.png",           #   62
    "http://img187.imageshack.us/img187/6240/637ju.png",       #   63
    "http://img275.imageshack.us/img275/9440/648zq.png",       #   64
]

imagesused = set()

class whatever: pass

log = []


# parseitems(file)
## Returns list with items from eathena item_db file.

def saveint(string, altval = 0):
    a = 0
    try:
        a = int(string)
    except:
        a = altval
    return a
        
def parsescript(s):
    # Assumes that there's only one call of each method, otherwise it would need to know
    # how to combine those function calls. In practice, the latter call would prevail.
    script = {}
    scriptentry = ""
    parentry = ""
    mode = 0
    for a in s:
        if mode == 0: # looking for method
            if a.isalpha(): 
                mode = 1
                scriptentry += a
            elif a == '}': mode = 9
        elif mode == 1: # reading method name
            if a in " ;}":
                if a == " ": mode = 2
                elif a == ";": mode = 1
                elif a == "}": mode = 9
                parentry = ""
                script[scriptentry] = []
            else: scriptentry += a
        elif mode == 2: #looking for param
            if a == " ": pass
            elif a == ";": 
                mode = 0
                scriptentry = ""
            else:
                mode = 3
                parentry = a
        elif mode == 3: #reading param
            if a in (" ", ",", ";"):
                script[scriptentry].append(parentry)
                parentry = ""
                if a == ';': 
                    mode = 0
                    scriptentry = ""
                else: mode = 2
            else: 
                parentry += a
        elif mode == 9: #finished
            pass

    # Convert all possible parameters to integers
    for i in script.keys():
        for j in range(len(script[i])):
            try:
                script[i][j] = int(script[i][j])
            except:
                #print script[i][j]
                pass
    return script
    

def parseitems(file):
    objects = []
    for line in file:
        s = line[:line.find('//')].strip().replace('\t','')
        if s:
            #Replace commas inbetween {} with |, so we can use split
            mode = 0
            sout = ""
            for a in s:
                if mode == 0: #Out of {}
                    if a == '{': mode = 1
                    sout += a
                elif mode == 1: #Inside {}
                    if a == ',': sout += '|'
                    else:
                        sout += a
                        if a == '}': mode = 0

            values = sout.split(',')
            if line[0] == '#':
                if debug:
                    log.append("FOUND COMMENT LINE: %s" % str(values))
                continue
            if len(values) != 20:
                log.append("item_db: Warning, item-line with ID %s has %d values instead of 19" % (values[0], len(values)))
                if debug:
                    log.append("  line was %s" % str(values))
                while len(values) < 20:
                    values.append('')
                while len(values) > 20:
                    values.pop()
            o = whatever()
            o.id        = int(values[0])
            o.name      = values[1]
            o.jname     = values[2]
            o.type      = saveint(values[3])
            o.price     = saveint(values[4])
            o.sell      = saveint(values[5])
            o.weight    = saveint(values[6])
            o.atk       = saveint(values[7])
            o.defense   = saveint(values[8])
            o.range     = saveint(values[9])
            o.mbonus    = saveint(values[10])
            o.slot      = saveint(values[11],-1)
            o.job       = saveint(values[12],-1)
            o.gender    = saveint(values[13],-1)
            o.loc       = saveint(values[14],-1)
            o.wlv       = saveint(values[15])
            o.elv       = saveint(values[16])
            o.view      = saveint(values[17],-1)
            o.usescript = parsescript(values[18].replace('|',','))
            o.equipscript = parsescript(values[19].replace('|',','))


            objects.append(o)

    return objects


# parsexmlitems(file)
## Creates a dictionary containing the values of a client items.xml
## Yeah, there are XML parsers in the standard python libraries, but they're too object
## oriented and thus don't fit the style of this program.
def parsexmlitems(file):
    items = {}
    pre = "<item "
    term = "/>"
    attrs = ["id", "image", "art", "name", "description", "type", "weight", "slot"]
    intattrs = ["id", "art", "type", "weight", "slot"]
    s = file.read()
    index = 0
    debug = 0
    while pre in s[index:]:
        index += s[index:].find(pre) + len(pre)
        curitem = {}
        termstart = index + s[index:].find(term) + len(term)

        for attr in attrs:
            found = s[index:].find(attr+'="')
            if found >= 0:
                start = index + found + len(attr+'="')
                end= start + s[start:].find('"')
            else:
                start = termstart

            if start < termstart:
                curitem[attr] = s[start:end]

        for a in intattrs:
            try:
                if a in curitem: curitem[a] = int(curitem[a])
            except:
                log.append("Item-ID %s: Cannot convert integer attribute %s to an integer. Value: '%s'" % (curitem["id"], a, curitem[a]))

        items[curitem['id']] = curitem


    return items
        

# addclientinformation(items, citems)
## Entends the item data with the data collected from the client items.xml. Adding imageurls,
## client-name and -description

def addclientinformation(items,citems):
    for i in items:
        if i.id in citems:
            i.imagename=citems[i.id]["image"]
            url=i.imagename[0].upper() + i.imagename[1:]
            i.imgurl = "[[Image:"+ url + "]]"
            imagesused.add( citems[i.id]["image"])
            i.description = citems[i.id]["description"]
            i.clientname = citems[i.id]["name"]
        else:
            i.imgurl = ''
            i.description = ''
            i.clientname = ''



# gettypedir (items)
## Returns sorted lists of items by itemtype
def gettypedir(items):
    items.sort(key=lambda x: x.price+x.sell)

    typedir = whatever()
    typedir.healthy = []
    typedir.status = []
    typedir.inspiring = []
    typedir.weapons = []
    typedir.combos = []
    typedir.armor = []
    typedir.other = []
    for item in items:
        if item.imgurl.strip() or item.clientname.strip():
            #if item.id == 537: log.append('"%s", "%s"' % (item.imgurl, item.name)
            if item.atk > 0:
                if item.defense == 0: typedir.weapons.append(item)
                else: typedir.combos.append(item)
            elif item.defense > 0: typedir.armor.append(item)
            elif "itemheal" in item.usescript:
                if item.usescript["itemheal"][0] > item.usescript["itemheal"][1]:
                    typedir.healthy.append(item)
                else:
                    typedir.inspiring.append(item)
            elif "sc_start" in item.usescript:
                typedir.status.append(item)
            else: typedir.other.append(item)

    typedir.weapons.sort(key=lambda x: x.atk)
    typedir.armor.sort(key=lambda x: x.defense)
    typedir.combos.sort(key=lambda x: x.defense+x.atk)

    typedir.healthy.sort(key=lambda x: int(x.usescript["itemheal"][0]))
    typedir.inspiring.sort(key=lambda x: int(x.usescript["itemheal"][1]))
    #typedir.other.sort(key=lambda x: x.price+x.sell)
    typedir.status.sort(key=lambda x: x.price+x.sell)

    return typedir
    

            
# printlog()
## Prints the global variable log to stdout
def printlog():
    global log
    if len(log) > 0:
        print '\n---------------------------------------'
    for line in log:
        print line


# print<>items(items, title)
## Creates the table in wikicode, depending on what kind of item is being printed

def getmoneystring(buy, sell):
    return '| align="right" | %d GP<br>%d gp\n' % (buy,sell)
def getidstring(id):
    return '| align="center" | [%d]\n' % id
    
def printhealitems(items,title):
    print '==%s==' % title
    print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"'
    # Print labels
    for title in health_titles:
        print '! style="background:#efdead;" | %s' % title
        
    for i in items:
        print '|-'
        print '| align="center" | %s' % i.imgurl
        #print '| %s' % i.jname.replace('_',' ')
        print '| %s' % i.clientname
        sys.stdout.write( getidstring(i.id) )
        print '| align="center" | %d' % i.usescript["itemheal"][0]
        print '| align="center" | %d' % i.usescript["itemheal"][1]
        sys.stdout.write( getmoneystring(i.price,i.sell) )
        print '| align="center!" | %d' % i.weight
        print '| %s' % i.description
    print '|}\n'
            
def printstatusitems(items,title):
    print '==%s==\n' % title)
    print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"\n')
    # Print labels
    for title in status_titles:
        print '! style="background:#efdead;" | %s' % title
        
    for i in items:
        print '|-'
        print '| align="center" | %s' % i.imgurl
        #print '| %s' % i.jname.replace('_',' ')
        print '| %s' % i.clientname
        sys.stdout.write( getidstring(i.id) )
        print '| align="center" | %s' % i.usescript["sc_start"][0]
        print '| align="center" | %s' % i.usescript["sc_start"][1]
        print '| align="center" | %s' % i.usescript["sc_start"][2]
        sys.stdout.write( getmoneystring(i.price,i.sell) )
        print '| align="center!" | %d' % i.weight
        print '| %s' % i.description
    print '|}\n'
            

def printweaponitems(items, title):
    print '==%s==\n' % title)
    print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"\n')
    # Print labels
    for title in weapon_titles:
        print '! style="background:#efdead;" | %s\n' % title)

    for i in items:
        print '|-'
        print '| align="center" | %s' % i.imgurl
        #print '| %s' % i.jname.replace('_',' ')
        print '| %s' % i.clientname
        sys.stdout.write( getidstring(i.id) )
        print '| align="center" | %d (%d)' % (i.atk,i.range)
        sys.stdout.write( getmoneystring(i.price,i.sell) )
        print '| align="center!" | %d' % i.weight
        print '| %s' % i.description
    print '|}\n'
    
def printarmoritems(items, title):
    print '==%s==' % title
    print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"'
    print '! style="background:#efdead;" | Image'
    print '! style="background:#efdead;" | Name'
    print '! style="background:#efdead;" | ID'
    print '! style="background:#efdead;" | Defense'
    print '! style="background:#efdead;" | Price<br>BUY/Sell'
    print '! style="background:#efdead;" | Description'
    for i in items:
        print '|-'
        print '| align="center" | %s' % i.imgurl
        #print '| %s' % i.jname.replace('_',' ')
        print '| %s' % i.clientname
        sys.stdout.write( getidstring(i.id) )
        print '| align="center" | %d' % i.defense
        sys.stdout.write( getmoneystring(i.price,i.sell) )
        print '| %s' % i.description
    print '|}\n'

def printcomboitems(items, title):
    print '==%s==' % title
    print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"'
    print '! style="background:#efdead;" | Image'
    print '! style="background:#efdead;" | Name'
    print '! style="background:#efdead;" | ID'
    print '! style="background:#efdead;" | Damage<br>(Range)'
    print '! style="background:#efdead;" | Defense'
    print '! style="background:#efdead;" | Price<br>BUY/Sell'
    print '! style="background:#efdead;" | Description'
    for i in items:
        print '|-'
        print '| align="center" | %s' % i.imgurl
        #print '| %s' % i.jname.replace('_',' ')
        print '| %s' % i.clientname
        sys.stdout.write( getidstring(i.id) )
        print '| align="center" | %d (%d)' % (i.atk,i.range)
        print '| align="center" | %d' % i.defense
        sys.stdout.write( getmoneystring(i.price,i.sell) )
        print '| %s' % i.description
    print '|}\n'

def getpropertystring(item):
    s = ""
    s += "Weight: %d, " % item.weight
    s += "Slot: %d, " % item.slot
    s += "Job: %d, " % item.job
    s += "Gender: %d, " % item.gender
    s += "Loc: %d, " % item.loc
    s += "wLV: %d, " % item.wlv
    s += "eLV: %d, " % item.wlv
    s += "View: %d " % item.view
    return s


def printotheritems(items, title):
    print '==%s==' % title
    print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"'
    print '! style="background:#efdead;" | Image'
    print '! style="background:#efdead;" | Name'
    print '! style="background:#efdead;" | ID'
    #print '! style="background:#efdead;" | Type'
    #print '! style="background:#efdead;" | Properties'
    print '! style="background:#efdead;" | Price<br>BUY/Sell'
    print '! style="background:#efdead;" | Description'
    for i in items:
        print '|-'
        print '| align="center" | %s' % i.imgurl
        #print '| %s' % i.jname.replace('_',' ')
        print '| %s' % i.clientname
        sys.stdout.write( getidstring(i.id) )
        #print '| align="center" | %d' % i.type
        #print '| align="center" | %s' % getpropertystring(i)
        sys.stdout.write( getmoneystring(i.price,i.sell) )
        print '| %s' % i.description
    print '|}\n'



def printunuseditems(title):
    ids = []
    for i in range(1,len(imageurls)):
        if i not in imagesused:
            ids.append(i)
    if len(ids):
        print '==%s==' % title
        print '{| border="1" cellspacing="0" cellpadding="5" width="100%" align="center"'
        print '|',
        for i in ids:
            print imageurls[i],
        print '\n|}\n'

    

#####################################################################
#  MAIN
#####################################################################

try:
    if len(sys.argv) == 1:
        item_db = "item_db.txt"
        item_xml = "items.xml"
    elif len(sys.argv) == 3:
        item_db = sys.argv[1]
        item_xml = sys.argv[2]
    else: 
        item_db = ''
        item_xml = ''
        print "Wrong number of arguments"

    if item_db and not os.path.isfile(item_db):
        print "File does not exist: %s" % item_db
        item_db = ''
    if item_xml and not os.path.isfile(item_xml):
        print "File does not exist: %s" % item_xml
        item_db = ''
    
    if not (item_db and item_xml):
        print "\nUSAGE:"
        print "dbtowiki without any arguments will use item_db.txt and items.xml in the current directory."
        print "to specify custom files, call: dbtowiki <item_db> <item_xml>"
        exit(-1);
    else:
        log.append("Item-list [item_db] = %s" % item_db)
        log.append("Item-list [item_xml] = %s" % item_xml)
        f = open(item_db)
        items = parseitems(f);
        f = open(item_xml)
        citems = parsexmlitems(f);

        addclientinformation(items, citems)

        typedir = gettypedir(items)
        if len(typedir.healthy) > 0: printhealitems(typedir.healthy, "Health")
        if len(typedir.status) > 0: printstatusitems(typedir.status, "Status")
        if len(typedir.inspiring) > 0: printhealitems(typedir.inspiring, "Mana")
        if len(typedir.weapons) > 0: printweaponitems(typedir.weapons, "Weapons")
        if len(typedir.armor) > 0: printarmoritems(typedir.armor, "Armor")
        if len(typedir.combos) > 0: printcomboitems(typedir.combos, "Combos")
        if len(typedir.other) > 0: printotheritems(typedir.other, "Other")

        if checkimagesonwiki:
            print "Checking for images on wiki: "
            images = []
            for item in typedir.healthy:
                images.append( (item.imagename, item.description))
            for item in typedir.inspiring:
                images.append( (item.imagename, item.description))
            for item in typedir.weapons:
                images.append( (item.imagename, item.description))
            for item in typedir.armor:
                images.append( (item.imagename, item.description)) 
            for item in typedir.combos:
                images.append( (item.imagename, item.description))
            for item in typedir.other:
                images.append( (item.imagename, item.description))

            need_to_upload=[]

            for imagename, description in images:
                fixedimagename = imagename[0].upper() + imagename[1:]
                curlstring='curl "http://wiki.themanaworld.org/index.php/' \
                    'Image:%s"' % fixedimagename
                if debug:
                    print "CHECKING URL: %s" % curlstring
                p=popen2.Popen4(curlstring) 
                # this could hang if there is a lot of output!
                returncode = p.wait() # wait for the process to finish
                if debug:
                    print "Process finished with %d" % returncode
                page = p.fromchild.read()
                
                if debug >= 3:
                    print "Read: %s" % page

                if "No file by this name exists" in page:
                    need_to_upload.append((imagename, description))
                    if debug:
                        print "NEED TO UPLOAD: %s" % need_to_upload[-1]
            
            

            if len(need_to_upload):
                curlstring = 'curl -d "wpName=%s&wpPassword=%s&wpLoginattempt=Log+in" -c cookie-jar "http://wiki.themanaworld.org/index.php?title=Special:Userlogin&action=submitlogin&type=login"'% (wikiuser, wikipassword)

                print "Logging in as %s, your password can be seen " \
                                 "in `ps ax`, also this is using http://... " \
                                 "so be warned!" % wikiuser
                p=popen2.Popen4(curlstring) 
                # this could hang if there is a lot of output!
                returncode = p.wait() # wait for the process to finish
                data = p.fromchild.read()
                if debug >= 1:
                    print "Read: %s" % data

                if "Login error" in data:
                    print "Login failed"

                if debug:
                    print "Process finished with %d" % returncode

                sys.stdout.write("Now it is time to upload: %s" % 
                                 need_to_upload)

                for imagename, description in need_to_upload:
                    if debug:
                        print "Uploading image: %s" % imagename

                    curlstring='curl -b cookie-jar -F "wpUploadFile=@%s/%s" -F "filename=%s" -F "wpDestFile=%s" -F "wpUploadDescription=%s" -F "wpUpload=Upload file" "http://wiki.themanaworld.org/index.php?title=Special:Upload"' % (image_path, imagename, imagename, imagename, description)
                    p=popen2.Popen4(curlstring) 
                    # this could hang if there is a lot of output!
                    returncode = p.wait() # wait for the process to finish
                    data = p.fromchild.read()
                    if debug >= 1:
                        print "Read: %s" % data

                    if debug:
                        print "Process finished with %d" % returncode

                    print "Uploaded: %s, %s" % (imagename, description))
                    

        printunuseditems("Still unknown")

        print "\n"

finally:
    printlog()