PDA

View Full Version : Developer Collaboration


Adrian Schneider
10-13-2009, 09:26 PM
Hi,

This is somewhat of a branch off Wayne's topic, but I don't want to disrupt that as there is a slight difference in goals.

Floris has been posting some good ideas lately, and I think we have all the tools we need in order to effectively work together on them without requiring any major infrastructure changes here at vBulletin.org.

Before I go any further, I'd be willing to help with this idea by posting tutorials and encouraging other people to give it a try. These tools are meant for huge collaboration projects, so they are definitely powerful enough to handle vBulletin products.



Version Control

First and foremost, we need to use version control. The two most popular contenders are Subversion (http://subversion.tigris.org/) and Git (http://git-scm.com/). I have been favoring Git lately, but either way will work. Git has an edge over Subversion, as it allows users to easily branch off each others work and projects will no longer fail because the original author has given up or has no time. In this model, it does not matter, because anybody can take over without messing up permissions or rights.

Collaboration Platform / Management

Next, we need a way to easily manage this source code. There are two very popular websites for this: SourceForge (http://sourceforge.net/) for Subversion, and GitHub (http://github.com/) for Git. This is where users can browse the code, track issues, and prepare packages for downloading.

Development Tools

I have been complaining for years about how ineffective working with the product system is for developers, and recently I have released a solution called VDE - vBulletin Development Environment (https://vborg.vbsupport.ru/showthread.php?t=224133). This tackles the problem on two points: 1) product data is split into separate files, so they can easily be managed by version control software, and 2) it automatically loads this data into memory as if it were active, so you don't have to import products either.



Where to start? I have been watching Floris' vBulletin Security Audit Product (https://vborg.vbsupport.ru/showthread.php?t=224053) in the hatchery. I have also been looking for some example mods to use for VDE, as I don't have any good examples yet. Honestly, I've been wanting to help out on the project, but it's too much of a hassle to actually download the product, work on it, and re-upload it, because it's up to the original author to try and merge the code together. With products, this can sometimes be very difficult. With VDE in place, it would be very trivial to perform changes, and to actually watch them get placed into the master branch again. It takes very little effort on the original author's part.

I am willing to bet good money that with such a system in place, even as an experiment, you will see a huge surge in developer collaboration, and these mods will flourish. For the other developers here who have already taken some initiate with VDE, or with the audit project, please post some feedback here. I think we can do this, and it's easier than a lot of you think.

TheLastSuperman
10-14-2009, 04:31 AM
I'm curious to see how this develops, I like the Security Audit product and even mentioned to Floris about perhaps getting with you in regards to the development environment ;) I love both these new ideas and support them 100%

I'd love to see more of this in vB already, 4.0 changes a lot of things but this can grow as well into something that helps all of us and remedy the need for confusion here by posting 4 different versions of the same mod because not matter how big bold and colored your text is saying compatible with all vB versions some members will not even visit that forum, I've heard it before and most do not know a 3.5 product might work on a 3.6 or 3.7/8 board. Again, I fully support both ideas, the audit product helped me save time, I had begun doing many changes to my new site before launching already and it saved me a massive amount of time simply clicking again to see what remained (chmod etc). I can't wait to see more getting involved with this too Adrian ;).

Mike

Carnage
10-16-2009, 04:15 PM
I'm not familiar with git, however I do know its superior in many ways to svn.

I'm designing something like this; the idea being that it integrates with vbulletin and svn. I felt that you went the wrong way with your mod; instead of bringing the power of svn into vbulletin you pulled all of the files outside of vb.

wilsoufra
10-16-2009, 05:18 PM
Hi,

This is somewhat of a branch off Wayne's topic, but I don't want to disrupt that as there is a slight difference in goals.

Floris has been posting some good ideas lately, and I think we have all the tools we need in order to effectively work together on them without requiring any major infrastructure changes here at vBulletin.org.

Before I go any further, I'd be willing to help with this idea by posting tutorials and encouraging other people to give it a try. These tools are meant for huge collaboration projects, so they are definitely powerful enough to handle vBulletin products.



Version Control

First and foremost, we need to use version control. The two most popular contenders are Subversion (http://subversion.tigris.org/) and Git (http://git-scm.com/). I have been favoring Git lately, but either way will work. Git has an edge over Subversion, as it allows users to easily branch off each others work and projects will no longer fail because the original author has given up or has no time. In this model, it does not matter, because anybody can take over without messing up permissions or rights.

Collaboration Platform / Management

Next, we need a way to easily manage this source code. There are two very popular websites for this: SourceForge (http://sourceforge.net/) for Subversion, and GitHub (http://github.com/) for Git. This is where users can browse the code, track issues, and prepare packages for downloading.

Development Tools

I have been complaining for years about how ineffective working with the product system is for developers, and recently I have released a solution called VDE - vBulletin Development Environment (https://vborg.vbsupport.ru/showthread.php?t=224133). This tackles the problem on two points: 1) product data is split into separate files, so they can easily be managed by version control software, and 2) it automatically loads this data into memory as if it were active, so you don't have to import products either.



Where to start? I have been watching Floris' vBulletin Security Audit Product (https://vborg.vbsupport.ru/showthread.php?t=224053) in the hatchery. I have also been looking for some example mods to use for VDE, as I don't have any good examples yet. Honestly, I've been wanting to help out on the project, but it's too much of a hassle to actually download the product, work on it, and re-upload it, because it's up to the original author to try and merge the code together. With products, this can sometimes be very difficult. With VDE in place, it would be very trivial to perform changes, and to actually watch them get placed into the master branch again. It takes very little effort on the original author's part.

I am willing to bet good money that with such a system in place, even as an experiment, you will see a huge surge in developer collaboration, and these mods will flourish. For the other developers here who have already taken some initiate with VDE, or with the audit project, please post some feedback here. I think we can do this, and it's easier than a lot of you think.

This is an interesting discussion. thank you for sharing
However I think you should vary more examples to your writing much more interesting !

__________________
Faire simulation pret personnel en ligne | (http://pretpersonnelenligne.org) Faire calcul taux pret personnel en ligne | (http://pretpersonnelenligne.org/pret-personnel-en-ligne/) Demander un financement simulation credit personnel (http://pretpersonnelenligne.org/simulation-credit-personnel/)

Adrian Schneider
10-16-2009, 05:35 PM
I'm not familiar with git, however I do know its superior in many ways to svn.

I'm designing something like this; the idea being that it integrates with vbulletin and svn. I felt that you went the wrong way with your mod; instead of bringing the power of svn into vbulletin you pulled all of the files outside of vb.
Feel free to share more details. I've been fighting with vBulletin + SVN for about 3 years now which is why I have taken this route.

I have talked to Floris and he has let me use his product as an example.... when I get some time I will be putting it up. :)

Carnage
10-16-2009, 06:29 PM
i'm taking inspiration from http://divmod.org/trac/wiki/DivmodCombinator a python tool for use with svn, it made my life so much easier with developing python modules I wanted something similar for vbulletin.

I'm probably going to mock something up in the next couple of hours, so I may have more details then.

--------------- Added 1255727698 at 1255727698 ---------------

Been playing around, found that there are very few (1) hooks in the plugins page which wasn't really of much use.

Copied some of the export code into a file and modfied it to export to the file system putting each plugin hook into its own file in ./products/plugins/hookname.php did the same for template and install code.

The idea is to use http://www.php.net/manual/en/book.svn.php the pecl svn module to create and update an svn repo for the code. Also there will need to be something to take it the other way and import from the file system into vbulletin.

Essentially a php file that provide the following functions:


Export product to ./products/ directory (currently only templates, plugins and install code done)
Manage svn repository pre product. (create, commit, rollback,checkout etc)
Import from file system to vbulletin.
Add a field in products table for additional files which will be copied to the products directory and included in import/export operations.
Creates a Full product export; includeing additional files when a product is exported from vbulletin.
Syncs product version and svn revision number (using branches or tags or something)


--------------- Added 1255733636 at 1255733636 ---------------

brainwave: If designed right, it wouldn't matter which backend version control system was used. The vbversion product could have plugins to use either svn git or cvs depending on personal preferance...