Esempio n. 1
0
 def _parse_spec(self, path):
     if not os.path.isfile(path):
         raise DataError("Spec file '%s' does not exist." % path)
     with ETSource(path) as source:
         root = ET.parse(source).getroot()
     if root.tag != 'keywordspec':
         raise DataError("Invalid spec file '%s'." % path)
     return root
Esempio n. 2
0
 def _parse_spec(self, path):
     if not os.path.isfile(path):
         raise DataError("Spec file '%s' does not exist." % path)
     with ETSource(path) as source:
         root = ET.parse(source).getroot()
     if root.tag != 'keywordspec':
         raise DataError("Invalid spec file '%s'." % path)
     return root
Esempio n. 3
0
 def _parse(self, source, start, end):
     context = ET.iterparse(source, events=('start', 'end'))
     if not self._include_keywords:
         context = self._omit_keywords(context)
     elif self._flattened_keywords:
         context = self._flatten_keywords(context, self._flattened_keywords)
     for event, elem in context:
         if event == 'start':
             start(elem)
         else:
             end(elem)
             elem.clear()
Esempio n. 4
0
 def _parse(self, source, start, end):
     context = ET.iterparse(source, events=('start', 'end'))
     if not self._include_keywords:
         context = self._omit_keywords(context)
     elif self._flattened_keywords:
         context = self._flatten_keywords(context, self._flattened_keywords)
     for event, elem in context:
         if event == 'start':
             start(elem)
         else:
             end(elem)
             elem.clear()
Esempio n. 5
0
 def _flatten_keywords(self, context, flattened):
     # Performance optimized. Do not change without profiling!
     name_match, by_name = self._get_matcher(FlattenByNameMatcher,
                                             flattened)
     type_match, by_type = self._get_matcher(FlattenByTypeMatcher,
                                             flattened)
     tags_match, by_tags = self._get_matcher(FlattenByTagMatcher, flattened)
     started = -1  # if 0 or more, we are flattening
     tags = []
     inside_kw = 0  # to make sure we don't read tags from a test
     seen_doc = False
     for event, elem in context:
         tag = elem.tag
         start = event == 'start'
         end = not start
         if start and tag == 'kw':
             inside_kw += 1
             if started >= 0:
                 started += 1
             elif by_name and name_match(elem.get('name', ''),
                                         elem.get('library')):
                 started = 0
                 seen_doc = False
             elif by_type and type_match(elem.get('type', 'kw')):
                 started = 0
                 seen_doc = False
         elif started < 0 and by_tags and inside_kw:
             if end and tag == 'tag':
                 tags.append(elem.text or '')
             elif end and tag == 'tags':
                 if tags_match(tags):
                     started = 0
                     seen_doc = False
                 tags = []
         if end and tag == 'kw':
             inside_kw -= 1
             if started == 0 and not seen_doc:
                 doc = ET.Element('doc')
                 doc.text = '_*Keyword content flattened.*_'
                 yield 'start', doc
                 yield 'end', doc
         if started == 0 and end and tag == 'doc':
             seen_doc = True
             elem.text = ('%s\n\n_*Keyword content flattened.*_' %
                          (elem.text or '')).strip()
         if started <= 0 or tag == 'msg':
             yield event, elem
         else:
             elem.clear()
         if started >= 0 and end and tag == 'kw':
             started -= 1