From 7b5cb390abf271b5f40f18eee2c43da56c11c9c3 Mon Sep 17 00:00:00 2001 From: Matthew Wampler-Doty Date: Tue, 29 Apr 2014 09:22:55 -0500 Subject: [PATCH] `setv` no longer creates variables with '.' in their names FIXES #577 --- AUTHORS | 1 + hy/compiler.py | 21 +++++++++++---------- tests/native_tests/core.hy | 28 ++++++++++++++++++++++++++++ 3 files changed, 40 insertions(+), 10 deletions(-) diff --git a/AUTHORS b/AUTHORS index 847740c..c83f5ff 100644 --- a/AUTHORS +++ b/AUTHORS @@ -46,3 +46,4 @@ * Brendan Curran-Johnson * Ivan Kozik * Allison Kaptur +* Matthew Wampler-Doty diff --git a/hy/compiler.py b/hy/compiler.py index 032a49a..353fb0d 100644 --- a/hy/compiler.py +++ b/hy/compiler.py @@ -1751,18 +1751,19 @@ class HyASTCompiler(object): def _compile_assign(self, name, result, start_line, start_column): result = self.compile(result) - - if result.temp_variables and isinstance(name, HyString): - result.rename(name) - return result - ld_name = self.compile(name) - st_name = self._storeize(ld_name) - result += ast.Assign( - lineno=start_line, - col_offset=start_column, - targets=[st_name], value=result.force_expr) + if result.temp_variables \ + and isinstance(name, HyString) \ + and '.' not in name: + result.rename(name) + else: + st_name = self._storeize(ld_name) + result += ast.Assign( + lineno=start_line, + col_offset=start_column, + targets=[st_name], + value=result.force_expr) result += ld_name return result diff --git a/tests/native_tests/core.hy b/tests/native_tests/core.hy index 98e403d..c5c58d5 100644 --- a/tests/native_tests/core.hy +++ b/tests/native_tests/core.hy @@ -57,6 +57,34 @@ (try (do (dec None) (assert False)) (catch [e [TypeError]] (assert (in "not a number" (str e)))))) +(defn test-setv [] + "NATIVE: testing setv mutation" + (setv x 1) + (setv y 1) + (assert-equal x y) + (setv x (setv y 12)) + (assert-equal x 12) + (assert-equal y 12) + (setv x (setv y (fn [x] 9))) + (assert-equal (x y) 9) + (assert-equal (y x) 9) + (try (do (setv a.b 1) (assert False)) + (catch [e [NameError]] (assert (in "name 'a' is not defined" (str e))))) + (try (do (setv b.a (fn [x] x)) (assert False)) + (catch [e [NameError]] (assert (in "name 'b' is not defined" (str e))))) + (import itertools) + (setv foopermutations (fn [x] (itertools.permutations x))) + (setv p (set [(, 1 3 2) (, 3 2 1) (, 2 1 3) (, 3 1 2) (, 1 2 3) (, 2 3 1)])) + (assert-equal (set (itertools.permutations [1 2 3])) p) + (assert-equal (set (foopermutations [3 1 2])) p) + (setv permutations- itertools.permutations) + (setv itertools.permutations (fn [x] 9)) + (assert-equal (itertools.permutations p) 9) + (assert-equal (foopermutations foopermutations) 9) + (setv itertools.permutations permutations-) + (assert-equal (set (itertools.permutations [2 1 3])) p) + (assert-equal (set (foopermutations [2 3 1])) p)) + (defn test-distinct [] "NATIVE: testing the distinct function" (setv res (list (distinct [ 1 2 3 4 3 5 2 ])))