test262/tools/generation/lib/case.py

53 lines
1.8 KiB
Python
Raw Normal View History

2016-03-16 18:58:10 +01:00
# Copyright (C) 2016 the V8 project authors. All rights reserved.
# This code is governed by the BSD license found in the LICENSE file.
import codecs
2016-03-16 18:58:10 +01:00
import re
from .util.find_comments import find_comments
from .util.parse_yaml import parse_yaml
2016-03-16 18:58:10 +01:00
regionStartPattern = re.compile(r'-\s+(\S+)(?P<options>\s*.*)?')
metaPattern = r'\/\*---\n([\s]*)((?:\s|\S)*)[\n\s*]---\*\/'
2016-03-16 18:58:10 +01:00
class Case:
def __init__(self, file_name, encoding):
self.attribs = dict(meta=None, regions=dict(), region_options=dict())
2016-03-16 18:58:10 +01:00
with codecs.open(file_name, 'r', encoding) as handle:
2016-03-16 18:58:10 +01:00
self.attribs = self._parse(handle.read())
def _parse(self, source):
case = dict(meta=None, regions=dict(), region_options=dict())
2016-03-16 18:58:10 +01:00
region_name = None
region_start = 0
region_options = None
2016-03-16 18:58:10 +01:00
lines = source.split('\n')
search = re.search(metaPattern, source, re.DOTALL|re.MULTILINE)
2016-03-16 18:58:10 +01:00
if search:
meta = search.group()
meta = parse_yaml(meta[2:-2])
if meta and not case['meta']:
2016-03-16 18:58:10 +01:00
case['meta'] = meta
for comment in find_comments(source):
2016-03-16 18:58:10 +01:00
match = regionStartPattern.match(comment['source'])
if match:
if region_name:
case['regions'][region_name] = \
'\n'.join(lines[region_start:comment['lineno'] - 1])
region_name = match.group(1)
region_start = comment['lineno']
region_options = match.group('options').split()
if region_options:
case['region_options'][region_name] = set(region_options)
2016-03-16 18:58:10 +01:00
continue
if region_name:
case['regions'][region_name] = \
'\n'.join(lines[region_start:-1])
return case