Python 3 Porting Guide

Guide to porting Sugar Activities to Python 3.

Many activities were written in Python 2 with the PyGObject introspection library, GTK, GDK, GStreamer, and other dependencies. Activities usually did not have test cases or test coverage.

Required Skills

How to Port an Activity to Python 3:

Follow the Code Guidelines during all porting.

Write any comments in the code, by adding # README:, # TODO: and # FIXME: explaining what are the problems that you are having with that chunk of code. Put a link if it's necessary.

Releasing Activities (for maintainers)

Once an activity is ported, a new release can be made. The major version
should be greater than the existing one.

Please follow
this
guide for releasing a new version.

Avoid releasing Python 3 activities to https://activities.sugarlabs.org/ as these will not work on existing systems.

Resources:

Porting Examples:

Here are some examples of porting activities to Python 3:

Common Questions

Why does my traceback show Python 2?

Check that you have changed exec in activity.info, and that Sugar has been restarted.

Why does "consider porting to Python 3" still appear?

Check that you have changed exec in activity.info.