Skip to content
/ voc Public
forked from beeware/voc

A transpiler that converts Python bytecode into Java bytecode.

License

Notifications You must be signed in to change notification settings

idkwim/voc

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

71 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

http://pybee.org/voc/static/images/voc-72.png

VOC

https://travis-ci.org/pybee/voc.svg?branch=master

A transpiler that converts Python bytecode into Java bytecode.

This is experimental code. If it breaks, you get to keep all the shiny pieces.

What it does:

  • Provides an API to let you programmatically create Java class files.
  • Compiles a Python source file into a Java class file in a nominated package. Supports the conversion of:
    • Class definition and construction
    • Class instantiation
    • Method definition and invocation
    • Some mathematical operations
    • Exception handling
    • for/while/if constructs
    • Identification of mainline entry points
    • Static initialization of modules.

It doesn't currently support

  • Keyword arguments
  • List comprehensions
  • Generators
  • Import statements
  • exec()/eval()

These things should all be possible - it's just a matter of time and development effort.

Quickstart

Install voc, then run the example script:

$ pip install voc
$ python -m voc tests/example.py org.pyee
Creating class 'example'...
Writing example.class...
Done.

This will produce a example.class, in the org.pybee namespace, that you can run on any Java 1.7+ VM.

Next step - you need to compile the Python support libraries:

$ make

This will compile python.jar. You will need to make sure that the python.jar support file is in your classpath:

$ java -XX:-UseSplitVerifier -classpath python.jar:. example
Hello, World

The -CC:-UsesplitVerifier argument is necessary to turn off stack map verification in Java 7. This could be addressed by computing stack maps for generated code.

Documentation

Documentation for VOC can be found on Read The Docs.

Why "VOC"?

The Vereenigde Oostindische Compagnie (VOC), or Dutch East India Company, is often considered the be the world's first multinational corporation. It was also the first company to issue shares, and facilitate the trading of those shares. It was granted a 21 year monopoly to carry out trade activities in Asia, primarily the Spice Islands - the Dutch East Indies. They established a major trading port at Batavia - now Jakarta, on the island of Java (now part of Indonesia). As a result of their monopoly, the VOC became an incredibly valuable company, issuing an 18% annual dividend for almost 200 years.

VOC was... the world's first Enterprise using Java. (rimshot!)

VOC is also a backronym for "Vestigial Output Compiler". Or "Vexing Obtuse Compiler". Or "Valuable Obscure Compiler". Or "Varigated Ocelot Calibrator". It's your choice.

Community

VOC is part of the BeeWare suite. You can talk to the community through:

Contributing

If you experience problems with VOC, log them on GitHub. If you want to contribute code, please fork the code and submit a pull request.

About

A transpiler that converts Python bytecode into Java bytecode.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 73.5%
  • Java 26.0%
  • Makefile 0.5%