當前位置: 首頁>>代碼示例>>Python>>正文


Python PythonParser.parse_source方法代碼示例

本文整理匯總了Python中coverage.parser.PythonParser.parse_source方法的典型用法代碼示例。如果您正苦於以下問題:Python PythonParser.parse_source方法的具體用法?Python PythonParser.parse_source怎麽用?Python PythonParser.parse_source使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在coverage.parser.PythonParser的用法示例。


在下文中一共展示了PythonParser.parse_source方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: parse_source

# 需要導入模塊: from coverage.parser import PythonParser [as 別名]
# 或者: from coverage.parser.PythonParser import parse_source [as 別名]
 def parse_source(self, text):
     """Parse `text` as source, and return the `PythonParser` used."""
     if env.PY2:
         text = text.decode("ascii")
     text = textwrap.dedent(text)
     parser = PythonParser(text=text, exclude="nocover")
     parser.parse_source()
     return parser
開發者ID:silviot,項目名稱:coveragepy,代碼行數:10,代碼來源:test_parser.py

示例2: one_file

# 需要導入模塊: from coverage.parser import PythonParser [as 別名]
# 或者: from coverage.parser.PythonParser import parse_source [as 別名]
    def one_file(self, options, filename):
        """Process just one file."""

        try:
            text = get_python_source(filename)
            bp = ByteParser(text, filename=filename)
        except Exception as err:
            print("%s" % (err,))
            return

        if options.dis:
            print("Main code:")
            self.disassemble(bp, histogram=options.histogram)

        arcs = bp._all_arcs()
        if options.chunks:
            chunks = bp._all_chunks()
            if options.recursive:
                print("%6d: %s" % (len(chunks), filename))
            else:
                print("Chunks: %r" % chunks)
                print("Arcs: %r" % sorted(arcs))

        if options.source or options.tokens:
            cp = PythonParser(filename=filename, exclude=r"no\s*cover")
            cp.show_tokens = options.tokens
            cp.parse_source()

            if options.source:
                arc_width = 0
                arc_chars = {}
                if options.chunks:
                    arc_chars = self.arc_ascii_art(arcs)
                    if arc_chars:
                        arc_width = max(len(a) for a in arc_chars.values())

                exit_counts = cp.exit_counts()

                for lineno, ltext in enumerate(cp.lines, start=1):
                    m0 = m1 = m2 = m3 = a = ' '
                    if lineno in cp.statements:
                        m0 = '='
                    elif lineno in cp.raw_statements:
                        m0 = '-'
                    exits = exit_counts.get(lineno, 0)
                    if exits > 1:
                        m1 = str(exits)
                    if lineno in cp.raw_docstrings:
                        m2 = '"'
                    if lineno in cp.raw_classdefs:
                        m2 = 'C'
                    if lineno in cp.raw_excluded:
                        m3 = 'x'
                    a = arc_chars[lineno].ljust(arc_width)
                    print("%4d %s%s%s%s%s %s" % (lineno, m0, m1, m2, m3, a, ltext))
開發者ID:mociepka,項目名稱:coveragepy,代碼行數:57,代碼來源:parser.py

示例3: SimpleFileReporter

# 需要導入模塊: from coverage.parser import PythonParser [as 別名]
# 或者: from coverage.parser.PythonParser import parse_source [as 別名]
class SimpleFileReporter(PythonFileReporter):
  def __init__(self, morf, relpath):
    super(SimpleFileReporter, self).__init__(morf, coverage=None)
    self._relpath = relpath

  def relative_filename(self):
    return self._relpath

  # TODO(John Sirois): Kill the workaround overrides below if there is a useable upstream
  # resolution to:
  #   https://bitbucket.org/ned/coveragepy/issues/646/modifying-coverage-reporting-for-python

  @property
  def parser(self):
    if self._parser is None:
      self._parser = PythonParser(filename=self.filename)
      self._parser.parse_source()
    return self._parser

  def no_branch_lines(self):
    return self.parser.lines_matching(join_regex(DEFAULT_PARTIAL[:]),
                                      join_regex(DEFAULT_PARTIAL_ALWAYS[:]))
開發者ID:cosmicexplorer,項目名稱:pants,代碼行數:24,代碼來源:plugin.py

示例4: parse_file

# 需要導入模塊: from coverage.parser import PythonParser [as 別名]
# 或者: from coverage.parser.PythonParser import parse_source [as 別名]
 def parse_file(self, filename):
     """Parse `text` as source, and return the `PythonParser` used."""
     # pylint: disable=attribute-defined-outside-init
     parser = PythonParser(filename=filename, exclude="nocover")
     self.statements, self.excluded = parser.parse_source()
     return parser
開發者ID:silviot,項目名稱:coveragepy,代碼行數:8,代碼來源:test_parser.py

示例5: PythonFileReporter

