adapt master to develop
[taxeditor.git] / src / site / apt / getting-started.apt
index 1183ee840c80d4b2657150c0482c9ea765316100..2330106b955200a6cb04f32bd838e71c6e60aba0 100644 (file)
+        ------
+        Setting up a Taxonomic Editor development environment
+        ------
+        n.hoffmann
+        ------
+        
+
 Setting up a Taxonomic Editor development environment
 
-       This document describes all steps necessarry to create a development environment to develop the EDIT Taxonomic Editor. If you are looking for 
-       instructions on how to install the EDIT Taxonomic Editor please consult the {{{./manual.html} manual}}.
-       
-       <Table of Contents>
-       
+    This document describes all steps necessary to create a development environment to develop the EDIT Taxonomic Editor. If you are looking for 
+    instructions on how to install the EDIT Taxonomic Editor please consult the {{{./manual.html} manual}}.
+    
+    <Table of Contents>
+    
 %{toc|section=0|fromDepth=2|toDepth=3}
-       
+    
 * Requirements
-       
-       * CDM Library development environment set up on your machine (please follow the instructions on {{{http://wp5.e-taxonomy.eu/cdmlib/getting-started.html#Developing_the_CDM_Library}how to install a CDM Library development environment}})
-       
-       * Eclipse PDE Version >= 3.6
-       
-       
+
+    The current version of the EDIT Taxonomic Editor is developed using the Eclipse IDE for RCP developers.
+    
+    
 * Checking out the sources
 
-       Use subversion to check out the sources from the EDIT repository to a location on your development machine.
-       
+    Use git to check out the sources from the EDIT repository to a location on your development machine.
+    
 ---
-$ svn co http://dev.e-taxonomy.eu/svn/trunk/taxeditor
+$ git clone ssh://git@dev.e-taxonomy.eu/var/git/taxeditor.git
 ---
 
-       This will leave you with a directory <<<taxeditor/>>> containing everything that is needed. We will have a look at the contents later on.
+    This will leave you with a directory <<<taxeditor/>>> containing everything that is needed. We will have a look at the contents later on.
 
 * Setting up eclipse
 
-       The Taxonomic Editor uses maven for convenient configuration and automation of common tasks, such as setting up eclipse. 
-       
----
-$ cd taxeditor/
-$ mvn eclipse:eclipse
----
-       
-       This will take some time, as maven will download the required dependencies and configure the projects. After maven has finished follow these steps:
-       
-       * Start up eclipse (make sure you have the required version installed) and open a workspace. 
-       
-       * Open up the Import Wizard via <File -\> Import...> from the menu
-       
-       * Choose <General -\> Existing projects into Workspace > and click next.
-       
-       * Check <Select Root Directory> and browse to the <<<taxeditor/>>> directory. After confirming the directory selection dialog, the <Projects> list should contain a number of projects.
-       
-       * Click <Select All> and finish the wizard.
-       
-       The package exporer should show a bunch of projects. Although it will also show a bunch of errors, so please read on.
-       
-       
-* Initializing the cdmlib plugin
-
-       The <cdmlib-plugin> project contains all dependencies needed for the CDM Library to work except the <<<cdmlib-*>>> artifacts itself. Therefore the      
-       <<<cdmlib-plugin>>> project will show an error. In order to include these artifacts the project contains a shell (and bash) script to copy these from your local maven repository. Please make sure, that the <<<cdmlib-*>>> artifacts exist in your repository.
-       
+    * Start up eclipse and open a workspace. 
+    
+    * Open up the Import Wizard via <File -\> Import...> from the menu
+    
+    * Choose <Maven -\> Existing maven projects > and click next.
+    
+    * For setting the <Root Directory> browse to the <<<taxeditor/>>> directory. After confirming the directory selection dialog, the <Projects> list should contain a number of projects all starting with 
+    <<<eu.etaxonomy.taxeditor>>> which should be checked for import.
+    
+    * Click <Select All> to finish the wizard and import the projects into your workspace.
+    
+    You should now be able to see the taxeditor projects in your workspace.
+    
+* Dependencies
+    
+    The Taxonomic Editor uses <maven 3> for convenient configuration and automation of common tasks, 
+    such as resolving dependencies and automating builds.
+
+    We have two modules that use maven for dependency resolution: cdmlibrary and the molecular module.
+    
+    The <<<latest snapshot branch>>> of the Taxonomic Editor is programmed against the latest
+    SNAPSHOT version of the cdmlibrary. Because that dependency will change quickly, we
+    do not include it with the other dependencies but rather install it with maven. 
+
+    In order to do that you have to run <<<mvn install>>> and <<<mvn validate>>> in your <<<taxeditor>>> directory.
+
 ---
-$ cd taxeditor/cdmlib-plugin/
-$ ./_makeSources.sh
+$ cd taxeditor
+$ mvn clean install 
+$ mvn validate
 ---
 
-       Refresh the <<<cdmlib-plugin>>> project; the errors should be gone.
-       
-       <<Note:>> This will change in the very near future as these dependencies will also be managed by maven.
+    The maven pom.xml provides a special profile which you may want to use if you are developing the cdmlib at the same time. This profile, named <<<local-repository>>>, causes maven to always use the local maven repository, so the latest changes to the cdmlib will be used. You have to run <<<mvn install>>> in the cdmlib folder beforehand to install the local dependencies to the repository. In order to use this profile you would execute the <<<validate>>> gloal differently:
+
+ ---
+ $ mvn -P local-repository  -Dlocalrepo=/home/${youUserName}/.m2/repository validate
+ ---
+
+    This will take some time, as maven will download the required dependencies.
+    
+    There is also a convenience shell script <<<setup-project.sh>>> in the <<<taxeditor>>> directory which runs the above mentioned commands.
+    
+ ---
+ $ ./setup-project.sh
+ ---
+
+
+    After maven has finished follow these steps:
 
-       After this you have to update the classpaths of all plugin projects as well. To do this right-click any of the <taxeditor-*> projects and choose <PDE Tools -\> Update Classpath...>. Click <Select All> in the dialog and confirm. After a rebuild of your entire workspace all errors should be gone and you are ready to go.
-       
+    The UI is implemented using a fixed version of SWT. So please follow the steps to correctly set the  {{{https://dev.e-taxonomy.eu/redmine/projects/edit/wiki/TaxonomicEditorDevelopersGuide#Target-RCP-Environment}Target-RCP-Environment}} 
+
+
+    
 * Bundle overview
 
-       Let's have a quick look at the projects:
-       
-** <taxeditor-store>
+    Let's have a quick look at some important projects:
+    
+** <eu.etaxonomy.taxeditor.store>
+
+    This package communicates with cdmlib-service directly, offering all services, basic operations on cdm data as well as import export functionality. Database and user management is also contained in this package.
+    
+** <eu.etaxonomy.taxeditor.navigation>
+
+    The <Taxon Navigator> as well as the <Search> view are located in this plugin.
 
+** <eu.etaxonomy.taxeditor.editor>
 
-       
-** <taxeditor-navigation>
+    Everything that has to do with editing taxa or specimens or data that is connected to those resides in this plugin. This includes the <Name Editor>, the <Specimen Editor>, the <Details View>,
+    the <Supplemental View>, the <Descriptive Data View> as well as the <Media View>. All interface elements that are used in the <taxeditor-bulkeditor> plugin are 
+    also located here.
 
-       The <Taxon Navigator> as well as the <Search> view are located in this plugin.
+** <eu.etaxonomy.taxeditor.bulkeditor>
 
-** <taxeditor-editor>
+    The different bulkeditors are in this plugin.
 
-       Everything that has to do with editing a taxon or data that is connected to a taxon resides in this plugin. This includes the <Name Editor>, the <Details View>,
-       the <Supplemental View>, the <Descriptive Data View> as well as the <Media View>. All interface elements that are used in the <taxeditor-bulkeditor> plugin are 
-       also located here.
+** <eu.etaxonomy.taxeditor.molecular>
 
-** <taxeditor-bulkeditor>
+    This plugin provides editors and views for working with phylogenetic data like single reads and consensus sequences. This includes the <Alignment Editor>, the <Pherogram View> and export functionality.
 
-       The different bulkeditors are in this plugin.
+** <eu.etaxonomy.taxeditor.molecular.lib>
 
-** <taxeditor-printpublisher>
+    Manages the external dependencies for the molecular plugin.
 
-       This plugin is a frontend and GUI for the <cdmlib-print> module. Please see the {{{http://wp5.e-taxonomy.eu/printpublisher/}according documentation}} for further information.
+** <eu.etaxonomy.taxeditor.webapp>
+    
+    Provides all remoting facilities i.e. manages the internal CDM Server to connect to remote data sources.
 
-** <taxeditor-application>
+** <eu.etaxonomy.taxeditor.printpublisher>
 
-       This plugin bundles all the previous plugins into an application and configures the look and feel.
+    This plugin is a frontend and GUI for the <cdmlib-print> module. Please see the {{{http://cybertaxonomy.org/printpublisher/}according documentation}} for further information.
 
-** <taxeditor-cdmlib-plugin>
+** <eu.etaxonomy.taxeditor.application>
 
-       As said before, <cdmlib> dependecies reside in this plugin. Please also note that this plugin does not contain any sourcecode.
+    This plugin bundles all the previous plugins into an application and configures the look and feel.
 
-** <taxeditor-feature-platform>
+** <eu.etaxonomy.taxeditor.cdmlib>
 
-       A feature containing all dependencies for the eclipse platform.
+    As said before, <cdmlib> dependecies reside in this plugin. Please also note that this plugin does not contain any sourcecode.
 
-** <taxeditor-feature-product>
+** <eu.etaxonomy.taxeditor.feature.platform>
 
-       A feature configuring the standalone application and bundling all plugins and dependencies.
+    A feature containing all dependencies for the eclipse platform.
+
+** <eu.etaxonomy.taxeditor>
+
+    The product configuration for the standalone application.
+
+** <eu.etaxonomy.taxeditor.test>
+    
+    Automated GUI Tests for the Taxonomic Editor that can be run with {{{http://eclipse.org/swtbot/}SWTBot}}.
 
 * Creating a launch configuration
 
-       To start the Taxonomic Editor from your newly created development environment you need to create a launch configuration.
-       
-       * Expand <taxeditor-feature-product> and open <<<taxeditor.product>>>
-       
-       * In the <Testing> section (down left) click on <Launch an Eclipse application in Debug mode>
-       
-       The Taxonomic Editor should launch.
-       
+    To start the Taxonomic Editor from your newly created development environment you need to create a launch configuration.
+    
+    * Expand <eu.etaxonomy.taxeditor> and open <<<eu.etaxonomy.taxeditor.product>>>
+    
+    * In the <Testing> section (down left) click on <Launch an Eclipse application in Debug mode>
+    
+    The Taxonomic Editor should launch. Note: You might want to tweak the launch configuration, e.g. increase the memory.
+    
 * Where do I go from here?
+
+    Please read the {{{http://dev.e-taxonomy.eu/trac/wiki/TaxonomicEditorDev}wiki}} for how-to's and code examples.