Before you start you might be interested in reading the Project Structure tutorial which shows the directory organization of the Cargo sources. The Building tutorial explains how to build Cargo from sources and the Contributing tutorial explains what rules to follow when contributing code.
Here are some quick steps to follow if you wish to add support for a new container in Cargo:
- Subscribe to the cargo dev mailing list and ask as many question you'd like there!

- Create a JIRA issue on http://jira.codehaus.org (you'll need to register). I'll then add you to the cargo-developers group in JIRA and assign the issue to you
- Checkout Cargo from SVN trunk
- Understand the Cargo project's directory structure. Container implementations are located in
trunk/core/containers/ContainerName. - Have a look at existing container implementations (search for example for
Resin3xLocalContainerorOrion2xLocalContainer). - Create a
org.codehaus.cargo.container.containerNamepackage if it doesn't already exist. - Create the following classes:
- A container implementation class named
_ServerNameNxContainerType_ContainerwhereServerNameis the name of the container,Nthe version andContainerTypethe type of container (Local or Remote). For example:JBoss3xLocalContainer. - A configuration implementation class named
_ServerNameConfigurationType_ConfigurationwhereConfigurationTypecan beStandaloneLocalorExistingLocal. For exampleJBossStandaloneLocalConfiguration. - You may need to implement some ancillary classes but those are the main 2 required. Check how the other container are implemented to see how to implement them and what other classes you may need to implement.
- A container implementation class named
- Cargo has an SPI that you should use and that should make it easy for you. Your container class should extend
org.codehaus.cargo.container.spi.Abstract_ContainerType_Containerand your configuration class should extendorg.codehaus.cargo.container.spi.configuration.Abstract_ConfigurationType_Configuration. - Register your new classes in the generic API in the Factory classes
trunk/core/api/genericso that users can use your new container by using the generic API. - Add your container to the tests in
trunk/samples/java. This means editing the*Test.javaclasses and adding your container in thesuite()method. - Run the Cargo build to ensure everything is working. You'll probably find that you haven't followed the Cargo project's coding conventions... Fix those and build again until it passes!

- Register on Codehaus' confluence. Once this is done I'll add you to the cargo-developers user group so that you have the right to edit yourself the Cargo web site pages
- Document the new container on the Cargo web site
- Create a SVN patch and attach it to the JIRA issue you have created above
Thanks and happy coding!
Labels