# 需要導入模塊: from coverage.parser import PythonParser [as 別名]
# 或者: from coverage.parser.PythonParser import parse_source [as 別名]
class PythonFileReporter(FileReporter):
    """Report support for a Python file."""

    def __init__(self, morf, coverage=None):
        self.coverage = coverage

        if hasattr(morf, '__file__'):
            filename = morf.__file__
        elif isinstance(morf, types.ModuleType):
            # A module should have had .__file__, otherwise we can't use it.
            # This could be a PEP-420 namespace package.
            raise CoverageException("Module {0} has no file".format(morf))
        else:
            filename = morf

        filename = files.unicode_filename(filename)

        # .pyc files should always refer to a .py instead.
        if filename.endswith(('.pyc', '.pyo')):
            filename = filename[:-1]
        elif filename.endswith('$py.class'):   # Jython
            filename = filename[:-9] + ".py"

        super(PythonFileReporter, self).__init__(files.canonical_filename(filename))

        if hasattr(morf, '__name__'):
            name = morf.__name__
            name = name.replace(".", os.sep) + ".py"
            name = files.unicode_filename(name)
        else:
            name = files.relative_filename(filename)
        self.relname = name

        self._source = None
        self._parser = None
        self._statements = None
        self._excluded = None

    @contract(returns='unicode')
    def relative_filename(self):
        return self.relname

    @property
    def parser(self):
        """Lazily create a :class:`PythonParser`."""
        if self._parser is None:
            self._parser = PythonParser(
                filename=self.filename,
                exclude=self.coverage._exclude_regex('exclude'),
            )
            self._parser.parse_source()
        return self._parser

    def lines(self):
        """Return the line numbers of statements in the file."""
        return self.parser.statements

    def excluded_lines(self):
        """Return the line numbers of statements in the file."""
        return self.parser.excluded

    def translate_lines(self, lines):
        return self.parser.translate_lines(lines)

    def translate_arcs(self, arcs):
        return self.parser.translate_arcs(arcs)

    @expensive
    def no_branch_lines(self):
        no_branch = self.parser.lines_matching(
            join_regex(self.coverage.config.partial_list),
            join_regex(self.coverage.config.partial_always_list)
            )
        return no_branch

    @expensive
    def arcs(self):
        return self.parser.arcs()

    @expensive
    def exit_counts(self):
        return self.parser.exit_counts()

    def missing_arc_description(self, start, end, executed_arcs=None):
        return self.parser.missing_arc_description(start, end, executed_arcs)

    @contract(returns='unicode')
    def source(self):
        if self._source is None:
            self._source = get_python_source(self.filename)
        return self._source

    def should_be_python(self):
        """Does it seem like this file should contain Python?

        This is used to decide if a file reported as part of the execution of
        a program was really likely to have contained Python in the first
        place.

        """
#.........這裏部分代碼省略.........
開發者ID:Aisling-Dempsey,項目名稱:pencil_me_in,代碼行數:103,代碼來源:python.py

示例6: parse_file

# 需要導入模塊: from coverage.parser import PythonParser [as 別名]
# 或者: from coverage.parser.PythonParser import parse_source [as 別名]
 def parse_file(self, filename):
     """Parse `text` as source, and return the `PythonParser` used."""
     parser = PythonParser(filename=filename, exclude="nocover")
     parser.parse_source()
     return parser
開發者ID:MPLinder,項目名稱:coveragepy,代碼行數:7,代碼來源:test_parser.py

示例7: parse_source

# 需要導入模塊: from coverage.parser import PythonParser [as 別名]
# 或者: from coverage.parser.PythonParser import parse_source [as 別名]
 def parse_source(self, text):
     """Parse `text` as source, and return the `PythonParser` used."""
     text = textwrap.dedent(text)
     parser = PythonParser(text=text, exclude="nocover")
     parser.parse_source()
     return parser
開發者ID:MPLinder,項目名稱:coveragepy,代碼行數:8,代碼來源:test_parser.py

示例8: print

# 需要導入模塊: from coverage.parser import PythonParser [as 別名]
# 或者: from coverage.parser.PythonParser import parse_source [as 別名]
"""Parse every Python file in a tree."""

import os
import sys

from coverage.misc import CoverageException
from coverage.parser import PythonParser

for root, dirnames, filenames in os.walk(sys.argv[1]):
    for filename in filenames:
        if filename.endswith(".py"):
            filename = os.path.join(root, filename)
            print(":: {}".format(filename))
            try:
                par = PythonParser(filename=filename)
                par.parse_source()
                par.arcs()
            except Exception as exc:
                print("  ** {}".format(exc))
開發者ID:d-b-w,項目名稱:coveragepy,代碼行數:21,代碼來源:parse_all.py

示例9: one_file

