Difference between revisions of "Summer of Code/2015"

From Sugar Labs
Jump to navigation Jump to search
 
(25 intermediate revisions by 6 users not shown)
Line 3: Line 3:
 
== Project candidates ==
 
== Project candidates ==
  
In the table below is a list of projects potential participants might contribute to in the GSoC program.  
+
In the table below is a list of projects potential participants might contribute to in the GSoC program.
  
;Note 1: We are focusing on the Javascript components within Sugar this summer.
+
;Note 0: These are project ideas from Sugar Labs contributors. Students, feel free to propose your ideas as well.
 +
;Note 1: We are focusing on the Javascript components within Sugar this summer. It means that you've got to write activities for Sugar Web and Sugarizer. More information: on Sugar Web [https://github.com/sugarlabs/sugar-docs/blob/master/web-architecture.md][https://github.com/sugarlabs/sugar-docs/blob/master/activity.md] and on Sugarizer [http://sugarizer.org]
 
;Note 2: Potential mentors, please feel free to add ideas to this list. Also, feel free to add your name to a project you'd be willing to co-mentor.
 
;Note 2: Potential mentors, please feel free to add ideas to this list. Also, feel free to add your name to a project you'd be willing to co-mentor.
 
;Note 3: Potential students, more project ideas can be found on our [[Features]] page.
 
;Note 3: Potential students, more project ideas can be found on our [[Features]] page.
Line 16: Line 17:
 
!  !! Title !! Mentor !! Project
 
!  !! Title !! Mentor !! Project
 
|-
 
