menudata.py 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. """!
  2. @package menudata.py
  3. @brief Complex list for main menu entries for GRASS wxPython GUI.
  4. Classes:
  5. - Data
  6. - MenuTree
  7. (C) 2007-2009 by the GRASS Development Team
  8. This program is free software under the GNU General Public
  9. License (>=v2). Read the file COPYING that comes with GRASS
  10. for details.
  11. @author Michael Barton (Arizona State University)
  12. @author Yann Chemin <yann.chemin gmail.com>
  13. @author Martin Landa <landa.martin gmail.com>
  14. @author Glynn Clements
  15. """
  16. import os
  17. try:
  18. import xml.etree.ElementTree as etree
  19. except ImportError:
  20. import elementtree.ElementTree as etree # Python <= 2.4
  21. class Data:
  22. '''!Data object that returns menu descriptions to be used in wxgui.py.'''
  23. def __init__(self, gisbase=None):
  24. if not gisbase:
  25. gisbase = os.getenv('GISBASE')
  26. filename = os.path.join(gisbase, 'etc', 'wxpython', 'xml', 'menudata.xml')
  27. self.tree = etree.parse(filename)
  28. def getMenuItem(self, mi):
  29. if mi.tag == 'separator':
  30. return ('', '', '', '', '')
  31. elif mi.tag == 'menuitem':
  32. label = _(mi.find('label').text)
  33. help = _(mi.find('help').text)
  34. handler = mi.find('handler').text
  35. gcmd = mi.find('command') # optional
  36. keywords = mi.find('keywords') # optional
  37. if gcmd != None:
  38. gcmd = gcmd.text
  39. else:
  40. gcmd = ""
  41. if keywords != None:
  42. keywords = keywords.text
  43. else:
  44. keywords = ""
  45. return (label, help, handler, gcmd, keywords)
  46. elif mi.tag == 'menu':
  47. return self.getMenu(mi)
  48. else:
  49. raise Exception()
  50. def getMenu(self, m):
  51. label = _(m.find('label').text)
  52. items = m.find('items')
  53. return (label, tuple(map(self.getMenuItem, items)))
  54. def getMenuBar(self, mb):
  55. return tuple(map(self.getMenu, mb.findall('menu')))
  56. def getMenuData(self, md):
  57. return list(map(self.getMenuBar, md.findall('menubar')))
  58. def GetMenu(self):
  59. return self.getMenuData(self.tree.getroot())
  60. def PrintStrings(self, fh):
  61. """!Print menu strings to file (used for localization)
  62. @param fh file descriptor"""
  63. fh.write('menustrings = [\n')
  64. for node in self.tree.getiterator():
  65. if node.tag in ['label', 'help']:
  66. fh.write(' _(%r),\n' % node.text)
  67. fh.write(' \'\']\n')
  68. def PrintTree(self, fh):
  69. """!Print menu tree to file
  70. @param fh file descriptor"""
  71. level = 0
  72. for eachMenuData in self.GetMenu():
  73. for label, items in eachMenuData:
  74. print >> fh, '-', label
  75. self.__PrintTreeItems(fh, level + 1, items)
  76. def __PrintTreeItems(self, fh, level, menuData):
  77. """!Print menu tree items to file (used by PrintTree)
  78. @param fh file descriptor
  79. @param level menu level
  80. @param menuData menu data to print out"""
  81. for eachItem in menuData:
  82. if len(eachItem) == 2:
  83. if eachItem[0]:
  84. print >> fh, ' ' * level, '-', eachItem[0]
  85. self.__PrintTreeItems(fh, level + 1, eachItem[1])
  86. else:
  87. if eachItem[0]:
  88. print >> fh, ' ' * level, '-', eachItem[0]
  89. def GetModules(self):
  90. """!Create dictionary of modules used to search module by
  91. keywords, description, etc."""
  92. modules = dict()
  93. for node in self.tree.getiterator():
  94. if node.tag == 'menuitem':
  95. module = description = ''
  96. keywords = []
  97. for child in node.getchildren():
  98. if child.tag == 'help':
  99. description = child.text
  100. if child.tag == 'command':
  101. module = child.text
  102. if child.tag == 'keywords':
  103. keywords = child.text.split(',')
  104. if module:
  105. modules[module] = { 'desc': description,
  106. 'keywords' : keywords }
  107. return modules
  108. if __name__ == "__main__":
  109. import sys
  110. # i18N
  111. import gettext
  112. gettext.install('grasswxpy', os.path.join(os.getenv("GISBASE"), 'locale'), unicode=True)
  113. if len(sys.argv) > 1:
  114. data = Data(sys.argv[1])
  115. else:
  116. data = Data()
  117. data.PrintTree(sys.stdout)
  118. sys.exit(0)