From 73dd55392d1158f16d74824d114379b62ad1840f Mon Sep 17 00:00:00 2001 From: dours Date: Fri, 19 Aug 2022 22:00:33 +0300 Subject: [PATCH 01/12] support .keys for a map --- transpiler/src/main/eo/preface/xmyMap.eo | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/transpiler/src/main/eo/preface/xmyMap.eo b/transpiler/src/main/eo/preface/xmyMap.eo index 66646671d..a2f693da0 100644 --- a/transpiler/src/main/eo/preface/xmyMap.eo +++ b/transpiler/src/main/eo/preface/xmyMap.eo @@ -7,6 +7,7 @@ +alias sprintf org.eolang.txt.sprintf +alias mkCopy preface.mkCopy +alias pair preface.pair ++alias xmyArray preface.xmyArray [] > xmyMap pyint 16 > x__id__ @@ -89,6 +90,22 @@ self.value.write (*) stackUp.forward (return 0) 123 + [] > xkeys + [self] > apply + [stackUp] > @ + (goto ((xmyArray.apply (*)).@)).result > accum + memory 0 > i + seq > @ + (i.lt (value.length)).while + [unused] + (self.value.get i).fst > x + seq > @ + (goto ((accum.xappend.apply accum x).@)).result + i.write (i.plus 1) + 0 + stdout (sprintf "keys len = %d\n" (accum.value.length)) + stackUp.forward (return accum) + 0 [x] > eq memory TRUE > acc memory 0 > pos From 87d90be681d0f53898bf9b26259cd44e22f18bc0 Mon Sep 17 00:00:00 2001 From: dours Date: Fri, 19 Aug 2022 22:00:59 +0300 Subject: [PATCH 02/12] make pyint.eq ad-hoc polymorphic --- transpiler/src/main/eo/preface/pyint.eo | 17 ++++++++--------- 1 file changed, 8 insertions(+), 9 deletions(-) diff --git a/transpiler/src/main/eo/preface/pyint.eo b/transpiler/src/main/eo/preface/pyint.eo index 31f139676..8b74a9d60 100644 --- a/transpiler/src/main/eo/preface/pyint.eo +++ b/transpiler/src/main/eo/preface/pyint.eo @@ -20,17 +20,16 @@ fakeclasses.convert (pyint value) x > p seq > @ if. - (fakeclasses.has-type x (fakeclasses.pyIntClass)) - pybool (value.eq (x.value)) - p.fst.eq (p.snd) + ((fakeclasses.has-type x (fakeclasses.pyIntClass)).not).and + ((fakeclasses.has-type x (fakeclasses.pyFloatClass)).not).and ((fakeclasses.has-type x (fakeclasses.pyComplexClass)).not) + pybool FALSE + if. + (fakeclasses.has-type x (fakeclasses.pyIntClass)) + pybool (value.eq (x.value)) + p.fst.eq (p.snd) [x] > neq - fakeclasses.convert (pyint value) x > p - seq > @ - if. - (fakeclasses.has-type x (fakeclasses.pyIntClass)) - pybool (value.neq (x.value)) - p.fst.neq (p.snd) + (eq x).not > @ [x] > less fakeclasses.convert (pyint value) x > p From d7cb4c13e8ecf174ec910ea21e097e9ffcba1a18 Mon Sep 17 00:00:00 2001 From: dours Date: Fri, 19 Aug 2022 22:01:29 +0300 Subject: [PATCH 03/12] this test should work now --- .../simple-tests/expressions/comparisons/comparison-3.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/comparisons/comparison-3.yaml b/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/comparisons/comparison-3.yaml index 4a354c9ba..f9de72c98 100644 --- a/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/comparisons/comparison-3.yaml +++ b/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/comparisons/comparison-3.yaml @@ -1,4 +1,4 @@ -enabled: False +enabled: True python: | def test(): return 1 in {'name': 'John', 1: [2, 4, 3]}.keys() \ No newline at end of file From c987908365a957d2a8b8a70c77a55c31586f78c4 Mon Sep 17 00:00:00 2001 From: dours Date: Fri, 19 Aug 2022 23:22:05 +0300 Subject: [PATCH 04/12] implement map equality the correct way (xget-internal and xkeys-internal are needed because using $ as self does not work...) --- transpiler/src/main/eo/preface/xmyMap.eo | 60 ++++++++++++++++++++---- 1 file changed, 50 insertions(+), 10 deletions(-) diff --git a/transpiler/src/main/eo/preface/xmyMap.eo b/transpiler/src/main/eo/preface/xmyMap.eo index a2f693da0..dc1a5c045 100644 --- a/transpiler/src/main/eo/preface/xmyMap.eo +++ b/transpiler/src/main/eo/preface/xmyMap.eo @@ -39,6 +39,22 @@ i.write (i.plus 1) stdout "get left the loop\n" 0 + [] > xget-internal + [key] > apply + [stackUp] > @ + memory 0 > i + seq > @ + stdout (sprintf "xget %s\n" key) + (i.lt (value.length)).while + [unused] + seq > @ + stdout (sprintf "%s ?= %s\n" ((value.get i).fst) key) + if. + (value.get i).fst.eq key + stackUp.forward (return ((value.get i).snd)) + i.write (i.plus 1) + stdout "get left the loop\n" + 0 [] > x__contains__ [self key] > apply [stackUp] > @ @@ -71,12 +87,10 @@ (goto ((x__contains__.apply self key).@)).result.if stackUp.forward (return 0) 0 - stdout "2\n" mkCopy (self.value) > tmp mkCopy (key.value) > kv mkCopy (val.value) > vv self.value.write (tmp.copy.with (pair (key.with-value (kv.copy)) (val.with-value (vv.copy)))) - stdout "3\n" stackUp.forward (return 0) 123 [] > xappend @@ -106,21 +120,47 @@ stdout (sprintf "keys len = %d\n" (accum.value.length)) stackUp.forward (return accum) 0 + [] > xkeys-internal + [] > apply + [stackUp] > @ + (goto ((xmyArray.apply (*)).@)).result > accum + memory 0 > i + seq > @ + (i.lt (value.length)).while + [unused] + (value.get i).fst > x + seq > @ + (goto ((accum.xappend.apply accum x).@)).result + i.write (i.plus 1) + 0 + stdout (sprintf "keys len = %d\n" (accum.value.length)) + stackUp.forward (return accum) + 0 [x] > eq memory TRUE > acc memory 0 > pos + (goto ((xkeys-internal.apply).@)).result > my-keys + (goto ((x.xkeys.apply x).@)).result > his-keys if. > res ((x.x__class__.x__id__.eq x__id__).value.and (value.length.eq (x.value.length))) - seq - (acc.and (pos.lt (value.length))).while - [unused] - seq > @ - acc.write (acc.and (((value.get pos).eq (x.value.get pos)).value)) - pos.write (pos.plus 1) - 123 - pybool acc + if. + my-keys.eq his-keys + seq + (acc.and (pos.lt (my-keys.value.length))).while + [unused] + my-keys.value.get i > key + (goto ((xget-internal.apply key).@)).result > my-value + (goto ((x.xget.apply x key).@)).result > his-value + seq > @ + stdout (sprintf "i = %d\n" pos) + acc.write (acc.and ((my-value.eq his-value).value)) + pos.write (pos.plus 1) + 123 + pybool acc + pybool FALSE pybool FALSE seq > @ + stdout "eq\n" res stdout "after\n" res From eb2c056426fc70202b3da248341ff08151ad4319 Mon Sep 17 00:00:00 2001 From: dours Date: Fri, 19 Aug 2022 23:22:54 +0300 Subject: [PATCH 05/12] support dict comprehension as a pass --- .../py2eo/transpiler/ExpressionPasses.scala | 74 +++++++++++++------ 1 file changed, 51 insertions(+), 23 deletions(-) diff --git a/transpiler/src/main/scala/org/polystat/py2eo/transpiler/ExpressionPasses.scala b/transpiler/src/main/scala/org/polystat/py2eo/transpiler/ExpressionPasses.scala index 5e15ff29a..d0a7f2ffb 100644 --- a/transpiler/src/main/scala/org/polystat/py2eo/transpiler/ExpressionPasses.scala +++ b/transpiler/src/main/scala/org/polystat/py2eo/transpiler/ExpressionPasses.scala @@ -14,33 +14,55 @@ import org.polystat.py2eo.transpiler.StatementPasses.{EAfterPass, Names, NamesU, import scala.collection.immutable.HashMap object ExpressionPasses { - def simplifyCollectionComprehension(lhs : Boolean, e : T, ns : NamesU) : (EAfterPass, NamesU) = { + + def simplifyComprehensionList(inner : Statement.T, l : List[Comprehension], ann : GeneralAnnotation) : Statement.T = { + l.foldRight(inner : Statement.T)((comprehension, accum) => { + comprehension match { + case IfComprehension(cond) => + IfSimple(cond, accum, Pass(ann.pos), ann.pos) + case ForComprehension(what, in, isAsync) => + For(what, in, accum, None, isAsync, ann.pos) + } + }) + } + + def simplifyComprehension(lhs : Boolean, e : T, ns : NamesU) : (EAfterPass, NamesU) = { if (!lhs) { e match { case CollectionComprehension(kind, base, l, ann) => { + val inner = Assign(List(CallIndex( + true, + Field(Ident("collectionAccum", ann.pos), "append", ann.pos), + List((None, base)), + ann.pos + )), + ann.pos + ) val st = Suite( - List( - Assign(List(Ident("collectionAccum", ann.pos), CollectionCons(kind, List(), ann.pos)), ann.pos), - l.foldRight( - Assign(List(CallIndex( - true, - Field(Ident("collectionAccum", ann.pos), "append", ann.pos), - List((None, base)), - ann.pos - )), - ann.pos - ): Statement.T - )((comprehension, accum) => { - comprehension match { - case IfComprehension(cond) => - IfSimple(cond, accum, Pass(ann.pos), ann.pos) - case ForComprehension(what, in, isAsync) => - For(what, in, accum, None, isAsync, ann.pos) - } - }) - ), - ann.pos - ) + List( + Assign(List(Ident("collectionAccum", ann.pos), CollectionCons(kind, List(), ann.pos)), ann.pos), + simplifyComprehensionList(inner, l, ann) + ), + ann.pos + ) + (Right((st : Statement.T, Ident("collectionAccum", ann.pos))), ns) + } + case DictComprehension(Left((k, v)), l, ann) => { + val inner = Assign(List(CallIndex( + true, + Field(Ident("collectionAccum", ann.pos), "add", ann.pos), + List((None, k),(None, v)), + ann.pos + )), + ann.pos + ) + val st = Suite( + List( + Assign(List(Ident("collectionAccum", ann.pos), DictCons(List(), ann.pos)), ann.pos), + simplifyComprehensionList(inner, l, ann) + ), + ann.pos + ) (Right((st : Statement.T, Ident("collectionAccum", ann.pos))), ns) } case x : Any => (Left(x), ns) @@ -341,6 +363,12 @@ object ExpressionPasses { val l3 = call2comprehensions(l.zip(l2)) CollectionComprehension(kind, base, l3, ann.pos) }, l1, ns) + case DictComprehension(Left((k, v)), l, ann) => + val l1 = k :: v :: comprehensions2calls(l, ann) + reconstruct(lhs, { case k :: v :: l2 => + val l3 = call2comprehensions(l.zip(l2)) + DictComprehension(Left((k, v)), l3, ann.pos) + }, l1, ns) case GeneratorComprehension(base, l, ann) => val l1 = base :: comprehensions2calls(l, ann) reconstruct(lhs, { case base :: l2 => From 295b67b0c60d51b5ad51eac19c9f1891be14a8b9 Mon Sep 17 00:00:00 2001 From: dours Date: Fri, 19 Aug 2022 23:23:13 +0300 Subject: [PATCH 06/12] this should work now --- .../dictionary-displays/dict-display-comprehension.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/dictionary-displays/dict-display-comprehension.yaml b/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/dictionary-displays/dict-display-comprehension.yaml index 5bbd08818..07ddd458c 100644 --- a/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/dictionary-displays/dict-display-comprehension.yaml +++ b/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/dictionary-displays/dict-display-comprehension.yaml @@ -1,4 +1,4 @@ -enabled: False +enabled: True python: | def setDisplayComprehension(): l = { x : x * x for x in range(1, 6) if (x % 2) == 1 } From d49e701bd36fe6954918fe41f4f4c9c2ddbe7ca1 Mon Sep 17 00:00:00 2001 From: dours Date: Fri, 19 Aug 2022 23:29:06 +0300 Subject: [PATCH 07/12] forgotten --- .../main/scala/org/polystat/py2eo/transpiler/Transpile.scala | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/transpiler/src/main/scala/org/polystat/py2eo/transpiler/Transpile.scala b/transpiler/src/main/scala/org/polystat/py2eo/transpiler/Transpile.scala index 1d2642da4..a6f254ef2 100644 --- a/transpiler/src/main/scala/org/polystat/py2eo/transpiler/Transpile.scala +++ b/transpiler/src/main/scala/org/polystat/py2eo/transpiler/Transpile.scala @@ -60,7 +60,7 @@ object Transpile { debugPrinter(simIf._1, "simplifyIf") val simAssList = StatementPasses.procStatement(StatementPasses.simplifyAssignmentList)(simIf._1, simIf._2) debugPrinter(simAssList._1, "simplifyAssList") - val simCompr = StatementPasses.procExprInStatement((ExpressionPasses.simplifyCollectionComprehension))(simAssList._1, simAssList._2) + val simCompr = StatementPasses.procExprInStatement((ExpressionPasses.simplifyComprehension))(simAssList._1, simAssList._2) debugPrinter(simCompr._1, "afterSimplifyCollectionComprehension") val simForAgain = StatementPasses.procStatement(StatementPasses.simplifyFor)(simCompr._1, simCompr._2) debugPrinter(simForAgain._1, "afterSimForAgain") From 148578b25debf0a89da539066c9c32cbd9764ed9 Mon Sep 17 00:00:00 2001 From: dours Date: Fri, 19 Aug 2022 23:41:46 +0300 Subject: [PATCH 08/12] remove this nonsensically empty test --- .../simple-tests/expressions/set-displays/set-display.yaml | 5 ----- 1 file changed, 5 deletions(-) delete mode 100644 transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/set-displays/set-display.yaml diff --git a/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/set-displays/set-display.yaml b/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/set-displays/set-display.yaml deleted file mode 100644 index 6885da663..000000000 --- a/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/set-displays/set-display.yaml +++ /dev/null @@ -1,5 +0,0 @@ -enabled: False -python: | - def setDisplay(): - l = { 1, 2, 3, 1 } - From aafc4593d03254ea4596e7b700472c5cb0432868 Mon Sep 17 00:00:00 2001 From: dours Date: Fri, 19 Aug 2022 23:42:05 +0300 Subject: [PATCH 09/12] should work. enable --- .../expressions/set-displays/set-display-comprehension.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/set-displays/set-display-comprehension.yaml b/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/set-displays/set-display-comprehension.yaml index 4511cd25e..9af66ba5f 100644 --- a/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/set-displays/set-display-comprehension.yaml +++ b/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/expressions/set-displays/set-display-comprehension.yaml @@ -1,4 +1,4 @@ -enabled: False +enabled: True python: | def setDisplayComprehension(): l = { x * x for x in range(1, 6) if (x % 2) == 1 } From 1598595f81eac101e05f425b0a685ff4a33f9f5c Mon Sep 17 00:00:00 2001 From: dours Date: Sat, 20 Aug 2022 23:45:23 +0300 Subject: [PATCH 10/12] avoid the .with-value hack with this wrapper! --- transpiler/src/main/eo/preface/xmyMap.eo | 27 +++++++++++------------- 1 file changed, 12 insertions(+), 15 deletions(-) diff --git a/transpiler/src/main/eo/preface/xmyMap.eo b/transpiler/src/main/eo/preface/xmyMap.eo index dc1a5c045..fc4f37770 100644 --- a/transpiler/src/main/eo/preface/xmyMap.eo +++ b/transpiler/src/main/eo/preface/xmyMap.eo @@ -10,6 +10,7 @@ +alias xmyArray preface.xmyArray [] > xmyMap + [value] > wrapper pyint 16 > x__id__ [initValue] > apply [stackUp] > @ @@ -28,14 +29,12 @@ [stackUp] > @ memory 0 > i seq > @ - stdout (sprintf "xget %s\n" key) (i.lt (self.value.length)).while [unused] seq > @ - stdout (sprintf "%s ?= %s\n" ((self.value.get i).fst) key) if. - (self.value.get i).fst.eq key - stackUp.forward (return ((self.value.get i).snd)) + (self.value.get i).value.fst.eq key + stackUp.forward (return ((self.value.get i).value.snd)) i.write (i.plus 1) stdout "get left the loop\n" 0 @@ -44,14 +43,12 @@ [stackUp] > @ memory 0 > i seq > @ - stdout (sprintf "xget %s\n" key) (i.lt (value.length)).while [unused] seq > @ - stdout (sprintf "%s ?= %s\n" ((value.get i).fst) key) if. - (value.get i).fst.eq key - stackUp.forward (return ((value.get i).snd)) + (value.get i).value.fst.eq key + stackUp.forward (return ((value.get i).value.snd)) i.write (i.plus 1) stdout "get left the loop\n" 0 @@ -64,7 +61,7 @@ [unused] seq > @ if. - (self.value.get i).fst.eq key + (self.value.get i).value.fst.eq key stackUp.forward (return (pybool TRUE)) i.write (i.plus 1) stdout "c1\n" @@ -76,7 +73,7 @@ FALSE [acc item] seq > @ - acc.or ((elt.eq (item.fst)).value) + acc.or ((elt.eq (item.value.fst)).value) seq > @ stdout (sprintf "len = %d\n" (value.length)) pybool result @@ -88,9 +85,9 @@ stackUp.forward (return 0) 0 mkCopy (self.value) > tmp - mkCopy (key.value) > kv - mkCopy (val.value) > vv - self.value.write (tmp.copy.with (pair (key.with-value (kv.copy)) (val.with-value (vv.copy)))) + mkCopy (key) > kv + mkCopy (val) > vv + self.value.write (tmp.copy.with (wrapper (pair ((kv.copy)) ((vv.copy))))) stackUp.forward (return 0) 123 [] > xappend @@ -112,7 +109,7 @@ seq > @ (i.lt (value.length)).while [unused] - (self.value.get i).fst > x + (self.value.get i).value.fst > x seq > @ (goto ((accum.xappend.apply accum x).@)).result i.write (i.plus 1) @@ -128,7 +125,7 @@ seq > @ (i.lt (value.length)).while [unused] - (value.get i).fst > x + (value.get i).value.fst > x seq > @ (goto ((accum.xappend.apply accum x).@)).result i.write (i.plus 1) From 329ccb1e97dfdc9c3861aa948c0fa47a3d31c634 Mon Sep 17 00:00:00 2001 From: dours Date: Sat, 20 Aug 2022 23:45:39 +0300 Subject: [PATCH 11/12] this test should work now --- .../transpiler/simple-tests/library/dictionary/dict-4.yaml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/library/dictionary/dict-4.yaml b/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/library/dictionary/dict-4.yaml index c85a7e457..89b024d1a 100644 --- a/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/library/dictionary/dict-4.yaml +++ b/transpiler/src/test/resources/org/polystat/py2eo/transpiler/simple-tests/library/dictionary/dict-4.yaml @@ -1,4 +1,4 @@ -enabled: False +enabled: True python: | def test(): class A: @@ -9,4 +9,4 @@ python: | dict = {'name': 'John', 1: x} - return dict.get(1).__class__ == A \ No newline at end of file + return dict.get(1).__class__ == A From a7dc1079134027ac1ec43c61346d527eaaf94c9a Mon Sep 17 00:00:00 2001 From: dours Date: Sun, 21 Aug 2022 01:22:39 +0300 Subject: [PATCH 12/12] support comparison of classes (they compare the types basically) --- .../py2eo/transpiler/PrintLinearizedMutableEOWithCage.scala | 2 ++ 1 file changed, 2 insertions(+) diff --git a/transpiler/src/main/scala/org/polystat/py2eo/transpiler/PrintLinearizedMutableEOWithCage.scala b/transpiler/src/main/scala/org/polystat/py2eo/transpiler/PrintLinearizedMutableEOWithCage.scala index 76419d431..f532434e1 100644 --- a/transpiler/src/main/scala/org/polystat/py2eo/transpiler/PrintLinearizedMutableEOWithCage.scala +++ b/transpiler/src/main/scala/org/polystat/py2eo/transpiler/PrintLinearizedMutableEOWithCage.scala @@ -99,6 +99,8 @@ object PrintLinearizedMutableEOWithCage { name :: "[]" :: indent( "newUID.apply 0 > x__id__" :: + "[x] > eq" :: + " x__id__.eq (x.x__id__) > @" :: s"[$consArgs] > apply" :: indent( "[stackUp] > @" ::