Author: niallp
Date: Sat Mar 13 23:10:02 2010
New Revision: 922687

URL: http://svn.apache.org/viewvc?rev=922687&view=rev
Log:
Add a page on setting up a new sandbox component

Added:
    commons/proper/commons-site/src/site/xdoc/new-sandbox-component.xml   (with 
props)

Added: commons/proper/commons-site/src/site/xdoc/new-sandbox-component.xml
URL: 
http://svn.apache.org/viewvc/commons/proper/commons-site/src/site/xdoc/new-sandbox-component.xml?rev=922687&view=auto
==============================================================================
--- commons/proper/commons-site/src/site/xdoc/new-sandbox-component.xml (added)
+++ commons/proper/commons-site/src/site/xdoc/new-sandbox-component.xml Sat Mar 
13 23:10:02 2010
@@ -0,0 +1,176 @@
+<?xml version="1.0"?>
+<!--
+ Licensed to the Apache Software Foundation (ASF) under one or more
+ contributor license agreements.  See the NOTICE file distributed with
+ this work for additional information regarding copyright ownership.
+ The ASF licenses this file to You under the Apache License, Version 2.0
+ (the "License"); you may not use this file except in compliance with
+ the License.  You may obtain a copy of the License at
+
+      http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+-->
+ 
+<document>
+ 
+ <properties>
+  <title>Adding a new Sandbox component</title>
+ </properties>
+
+  <body>
+
+    <section name="Adding a new Sandbox component">
+
+      <p>
+        This page describes the steps to setup a new <a 
href="sandbox/index.html">Sandbox Component</a>
+        using component <strong>foo</strong> as an example.
+      </p>
+
+      <subsection name="Subversion Repository">
+        <p>
+          <strong>Create the Repository</strong><br />
+          Create the <em>foo</em> repository in
+          <a 
href="https://svn.apache.org/repos/asf/commons/sandbox/";>https://svn.apache.org/repos/asf/commons/sandbox/</a>
+          with the usual folder structure:
+        </p>
+
+        <source>
+          foo
+           |
+           +--branches
+           |
+           +--tags
+           |
+           +--trunk
+        </source>
+
+        <p>
+          <strong>Add the component to <code>trunks-sandbox</code></strong><br 
/>
+          <a 
href="https://svn.apache.org/repos/asf/commons/trunks-sandbox/";>trunks-sandbox</a>
+          uses subversion a <code>svn:externals</code> property to link to the 
<i>trunks</i> of all the sandbox compoenent - update the
+          <code>svn:externals</code> property for <a 
href="https://svn.apache.org/repos/asf/commons/trunks-sandbox/";>trunks-sandbox</a>
+          to include the new Sandbox component:
+        </p>
+
+        <source>
+          foo https://svn.apache.org/repos/asf/commons/sandbox/foo/trunk
+        </source>
+
+        <p>
+          <strong>Copying the code</strong><br />
+          If the code is being brought to the <a 
href="sandbox/index.html">Commons Sandbix</a> from elsewhere at the
+          <a href="http://www.apache.org/";>ASF</a> then please do a 
<i>subversion cop</i> so that the history of
+          the code is retained.
+        </p>
+
+      </subsection>
+
+      <subsection name="Create the project structure">
+        <p>
+          Commons components use <a href="http://maven.apache.org/";>Maven</a> 
as their primary build system and
+          it is recommended that the project adopts the default Maven 
structure:
+        </p>
+        <source>
+          trunk
+           |
+           +--NOTICE.txt
+           +--LICENSE.txt
+           +--pom.xml
+           +--trunk
+           +--src
+               +--main
+               |    |
+               |    +--java
+               |    +--resources
+               |
+               +--test
+               |    |
+               |    +--java
+               |
+               +--site
+                    |
+                    +--site.xml
+                    +--resources
+                    |      |
+                    |      +--images
+                    |
+                    +--xdoc
+                         |
+                         +--index.xml
+        </source>
+
+        <p>
+          See <a 
href="http://svn.apache.org/repos/asf/commons/sandbox/test-maven/sample-sandbox-project/";>here</a>
+          for a sample Sandbox project.
+        </p>
+      </subsection>
+
+      <subsection name="Using Maven">
+
+        <p>
+          if you're new to <a href="http://maven.apache.org/";>Maven</a>, here 
are some useful links to get started:
+        </p>
+        <ul>
+          <li><a href="http://maven.apache.org/download.html";>Download 
Maven</a></li>
+          <li><a 
href="http://maven.apache.org/download.html#Installation";>Installation 
Instructions</a></li>
+          <li><a 
href="http://maven.apache.org/guides/getting-started/maven-in-five-minutes.html";>Maven
 in 5 Minutes</a></li>
+        </ul>
+        <p>
+          Once you have installed maven the following commands are useful:
+        </p>
+        <source><![CDATA[
+          mvn clean              <!-- clean the project -->
+          mvn test               <!-- compile and run the tests -->
+          mvn package            <!-- compile, run tests and create the jar -->
+          mvn site               <!-- create the component site -->
+        ]]></source>
+
+      </subsection>
+
+      <subsection name="Setup a Maven pom.xml">
+        <p>
+          There is a <a 
href="http://svn.apache.org/repos/asf/commons/sandbox/test-maven/sample-sandbox-project/trunk/pom.xml";>sample
 pom.xml</a>
+          in the <a 
href="http://svn.apache.org/repos/asf/commons/sandbox/test-maven/sample-sandbox-project/";>sample
 project</a>
+          mentioned above.
+        </p>
+        <p>
+          Sandbox projects use the
+          in the <a 
href="http://svn.apache.org/repos/asf/commons/proper/commons-sandbox-parent/trunk/pom.xml";>commons-sandbox-parent</a>
+          pom.xml as there parent, which in turn has the
+          <a 
href="http://svn.apache.org/repos/asf/commons/proper/commons-parent/trunk/pom.xml";>commons-parent</a>
 as its parent.
+          There are notes on what the commons-parent pom <a 
href="commons-parent-pom.html">here</a>.
+        </p>
+      </subsection>
+
+      <subsection name="Create a SANDBOX JIRA component">
+
+        <p>
+          There is a single JIRA projects for all <a 
href="sandbox/index.html">Sandbox</a>
+          components:
+        </p>
+
+        <p>
+          <a 
href="http://issues.apache.org/jira/browse/SANDBOX";>http://issues.apache.org/jira/browse/SANDBOX</a>
+        </p>
+
+        <ul>
+          <li>Create a new component in JIRA, making a note of the 
<code>componentid</code></li>
+          <li>Set <code>commons.jira.componentid</code> property in the 
component's pom.xml to to the <code>componentid</code></li>
+          <li>Run the following command in your new Sandbox project to create 
a custom issue tracking page:</li>
+        </ul>
+
+        <source>
+          mvn commons:sandbox-jira-page
+        </source>
+
+      </subsection>
+
+    </section>
+
+  </body>
+</document>

Propchange: commons/proper/commons-site/src/site/xdoc/new-sandbox-component.xml
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: commons/proper/commons-site/src/site/xdoc/new-sandbox-component.xml
------------------------------------------------------------------------------
    svn:keywords = Date Author Id Revision HeadURL


Reply via email to