recruiting sourcepeople.redhat.com/yamato/talks/recruitingsource.pdf · attracts many developers...
TRANSCRIPT
Recruiting Source
Masatake YAMATOTranslated by Ryoko YAMATO
Special Form of Software Development MethodUsed in XTLA
Ideal Open Source Development● Attracts many developers and users, which leads
to the project growth.● Ideal growing cycle:
1.First, source code is open to public.
2.Developers begin to join the project.
3.Functions and quality are improved.
4. Increase in the number of users catches the eyes of other developers.
5.More developers will join the project.
6.More users, as a result.
Open Source Development in Reality● Too many projects for the number of developers on
earth. – The number of developers per project will not increase.– The number of users per project will not increase either.– Another similar project to be started by others; since the
existence of the initial project is hardly known to people.– Similar projects fight over developers and users.– Each similar project is likely to remain imperfect.
● The whole category, which these projects belongs to, might fade.
Ideal Project
Project leader
Developers
Users
Deadend Project
Project leader = Developer = User
Ideal Category
Project A
Project B
Project C
Mutual growth by competing each other
Deadend Category
● Users can't easily see which one is the best to try. ● Many projects are not ready for practical use.● Developers can't see which project they should compete with.
Deadend Category
Even if you start another project to overcome the situation, your project will be hardly recognized in too many projects.
Example of Deadend Category : IDE
In case you don't know Eclipse, you have to check all 519 projects.
Example of Deadend Category : IDE
No more subdirectory here. You have to browse 26 pages.
March 11, 2004In the category of "Emacs Frontend for
GNU Arch"
Three projects were already in this niche category.This category is destined for deadend, too?
What can be done ?
tla.elMilan Zamazal
tilly.elMartin Pool
xtla.elStefan Reichör
Outline
● Open Source Development method, in which you make source code open to public and wait for developers and users coming to you, cannot be a solution to prevent a category from becoming "dead end."
● Proposal for "Recruiting Source Development(RSD)" method where you invite other project members who already have their assets (experience, source code) to work together.
● Reporting the growth of XTLA project to which RSD was applied.
To be covered in this presentation:● Supportive software in this project
– GNU Arch– QuickML
● Process of XTLA development● Recruiting Source Development method
Supportive software in RSD
Distributed version control systemGNU Arch
CVS
Repository
developer developer developer
install
modifications
Arch
developer developer developer
exchange modifications
Archive
Distributed version control systemGNU Arch (cont’d)
● No permission is needed to make a branch.● Easy to create a mirror archive to publish your branch.● Development at your own pace.
– Little interference from others.– Cause little trouble to others.
● Relation to XTLA– XTLA covers up complex command line interface of Arch.– Source code of XTLA itself is managed in Arch archives.
Lightweight mailing list systemQuickML
● Run at QuickML.com ● Management tasks such as
creating mailing lists and adding members can be done by just sending a mail.
Subject: meetingTo: [email protected]: [email protected]: [email protected], [email protected]
● Anyone in the mailing list can invite other people to the list.
Subject: add membersTo: [email protected]: [email protected]: [email protected]
Development process of XTLA projectThe first three months
Why XTLA?● I have been interested in distributed version control system
since the failure to have gscjk patch merged to Ghostscript.● I really liked pclcvs, the Emacs frontend to CVS.● There had already been three projects of frontend
development, so I did not think of starting another one by myself.
● After tring tla.el, tilly.el, and xtla.el, I found out xtla.el was the closest to what I was looking for.
● The author of xtla.el (hereafter Stefan) was also a developer of psvn, a Subversion interface for Emacs.
First contact● I wanted an Emacs frontend as soon as possible.● To avoid this category from falling into deadend, I decided to
take part in one of the projects.● xtla.el looked the most promising.● March 15, 2004: Sent my selfintroduction by email to
Stephan. His reply was "contribution welcome." I could get a feeling for his personality from his email.
● March 18 : Sent my first patch to show my enthusiasm. Stefan merged it on that day and released the new version.
Mailing List started● March 21: Stefan requested savannah.gnu.org to register our
project. Screening process was delayed. ● April 10 : Launched a mailing list at QuickML.com as a
temporary one.– Stefan, Matthiew Moy, and I became the ML member.– So far, XTLA project had three times as many developers
as the other two frontend development projects did.● (March 15 : Matthiew had already made a contribution to
XTLA)
Distributed development for XTLA by XTLA● (Since Stefan had not set up an archivemirror for managing
XTLA source code yet, the rest of two sent patches by emails.) ● All of three set out to open each one’s archivemirror to public
from April 8, and finished it by April 15.● Various XTLA functions needed for distributed development
were implemented one after another.
– Setting up mirrors– Picking up changesets from other repositories.
● XTLA became the tool to develop XTLA itself.
Recruiting developers● How can we have more, skilled developers in our project?● Is there anyone who wants Emacs interface for GNU
Arch, can use Emacs lisp, and knows about GNU Arch?● April 19: Sent an email to the author of tla.el, Milan
Zamazal, to ask if we could work together. He accepted our offer, and was added to the mailing list.
● April 21:Matthiew sent an email to the author of tilly.el, Martin Pool. Here again, his reply was "yes" and he joined the mailing list.
Using web search results for recruiting developers● Obtaining resources (developers, source code, knowhows) by just
sending a mail! Getting a taste of success, I used Google web search to look for developers. Keywords: tla frontend emacs xtla
● May 8: Contacted with the author of xxx.el(anonymous), Mr. Foobar(anonymous). But it was unsuccessful.
● May 16 : Succeeded in recruiting the author of mstarch.el, Mark Triggs.
● May 17 : Matthiew invited Christian Neukirchen, the author of nbbba.el. He showed his interest, but he was not active in coding.
May 17, 2004The category of
“Emacs frontend for GNU Arch"
xxx.elMr.Foobar
XTLA
Stefan ReichörMatthiew Moy, Martin Pool, Mark Triggs, Robert WidhopfFenk*,
Masatake YAMATO, Milan Zamazal
The developers of XTLA enriched this niche category.*Joined to XTLA without being recruited.
After that...● Enough developers that we wanted to have agreed to
merge their code and work together, so there was no need to recruit another any more.
● The end of April 2004: Set up the project at gna.org. Gradually went back to Open Source development style.
● May 24, 2005 : Version 1.0 was out.
Recruiting Source Development Method
Recruiting Source Development (RSD)● A Special form of Open Source Development(OSD)● Taking action to recruit developers, not just waiting
for them to join the project.● From "to be chosen" to "to choose"
– OSD: People decide whether to join or not by evaluating publicly available source code and its project theme.
– RSD:WE decide whether to recruit him/her for our project by evaluating his/her source code and project theme.
Selection of developers
● Do they have enough knowledge and skills in the area? (example: Emacs lisp, GNU arch)
● Can they share the development goals with you? (in this case: Did they know about pclcvs and want to develop a similar project?)
● Are they willing to cooperate in order to achieve the goal as soon as possible?
When contacting to a prospective developer*
● Carefully review the developer's work, and clearly explain to him/her the significance of merging.
● However, do not put so much pressure on that developer.
*From the interview with Mr. Foobar
After recruiting ● Encourage the recruited person to develop actively.● Recruiting activity should not be timeconsuming for
recruiters.● Helpful software:
– QuickML: Easy to use, and it provides a smooth process from recruiting to inviting a prospective developer to the mailing list.
– GNU Arch● Developers can work at their own pace.● Developers can look into peer's work very easily.
Conditions to apply RSD● Members agree that they want their products to be used
by many people, and provide it as soon as possible.● The category should be young (not mature).
– RSD works well only among young projects.– Offer to merge from mature project to young project threat.→
– Offer to merge from young project to mature project ridiculous→
● Members share the development goal.– When recruiting, it is easy to communicate using proper words.– Development speed may differ, but all developers look at the
same direction.
Conclusion and future issues● Recruiting Source Development was proposed. ● The development process of XTLA was
introduced as the project managed by RSD method.
● RSD method is not a perfect solution to the whole “deadend” category problem. However, I would like to raise the awareness of this problem and introduce this method to the world.
Acknowledgments
The author would like to express his thanks to...● Shigeru AOSASA who encouraged me to publish
the idea of RSD.● XTLA developers who gave me a chance to go
through this advanced development process. ● Mr. Foobar who agreed willingly to be
interviewed by the author.