Difference between revisions of "User:Mm Alder/SLDev Open Source Viewer"
(20 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
=What is the SLDev Open Source Viewer?= | =What is the SLDev Open Source Viewer?= | ||
==Second Life is Open Source!== | |||
According to [https://blogs.secondlife.com/community/technology/blog/2009/03/30/intensifying-open-source-efforts the announcement from Linden Lab] | |||
"Our hope is that we can create a widely-used openly developed version of the Second Life client which is a compelling alternative for a broad set of users, and contains enhancements and development that then rapidly make their way back into the mainstream Second Life version." | |||
Translated, that means it's how you, the open source developer, get your code into the Second Life viewer. | |||
==What's in the SLDev viewer that's not in the official viewer?== | |||
See [[SLDev Viewer Current Cycle]] for the latest news on what's happening this release cycle. | |||
==Some History== | |||
===Second Life is Open Source!=== | |||
In January, 2007 Linden [https://blogs.secondlife.com/community/features/blog/2007/01/08/embracing-the-inevitable opened the source] for the Second Life viewer and many residents began to [[Participating|contribute code]] to improve or otherwise extend the functionality, reliability, and openness of the viewer. But the code wasn't really open for mutual development between Lindens and residents. Residents got to see the source, and they could create patches to be applied to it, but they needed a Linden to actually apply that patch to the code used to build the Linden public viewer. | In January, 2007 Linden [https://blogs.secondlife.com/community/features/blog/2007/01/08/embracing-the-inevitable opened the source] for the Second Life viewer and many residents began to [[Participating|contribute code]] to improve or otherwise extend the functionality, reliability, and openness of the viewer. But the code wasn't really open for mutual development between Lindens and residents. Residents got to see the source, and they could create patches to be applied to it, but they needed a Linden to actually apply that patch to the code used to build the Linden public viewer. | ||
Line 9: | Line 23: | ||
The result was an ever increasing difficulty for open source developers to get code accepted into the published viewer. | The result was an ever increasing difficulty for open source developers to get code accepted into the published viewer. | ||
==The | ===The Nicholaz viewer, The Dale Glass viewer, Kirsten's viewer, Imprudence, and more=== | ||
Eventually, developers became impatient, and decided to publish [[Alternate viewers|their own versions of the viewer]] under the open source license granted by Linden Lab. The result was that residents came to like the alternate viewers more than the official viewer. They were faster, easier to use, had nifty new fietures, and crashed a lot less. | Eventually, developers became impatient, and decided to publish [[Alternate viewers|their own versions of the viewer]] under the open source license granted by Linden Lab. The result was that residents came to like the alternate viewers more than the official viewer. They were faster, easier to use, had nifty new fietures, and crashed a lot less. | ||
Line 15: | Line 29: | ||
Unfortunately, some of the noble developers who undertook this task, had real lives, and couldn't afford to take the time to figure out and merge in the new features published by Linden every time a new official Linden release came out. | Unfortunately, some of the noble developers who undertook this task, had real lives, and couldn't afford to take the time to figure out and merge in the new features published by Linden every time a new official Linden release came out. | ||
==Philip, Benevolent Dictator For Life== | ===Philip, Benevolent Dictator For Life=== | ||
But someone at Linden looked around and thought to himself, "If they can do it, why can't we?" | But someone at Linden looked around and thought to himself, "If they can do it, why can't we?" | ||
The Open Source Viewer is the brainchild of Philip Linden, the Chairman of the Board at Linden Lab. When Philip decided to [https://blogs.secondlife.com/community/features/blog/2008/03/14/changing-my-job give up his role as CEO], he found he had time to | The Open Source Viewer is the brainchild of [http://lindenlab.com/about/management#rosedale Philip Linden], the founder and Chairman of the Board at Linden Lab. When Philip decided to [https://blogs.secondlife.com/community/features/blog/2008/03/14/changing-my-job give up his role as CEO], he found he had time to get back to his other passions. | ||
Philip realized that developers were becoming discouraged with the difficulty they were having getting their ideas into the official viewer, and if Linden didn't do something, they would lose all interest. So he proposed that Linden follow the trail charted by Nicholaz, Dale Glass, and many others, and have their own Open Source Viewer, but with one decided advantage: he could get the latest Linden changes merged in just by decreeing (oops!) asking. | |||
And so it was. | |||
=How do I contribute to it?= | =How do I contribute to it?= | ||
==Talk to the mailing list== | ==Talk to the mailing list== | ||
Before you set off coding your great idea for Python versions of the shaders, you better ask around to see if either everyone hates your idea, or Linden is already working on it but hasn't told anyone yet, or someone else has already started a similar project and would welcome your help, or you've managed to design a mousetrap that slices bread and is a dessert topping too! | |||
The first thing you could do is to search the [[Issue tracker|public issue tracker]], also known as the PJIRA, to see if there's something similar out there. If there's nothing, or if it's just a request, then take it to the masses. | |||
All of that kind of discussion, and much worse, takes place on the [[SLDev]] mailing list. Sure there's a lot of arrogant know-it-alls on the list who will quickly belittle your wonderful idea. No, just kidding! Well, except for Mm Alder, but he's harmless. Just go for it! Everybody has to start somewhere. We've been there too. And there's plenty to do. We can use all the help we can get. | |||
==Write your code== | ==Write your code== | ||
OK, everyone loves your mousetrap. Where do you start? Well, first, post your idea to the [[Issue tracker|PJIRA]] so somebody else interested in mousetraps can find out what you intend to do. | |||
===Where do I get the source?=== | |||
Then, you have to figure out which version of the code to use as your base. You get lots of choices: the [[Source downloads|source]] for the official viewer, the source for the [[Release Candidate]], the [[Source branches|trunk]], or the [[Source branches|current SLDev project]]. | |||
If you're fixing a bug, the trunk is probably your best bet because that gets the latest code fixes. If your project might take months to develop, you should go with the source for the official viewer because it's not going to change for a while. It's a pain to have your code changes break when you do an update from the repository. You ca never tell if it's your fault or somebody else's. | |||
The official viewer changes every few months; the Release Candidate source every few weeks; the trunk and SLDev project source changes constantly. The choice is yours. Before you think about submitting it to the SLDev project, though, you will have to make a patch relative to the SLDev source code. | |||
===How do I make sense of this mess?=== | |||
Indra? Oh God! Newview? Compared to what? And H-E double-hockey-sticks everywhere! | |||
Don't despair. The [[Viewer Architecture]] is a good place to start. The [[Viewer source]] article gives you some hints about the directory structure. And [[Using Doxygen|Doxygen]] will let you breathe a sigh of relief. | |||
Just watch out for the [[Hippo]]. | |||
And if you happen to be wandering around dense murky code that has no [[documentation]] on the wiki, then Dr. Livingston, it's your duty to write about it on the wiki for the next intrepid explorer. | |||
===How do I build it?=== | |||
Nowadays people are using [[CMake]] to make solution files for the [[Microsoft Visual Studio]] integrated development environment (IDE) on Microsoft Windows, or to make project files for XCode on Mac OS X, or to generate makefiles for gcc on Linux. The [[Get source and compile|build process]] is still being developed and it's getting easier, but it still takes a bit of perseverence. | |||
===Are there any style guidelines?=== | |||
Reading the source code, you may get the impression that there is no standard style used by Linden, but in fact there is a [[coding standard]]. The existing code has been developed over many many years and can be excused for violating the standards. You will not be excused. Reading the standards before starting to code could save you a lot of editing later. | |||
===Testing...1...2...3...=== | |||
Writing code isn't just writing the lines of C++. It's also documenting the code, designing a test plan, doing the actual testing, and making sure it works in a variety of situations. | |||
You should attach the test plan in the JIRA, either directly in a comment, an attached document, or a nonvolatile link to it on the web. | |||
===Patch? What's a patch?=== | |||
Once you've written, debugged, documented, and thoroughly tested your code, it's time to [[Submitting code|publish it to the world]]. That's done by attaching a patch file to the PJIRA issue that you created way back when you started all of this. If the changes are small, you can describe what you did as a comment on the PJIRA issue. If it's a major change, create a wiki page User:(your avatar name here)/(feature name here) and put a link to it on your PJIRA issue. Then let the [[SLDev]] mailing list know about it; stand back; and accept the accolades of your peers. OK, well maybe accolades are a bit scarce these days. Enjoy the satisfaction of a job well done. You knew you weren't getting paid for this anyway. | |||
==Get your code reviewed== | ==Get your code reviewed== | ||
This is the hard part. In the past, contributors would get other residents to vote for their contributions and Linden developers would choose from among [http://www.sljirastats.com/jira_search.php?search=29 the highest vote getters]. It usually took quite a while to get through the process. | |||
Now it's first-come first-served. Add your issue to the list of [[SLDev_Viewer_Current_Cycle#Pending_merge_queue_proposals|proposed changes]] for the next release. Include the PJIRA issue title, issue number, and a link to the issue on PJIRA. Then send a note to the [[SLDev]] mailing list with this same information, asking for comments on the PJIRA. | |||
Try to keep discussions about the issue on the PJIRA, not on the mailing list. It keeps all of the comments together. Mailing list posts are very transient. Anything said there is quickly lost among newer posts. Anyone with a serious concern will take the time to read the issue before offering comments. | |||
Give people time (at least a day, maybe quite a bit more depending on the complexity of your submission and the timing) to evaluate it and comment. Then try to get one of the [[SLDev_Viewer_Development_Process#Committers_list|people who are authorized to commit code to the repository]] to look at the patch file. | |||
It is quite difficult to evaluate a code contribution just looking at a patch file and reviewers will want to be sure there are no bugs before agreeing to commit the code. | |||
Ironically, the review of code intended for an immersive collaborative virtual world uses primarily a text-based issue tracker for discussion. It is still very difficult to make visual presentations in-world and voice chat is usually considered exclusionary. So let your fingers do the talking. | |||
Keep in mind that a positive, engaged attitude on SLDev and in JIRA is likely to garner more support than a more negative approach. | |||
==Get it committed to the repository== | ==Get it committed to the repository== | ||
There is a group of committers that do have commit privileges to the [[SVN]] repository. The big difference with the "old LL way of doing things" is that this group of committers has Lindens '''and''' non-Lindens. If there is community | |||
support and a good review of the code from committers, the patch will | |||
be taken in and committed by one of the committers. Eventually, if someone does quite a bit of good contributions in line with the project, | |||
the committers will propose that that person become a committer themselves. The | |||
committers group grows by co-optation only. | |||
If someone objects (and if our community is alive, there will be | |||
someone to object...), we debate and try to reach a consensus on the SLDev | |||
list. If there's a really contentious decision to be made (split | |||
debate), Philip, our BDFL (Benevolent Dictator For Life), will weight | |||
in and make the decision. | |||
We won't have SVN wars like Wiki wars since the group of | |||
committers will be co-opted. Obviously, the committers will be careful | |||
co-opting only people who share their view and philosophy of | |||
development. If one committer would all of a sudden commit | |||
controversial patches with no respect for due debate or the general | |||
direction of the project (as decided by the BDFL), he or she'll see | |||
his/her commit rights revoked. The BDFL has full authority in that | |||
matter. | |||
==Track it through the merge process== | ==Track it through the merge process== | ||
The SLDev project is [[Source branches|branched off]] from the trunk, but is kept current with changes to the trunk by Linden developers. In order to get into the official viewer, a patch must make its way from the SLDev branch back to the trunk, which then gets branched off as a Release Candidate, and after beta testing and bug fixes, becomes the official viewer. | |||
Not all contributions will be chosen to get incorporated into the official viewer. That decision is separate from the decision to include it in the SLDev viewer. | |||
If a contribution is selected for inclusion into the official viewer, the contributor is expected to follow the code through the merge process, testing it along the way to make sure it doesn't get broken by other changes. | |||
We do hope that most of the innovations battle tested here will | |||
eventually make it to the official viewer codebase but things that are | |||
clearly not mainstream enough or not very popular with this community | |||
simply won't make it there, and that's OK. People will still be able to | |||
get those features in the SLDev viewer download. | |||
Each project (RC, maint, etc...) has its own way of ensuring quality and consistency of its project, mitigating agility vs prudence. As far as the merge back to the official viewer of contributions is concerned, that'll be up to the Linden Lab viewer team to cherry pick and merge patches/commits separately. | |||
This is not easy to do. Making this more manageable is one | |||
of the big reason for the push to hg (mercurial) for source version control. It does make merges from various sources much more easier than SVN. | |||
==Take a bow== | ==Take a bow== | ||
Every year Linden Lab offers the [[Linden Lab Innovation Awards]] to open source contributors. The categories change a bit year to year, but last year's were for Best Documentation, Best Organizer, Best Code Contribution, The Jesse Malthus Award for Best Community Influence, and Contributor of the Year. | |||
But nothing beats the feeling you get when you read on someone's blog about a cool new feature in Second Life, and it's yours! |
Latest revision as of 11:30, 10 May 2009
What is the SLDev Open Source Viewer?
According to the announcement from Linden Lab
"Our hope is that we can create a widely-used openly developed version of the Second Life client which is a compelling alternative for a broad set of users, and contains enhancements and development that then rapidly make their way back into the mainstream Second Life version."
Translated, that means it's how you, the open source developer, get your code into the Second Life viewer.
What's in the SLDev viewer that's not in the official viewer?
See SLDev Viewer Current Cycle for the latest news on what's happening this release cycle.
Some History
Second Life is Open Source!
In January, 2007 Linden opened the source for the Second Life viewer and many residents began to contribute code to improve or otherwise extend the functionality, reliability, and openness of the viewer. But the code wasn't really open for mutual development between Lindens and residents. Residents got to see the source, and they could create patches to be applied to it, but they needed a Linden to actually apply that patch to the code used to build the Linden public viewer.
In addition there were two systems for reporting bugs, fixes, and features: the public JIRA (PJIRA) and the internal Linden JIRA (just JIRA). Residents read the former and Lindens read the latter. Every now and then a Linden will comment on the PJIRA, but if you add them all up, you'd think Linden was operating out of someone's garage. There was talk of merging the two, but that never happened.
At the same time, there was a clamor from residents to fix the bugs before adding new features that nobody wanted. Like WindLight.
The result was an ever increasing difficulty for open source developers to get code accepted into the published viewer.
The Nicholaz viewer, The Dale Glass viewer, Kirsten's viewer, Imprudence, and more
Eventually, developers became impatient, and decided to publish their own versions of the viewer under the open source license granted by Linden Lab. The result was that residents came to like the alternate viewers more than the official viewer. They were faster, easier to use, had nifty new fietures, and crashed a lot less.
Unfortunately, some of the noble developers who undertook this task, had real lives, and couldn't afford to take the time to figure out and merge in the new features published by Linden every time a new official Linden release came out.
Philip, Benevolent Dictator For Life
But someone at Linden looked around and thought to himself, "If they can do it, why can't we?"
The Open Source Viewer is the brainchild of Philip Linden, the founder and Chairman of the Board at Linden Lab. When Philip decided to give up his role as CEO, he found he had time to get back to his other passions.
Philip realized that developers were becoming discouraged with the difficulty they were having getting their ideas into the official viewer, and if Linden didn't do something, they would lose all interest. So he proposed that Linden follow the trail charted by Nicholaz, Dale Glass, and many others, and have their own Open Source Viewer, but with one decided advantage: he could get the latest Linden changes merged in just by decreeing (oops!) asking.
And so it was.
How do I contribute to it?
Talk to the mailing list
Before you set off coding your great idea for Python versions of the shaders, you better ask around to see if either everyone hates your idea, or Linden is already working on it but hasn't told anyone yet, or someone else has already started a similar project and would welcome your help, or you've managed to design a mousetrap that slices bread and is a dessert topping too!
The first thing you could do is to search the public issue tracker, also known as the PJIRA, to see if there's something similar out there. If there's nothing, or if it's just a request, then take it to the masses.
All of that kind of discussion, and much worse, takes place on the SLDev mailing list. Sure there's a lot of arrogant know-it-alls on the list who will quickly belittle your wonderful idea. No, just kidding! Well, except for Mm Alder, but he's harmless. Just go for it! Everybody has to start somewhere. We've been there too. And there's plenty to do. We can use all the help we can get.
Write your code
OK, everyone loves your mousetrap. Where do you start? Well, first, post your idea to the PJIRA so somebody else interested in mousetraps can find out what you intend to do.
Where do I get the source?
Then, you have to figure out which version of the code to use as your base. You get lots of choices: the source for the official viewer, the source for the Release Candidate, the trunk, or the current SLDev project.
If you're fixing a bug, the trunk is probably your best bet because that gets the latest code fixes. If your project might take months to develop, you should go with the source for the official viewer because it's not going to change for a while. It's a pain to have your code changes break when you do an update from the repository. You ca never tell if it's your fault or somebody else's.
The official viewer changes every few months; the Release Candidate source every few weeks; the trunk and SLDev project source changes constantly. The choice is yours. Before you think about submitting it to the SLDev project, though, you will have to make a patch relative to the SLDev source code.
How do I make sense of this mess?
Indra? Oh God! Newview? Compared to what? And H-E double-hockey-sticks everywhere!
Don't despair. The Viewer Architecture is a good place to start. The Viewer source article gives you some hints about the directory structure. And Doxygen will let you breathe a sigh of relief.
Just watch out for the Hippo.
And if you happen to be wandering around dense murky code that has no documentation on the wiki, then Dr. Livingston, it's your duty to write about it on the wiki for the next intrepid explorer.
How do I build it?
Nowadays people are using CMake to make solution files for the Microsoft Visual Studio integrated development environment (IDE) on Microsoft Windows, or to make project files for XCode on Mac OS X, or to generate makefiles for gcc on Linux. The build process is still being developed and it's getting easier, but it still takes a bit of perseverence.
Are there any style guidelines?
Reading the source code, you may get the impression that there is no standard style used by Linden, but in fact there is a coding standard. The existing code has been developed over many many years and can be excused for violating the standards. You will not be excused. Reading the standards before starting to code could save you a lot of editing later.
Testing...1...2...3...
Writing code isn't just writing the lines of C++. It's also documenting the code, designing a test plan, doing the actual testing, and making sure it works in a variety of situations.
You should attach the test plan in the JIRA, either directly in a comment, an attached document, or a nonvolatile link to it on the web.
Patch? What's a patch?
Once you've written, debugged, documented, and thoroughly tested your code, it's time to publish it to the world. That's done by attaching a patch file to the PJIRA issue that you created way back when you started all of this. If the changes are small, you can describe what you did as a comment on the PJIRA issue. If it's a major change, create a wiki page User:(your avatar name here)/(feature name here) and put a link to it on your PJIRA issue. Then let the SLDev mailing list know about it; stand back; and accept the accolades of your peers. OK, well maybe accolades are a bit scarce these days. Enjoy the satisfaction of a job well done. You knew you weren't getting paid for this anyway.
Get your code reviewed
This is the hard part. In the past, contributors would get other residents to vote for their contributions and Linden developers would choose from among the highest vote getters. It usually took quite a while to get through the process.
Now it's first-come first-served. Add your issue to the list of proposed changes for the next release. Include the PJIRA issue title, issue number, and a link to the issue on PJIRA. Then send a note to the SLDev mailing list with this same information, asking for comments on the PJIRA.
Try to keep discussions about the issue on the PJIRA, not on the mailing list. It keeps all of the comments together. Mailing list posts are very transient. Anything said there is quickly lost among newer posts. Anyone with a serious concern will take the time to read the issue before offering comments.
Give people time (at least a day, maybe quite a bit more depending on the complexity of your submission and the timing) to evaluate it and comment. Then try to get one of the people who are authorized to commit code to the repository to look at the patch file.
It is quite difficult to evaluate a code contribution just looking at a patch file and reviewers will want to be sure there are no bugs before agreeing to commit the code.
Ironically, the review of code intended for an immersive collaborative virtual world uses primarily a text-based issue tracker for discussion. It is still very difficult to make visual presentations in-world and voice chat is usually considered exclusionary. So let your fingers do the talking.
Keep in mind that a positive, engaged attitude on SLDev and in JIRA is likely to garner more support than a more negative approach.
Get it committed to the repository
There is a group of committers that do have commit privileges to the SVN repository. The big difference with the "old LL way of doing things" is that this group of committers has Lindens and non-Lindens. If there is community support and a good review of the code from committers, the patch will be taken in and committed by one of the committers. Eventually, if someone does quite a bit of good contributions in line with the project, the committers will propose that that person become a committer themselves. The committers group grows by co-optation only.
If someone objects (and if our community is alive, there will be someone to object...), we debate and try to reach a consensus on the SLDev list. If there's a really contentious decision to be made (split debate), Philip, our BDFL (Benevolent Dictator For Life), will weight in and make the decision.
We won't have SVN wars like Wiki wars since the group of committers will be co-opted. Obviously, the committers will be careful co-opting only people who share their view and philosophy of development. If one committer would all of a sudden commit controversial patches with no respect for due debate or the general direction of the project (as decided by the BDFL), he or she'll see his/her commit rights revoked. The BDFL has full authority in that matter.
Track it through the merge process
The SLDev project is branched off from the trunk, but is kept current with changes to the trunk by Linden developers. In order to get into the official viewer, a patch must make its way from the SLDev branch back to the trunk, which then gets branched off as a Release Candidate, and after beta testing and bug fixes, becomes the official viewer.
Not all contributions will be chosen to get incorporated into the official viewer. That decision is separate from the decision to include it in the SLDev viewer.
If a contribution is selected for inclusion into the official viewer, the contributor is expected to follow the code through the merge process, testing it along the way to make sure it doesn't get broken by other changes.
We do hope that most of the innovations battle tested here will eventually make it to the official viewer codebase but things that are clearly not mainstream enough or not very popular with this community simply won't make it there, and that's OK. People will still be able to get those features in the SLDev viewer download.
Each project (RC, maint, etc...) has its own way of ensuring quality and consistency of its project, mitigating agility vs prudence. As far as the merge back to the official viewer of contributions is concerned, that'll be up to the Linden Lab viewer team to cherry pick and merge patches/commits separately.
This is not easy to do. Making this more manageable is one of the big reason for the push to hg (mercurial) for source version control. It does make merges from various sources much more easier than SVN.
Take a bow
Every year Linden Lab offers the Linden Lab Innovation Awards to open source contributors. The categories change a bit year to year, but last year's were for Best Documentation, Best Organizer, Best Code Contribution, The Jesse Malthus Award for Best Community Influence, and Contributor of the Year.
But nothing beats the feeling you get when you read on someone's blog about a cool new feature in Second Life, and it's yours!