Skip to content

Commit

Permalink
readwrite: Replace use of deprecated ast classes
Browse files Browse the repository at this point in the history
  • Loading branch information
ales-erjavec committed Jul 12, 2024
1 parent 8a3ecf1 commit 0287f9f
Show file tree
Hide file tree
Showing 5 changed files with 26 additions and 23 deletions.
4 changes: 0 additions & 4 deletions .github/workflows/run-tests-workflow.yml
Original file line number Diff line number Diff line change
Expand Up @@ -21,10 +21,6 @@ jobs:
python-version: 3.8
test-env: "PyQt5~=5.12.0"

- os: ubuntu-20.04
python-version: 3.7
test-env: "PyQt5~=5.15.0"

- os: ubuntu-20.04
python-version: 3.8
test-env: "PyQt5~=5.15.0"
Expand Down
2 changes: 1 addition & 1 deletion .readthedocs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ version: 2
build:
os: ubuntu-22.04
tools:
python: "3.7"
python: "3.8"

python:
install:
Expand Down
31 changes: 15 additions & 16 deletions orangecanvas/scheme/readwrite.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,6 @@
"""
import numbers
import sys
import types
import warnings
import base64
import binascii
import itertools
Expand All @@ -14,7 +11,7 @@
from xml.etree.ElementTree import TreeBuilder, Element, ElementTree, parse

from collections import defaultdict
from itertools import chain, count
from itertools import chain

import pickle
import json
Expand All @@ -29,6 +26,8 @@
NamedTuple, Dict, Tuple, List, Union, Any, Optional, AnyStr, IO
)

from typing_extensions import TypeGuard

from . import SchemeNode, SchemeLink
from .annotations import SchemeTextAnnotation, SchemeArrowAnnotation
from .errors import IncompatibleChannelTypeError
Expand Down Expand Up @@ -65,9 +64,10 @@ def string_eval(source):
"""
node = _ast_parse_expr(source)
if not isinstance(node.body, ast.Str):
body = node.body
if not _is_constant(body, (str,)):
raise ValueError("%r is not a string literal" % source)
return node.body.s
return body.value


def tuple_eval(source):
Expand All @@ -85,11 +85,11 @@ def tuple_eval(source):
if not isinstance(node.body, ast.Tuple):
raise ValueError("%r is not a tuple literal" % source)

if not all(isinstance(el, (ast.Str, ast.Num)) or
if not all(_is_constant(el, (str, float, complex, int)) or
# allow signed number literals in Python3 (i.e. -1|+1|-1.0)
(isinstance(el, ast.UnaryOp) and
isinstance(el.op, (ast.UAdd, ast.USub)) and
isinstance(el.operand, ast.Num))
_is_constant(el.operand, (float, complex, int)))
for el in node.body.elts):
raise ValueError("Can only contain numbers or strings")

Expand All @@ -112,18 +112,17 @@ def terminal_eval(source):

def _terminal_value(node):
# type: (ast.AST) -> Union[str, bytes, int, float, complex, None]
if isinstance(node, ast.Str):
return node.s
elif isinstance(node, ast.Bytes):
return node.s
elif isinstance(node, ast.Num):
return node.n
elif isinstance(node, ast.NameConstant):
if _is_constant(node, (str, bytes, int, float, complex, type(None))):
return node.value

raise ValueError("Not a terminal")


def _is_constant(
node: ast.AST, types: Tuple[type, ...]
) -> TypeGuard[ast.Constant]:
return isinstance(node, ast.Constant) and isinstance(node.value, types)


# Intermediate scheme representation
_scheme = NamedTuple(
"_scheme", [
Expand Down
9 changes: 8 additions & 1 deletion orangecanvas/scheme/tests/test_readwrite.py
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,9 @@ def test_safe_evals(self):
s = readwrite.string_eval(r"'\x00\xff'")
self.assertEqual(s, chr(0) + chr(255))

with self.assertRaises(ValueError):
readwrite.string_eval("3")

with self.assertRaises(ValueError):
readwrite.string_eval("[1, 2]")

Expand All @@ -96,10 +99,14 @@ def test_safe_evals(self):
self.assertIs(readwrite.terminal_eval("True"), True)
self.assertIs(readwrite.terminal_eval("False"), False)
self.assertIs(readwrite.terminal_eval("None"), None)

self.assertEqual(readwrite.terminal_eval("42"), 42)
self.assertEqual(readwrite.terminal_eval("42."), 42.)
self.assertEqual(readwrite.terminal_eval("'42'"), '42')
self.assertEqual(readwrite.terminal_eval(r"b'\xff\x00'"), b'\xff\x00')
with self.assertRaises(ValueError):
readwrite.terminal_eval("...")
with self.assertRaises(ValueError):
readwrite.terminal_eval("{}")

def test_literal_dump(self):
struct = {1: [{(1, 2): ""}],
Expand Down
3 changes: 2 additions & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@
"qasync>=0.10.0",
"importlib_metadata; python_version<'3.10'",
"importlib_resources; python_version<'3.9'",
"typing_extensions",
"packaging",
"numpy",
)
Expand Down Expand Up @@ -59,7 +60,7 @@
"Documentation": "https://orange-canvas-core.readthedocs.io/en/latest/",
}

PYTHON_REQUIRES = ">=3.6"
PYTHON_REQUIRES = ">=3.8"

if __name__ == "__main__":
setup(
Expand Down

0 comments on commit 0287f9f

Please sign in to comment.