Ceibal Jam/Aplicaciones

From OLPC
< Ceibal Jam
Revision as of 10:27, 28 May 2008 by Geirea (talk | contribs) (<tt>setup.py</tt>)
Jump to: navigation, search

(Información preliminar, en el correr de los días voy a poner algo más elaborado. Geirea)

Objetivo

Se buscó responder a las siguientes interrogantes:

  • ¿Es posible instalar aplicaciones propias en las XO del Plan Ceibal como un usuario común?
  • ¿Cómo se empaqueta una aplicación para ser instalada en la XO?
  • ¿Cómo se define el icono de una aplicación para que aparezca igual que el resto de las actividades?
  • ¿Existe alguna forma fácil e independiente de distribuir nuestras aplicaciones entre los niños?

Estructura básica de una actividad

Al iniciar Sugar, las aplicaciones (actividades en la nomenclatura de OLPC) se buscan en dos directorios:

  • /usr/share/activities
  • /home/olpc/activities

El primero de ellos no puede ser modificado por el usuario; es necesario tener password de root, que en las laptops de OLPC no es conocido por el usuario. El usuario por defecto es llamado olpc, entonces el segundo directorio de la lista es el directorio home del usuario en el cual sí se pueden escribir y modificar archivos. Es en este último donde se pueden instalar las actividades que el usuario desee.

Usaremos como ejemplo una actividad de nombre Prueba. Las actividades se instalan en una estructura de directorios (debajo del directorio /home/olpc/activities/) como la que sigue:

Prueba.activity/
Prueba.activity/prueba.py
Prueba.activity/setup.py
Prueba.activity/activity/
Prueba.activity/activity/activity.info
Prueba.activity/activity/activity-prueba.svg

Donde:

  • prueba.py contiene el código principal de la actividad definido dentro de una clase en Python, pudiendo haber otros archivos con más código en el mismo directorio
  • setup.py contiene un código muy simple que sirve para que Sugar realice la instalación de la actividad
  • activity/activity.info es un archivo de texto que contiene la información básica de la actividad
  • activity/activity-prueba.svg es el icono de la actividad

A continuación se describe en mayor detalle cada uno de estos archivos.

prueba.py

Este archivo contiene el código principal de la actividad, que debe formar parte de una clase que hereda de sugar.activity.Activity. A continuación se muestra un ejemplo de cómo hacer esto.

# prueba.py
# ejemplo de como escribir la clase principal de la actividad
from sugar.activity import activity
class prueba(activity.Activity):
    def __init__(self,handle):
        activity.Activity.__init__(self,handle)
        # aca va el codigo de la aplicacion
# fin de prueba.py

En este ejemplo vemos:

  1. se importa la clase activity de la biblioteca sugar
  2. se define una clase prueba que hereda de activity.Activity
  3. en el constructor de dicha clase se llama al constructor de la clase madre (esto es típico de Python, el constructor debe ser llamado explícitamente)

setup.py

Este archivo es utilizado por Sugar para inicializar la actividad. El código debe ser el siguiente.

# setup.py
from sugar.activity import bundlebuilder
bundlebuilder.start("prueba")
# fin de setup.py

activity/activity.info

activity/activity-prueba.svg

Archivos auxiliares de una actividad

También se recomienda incluir otros archivos, aunque en la práctica se comprobó que no son estrictamente necesarios. Los archivos adicionales son:

Prueba.activity/NEWS
Prueba.activity/TODO
Prueba.activity/MANIFEST
Prueba.activity/locale/

Donde

  • NEWS es un archivo de texto donde se deja constancia de las sucesivas revisiones de la actividad, las cosas que se incluyeron, que se modificaron, etc.
  • TODO es un archivo de texto donde se escriben las cosas que quedan pendientes realizar
  • MANIFEST es un archivo de texto que contiene la lista de archivos contenidos en el paquete de la actividad
  • locale/ es un directorio donde se incluye información para traducir la aplicación a distintos idiomas

Empaquetado de una actividad

Conclusiones

Se concluye que sí es posible instalar aplicaciones propias en las XO del Plan Ceibal sin necesidad de tener usuario root y sin obstáculos que podrían ser firmas digitales, etc.

La aplicación se instala en el directorio /home/olpc/Activities, siguiendo una estructura de directorios sencilla. La rutina principal de la aplicación debe incluirse en un archivo Python, como parte de una clase que hereda de la clase Sugar.Activities. Se deben además crear una serie de archivos auxiliares con un formato de texto muy sencillo. El icono de la actividad debe ser en formato svg; si se quiere que titile como los iconos de las actividades estándar, se debe retocar el archivo con un editor de texto para definir los colores en concordancia con la interfaz Sugar.

Toda la estructura de directorios se puede empaquetar en formato tar.gzip y renombrar con extensión .xo. Cuando la actividad Browse baja un archivo con dicha extensión de una página web, realiza la descompresión e instala la actividad automáticamente.

Se concluye que es posible entonces empaquetar nuestras actividades, subirlas a una página web, y que después los niños puedan bajarla e instalarla automáticamente.