menudata.py 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. """!
  2. @package menudata.py
  3. @brief Complex list for main menu entries for GRASS wxPython GUI.
  4. Classes:
  5. - Data
  6. - MenuTree
  7. Usage:
  8. @code
  9. python menudata.py action [file]
  10. @endcode
  11. where <i>action</i>:
  12. - strings (default)
  13. - tree
  14. - commands
  15. (C) 2007-2009 by the GRASS Development Team
  16. This program is free software under the GNU General Public
  17. License (>=v2). Read the file COPYING that comes with GRASS
  18. for details.
  19. @author Michael Barton (Arizona State University)
  20. @author Yann Chemin <yann.chemin gmail.com>
  21. @author Martin Landa <landa.martin gmail.com>
  22. @author Glynn Clements
  23. """
  24. import os
  25. try:
  26. import xml.etree.ElementTree as etree
  27. except ImportError:
  28. import elementtree.ElementTree as etree # Python <= 2.4
  29. class Data:
  30. '''!Data object that returns menu descriptions to be used in wxgui.py.'''
  31. def __init__(self, gisbase=None):
  32. if not gisbase:
  33. gisbase = os.getenv('GISBASE')
  34. filename = os.path.join(gisbase, 'etc', 'wxpython', 'xml', 'menudata.xml')
  35. self.tree = etree.parse(filename)
  36. def getMenuItem(self, mi):
  37. if mi.tag == 'separator':
  38. return ('', '', '', '', '')
  39. elif mi.tag == 'menuitem':
  40. label = _(mi.find('label').text)
  41. help = _(mi.find('help').text)
  42. handler = mi.find('handler').text
  43. gcmd = mi.find('command') # optional
  44. keywords = mi.find('keywords') # optional
  45. shortcut = mi.find('shortcut') # optional
  46. if gcmd != None:
  47. gcmd = gcmd.text
  48. else:
  49. gcmd = ""
  50. if keywords != None:
  51. keywords = keywords.text
  52. else:
  53. keywords = ""
  54. if shortcut != None:
  55. shortcut = shortcut.text
  56. else:
  57. shortcut = ""
  58. return (label, help, handler, gcmd, keywords, shortcut)
  59. elif mi.tag == 'menu':
  60. return self.getMenu(mi)
  61. else:
  62. raise Exception()
  63. def getMenu(self, m):
  64. label = _(m.find('label').text)
  65. items = m.find('items')
  66. return (label, tuple(map(self.getMenuItem, items)))
  67. def getMenuBar(self, mb):
  68. return tuple(map(self.getMenu, mb.findall('menu')))
  69. def getMenuData(self, md):
  70. return list(map(self.getMenuBar, md.findall('menubar')))
  71. def GetMenu(self):
  72. return self.getMenuData(self.tree.getroot())
  73. def PrintStrings(self, fh):
  74. """!Print menu strings to file (used for localization)
  75. @param fh file descriptor"""
  76. fh.write('menustrings = [\n')
  77. for node in self.tree.getiterator():
  78. if node.tag in ['label', 'help']:
  79. fh.write(' _(%r),\n' % node.text)
  80. fh.write(' \'\']\n')
  81. def PrintTree(self, fh):
  82. """!Print menu tree to file
  83. @param fh file descriptor"""
  84. level = 0
  85. for eachMenuData in self.GetMenu():
  86. for label, items in eachMenuData:
  87. fh.write('- %s\n' % label)
  88. self.__PrintTreeItems(fh, level + 1, items)
  89. def __PrintTreeItems(self, fh, level, menuData):
  90. """!Print menu tree items to file (used by PrintTree)
  91. @param fh file descriptor
  92. @param level menu level
  93. @param menuData menu data to print out"""
  94. for eachItem in menuData:
  95. if len(eachItem) == 2:
  96. if eachItem[0]:
  97. fh.write('%s - %s\n' % (' ' * level, eachItem[0]))
  98. self.__PrintTreeItems(fh, level + 1, eachItem[1])
  99. else:
  100. if eachItem[0]:
  101. fh.write('%s - %s\n' % (' ' * level, eachItem[0]))
  102. def PrintCommands(self, fh, itemSep = ' | ', menuSep = ' > '):
  103. """!Print commands list (command | menu item > menu item)
  104. @param fh file descriptor
  105. """
  106. level = 0
  107. for eachMenuData in self.GetMenu():
  108. for label, items in eachMenuData:
  109. menuItems = [label, ]
  110. self.__PrintCommandsItems(fh, level + 1, items,
  111. menuItems, itemSep, menuSep)
  112. def __PrintCommandsItems(self, fh, level, menuData,
  113. menuItems, itemSep, menuSep):
  114. """!Print commands item (used by PrintCommands)
  115. @param fh file descriptor
  116. @param menuItems list of menu items
  117. """
  118. for eachItem in menuData:
  119. if len(eachItem) == 2:
  120. if eachItem[0]:
  121. try:
  122. menuItems[level] = eachItem[0]
  123. except IndexError:
  124. menuItems.append(eachItem[0])
  125. self.__PrintCommandsItems(fh, level + 1, eachItem[1],
  126. menuItems, itemSep, menuSep)
  127. else:
  128. try:
  129. del menuItems[level]
  130. except IndexError:
  131. pass
  132. if eachItem[3]:
  133. fh.write('%s%s' % (eachItem[3], itemSep))
  134. fh.write(menuSep.join(menuItems))
  135. fh.write('%s%s' % (menuSep, eachItem[0]))
  136. fh.write('\n')
  137. def GetModules(self):
  138. """!Create dictionary of modules used to search module by
  139. keywords, description, etc."""
  140. modules = dict()
  141. for node in self.tree.getiterator():
  142. if node.tag == 'menuitem':
  143. module = description = ''
  144. keywords = []
  145. for child in node.getchildren():
  146. if child.tag == 'help':
  147. description = child.text
  148. if child.tag == 'command':
  149. module = child.text
  150. if child.tag == 'keywords':
  151. keywords = child.text.split(',')
  152. if module:
  153. modules[module] = { 'desc': description,
  154. 'keywords' : keywords }
  155. return modules
  156. if __name__ == "__main__":
  157. import sys
  158. # i18N
  159. import gettext
  160. gettext.install('grasswxpy', os.path.join(os.getenv("GISBASE"), 'locale'), unicode=True)
  161. file = None
  162. if len(sys.argv) == 1:
  163. action = 'strings'
  164. elif len(sys.argv) > 1:
  165. action = sys.argv[1]
  166. if len(sys.argv) > 2:
  167. file = sys.argv[2]
  168. if file:
  169. data = Data(file)
  170. else:
  171. data = Data()
  172. if action == 'strings':
  173. data.PrintStrings(sys.stdout)
  174. elif action == 'tree':
  175. data.PrintTree(sys.stdout)
  176. elif action == 'commands':
  177. data.PrintCommands(sys.stdout)
  178. sys.exit(0)