# 需要導入模塊: from coverage.parser import PythonParser [as 別名]
# 或者: from coverage.parser.PythonParser import parse_source [as 別名]
    def one_file(self, options, filename):
        """Process just one file."""
        # `filename` can have a line number suffix. In that case, extract those
        # lines, dedent them, and use that.  This is for trying test cases
        # embedded in the test files.
        match = re.search(r"^(.*):(\d+)-(\d+)$", filename)
        if match:
            filename, start, end = match.groups()
            start, end = int(start), int(end)
        else:
            start = end = None

        try:
            text = get_python_source(filename)
            if start is not None:
                lines = text.splitlines(True)
                text = textwrap.dedent("".join(lines[start-1:end]).replace("\\\\", "\\"))
            pyparser = PythonParser(text, filename=filename, exclude=r"no\s*cover")
            pyparser.parse_source()
        except Exception as err:
            print("%s" % (err,))
            return

        if options.dis:
            print("Main code:")
            self.disassemble(pyparser.byte_parser, histogram=options.histogram)

        arcs = pyparser.arcs()

        if options.source or options.tokens:
            pyparser.show_tokens = options.tokens
            pyparser.parse_source()

            if options.source:
                arc_chars = self.arc_ascii_art(arcs)
                if arc_chars:
                    arc_width = max(len(a) for a in arc_chars.values())

                exit_counts = pyparser.exit_counts()

                for lineno, ltext in enumerate(pyparser.lines, start=1):
                    marks = [' ', ' ', ' ', ' ', ' ']
                    a = ' '
                    if lineno in pyparser.raw_statements:
                        marks[0] = '-'
                    if lineno in pyparser.statements:
                        marks[1] = '='
                    exits = exit_counts.get(lineno, 0)
                    if exits > 1:
                        marks[2] = str(exits)
                    if lineno in pyparser.raw_docstrings:
                        marks[3] = '"'
                    if lineno in pyparser.raw_classdefs:
                        marks[3] = 'C'
                    if lineno in pyparser.raw_excluded:
                        marks[4] = 'x'

                    if arc_chars:
                        a = arc_chars[lineno].ljust(arc_width)
                    else:
                        a = ""

                    print("%4d %s%s %s" % (lineno, "".join(marks), a, ltext))
開發者ID:d-b-w,項目名稱:coveragepy,代碼行數:65,代碼來源:parser.py

示例10: parse_text

# 需要導入模塊: from coverage.parser import PythonParser [as 別名]
# 或者: from coverage.parser.PythonParser import parse_source [as 別名]
 def parse_text(self, source):
     """Parse Python source, and return the parser object."""
     parser = PythonParser(textwrap.dedent(source))
     parser.parse_source()
     return parser
開發者ID:dstufft,項目名稱:coveragepy,代碼行數:7,代碼來源:test_parser.py

示例11: PythonFileReporter

# 需要導入模塊: from coverage.parser import PythonParser [as 別名]
# 或者: from coverage.parser.PythonParser import parse_source [as 別名]
class PythonFileReporter(FileReporter):
    """Report support for a Python file."""

    def __init__(self, morf, coverage=None):
        self.coverage = coverage

        filename = source_for_morf(morf)

        super(PythonFileReporter, self).__init__(files.canonical_filename(filename))

        if hasattr(morf, '__name__'):
            name = morf.__name__.replace(".", os.sep)
            if os.path.basename(filename).startswith('__init__.'):
                name += os.sep + "__init__"
            name += ".py"
            name = files.unicode_filename(name)
        else:
            name = files.relative_filename(filename)
        self.relname = name

        self._source = None
        self._parser = None
        self._statements = None
        self._excluded = None

    def __repr__(self):
        return "<PythonFileReporter {0!r}>".format(self.filename)

    @contract(returns='unicode')
    def relative_filename(self):
        return self.relname

    @property
    def parser(self):
        """Lazily create a :class:`PythonParser`."""
        if self._parser is None:
            self._parser = PythonParser(
                filename=self.filename,
                exclude=self.coverage._exclude_regex('exclude'),
            )
            self._parser.parse_source()
        return self._parser

    def lines(self):
        """Return the line numbers of statements in the file."""
        return self.parser.statements

    def excluded_lines(self):
        """Return the line numbers of statements in the file."""
        return self.parser.excluded

    def translate_lines(self, lines):
        return self.parser.translate_lines(lines)

    def translate_arcs(self, arcs):
        return self.parser.translate_arcs(arcs)

    @expensive
    def no_branch_lines(self):
        no_branch = self.parser.lines_matching(
            join_regex(self.coverage.config.partial_list),
            join_regex(self.coverage.config.partial_always_list)
            )
        return no_branch

    @expensive
    def arcs(self):
        return self.parser.arcs()

    @expensive
    def exit_counts(self):
        return self.parser.exit_counts()

    def missing_arc_description(self, start, end, executed_arcs=None):
        return self.parser.missing_arc_description(start, end, executed_arcs)

    @contract(returns='unicode')
    def source(self):
        if self._source is None:
            self._source = get_python_source(self.filename)
        return self._source

    def should_be_python(self):
        """Does it seem like this file should contain Python?

        This is used to decide if a file reported as part of the execution of
        a program was really likely to have contained Python in the first
        place.

        """
        # Get the file extension.
        _, ext = os.path.splitext(self.filename)

        # Anything named *.py* should be Python.
        if ext.startswith('.py'):
            return True
        # A file with no extension should be Python.
        if not ext:
            return True
        # Everything else is probably not Python.
#.........這裏部分代碼省略.........
開發者ID:hugovk,項目名稱:coveragepy,代碼行數:103,代碼來源:python.py


注:本文中的coverage.parser.PythonParser.parse_source方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。