Translation(s): none

Diaspora packaging

This page will be used to store available information and links which will help to build diaspora and its dependencies for Debian. You can find instructions to test the current version of package from here.

We hang out at #debian-diaspora (on OFTC), so come there if you have any questions.

Regular meetings will take place every Saturday and Sunday at 21:00 IST


  1. Why do you have to package diaspora? -

  2. What does packaging Diaspora for debian mean? -

  3. Why do you have to package all the gems? Can't you use rvm? -

Current status



Note: Feel free to improve these steps/notes. Add links to more documentation when anything is not clear.

Step 0 - Introduction

Diaspora is written in Ruby language using Rails framework. Diaspora uses many existing ruby libraries and these libraries are distributed as gems. So we need to package all depending gems to package diaspora.

Though rubygems itself is a package familiar with ruby developers, we want to provide single method via debian tools (apt/synaptic/software center) for debian users, similar to software written in every other language, so they don't have to learn how each language community distributes their packages.

If you are familiar with C programming you would know the first line of most C programs,

#include <stdio.h>

stdio.h is provided by the standard C library (glibc in most GNU/Linux distributions). It provides functions like printf and scanf. Similarly in Ruby, libraries are included by a line like,

require 'rspec'

It means that particular Ruby program (.rb file) can now use functions provided by rspec library (similar to how you use printf and scanf functions in your C program).

Try installing a gem and see if ruby can find it

gem install vegas
gem list
require 'vegas'

You should see 'true' as output. Press control+d to exit from irb.

Step 1 - Select a Gem

Choose a gem to package from latest pdf file from (it has a graph of all dependencies for diaspora). If it has a dependency select that first.

  1. Check if it is already packaged in debian. Search for the package from

  2. Check if it is already being worked on by someone else from

    Note 1: Remember to select ITP from the list and give your gem name as project

    Note 2: Debian package names uses '-' instead of '_', prepended with ruby-, unless it is an application (in opposition with libraries, ex: cucumber, rake)

Step 2 - Build a debian package

Simple package

See Initial Build with gem2deb

More complicated cases

  1. ruby tests - make sure you run the tests

  2. basic quilt - if you want to change any upstream files

Clean build

See sbuild or pbuilder - make sure it builds cleanly (to check it has correct build dependencies)

ruby-team/meta scritps can be used to run sbuild, autopkgtest. It also allows you to run autopkgtest of all reverse dependencies and rebuild all reverse build dependencies when updating a package.

Step 3 - tell others about your work

See ITP - say you're going to package something

Step 4 - Get your package reviewed and uploaded

  1. salsa - push the code into debian's gitlab instance

  2. upload to mentors - upload it to mentors for sponsors (we usually take directly from git, so this step is not directly required, but is good for you to learn as it applies to a new package in general, you'll need this when you want to upload a package outside this team)

  3. RFS - request a sponsor to upload your package to debian


  1. Getting packages in NEW queue - when some dependencies are waiting to enter archive in NEW

  2. Updating existing package to New upstream Release

  3. build scripts used by ruby team - helps testing reverse dependencies easily

  4. git and git-buildpackage commands

  5. building packages for experimental

  6. unsorted tips

  7. setting up an environment for building packages - especially a quick-start guide for the ruby folks who want to help with tests and don't want to bother much with packaging part

  8. how to deal with changes in source tarball itself outside of patch/quilt - say you want to take github tarball or you want to remove vendor directory

  9. Backporting to Jessie

  10. Import new diaspora release