view tests/heredoctest.py @ 29936:3e7ded768556

rebase: make debug logging more consistent We emit some lines that mix revision numbers with nodeids, which makes little sense to me.
author Martin von Zweigbergk <martinvonz@google.com>
date Tue, 13 Sep 2016 13:49:42 -0700
parents 6a98f9408a50
children 55fd0fefbec4
line wrap: on
line source

from __future__ import absolute_import, print_function

import sys

globalvars = {}
lines = sys.stdin.readlines()
while lines:
    l = lines.pop(0)
    if l.startswith('SALT'):
        print(l[:-1])
    elif l.startswith('>>> '):
        snippet = l[4:]
        while lines and lines[0].startswith('... '):
            l = lines.pop(0)
            snippet += l[4:]
        c = compile(snippet, '<heredoc>', 'single')
        try:
            exec(c, globalvars)
        except Exception as inst:
            print(repr(inst))