Skip to content

Commit

Permalink
update to python 3.8+
Browse files Browse the repository at this point in the history
  • Loading branch information
a16bitsysop committed Jan 4, 2022
1 parent 46af0ae commit 94b4a1e
Show file tree
Hide file tree
Showing 4 changed files with 29 additions and 9 deletions.
19 changes: 13 additions & 6 deletions pypytools/pypylog/model.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
import itertools
from collections import defaultdict
import attr
import numpy as np
from pypytools.util import PY3

if not PY3:
import itertools

@attr.s
class Event(object):
Expand Down Expand Up @@ -46,15 +49,15 @@ def add_event(self, ev):

def print_summary(self):
fmt = '%-28s %6s %8s'
print fmt % ('section', 'n', 'delta')
print '-'*44
print(fmt % ('section', 'n', 'delta'))
print('-'*44)
for name, events in sorted(self.sections.iteritems()):
total = 0
for ev in events:
delta = ev.end - ev.start
assert delta >= 0
total += delta
print fmt % (name, len(events), format(delta, '.4f'))
print(fmt % (name, len(events), format(delta, '.4f')))

class Series(object):

Expand All @@ -79,8 +82,12 @@ def __len__(self):
return len(self.X)

def __iter__(self):
for x, y in itertools.izip(self.X, self.Y):
yield x, y
if PY3:
for x, y in zip(self.X, self.Y):
yield x, y
else:
for x, y in itertools.izip(self.X, self.Y):
yield x, y

def __getitem__(self, i):
return self.X[i], self.Y[i]
Expand Down
3 changes: 3 additions & 0 deletions pypytools/pypylog/parse.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import re
import attr
from pypytools.pypylog import model
from pypytools.util import PY3

# stolen from rpython/tool/logparse.py
_color = "(?:\x1b.*?m)?"
Expand Down Expand Up @@ -35,6 +36,8 @@ def parse_file(f):
#
if log is None:
log = model.PyPyLog()
if PY3:
basestring = str
if isinstance(fname, basestring):
with open(fname) as f:
return parse_file(f)
Expand Down
13 changes: 10 additions & 3 deletions pypytools/pypylog/testing/test_parse.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,13 @@
import pytest
import textwrap
from cStringIO import StringIO

from pypytools.util import PY3

if PY3:
from io import StringIO
else:
from cStringIO import StringIO

from pypytools.pypylog import parse
from pypytools.pypylog import model
from pypytools.pypylog.model import Event, GcMinor, GcCollectStep
Expand Down Expand Up @@ -33,7 +40,7 @@ def test_mismatch(self):
[456] foo}
[0ab] bar}
"""
pytest.raises(parse.ParseError, "self.parse(log)")
pytest.raises(parse.ParseError(self.parse(log)))

def test_nested(self):
log = self.parse("""
Expand Down Expand Up @@ -124,4 +131,4 @@ def test_parse_frequency():
assert pf('40 KHz') == 40e3
assert pf('40 MHz') == 40e6
assert pf('40 GHz') == 40e9
pytest.raises(ValueError, "pf('')")
pytest.raises(ValueError(pf('')))
3 changes: 3 additions & 0 deletions pypytools/util.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
from sys import version_info

PY3 = version_info.major == 3
PY3M = version_info.minor

def clonefunc(f):
"""Deep clone the given function to create a new one.
Expand All @@ -22,6 +23,8 @@ def clonefunc(f):
co.co_firstlineno, co.co_lnotab, co.co_freevars, co.co_cellvars]
if PY3:
args.insert(1, co.co_kwonlyargcount)
if PY3 and PY3M >= 8:
args.insert(1, co.co_posonlyargcount)
co2 = types.CodeType(*args)
#
# then, we clone the function itself, using the new co2
Expand Down

0 comments on commit 94b4a1e

Please sign in to comment.