Jump to: navigation, search


2,440 bytes added, 01:31, 19 December 2016
GSoC Meetings
== The Karma Project ==
Karma is a framework for creating educational software using JavaScript, html5, and SVG. The Karma team is primarily focused on developing Sugar activities using Karma but it you can also be used outside of SugarKarma to create lessons that run in any web browser that supports html5. The best ways to get involved are to join the [ mailing list] and [ get the code]
=== Rationale ===
=== Status ===
Karma is a sub-project of Sugar Labs that is under active development as a part of a [[Karma#GSoC_Project| Google Summer of Code project]]. The latest examples can be seen at []. You can also check out the [ Karma Project blog] for updates.
To try out the karma examples you need to have an html5-capable browser. The Browse activity within Sugar does not currently support html5. To try out karma within Sugar you need to install [ Surf] and its webkit dependencies or run Firefox 3.5 from the command-line (yum install pywebkitgtk WebKit-gtk gnome-python2-gconf).
The current focus of development is to convert Nepal's set of lessons coded in Squeak smalltalk. You can find the list of lessons to be converted [ here]. This is a good place for new contributors to get started
=== What Karma Is ===
* Moodle Integration -- method to be determined
* [[Karma/Bundle_layout|Repo and Bundle layout]]
* UI Widgets
** [[Scoreboard]]
** Dialog -- use standard jQuery UI one?
=== Conventions ===
* The [[Karma/Dictionary|Karma Dictionary]]
* [[Karma/Specifications|Karma Specifications]] (early draft)
* [[Karma/Anti-conventions|Anti-Conventions]] -- coding no-nos* [[Karma/Layout_Converted_Squeak_Lessons|Layout for converted Squeak Lessons]]* Source Code stored in* Working demos at http://karma.sugarlabs.orgEach lesson must be in a folder named according to the schema "karma_Grade_Maths_title_WeekNo" where the week number is optional The following are valid names karma_3_Maths_LargestNumber_15 karma_2_English_MatchingPuzzle karma_6_Maths_AddingUpTo10_4* Version Control and repository management see the [[Karma#Version_Control|Version Control]] section of this page* Unit tests testing is required for the karma.js library but not for individual lessons
* Project Documentation kept in the Sugar Labs wiki
* Coding conventions: Based on [ Dojo Style Guide]
** Use camel-case sadCamelCase for function names and variables
** Exception to above -- object constructors should start with a capital letter
** Set column-width to 79 characters (from Python standard practice)boolean variables should be prefixed with "is", "has", "can", or "should"** counters should be prefixed with "num" or "count"** Whenever possible, use [http://www.jslint and then teach the rest of us how** Anything Doug Crockford advises in "JavaScript: The Good Parts".com/ jslint]
* File naming conventions: lowercase letters, underscore instead of spaces (need to write more about it)
* Coding Pattern - We generally try to follow this coding pattern as it makes it easier to browse your code
Put code in following order
1) variable declarations
2) method declarations
3) method calls
== Version Control ==
Currently all lessons are stored in the examples/ folder of [ main karma repository]
Here is how you can use the karma_lesson template to create a new repository from scratch
$ git clone git://
$ mkdir ../karma_3_English_3 # create a new lesson directory following our naming convention
$ cp -r * ../karma_3_English_3
$ cd ../karma_3_English_3
$ rm -r .git # make sure you get rid of the old git directory
$ git init
$ git add .
$ git commit -a -m "first commit"
Now go to the, make sure you are logged in
Create a new project, use the same name as you did for your lesson's main folder
$ git remote add origin git://... # the pubic push url
Then on to coding your lesson ;)
From then on
$ git push origin master # will sync your local tree w/ the server
'''Tagging''' -- a karma lesson can be in only one of two states, stable or unstable. Any commit tagged 'stable' is the stable version of your code. Every other version of your code is unstable. We will not use numeric versioning such as 0.1, 1.0, 1.2, etc. for the foreseeable future.
== Meetings ==
[[Karma:Meeting 21 December 2009]]
== GSoC Project ==
Karma started as a GSoC project with Felipe Lopez Toledo "SubZero" as the student participant and [[USER:BryanWB| Bryan Berry]] as mentor.
=== GSoC Meetings ===
Notes from GSoC meetings - kept for archival purposes
* [[Karma:Meeting 14 Sep 2009]]
* [[Karma:Meeting 21 Sep 2009]]
* [[Karma:Meeting 21 December 2009]]
=== Roadmaps =Project Roadmap ==
==== 0.1 "Osito" ====
==== 0.2 "Gatito" ====
Due Completed mid-December 2009 This release is timed to coincide with Bryan's visit to Google HQ for the GSoC Mentor's Summit
* unit testing added to karma.js using QUnit -- DONE
* API documented w/ jsdoc-toolkit
* support for SVG and canvas animation -- DONE
* 3 working examples
** Adding_Up_to_10 using both SVG and canvas -- DONE** Quadrilaterals -- 50% done
** "Conozco A Uruguay" done with karma -- 50% done
==== 0.4 3 "niño" ====
Due 31 January March 2010
* Full i18n support
* All Squeak lessons converted to Karma
* Integrate all of the existing E-Paath lesson into chakra
* narwhal build script to build one giant karma bundle w/ all the E-Paath lessons inside it and chakra
* Version 0.1 draft of karma specification done
==== 1.0 "Muchacho" Future Direction of Karma ====
This release may also be called "Karma 1000" and is a big wishlistNo schedule yet.
* Full moodle integration* Offline storage and synchronization with moodle* Integration with the Sugar Journal* Integration with Telepathy on Sugar* fully functional "kpages"[[Karma/Future Direction|This page]] has more information.
=== Library ===
Coding Tools and Conventions
* Venkman -- javascript debugger
* Firebug ---
* Web-Inspector --- webkit's answer to firebug
* Browsers --- We primarily work with Chromium and Firefox > 3.5
* For emacs users -- nxhtml mode and magit.el for working w/ git
* [ jslint]
* [ inkscape]
* [ narwhal]
== Subpages ==

Navigation menu