Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
T
typon-compiler
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
typon
typon-compiler
Commits
85f54768
Commit
85f54768
authored
Feb 20, 2024
by
Tom Niget
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make first things work
parent
54759ed9
Changes
5
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
188 additions
and
170 deletions
+188
-170
typon/runtime
typon/runtime
+1
-1
typon/trans/transpiler/phases/emit_cpp/expr.py
typon/trans/transpiler/phases/emit_cpp/expr.py
+71
-60
typon/trans/transpiler/phases/emit_cpp/function.py
typon/trans/transpiler/phases/emit_cpp/function.py
+112
-106
typon/trans/transpiler/phases/emit_cpp/visitors.py
typon/trans/transpiler/phases/emit_cpp/visitors.py
+3
-2
typon/trans/transpiler/transpiler.py
typon/trans/transpiler/transpiler.py
+1
-1
No files found.
runtime
@
79677d12
Subproject commit
285703a35af4ca1476ce30e2404b73af9d880ec
5
Subproject commit
79677d125f915f7c61492d8d1d8cde9fc6a1187
5
typon/trans/transpiler/phases/emit_cpp/expr.py
View file @
85f54768
...
@@ -79,71 +79,79 @@ class ExpressionVisitor(NodeVisitor):
...
@@ -79,71 +79,79 @@ class ExpressionVisitor(NodeVisitor):
# yield from self.visit_binary_operation(op, left, right, make_lnd(left, right))
# yield from self.visit_binary_operation(op, left, right, make_lnd(left, right))
def
visit_BoolOp
(
self
,
node
:
ast
.
BoolOp
)
->
Iterable
[
str
]:
def
visit_BoolOp
(
self
,
node
:
ast
.
BoolOp
)
->
Iterable
[
str
]:
if
len
(
node
.
values
)
==
1
:
raise
NotImplementedError
()
yield
from
self
.
visit
(
node
.
values
[
0
])
return
# if len(node.values) == 1:
cpp_op
=
{
# yield from self.visit(node.values[0])
ast
.
And
:
"&&"
,
# return
ast
.
Or
:
"||"
# cpp_op = {
}[
type
(
node
.
op
)]
# ast.And: "&&",
with
self
.
prec_ctx
(
cpp_op
):
# ast.Or: "||"
yield
from
self
.
visit_binary_operation
(
cpp_op
,
node
.
values
[
0
],
node
.
values
[
1
],
make_lnd
(
node
.
values
[
0
],
node
.
values
[
1
]))
# }[type(node.op)]
for
left
,
right
in
zip
(
node
.
values
[
1
:],
node
.
values
[
2
:]):
# with self.prec_ctx(cpp_op):
yield
f"
{
cpp_op
}
"
# yield from self.visit_binary_operation(cpp_op, node.values[0], node.values[1], make_lnd(node.values[0], node.values[1]))
yield
from
self
.
visit_binary_operation
(
cpp_op
,
left
,
right
,
make_lnd
(
left
,
right
))
# for left, right in zip(node.values[1:], node.values[2:]):
# yield f" {cpp_op} "
# yield from self.visit_binary_operation(cpp_op, left, right, make_lnd(left, right))
def
visit_Call
(
self
,
node
:
ast
.
Call
)
->
Iterable
[
str
]:
def
visit_Call
(
self
,
node
:
ast
.
Call
)
->
Iterable
[
str
]:
yield
"("
yield
from
self
.
visit
(
node
.
func
)
yield
")("
yield
from
join
(
", "
,
map
(
self
.
visit
,
node
.
args
))
yield
")"
#raise NotImplementedError()
# TODO
# TODO
# if getattr(node, "keywords", None):
# if getattr(node, "keywords", None):
# raise NotImplementedError(node, "keywords")
# raise NotImplementedError(node, "keywords")
if
getattr
(
node
,
"starargs"
,
None
):
#
if getattr(node, "starargs", None):
raise
NotImplementedError
(
node
,
"varargs"
)
#
raise NotImplementedError(node, "varargs")
if
getattr
(
node
,
"kwargs"
,
None
):
#
if getattr(node, "kwargs", None):
raise
NotImplementedError
(
node
,
"kwargs"
)
#
raise NotImplementedError(node, "kwargs")
func
=
node
.
func
#
func = node.func
if
isinstance
(
func
,
ast
.
Attribute
):
#
if isinstance(func, ast.Attribute):
if
sym
:
=
DUNDER_SYMBOLS
.
get
(
func
.
attr
,
None
):
#
if sym := DUNDER_SYMBOLS.get(func.attr, None):
if
len
(
node
.
args
)
==
1
:
#
if len(node.args) == 1:
yield
from
self
.
visit_binary_operation
(
sym
,
func
.
value
,
node
.
args
[
0
],
linenodata
(
node
))
#
yield from self.visit_binary_operation(sym, func.value, node.args[0], linenodata(node))
else
:
#
else:
yield
from
self
.
visit_unary_operation
(
sym
,
func
.
value
)
#
yield from self.visit_unary_operation(sym, func.value)
return
#
return
for
name
in
(
"fork"
,
"future"
):
#
for name in ("fork", "future"):
if
compare_ast
(
func
,
ast
.
parse
(
name
,
mode
=
"eval"
).
body
):
#
if compare_ast(func, ast.parse(name, mode="eval").body):
assert
len
(
node
.
args
)
==
1
#
assert len(node.args) == 1
arg
=
node
.
args
[
0
]
#
arg = node.args[0]
assert
isinstance
(
arg
,
ast
.
Lambda
)
#
assert isinstance(arg, ast.Lambda)
node
.
is_future
=
name
#
node.is_future = name
vis
=
self
.
reset
()
#
vis = self.reset()
vis
.
generator
=
CoroutineMode
.
SYNC
#
vis.generator = CoroutineMode.SYNC
# todo: bad code
#
# todo: bad code
if
CoroutineMode
.
ASYNC
in
self
.
generator
:
#
if CoroutineMode.ASYNC in self.generator:
yield
f"co_await typon::
{
name
}
("
#
yield f"co_await typon::{name}("
yield
from
vis
.
visit
(
arg
.
body
)
#
yield from vis.visit(arg.body)
yield
")"
#
yield ")"
return
#
return
elif
CoroutineMode
.
FAKE
in
self
.
generator
:
#
elif CoroutineMode.FAKE in self.generator:
yield
from
self
.
visit
(
arg
.
body
)
#
yield from self.visit(arg.body)
return
#
return
if
compare_ast
(
func
,
ast
.
parse
(
'sync'
,
mode
=
"eval"
).
body
):
#
if compare_ast(func, ast.parse('sync', mode="eval").body):
if
CoroutineMode
.
ASYNC
in
self
.
generator
:
#
if CoroutineMode.ASYNC in self.generator:
yield
"co_await typon::Sync()"
#
yield "co_await typon::Sync()"
elif
CoroutineMode
.
FAKE
in
self
.
generator
:
#
elif CoroutineMode.FAKE in self.generator:
yield
from
()
#
yield from ()
return
#
return
# TODO: precedence needed?
#
#
TODO: precedence needed?
if
CoroutineMode
.
ASYNC
in
self
.
generator
and
node
.
is_await
:
#
if CoroutineMode.ASYNC in self.generator and node.is_await:
yield
"("
# TODO: temporary
#
yield "(" # TODO: temporary
yield
"co_await "
#
yield "co_await "
node
.
in_await
=
True
#
node.in_await = True
elif
CoroutineMode
.
FAKE
in
self
.
generator
:
#
elif CoroutineMode.FAKE in self.generator:
func
=
ast
.
Attribute
(
value
=
func
,
attr
=
"sync"
,
ctx
=
ast
.
Load
())
#
func = ast.Attribute(value=func, attr="sync", ctx=ast.Load())
yield
from
self
.
prec
(
"()"
).
visit
(
func
)
#
yield from self.prec("()").visit(func)
yield
"("
#
yield "("
yield
from
join
(
", "
,
map
(
self
.
reset
().
visit
,
node
.
args
))
#
yield from join(", ", map(self.reset().visit, node.args))
yield
")"
#
yield ")"
if
CoroutineMode
.
ASYNC
in
self
.
generator
and
node
.
is_await
:
#
if CoroutineMode.ASYNC in self.generator and node.is_await:
yield
")"
#
yield ")"
def
visit_Lambda
(
self
,
node
:
ast
.
Lambda
)
->
Iterable
[
str
]:
def
visit_Lambda
(
self
,
node
:
ast
.
Lambda
)
->
Iterable
[
str
]:
yield
"[]"
yield
"[]"
...
@@ -157,12 +165,15 @@ class ExpressionVisitor(NodeVisitor):
...
@@ -157,12 +165,15 @@ class ExpressionVisitor(NodeVisitor):
yield
"}"
yield
"}"
def
visit_BinOp
(
self
,
node
:
ast
.
BinOp
)
->
Iterable
[
str
]:
def
visit_BinOp
(
self
,
node
:
ast
.
BinOp
)
->
Iterable
[
str
]:
raise
NotImplementedError
()
yield
from
self
.
visit_binary_operation
(
node
.
op
,
node
.
left
,
node
.
right
,
linenodata
(
node
))
yield
from
self
.
visit_binary_operation
(
node
.
op
,
node
.
left
,
node
.
right
,
linenodata
(
node
))
def
visit_Compare
(
self
,
node
:
ast
.
Compare
)
->
Iterable
[
str
]:
def
visit_Compare
(
self
,
node
:
ast
.
Compare
)
->
Iterable
[
str
]:
raise
NotImplementedError
()
yield
from
self
.
visit_binary_operation
(
node
.
ops
[
0
],
node
.
left
,
node
.
comparators
[
0
],
linenodata
(
node
))
yield
from
self
.
visit_binary_operation
(
node
.
ops
[
0
],
node
.
left
,
node
.
comparators
[
0
],
linenodata
(
node
))
def
visit_binary_operation
(
self
,
op
,
left
:
ast
.
AST
,
right
:
ast
.
AST
,
lnd
:
dict
)
->
Iterable
[
str
]:
def
visit_binary_operation
(
self
,
op
,
left
:
ast
.
AST
,
right
:
ast
.
AST
,
lnd
:
dict
)
->
Iterable
[
str
]:
raise
NotImplementedError
()
# if type(op) == ast.In:
# if type(op) == ast.In:
# call = ast.Call(ast.Attribute(right, "__contains__", **lnd), [left], [], **lnd)
# call = ast.Call(ast.Attribute(right, "__contains__", **lnd), [left], [], **lnd)
# call.is_await = False
# call.is_await = False
...
...
typon/trans/transpiler/phases/emit_cpp/function.py
View file @
85f54768
This diff is collapsed.
Click to expand it.
typon/trans/transpiler/phases/emit_cpp/visitors.py
View file @
85f54768
...
@@ -6,7 +6,7 @@ from typing import Iterable
...
@@ -6,7 +6,7 @@ from typing import Iterable
import
transpiler.phases.typing.types
as
types
import
transpiler.phases.typing.types
as
types
from
transpiler.phases.typing.exceptions
import
UnresolvedTypeVariableError
from
transpiler.phases.typing.exceptions
import
UnresolvedTypeVariableError
from
transpiler.phases.typing.types
import
BaseType
from
transpiler.phases.typing.types
import
BaseType
from
transpiler.utils
import
UnsupportedNodeError
from
transpiler.utils
import
UnsupportedNodeError
,
highlight
class
UniversalVisitor
:
class
UniversalVisitor
:
...
@@ -48,7 +48,8 @@ class NodeVisitor(UniversalVisitor):
...
@@ -48,7 +48,8 @@ class NodeVisitor(UniversalVisitor):
def
fix_name
(
self
,
name
:
str
)
->
str
:
def
fix_name
(
self
,
name
:
str
)
->
str
:
if
name
.
startswith
(
"__"
)
and
name
.
endswith
(
"__"
):
if
name
.
startswith
(
"__"
)
and
name
.
endswith
(
"__"
):
return
f"py_
{
name
[
2
:
-
2
]
}
"
return
f"py_
{
name
[
2
:
-
2
]
}
"
return
MAPPINGS
.
get
(
name
,
name
)
return
name
#return MAPPINGS.get(name, name)
def
visit_BaseType
(
self
,
node
:
BaseType
)
->
Iterable
[
str
]:
def
visit_BaseType
(
self
,
node
:
BaseType
)
->
Iterable
[
str
]:
node
=
node
.
resolve
()
node
=
node
.
resolve
()
...
...
typon/trans/transpiler/transpiler.py
View file @
85f54768
...
@@ -54,7 +54,7 @@ def transpile(source, name: str, path: Path):
...
@@ -54,7 +54,7 @@ def transpile(source, name: str, path: Path):
# yield from code
# yield from code
# yield "}"
# yield "}"
yield
"#else"
yield
"#else"
yield
"typon::Root root()
const
{"
yield
"typon::Root root() {"
yield
f"co_await dot(PROGRAMNS::
{
module
.
name
()
}
, main)();"
yield
f"co_await dot(PROGRAMNS::
{
module
.
name
()
}
, main)();"
yield
"}"
yield
"}"
yield
"int main(int argc, char* argv[]) {"
yield
"int main(int argc, char* argv[]) {"
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment