# HG changeset patch
# User jankanis
# Date 1401200470 14400
# Node ID 5972e67030fd8dd95081977a46757e2cd3d33134
# Parent  59b33d253163b525d2b5e7a96d03473a7465ec72
enable dbm module, update docs
diff -r 59b33d253163 -r 5972e67030fd tool_dependencies.xml
--- a/tool_dependencies.xml	Mon May 26 09:28:34 2014 -0400
+++ b/tool_dependencies.xml	Tue May 27 10:21:10 2014 -0400
@@ -9,7 +9,7 @@
   
 
   
-    
+    
   
 
   
@@ -25,7 +25,7 @@
           
             
           
-          
+          
             
           
         
@@ -33,7 +33,9 @@
         
           # The python build system doesn't check CPATH / C(PLUS)_INCLUDE_PATH which is set by the depended-upon
           # tool definitions for these sources, but it does check CPPFLAGS / LDFLAGS
-          # Currently not whitespace-safe, but galaxy itself isn't whitespace-safe either so it doesn't matter (yet)
+          # Currently not whitespace-safe, I haven't found a way yet to quote the *FLAGS values so that they are
+          # correctly recognized by the python build process and the compiler. But as galaxy itself isn't
+          # whitespace-safe either it doesn't really matter (currently).
           oldifs="$IFS"
           IFS=:
           for p in $CPLUS_INCLUDE_PATH
@@ -69,28 +71,44 @@
     
 
     
-    Python 3.4.1
+      Python 3.4.1
 
-    This build of python is configured with --enable-loadable-sqlite-extensions and a --prefix, any other settings are default. This build does not include modules for lzma, Tkinter and dbm, but does include ssl, gdbm and sqlite. Adding the missing modules should not be very difficult but requires wrapping the external sources that these modules require inside galaxy. 
+      This build of python is configured with --enable-loadable-sqlite-extensions and a --prefix, any other settings are default. This build does not include modules for lzma and Tkinter, but does include ssl, (g)dbm and sqlite. Adding the missing modules should not be very difficult but requires wrapping the external sources that these modules require inside galaxy. 
 
-    Python as of version 3.3 includes a built-in virtual environment manager. To create a python 3 virtual env, include the following actions in your tool_dependencies.xml:
+      Python as of version 3.3 includes a built-in virtual environment manager. To create a python 3 virtual env, include the following actions in your tool_dependencies.xml:
 
       <action type="set_environment_for_install">
         <repository name="python3" owner="jankanis">
           <package name="python3" version="3.4.1" />
         </repository>
+	<!-- other install time dependencies -->
       </action>
+
       <action type="shell_command">
-        # Unset any saved environment settings from parent virtual
-        # environments, e.g. for python 2 or if Galaxy itself is running
-        # from within a virtual environment.
-        unset _OLD_VIRTUAL_PATH; unset _OLD_VIRTUAL_PYTHONHOME
-        pyvenv {{\$MY_PACKAGE_NAME}}
-        . {{\$MY_PACKAGE_NAME}}/bin/activate
-        pip3 install {{\$PYTHON-PACKAGE}}
+	# Unset any saved environment settings from parent virtual
+	# environments, e.g. for python 2 or if Galaxy itself is running
+	# from within a virtual environment.
+	unset _OLD_VIRTUAL_PATH; unset _OLD_VIRTUAL_PYTHONHOME
+	pyvenv MY_TOOL_venv
+	MY_TOOL_venv/bin/pip3 install {{NEEDED_PYTHON_PACKAGES}}
       </action>
+
       <action type="set_environment">
-        <environment_variable name="PYTHONPATH" action="prepend_to">\$INSTALL_DIR/lib/python3.4/site-packages</environment_variable>
+        <!-- Remove any incoming PYTHONPATH elements from Galaxy's own python 2 environment.
+	     If you want to chain multiple virtual environments so that packages installed
+	     in all of them are visible, you need to arrange for PYTHONPATH to include the
+	     site-packages directories of all of them, so in that case just a plain 'set_to'
+	     would not be sufficient.
+	 -->
+	<environment_variable name="PYTHONPATH" action="set_to">$INSTALL_DIR/MY_TOOL_venv/lib/python3.4/site-packages</environment_variable>
+	<!-- All that is really needed to use a specific virtual environment is that the
+	     python interpreter in that environment is used, so add it to PATH -->
+	<environment_variable name="PATH" action="prepend_to">$INSTALL_DIR/MY_TOOL_venv/bin</environment_variable>
+	<!-- Clear incoming PYTHONHOME just like the venv's 'activate' command does -->
+	<environment_variable name="PYTHONHOME" action="set_to"></environment_variable>
+	<!-- To find shared libraries for python built-in modules such as libssl or libsqlite3
+	     we need to re-export LD_LIBRARY_PATH -->
+	<environment_variable name="LD_LIBRARY_PATH" action="prepend_to">$ENV[LD_LIBRARY_PATH]</environment_variable>
       </action>