alanjds / grumpy

**MOVED TO NEW MOTHER ORG `grumpyhome/grumpy`** Grumpy is a Python to Go source code transcompiler and runtime.
https://github.com/grumpyhome/grumpy
Apache License 2.0
16 stars 1 forks source link

__builtins__ not defined #35

Open alanjds opened 6 years ago

alanjds commented 6 years ago

I'm aware that not all builtins have been written yet. I tried to take a look at what has been written so far:

$ echo 'dir(__builtins__)' | make run
NameError: name '__builtins__' is not defined
exit status 1
make: *** [run] Error 1

I think there's some low-hanging fruit in writing plain Python implementations for a few builtins like sum, map, etc. Where's the right place to write those?

alanjds commented 6 years ago

Comment by trotterdylan Friday Jan 06, 2017 at 00:00 GMT


Check out builtin_types.go

alanjds commented 6 years ago

Comment by meadori Friday Jan 06, 2017 at 00:46 GMT


I am working through several of these now starting with abs google/grumpy#28. I plan to go after all next. Not sure if it is worth it to open an issue per builtin, or just use this one as catch all.

alanjds commented 6 years ago

Comment by selik Friday Jan 06, 2017 at 13:44 GMT


Would it be reasonable to add plain Python implementations to builtin.py instead?

For example:

from itertools import izip

def map(function, *sequences):
    if len(sequences) == 1: # avoid infinite recursion from izip calling map
        return [function(arg) for arg in sequences[0]]
    return [function(*args) for args in izip(*sequences)]
alanjds commented 6 years ago

Comment by trotterdylan Friday Jan 06, 2017 at 16:49 GMT


Yeah, I'm OK with that.

alanjds commented 6 years ago

Comment by meadori Friday Jan 06, 2017 at 17:03 GMT


I can see two reason for doing it in the Go runtime:

  1. Efficiency - depending on the state of the transpiler and the host Go compiler, writing hand-tuned code in the runtime might lead to a faster implementation (especially for heavily used builtins).
  2. Circularity - in some cases you might have to implement builtins with builtins, thus precluding a pure Python implementaiton (like the use of len above).

We should probably review builtins on a case-by-case basis to determine whether Python or the Go-based runtime is more suitable.

alanjds commented 6 years ago

Comment by trotterdylan Friday Jan 06, 2017 at 17:11 GMT


Yep, I think that's a good summary. Long term I expect we'll want all builtins to be written in Go for reason google/grumpy#1 but short term I think it's fine to write some in Python.

alanjds commented 6 years ago

Comment by selik Friday Jan 06, 2017 at 17:16 GMT


I defined a map and all in lib\__builtin__.py but it didn't appear in my __main__ global namespace. I expected some magic to make anything in that module available everywhere.

alanjds commented 6 years ago

Comment by trotterdylan Friday Jan 06, 2017 at 17:29 GMT


Oh that's right. The way things work right now there's a grumpy.Builtins *Dict that contains all the builtins. The __builtin__ module just copies stuff out of there into its own namespace. When doing a builtin name lookup, grumpy.Builtins is used rather than the __builtin__ module's own dict. That should change so that the __builtin__ dict is the canonical namespace for lookups otherwise code that adds stuff to __builtin__ won't work correctly.

alanjds commented 6 years ago

Comment by selik Friday Jan 06, 2017 at 18:03 GMT


Ideally there should be a __builtins__ variable in every module's globals(), that references the __builtin__ module.

>>> __builtins__
<module '__builtin__' (built-in)>
alanjds commented 6 years ago

Comment by meadori Friday Jan 06, 2017 at 18:18 GMT


I added a Go implementation of all in google/grumpy#54. any will follow next. It is very similar.