|-
!valign=top | [[File:git_logo.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Git backend||valign=top width="15%" | Martin Abente and Walter Bender ||align=left valign=top|
+
!valign=top | [[File:git_logo.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Git backend||valign=top width="15%" | Martin Abente Lahaye and Walter Bender ||align=left valign=top|
 
;Brief explanation: The Sugar Journal doesn't do a great job of supporting versioning or forking. This project is to build a backend for the Journal that is based on git, which does support versioning and forking. By building on top of a git hosting site we get the added benefit of network access as well.
 
;Brief explanation: The Sugar Journal doesn't do a great job of supporting versioning or forking. This project is to build a backend for the Journal that is based on git, which does support versioning and forking. By building on top of a git hosting site we get the added benefit of network access as well.
;Expected results:  
+
;Expected results: Working code and an integration with Turtle Blocks
;Knowledge prerequisite: Strong background in Python
+
;Knowledge prerequisite: Strong background in Git and scripting languages such as Python, Ruby and JavaScript.
 +
 
 +
|-
 +
!valign=top | [[File:Cordova_sugar.png|90px|center|thumb]] || valign=top  style="background:#e3e4e5;"  | Cordova/PhoneGap container for Sugar || valign=top | Puneet Kaur and Lionel Laské||align=left valign=top |
 +
;Brief explanation: Making cordova plugins for sugar and demonstrating the working plugins via sugar activities, incooperating cordova plugins with the existing sugar activities visit : http://sugarcordova.blogspot.com/ for more info
 +
;Expected results: Working Demonstration of new plugins and new activities based on implemented plugins
 +
;Knowledge prerequisite: Strong background in JavaScript,python
  
 
|-
 
|-
!valign=top | [[File:Cordova_sugar.png|90px|center|thumb]] || valign=top  style="background:#e3e4e5;"  | Cordova/PhoneGap container for Sugar || valign=top | Lionel Laské and Puneet Kaur||align=left valign=top |
+
!valign=top | || valign=top  style="background:#e3e4e5;"  | Performance tuning on machines with limited memory || valign=top | Samuel Greenfeld and James Cameron||align=left valign=top |
;Brief explanation:  
+
;Brief explanation: The newer Sugar builds have performance issues on some old hardware with limited memory. This is keeping some Sugar deployments from upgrading. This project is to look into the performance issues and tune Sugar for low-memory devices.
;Expected results:  
+
;Expected results: build suitable for running on OLPC XO-1 hardware
;Knowledge prerequisite: Strong background in JavaScript, don't be put off by Python.
+
;Knowledge prerequisite:
  
 +
|-
 +
!valign=top | || valign=top  style="background:#e3e4e5;"  | Re-design collaboration with web technologies || valign=top | Martin Abente Lahaye and Walter Bender ||align=left valign=top |
 +
;Brief explanation: Now that JavaScript has become a first class citizen in the Sugar ecosystem, we must re-design our collaboration model to allow collaboration between web activities regardless of the platform.
 +
;Knowledge prerequisite: JavaScript, web sockets, web services.
 
|}
 
|}
  
Line 37: Line 48:
 
!valign=top | [[File:turtlejs.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Blocks 3D Javascript||valign=top width="15%" | Tony Forster and Walter Bender||align=left valign=top|
 
!valign=top | [[File:turtlejs.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Blocks 3D Javascript||valign=top width="15%" | Tony Forster and Walter Bender||align=left valign=top|
 
;Brief explanation: The Python version of Turtle Blocks 3D is based on GTK since Sugar uses GTK and GTK is largely incompatible with OpenGL. In a Javascript version, we could use OpenGL and take advantage of many more graphics libraries, such as 3D lighting models and texture mapping.
 
;Brief explanation: The Python version of Turtle Blocks 3D is based on GTK since Sugar uses GTK and GTK is largely incompatible with OpenGL. In a Javascript version, we could use OpenGL and take advantage of many more graphics libraries, such as 3D lighting models and texture mapping.
;Expected results:  
+
;Expected results: A new Turtle Blocks spin that adds basic 3D transforms to Turtle Blocks (e.g., setxyz, pitch, roll, yaw); camera and lighting models; surface texture mapping; and a rich set of example projects.
 
;Knowledge prerequisite: Strong background in Javascript
 
;Knowledge prerequisite: Strong background in Javascript
 
|-
 
|-
 
!valign=top | [[File:turtlejs.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Blocks export as Javascript||valign=top width="15%" | Walter Bender||align=left valign=top|
 
!valign=top | [[File:turtlejs.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Blocks export as Javascript||valign=top width="15%" | Walter Bender||align=left valign=top|
 
;Brief explanation: The Python version of Turtle Blocks allows the user to export their project as Python code. We need an equivalent Javascript export for the Javascript version.
 
;Brief explanation: The Python version of Turtle Blocks allows the user to export their project as Python code. We need an equivalent Javascript export for the Javascript version.
;Expected results:  
+
;Expected results: Working code integrated into Turtle Blocks JS
 
;Knowledge prerequisite: Strong background in Javascript
 
;Knowledge prerequisite: Strong background in Javascript
 
|-
 
|-
 
!valign=top | [[File:turtlejs.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Blocks inline Javascript||valign=top width="15%" | Walter Bender||align=left valign=top|
 
!valign=top | [[File:turtlejs.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Blocks inline Javascript||valign=top width="15%" | Walter Bender||align=left valign=top|
 
;Brief explanation: There are several block-based programming environments that allow the user to extend the language in line, such as Blocky and Pencil Code. (Turtle Blocks uses plugins for this, but they are imported). The goal of this project is to write an in-line block editor for Turtle Blocks (Javascript version).
 
;Brief explanation: There are several block-based programming environments that allow the user to extend the language in line, such as Blocky and Pencil Code. (Turtle Blocks uses plugins for this, but they are imported). The goal of this project is to write an in-line block editor for Turtle Blocks (Javascript version).
;Expected results:  
+
;Expected results: Working code integrated into Turtle Blocks JS
 
;Knowledge prerequisite: Strong background in Javascript
 
;Knowledge prerequisite: Strong background in Javascript
 
|-
 
|-
 
!valign=top | [[File:turtlejs.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Blocks debugging tools||valign=top width="15%" | Cynthia Solomon and Walter Bender||align=left valign=top|
 
!valign=top | [[File:turtlejs.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Blocks debugging tools||valign=top width="15%" | Cynthia Solomon and Walter Bender||align=left valign=top|
;Brief explanation: There are several debugging tools in Turtle Blocks: the ability to set break points, step through code, and inspect variables. But we could use a more comprehensive approach, including a mechanism for tracking progress over time.
+
;Brief explanation: There are several debugging tools in Turtle Blocks: the ability to set breakpoints, step through code, and inspect variables. But we could use a more comprehensive approach, including a mechanism for tracking progress over time.
;Expected results:  
+
;Expected results: Working code integrated into Turtle Blocks JS
 
;Knowledge prerequisite: Strong background in Javascript
 
;Knowledge prerequisite: Strong background in Javascript
 
|-
 
|-
 
!valign=top | [[File:turtlejs.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Blocks for in-line programming||valign=top width="15%" | Gonzalo Odiard and Walter Bender||align=left valign=top|
 
!valign=top | [[File:turtlejs.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Blocks for in-line programming||valign=top width="15%" | Gonzalo Odiard and Walter Bender||align=left valign=top|
;Brief explanation: Often we'd like users to be able to extend or modify an activity. Rather than doing this by writing Pyhton or Javascript, why not let them use the block language of Turtle Blocks as an in-line editor. For example, in the Turtle Pond activity, the user can upload Python code representing search algorithms for the turtle as it tries to find its way out of the pond. Why not use a block editor to write the search algorithm?
+
;Brief explanation: Often we'd like users to be able to extend or modify an activity. Rather than doing this by writing Python or Javascript, why not let them use the block language of Turtle Blocks as an in-line editor. For example, in the Turtle Pond activity, the user can upload Python code representing search algorithms for the turtle as it tries to find its way out of the pond. Why not use a block editor to write the search algorithm? Using the Turtle Blocks engine as an editor inside existing activities would be the preferred mechanism, as oppose to constantly extending Turtle Blocks itself. This would (1) let the editor be more specific to the needs of the individual activity; (2) lessen the burden on the user for installing plugins and extensions; (3) circumvent situations where there are barriers to sharing data between activities -- e.g., running outside of Sugar; and (4) perhaps encourage more developers to incorporate more programmatic elements in their activities.
;Expected results:  
+
 
 +
;Expected results: Integration into the Physics Activity
 
;Knowledge prerequisite: Strong background in Javascript/Python
 
;Knowledge prerequisite: Strong background in Javascript/Python
 
|-
 
|-
!valign=top | [[File:mouse-music.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Music Blocks||valign=top width="15%" |Devin Ulibarri and Walter Bender||align=left valign=top|
+
!valign=top | [[File:mouse-music.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Music Blocks||valign=top width="15%" |Devin Ulibarri||align=left valign=top|
;Brief explanation: Using a framework similar to Turtle Blocks Javascript, build a suite of music tools for introducing the basic concepts of scale, beat, chord, phrasing, sequencing, transformations, etc.
+
;Brief explanation: Using a framework similar to Turtle Blocks Javascript, build a suite of music tools for introducing the basic concepts of scale, beat, chord, phrasing, sequencing, transformations, etc. See some of Devin's sketches at [http://people.sugarlabs.org/walter/2015-02-16%20Mouse%20Music.pdf].
;Expected results:  
+
;Expected results: Working code
 +
;Knowledge prerequisite: Strong background in Javascript
 +
|-
 +
!valign=top | [[File:confusion.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Beyond Flashcards: Programming to ReadJS||valign=top width="15%" | and Walter Bender||align=left valign=top|
 +
;Brief explanation: Back in the 1980s, IBM had a literacy program, "Writing to Read". The gist was that writing was a great way to spark a child's interest in reading. What if writing code could achieve a similar result? The project is to explore how programming might be incorporated into a literacy program. Like turtle, only simple sentences instead of stacks. It would be a "whole word" approach rather than a "phonics" approach: they can take "sentences" and make paragraphs that result in animations.
 +
;Expected results: Working prototype
 
;Knowledge prerequisite: Strong background in Javascript
 
;Knowledge prerequisite: Strong background in Javascript
 +
|-
 +
!valign=top |  ||valign=top width="15%" style="background:#e3e4e5;" | Covert Record, Clock, Speak and Measure to gstreamer 1.0 ||valign=top width="15%" | <TBD> ||align=left valign=top|
 +
;Brief explanation: The vast majority of Activities that use gstreamer for sound have been converted to gstreamer 1.0 because the older 0.10 is now End of Life and is no longer being developed. It also adds quite a large set of extra duplicate dependencies to Sugar distributions. There's a lot of good examples of Activities that have been converted to provide excellent examples. The gstreamer 1.0 bindings are provided by gobject-introspection so it also assists in the conversion of Activities to gtk3.
 +
;Expected results: As many of the above Activities converted to use gst 1.0
 +
;Knowledge prerequisite: Strong background in python, gobject-introspection and gstreamer
 +
|-
 +
!valign=top |  ||valign=top width="15%" style="background:#e3e4e5;" | Covert TamTam to Csound6 ||valign=top width="15%" | <TBD> ||align=left valign=top|
 +
;Brief explanation: TamTam makes extensive use of CSound, other Activities like Memorize, Pippy, and TurtleBlocks also can make use of CSound bindings. With the introduction of CSound 6 to a number of distributions TamTam needs migration to use the newer version of CSound.
 +
;Expected results: Convert TamTam to use CSound6, possibly other Activities
 +
;Knowledge prerequisite: Strong background in python, background in CSound
 +
|-
 +
!valign=top |  ||valign=top width="15%" style="background:#e3e4e5;" | Modernise Etoys Activity ||valign=top width="15%" | <TBD> ||align=left valign=top|
 +
;Brief explanation: Etoys hasn't been updated for some time to newer Sugar APIs and design. Improve the Sugar Etoys Activity to no longer depend on the long obsolete sugar-presence-service and generally update it to more modern Sugar design and APIs.
 +
;Expected results: Modernise Etoys Sugar Activity
 +
;Knowledge prerequisite: Strong background in python
 +
|}
 +
 +
== Sugar Activities (Ports) ==
 +
 +
These are existing Python activities we'd like to see ported to JavaScript. In porting we expect that the activities will take on new UI features and pedagogical significance.
 +
 +
{| border=1 cellpadding=3 style="border: 1px solid white; border-collapse: collapse; background: #e3e4e5;"
 +
|-style="background:#787878; color: white;"
 +
!  !! Title !! Mentor !! Project
 +
|-
 +
!valign=top | [[File:Gsoc2015 llaske.svg|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Sugar Web Basic Activity Set||valign=top width="15%" |Lionel Laské||align=left valign=top|
 +
Using Sugar Web Framework - the JavaScript Framework for Sugar - you will have to develop and enhance basic Sugar activity set including activities: Calculate, Paint, Memorize and Record. All activities should use Sugar features (specific UI, journal and collaboration) and should work both on Sugar/Fedora and Sugarizer/Web.
 +
Pre-requisite:
 +
* Good level on HTML5/JavaScript and knowledge of frameworks to handle Canvas objects.
 +
* Knowledge of PhoneGap/Cordova
 +
* Understanding of Python
 +
* Good capacity to do reverse engineering on existing code.
 +
More information: Sugar Web [https://github.com/sugarlabs/sugar-docs/blob/master/web-architecture.md]
 +
[https://github.com/sugarlabs/sugar-docs/blob/master/activity.md], Sugarizer [http://sugarizer.org], Calculate [http://activities.sugarlabs.org/en/sugar/addon/4076], Paint [http://activities.sugarlabs.org/en/sugar/addon/4082][http://activities.sugarlabs.org/en/sugar/addon/4695], Memorize [http://activities.sugarlabs.org/en/sugar/addon/4063][http://activities.sugarlabs.org/en/sugar/addon/4693] and Record [http://activities.sugarlabs.org/en/sugar/addon/4081].
 
|-
 
|-
 
!valign=top | [[File:abacus.jpg|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Abacus JS||valign=top width="15%" | Walter Bender||align=left valign=top|
 
!valign=top | [[File:abacus.jpg|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Abacus JS||valign=top width="15%" | Walter Bender||align=left valign=top|
;Brief explanation:  
+
;Brief explanation: Port of the Abacus activity.
 
;Expected results:  
 
;Expected results:  
 
;Knowledge prerequisite: Strong background in Javascript
 
;Knowledge prerequisite: Strong background in Javascript
 
|-
 
|-
 
!valign=top | [[File:fototoon.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Fototoons JS||valign=top width="15%" |Gonzalo Odiard||align=left valign=top|
 
!valign=top | [[File:fototoon.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Fototoons JS||valign=top width="15%" |Gonzalo Odiard||align=left valign=top|
;Brief explanation:
+
;Brief explanation: Port of Fototoons.
 
;Expected results:  
 
;Expected results:  
 
;Knowledge prerequisite: Strong background in Javascript
 
;Knowledge prerequisite: Strong background in Javascript
 
|-
 
|-
!valign=top | [[File:Activity-physics-55x55.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Physics JS||valign=top width="15%" | and Walter Bender||align=left valign=top|
+
!valign=top | [[File:Activity-physics-55x55.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Physics JS||valign=top width="15%" | Walter Bender||align=left valign=top|
;Brief explanation:
+
;Brief explanation: Port of Physics.
 
;Expected results:  
 
;Expected results:  
 
;Knowledge prerequisite: Strong background in Javascript
 
;Knowledge prerequisite: Strong background in Javascript
 
|-
 
|-
!valign=top | [[File:Dimensions-icon.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Dimensions JS||valign=top width="15%" | and Walter Bender||align=left valign=top|
+
!valign=top | [[File:Dimensions-icon.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Dimensions JS||valign=top width="15%" | Walter Bender||align=left valign=top|
;Brief explanation:
+
;Brief explanation: Port of Dimensions.
 
;Expected results:  
 
;Expected results:  
 
;Knowledge prerequisite: Strong background in Javascript
 
;Knowledge prerequisite: Strong background in Javascript
 
|-
 
|-
!valign=top | [[File:Spirolaterals-icon.svg|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Spirolaterals JS||valign=top width="15%" | and Walter Bender||align=left valign=top|
+
!valign=top | [[File:Spirolaterals-icon.svg|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Spirolaterals JS||valign=top width="15%" | Walter Bender||align=left valign=top|
;Brief explanation:
+
;Brief explanation: Port of Spirolaterals.
 
;Expected results:  
 
;Expected results:  
 
;Knowledge prerequisite: Strong background in Javascript
 
;Knowledge prerequisite: Strong background in Javascript
 
|-
 
|-
!valign=top | [[File:Turtle-Flags.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Flags JS||valign=top width="15%" | and Walter Bender||align=left valign=top|
+
!valign=top | [[File:Turtle-Flags.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Flags JS||valign=top width="15%" | Walter Bender||align=left valign=top|
;Brief explanation:
+
;Brief explanation: Port of Turtle Flags.
 
;Expected results:  
 
;Expected results:  
 
;Knowledge prerequisite: Strong background in Javascript
 
;Knowledge prerequisite: Strong background in Javascript
 
|-
 
|-
!valign=top | [[File:confusion.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Confusion JS||valign=top width="15%" | and Walter Bender||align=left valign=top|
+
!valign=top | [[File:confusion.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Turtle Confusion JS||valign=top width="15%" | Walter Bender||align=left valign=top|
;Brief explanation:
+
;Brief explanation: Port of Turtle Confusion.
 
;Expected results:  
 
;Expected results:  
 
;Knowledge prerequisite: Strong background in Javascript
 
;Knowledge prerequisite: Strong background in Javascript
 
|-
 
|-
!valign=top | [[File:confusion.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Beyond Flashcards: Programming to ReadJS||valign=top width="15%" | and Walter Bender||align=left valign=top|
+
!valign=top | ||valign=top width="15%" style="background:#e3e4e5;" |Image Viewer JS||valign=top width="15%" | Walter Bender||align=left valign=top|
;Brief explanation:
+
;Brief explanation: Port of Image Viewer (including image processing package)
 
;Expected results:  
 
;Expected results:  
 
;Knowledge prerequisite: Strong background in Javascript
 
;Knowledge prerequisite: Strong background in Javascript
 
|}
 
|}
  
 +
== Web Technology ==
 +
 +
Sugar is based on the Python programming language. A major new emphasis is on web techologies: HTML5, CSS, and Javascript. There is a need to help
 +
our users learn these technologies.
 +
 +
{| border=1 cellpadding=3 style="border: 1px solid white; border-collapse: collapse; background: #e3e4e5;"
 +
|-style="background:#787878; color: white;"
 +
!  !! Title !! Mentor !! Project
 +
|-
 +
!valign=top | [[File:GSOC_Browse.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Web Confusion||valign=top width="15%" |Tony Anderson||align=left valign=top|
 +
Create a representative set of web pages as challenges to learners who are developing skills in HTML and CSS. The idea is comparable to Turtle Confusion
 +
which provides a set of figures to be created using TurtleBlocks. The web pages should not require Javascript. Creative use of images, audio and video should be encouraged (users have access to a camera and microphone and so can create media).
 +
 +
Pre-requisite:
 +
* Good knowledge of HTML and CSS and creative design skills
 +
|}
 +
{| border=1 cellpadding=3 style="border: 1px solid white; border-collapse: collapse; background: #e3e4e5;"
 +
|-style="background:#787878; color: white;"
 +
!  !! Title !! Mentor !! Project
 +
|-
 +
!valign=top | [[File:GSOC_Browse.png|90px|thumb|center]] ||valign=top width="15%" style="background:#e3e4e5;" |Interactive Javascript Shell||valign=top width="15%" |Tony Anderson||align=left valign=top|
 +
 +
There are many online tools that allow the user to type in javascript and then immediately run it. This is very useful in teaching a language.
 +
Research available tools and their design, create an open source tool which can be run from an offline host (e.g. school server) or on the XO to support user learning of Javascript.
 +
 +
 +
Pre-requisite:
 +
* Good knowledge of javascript
 +
|}
 
==Subpages==
 
==Subpages==
 
{{Special:PrefixIndex/{{PAGENAMEE}}/}}
 
{{Special:PrefixIndex/{{PAGENAMEE}}/}}

Latest revision as of 20:33, 18 March 2015

Students: See our guide on how to participate in Google Summer of Code for more information.

Project candidates

In the table below is a list of projects potential participants might contribute to in the GSoC program.

Note 0
These are project ideas from Sugar Labs contributors. Students, feel free to propose your ideas as well.
Note 1
We are focusing on the Javascript components within Sugar this summer. It means that you've got to write activities for Sugar Web and Sugarizer. More information: on Sugar Web [1][2] and on Sugarizer [3]
Note 2
Potential mentors, please feel free to add ideas to this list. Also, feel free to add your name to a project you'd be willing to co-mentor.
Note 3
Potential students, more project ideas can be found on our Features page.
Note 4
Accepted projects are in Green

Sugar Core

Title Mentor Project
Git logo.png
Git backend Martin Abente Lahaye and Walter Bender
Brief explanation
The Sugar Journal doesn't do a great job of supporting versioning or forking. This project is to build a backend for the Journal that is based on git, which does support versioning and forking. By building on top of a git hosting site we get the added benefit of network access as well.
Expected results
Working code and an integration with Turtle Blocks
Knowledge prerequisite
Strong background in Git and scripting languages such as Python, Ruby and JavaScript.
Cordova sugar.png
Cordova/PhoneGap container for Sugar Puneet Kaur and Lionel Laské
Brief explanation
Making cordova plugins for sugar and demonstrating the working plugins via sugar activities, incooperating cordova plugins with the existing sugar activities visit : http://sugarcordova.blogspot.com/ for more info
Expected results
Working Demonstration of new plugins and new activities based on implemented plugins
Knowledge prerequisite
Strong background in JavaScript,python
Performance tuning on machines with limited memory Samuel Greenfeld and James Cameron
Brief explanation
The newer Sugar builds have performance issues on some old hardware with limited memory. This is keeping some Sugar deployments from upgrading. This project is to look into the performance issues and tune Sugar for low-memory devices.
Expected results
build suitable for running on OLPC XO-1 hardware
Knowledge prerequisite
Re-design collaboration with web technologies Martin Abente Lahaye and Walter Bender
Brief explanation
Now that JavaScript has become a first class citizen in the Sugar ecosystem, we must re-design our collaboration model to allow collaboration between web activities regardless of the platform.
Knowledge prerequisite
JavaScript, web sockets, web services.

Sugar Activities

Title Mentor Project
Turtlejs.png
Turtle Blocks 3D Javascript Tony Forster and Walter Bender
Brief explanation
The Python version of Turtle Blocks 3D is based on GTK since Sugar uses GTK and GTK is largely incompatible with OpenGL. In a Javascript version, we could use OpenGL and take advantage of many more graphics libraries, such as 3D lighting models and texture mapping.
Expected results
A new Turtle Blocks spin that adds basic 3D transforms to Turtle Blocks (e.g., setxyz, pitch, roll, yaw); camera and lighting models; surface texture mapping; and a rich set of example projects.
Knowledge prerequisite
Strong background in Javascript
Turtlejs.png
Turtle Blocks export as Javascript Walter Bender
Brief explanation
The Python version of Turtle Blocks allows the user to export their project as Python code. We need an equivalent Javascript export for the Javascript version.
Expected results
Working code integrated into Turtle Blocks JS
Knowledge prerequisite
Strong background in Javascript
Turtlejs.png
Turtle Blocks inline Javascript Walter Bender
Brief explanation
There are several block-based programming environments that allow the user to extend the language in line, such as Blocky and Pencil Code. (Turtle Blocks uses plugins for this, but they are imported). The goal of this project is to write an in-line block editor for Turtle Blocks (Javascript version).
Expected results
Working code integrated into Turtle Blocks JS
Knowledge prerequisite
Strong background in Javascript
Turtlejs.png
Turtle Blocks debugging tools Cynthia Solomon and Walter Bender
Brief explanation
There are several debugging tools in Turtle Blocks: the ability to set breakpoints, step through code, and inspect variables. But we could use a more comprehensive approach, including a mechanism for tracking progress over time.
Expected results
Working code integrated into Turtle Blocks JS
Knowledge prerequisite
Strong background in Javascript
Turtlejs.png
Turtle Blocks for in-line programming Gonzalo Odiard and Walter Bender
Brief explanation
Often we'd like users to be able to extend or modify an activity. Rather than doing this by writing Python or Javascript, why not let them use the block language of Turtle Blocks as an in-line editor. For example, in the Turtle Pond activity, the user can upload Python code representing search algorithms for the turtle as it tries to find its way out of the pond. Why not use a block editor to write the search algorithm? Using the Turtle Blocks engine as an editor inside existing activities would be the preferred mechanism, as oppose to constantly extending Turtle Blocks itself. This would (1) let the editor be more specific to the needs of the individual activity; (2) lessen the burden on the user for installing plugins and extensions; (3) circumvent situations where there are barriers to sharing data between activities -- e.g., running outside of Sugar; and (4) perhaps encourage more developers to incorporate more programmatic elements in their activities.
Expected results
Integration into the Physics Activity
Knowledge prerequisite
Strong background in Javascript/Python
Mouse-music.png
Music Blocks Devin Ulibarri
Brief explanation
Using a framework similar to Turtle Blocks Javascript, build a suite of music tools for introducing the basic concepts of scale, beat, chord, phrasing, sequencing, transformations, etc. See some of Devin's sketches at [4].
Expected results
Working code
Knowledge prerequisite
Strong background in Javascript
Confusion.png
Beyond Flashcards: Programming to ReadJS and Walter Bender
Brief explanation
Back in the 1980s, IBM had a literacy program, "Writing to Read". The gist was that writing was a great way to spark a child's interest in reading. What if writing code could achieve a similar result? The project is to explore how programming might be incorporated into a literacy program. Like turtle, only simple sentences instead of stacks. It would be a "whole word" approach rather than a "phonics" approach: they can take "sentences" and make paragraphs that result in animations.
Expected results
Working prototype
Knowledge prerequisite
Strong background in Javascript
Covert Record, Clock, Speak and Measure to gstreamer 1.0 <TBD>
Brief explanation
The vast majority of Activities that use gstreamer for sound have been converted to gstreamer 1.0 because the older 0.10 is now End of Life and is no longer being developed. It also adds quite a large set of extra duplicate dependencies to Sugar distributions. There's a lot of good examples of Activities that have been converted to provide excellent examples. The gstreamer 1.0 bindings are provided by gobject-introspection so it also assists in the conversion of Activities to gtk3.
Expected results
As many of the above Activities converted to use gst 1.0
Knowledge prerequisite
Strong background in python, gobject-introspection and gstreamer
Covert TamTam to Csound6 <TBD>
Brief explanation
TamTam makes extensive use of CSound, other Activities like Memorize, Pippy, and TurtleBlocks also can make use of CSound bindings. With the introduction of CSound 6 to a number of distributions TamTam needs migration to use the newer version of CSound.
Expected results
Convert TamTam to use CSound6, possibly other Activities
Knowledge prerequisite
Strong background in python, background in CSound
Modernise Etoys Activity <TBD>
Brief explanation
Etoys hasn't been updated for some time to newer Sugar APIs and design. Improve the Sugar Etoys Activity to no longer depend on the long obsolete sugar-presence-service and generally update it to more modern Sugar design and APIs.
Expected results
Modernise Etoys Sugar Activity
Knowledge prerequisite
Strong background in python

Sugar Activities (Ports)

These are existing Python activities we'd like to see ported to JavaScript. In porting we expect that the activities will take on new UI features and pedagogical significance.

Title Mentor Project
Gsoc2015 llaske.svg
Sugar Web Basic Activity Set Lionel Laské

Using Sugar Web Framework - the JavaScript Framework for Sugar - you will have to develop and enhance basic Sugar activity set including activities: Calculate, Paint, Memorize and Record. All activities should use Sugar features (specific UI, journal and collaboration) and should work both on Sugar/Fedora and Sugarizer/Web. Pre-requisite:

  • Good level on HTML5/JavaScript and knowledge of frameworks to handle Canvas objects.
  • Knowledge of PhoneGap/Cordova
  • Understanding of Python
  • Good capacity to do reverse engineering on existing code.

More information: Sugar Web [5] [6], Sugarizer [7], Calculate [8], Paint [9][10], Memorize [11][12] and Record [13].

Abacus.jpg
Abacus JS Walter Bender
Brief explanation
Port of the Abacus activity.
Expected results
Knowledge prerequisite
Strong background in Javascript
Fototoon.png
Fototoons JS Gonzalo Odiard
Brief explanation
Port of Fototoons.
Expected results
Knowledge prerequisite
Strong background in Javascript
Activity-physics-55x55.png
Physics JS Walter Bender
Brief explanation
Port of Physics.
Expected results
Knowledge prerequisite
Strong background in Javascript
Dimensions-icon.png
Dimensions JS Walter Bender
Brief explanation
Port of Dimensions.
Expected results
Knowledge prerequisite
Strong background in Javascript
Spirolaterals-icon.svg
Spirolaterals JS Walter Bender
Brief explanation
Port of Spirolaterals.
Expected results
Knowledge prerequisite
Strong background in Javascript
Turtle-Flags.png
Turtle Flags JS Walter Bender
Brief explanation
Port of Turtle Flags.
Expected results
Knowledge prerequisite
Strong background in Javascript
Confusion.png
Turtle Confusion JS Walter Bender
Brief explanation
Port of Turtle Confusion.
Expected results
Knowledge prerequisite
Strong background in Javascript
Image Viewer JS Walter Bender
Brief explanation
Port of Image Viewer (including image processing package)
Expected results
Knowledge prerequisite
Strong background in Javascript

Web Technology

Sugar is based on the Python programming language. A major new emphasis is on web techologies: HTML5, CSS, and Javascript. There is a need to help our users learn these technologies.

Title Mentor Project
GSOC Browse.png
Web Confusion Tony Anderson

Create a representative set of web pages as challenges to learners who are developing skills in HTML and CSS. The idea is comparable to Turtle Confusion which provides a set of figures to be created using TurtleBlocks. The web pages should not require Javascript. Creative use of images, audio and video should be encouraged (users have access to a camera and microphone and so can create media).

Pre-requisite:

  • Good knowledge of HTML and CSS and creative design skills
Title Mentor Project
GSOC Browse.png
Interactive Javascript Shell Tony Anderson

There are many online tools that allow the user to type in javascript and then immediately run it. This is very useful in teaching a language. Research available tools and their design, create an open source tool which can be run from an offline host (e.g. school server) or on the XO to support user learning of Javascript.


Pre-requisite:

  • Good knowledge of javascript

Subpages