]> git.sur5r.net Git - bacula/docs/blobdiff - docs/developers/generaldevel.tex
Link to all the other languages.
[bacula/docs] / docs / developers / generaldevel.tex
index 6d6d9f7b870f505a7f28d41e15ea229638597aa5..6beb52d9e63f0c225fbef8299b966cf9d0834541 100644 (file)
@@ -37,290 +37,550 @@ requirements for such code.
 
 Subject to the copyright assignment described below, your patches should be
 sent in {\bf diff -u} format relative to the current contents of the Source
-Forge CVS, which is the easiest to understand and integrate.
+Forge SVN, which is the easiest to understand and integrate.
 Please be sure to use the Bacula indenting standard (see below).
-If you have checked out the source with CVS, you can get a diff using:
+If you have checked out the source with SVN, you can get a diff using:
 
 \begin{verbatim}
-cvs diff -u > change.patch
+svn update 
+svn diff > change.patch
 \end{verbatim}
      
 If you plan on doing significant development work over a period of time,
 after having your first patch reviewed and approved, you will be eligible
-for having developer CVS access so that you can commit your changes
-directly to the CVS repository.  To do so, you will need a userid on Source
+for having developer SVN access so that you can commit your changes
+directly to the SVN repository.  To do so, you will need a userid on Source
 Forge.
 
 \subsubsection*{Copyrights}
 \index{Copyrights}
 \addcontentsline{toc}{subsubsection}{Copyrights}
 
-To avoid future problems concerning changing licensing or copyrights, all
-code contributions more than a hand full of lines must be in the Public
-Domain or have the copyright assigned to Kern Sibbald as in the current
-code.  Note, prior to November 2004, the code was copyrighted by Kern
-Sibbald and John Walker. When some sort of Bacula entity is created, this
-this copyright will be transferred to that entity.  Hopefully this will
-happen by Q1-2007.
+To avoid future problems concerning changing licensing or
+copyrights, all code contributions more than a hand full of lines
+must be in the Public Domain or have the copyright transferred to
+the Free Software Foundation Europe e.V. with a Fiduciary License
+Agreement (FLA) as in the current code.  Note, prior to
+November 2004, the code was copyrighted by Kern Sibbald and John
+Walker.  After November 2004, the code was copyrighted by Kern
+Sibbald, then on the 15th of November 2006, the copyright was
+transferred to the Free Software Foundation Europe e.V.
 
 Your name should be clearly indicated as the author of the code, and you
 must be extremely careful not to violate any copyrights or use other
 people's code without acknowledging it.  The purpose of this requirement is
-to avoid future copyright, patent, or intellectual property problems.  To
-understand on possible source of future problems, please examine the
-difficulties Mozilla is (was?) having finding previous contributors at
-\elink{ http://www.mozilla.org/MPL/missing.html}
+to avoid future copyright, patent, or intellectual property problems.  
+Please read the LICENSE agreement in the main source code
+directory.  When you sign the Fiduciary License Agreement (FLA)
+and send it in, you are argeeing to the terms of that LICENSE
+file.
+
+To understand the possible source of future problems, please
+examine the difficulties Mozilla is (was?) having finding
+previous contributors at \elink{
+http://www.mozilla.org/MPL/missing.html}
 {http://www.mozilla.org/MPL/missing.html}. The other important issue is to
 avoid copyright, patent, or intellectual property violations as are currently
 (May 2003) being claimed by SCO against IBM. 
 
-Although the copyright will be held by Kern, each developer is expected to
-indicate that he wrote and/or modified a particular module (or file) and
-any other sources.  The copyright assignment may seem a bit unusual, but in
-reality, it is not.  Most large projects require this.  In fact, the
-paperwork associated with making contributions to the Free Software
-Foundation, was for me unsurmountable, so hopefully the rather
-simplified procedure we have will not create any difficulties for
-you.
+Although the copyright will be held by the Free Software
+Foundation Europe e.V., each developer is expected to indicate
+that he wrote and/or modified a particular module (or file) and
+any other sources.  The copyright assignment may seem a bit
+unusual, but in reality, it is not.  Most large projects require
+this.
 
 If you have any doubts about this, please don't hesitate to ask.  The
 objective is to assure the long term servival of the Bacula project. 
 
 Items not needing a copyright assignment are: most small changes,
-enhancements, or bug fixes of 5-10 lines of code.                    
+enhancements, or bug fixes of 5-10 lines of code, which amount to    
+less than 20% of any particular file.
 
-\subsubsection*{Copyright Assignment}
+\subsubsection*{Copyright Assignment -- Fiduciary License Agreement}
 \index{Copyright Assignment}
 \index{Assignment!Copyright}
-\addcontentsline{toc}{subsubsection}{Copyright Assignment}
+\addcontentsline{toc}{subsubsection}{Copyright Assignment -- Fiduciary License Agreement}
 
-Since this is not a commercial enterprise, and I prefer to believe in
+Since this is not a commercial enterprise, and we prefer to believe in
 everyone's good faith, previously developers could assign the copyright by
 explicitly acknowledging that they do so in their first submission.  This
 was sufficient if the developer is independent, or an employee of a
 not-for-profit organization or a university.  However, in an effort to
 ensure that the Bacula code is really clean, beginning in August 2006, all
-previous and future developers with CVS access will be asked to submit a
-copyright assignment.
-
-Any developer who wants to contribute and is employed by a company must get
-a copyright assignment from his employer.  This is to avoid
+previous and future developers with SVN access will be asked to submit a
+copyright assignment (or Fiduciary License Agreement -- FLA),
+which means you agree to the LICENSE in the main source
+directory. It also means that you receive back the right to use
+the code that you have submitted.
+
+Any developer who wants to contribute and is employed by a company should
+either list the employer as the owner of the code, or get
+explicit permission from him to sign the copyright assignment.
+This is because in many
+countries, all work that an employee does whether on company time or in the
+employee's free time is considered to be Intellectual Property of the
+company.  Obtaining official approval or an FLA from the company will avoid
 misunderstandings between the employee, the company, and the Bacula
 project.  A good number of companies have already followed this procedure.
 
-\subsubsection*{Personal Copyright Assignment Statement}
-\index{Copyright!Personal Assignment}
-\index{Personal Copyright Assignment Statement}
-\addcontentsline{toc}{subsubsection}{Personal Copyright Assignment Statement}
+The Fiduciary License Agreement is posted on the Bacula web site at:
+\elink{http://www.bacula.org/FLA-bacula.en.pdf}{http://www.bacula.org/FLA-bacula.en.pdf}
 
-The following statement must be filled out by each non-employed developer
-(please see below for developer's that are employed), signed, and mailed
-to my address (please ask me for my address and I will email it -- I'd prefer
-not to include it here). 
+The instructions for filling out this agreement are also at:
+\elink{http://www.bacula.org/?page=fsfe}{http://www.bacula.org/?page=fsfe}
+
+It should be filled out, then sent to:
 
-\footnotesize
 \begin{verbatim}
-Copyright release and transfer statement.
-   From: <your name>
+     Free Software Foundation Europe
+     Freedom Task Force
+     Sumatrastrasse 25
+     8006 Zürich
+     Switzerland
+\end{verbatim}
 
-   To: Kern Sibbald
-   Concerning: Copyright release and transfer
+Please note that the above address is different from the officially
+registered office mentioned in the document.  When you send in such a
+complete document, please notify me: kern at sibbald dot com.
 
-   The undersigned hereby certifies that he/she is independent
-   and wishes to develop
-   code for and contribute code to the Bacula project for an
-   undetermined period of time.  The copyright as well as all
-   other rights to and interests in such contributed code are
-   hereby transferred to Kern Sibbald.
 
-   Signed in <City, Country> on <Date>:
 
-   <Name of Person>
+\subsection*{The Development Cycle}
+\index{Developement Cycle}
+\index{Cycle!Developement}
+\addcontentsline{toc}{subsubsection}{Development Cycle}
 
+As I noted in the 1.38 ReleaseNotes, version 1.38 was different from prior
+versions because it had a lot more contributions.  I expect that this trend
+will continue.  As a consequence, I am going to modify how I normally do
+development, and instead of making a list of all the features that I will
+implement in the next version, I will personally sign up for one (maybe
+two) projects at a time, and when they are complete, I will release a new
+version.
+
+The difference is that I will have more time to review the new code that is
+being contributed, and will be able to devote more time to a smaller number
+of projects (1.38 had too many new features for me to handle correctly).
+
+I expect that future release schedules will be much the same, and the
+number of new features will also be much the same providing that the
+contributions continue to come -- and they show no signs of let up :-)
+
+\index{Feature Requests}
+{\bf Feature Requests:} \\
+In addition, I would like to "formalize" the feature requests a bit.
+
+Instead of me maintaining an informal list of everything I run into 
+(kernstodo), I would like to maintain a "formal" list of projects.  This 
+means that all new feature requests, including those recently discussed on 
+the email lists, must be formally submitted and approved. 
+
+Formal submission of feature requests will take two forms: \\
+1. non-mandatory, but highly recommended is to discuss proposed new features
+on the mailing list.\\
+2.  Formal submission of an Feature Request in a special format.
+I'll give an example of this below, but you can also find it on the web
+site under "Support -\gt{} Feature Requests".  Since it takes a bit of time to
+properly fill out a Feature Request form, you probably should check on the email list
+first.
+
+Once the Feature Request is received by the keeper of the projects list, it
+will be sent to me, and  I will either accept it, send it back
+asking for clarification, send it to the email list asking for opinions, or
+reject it.
+
+If it is accepted, it will go in the "projects" file (a simple ASCII file) 
+maintained in the main Bacula source directory.
+
+{\bf Implementation of Feature Requests:}\\
+Any qualified developer can sign up for a project.  The project must have
+an entry in the projects file, and the developer's name will appear in the
+Status field.
+
+{\bf How Feature Requests are accepted:}\\
+Acceptance of Feature Requests depends on several things: \\
+1.  feedback from users.  If it is negative, the Feature Request will probably not be
+accepted.  \\
+2.  the difficulty of the project.  A project that is so
+difficult that I cannot imagine finding someone to implement probably won't
+be accepted. \\
+ 3.  whether or not the Feature Request fits within the
+current stategy of Bacula (for example an Feature Request that requests changing the
+tape to tar format would not be accepted, ...)
+
+{\bf How Feature Requests are prioritized:}\\
+Once an Feature Request is accepted, it needs to be implemented.  If you
+can find a developer for it, or one signs up for implementing it, then the
+Feature Request becomes top priority (at least for that developer).
+
+Between releases of Bacula, we will generally solicit Feature Request input
+for the next version, and by way of this email, we suggest that you send
+discuss and send in your Feature Requests for the next release.  Please
+verify that the Feature Request is not in the current list (attached to this email).
+
+Once users have had several weeks to submit Feature Requests, the keeper of the
+projects list will
+organize them, and request users to vote on them.  This will allow fixing
+prioritizing the Feature Requests.  Having a priority is one thing, but
+getting it implement is another thing -- we are hoping that the Bacula
+community will take more responsibility for assuring the implementation of
+accepted Feature Requests.
+
+Feature Request format:
+\begin{verbatim}
+============= Empty Feature Request form ===========
+Item n:   One line summary ...
+  Date:   Date submitted
+  Origin: Name and email of originator.
+  Status:
+
+  What:   More detailed explanation ...
+
+  Why:    Why it is important ...
+
+  Notes:  Additional notes or features (omit if not used)
+============== End Feature Request form ==============
 \end{verbatim}
-\normalsize
 
-This release/transfer statement must be sent to:
-Kern Sibbald
-Address-to-be-given
+\begin{verbatim}
+============= Example Completed  Feature Request form ===========
+Item 1:   Implement a Migration job type that will move the job
+          data from one device to another.
+  Origin: Sponsored by Riege Sofware International GmbH. Contact:
+          Daniel Holtkamp <holtkamp at riege dot com>
+  Date:   28 October 2005
+  Status: Partially coded in 1.37 -- much more to do. Assigned to
+          Kern.
+
+  What:   The ability to copy, move, or archive data that is on a
+          device to another device is very important.
 
-If you wish to retain the full rights to use the software you
-have contributed in different projects, this is not a problem. Just
-request a perpetual non-exclusive license before sending in your
-copyright assignment.  See the file <bacula-source>/src/lib/tls.c
-for an example of such a license.
+  Why:    An ISP might want to backup to disk, but after 30 days
+          migrate the data to tape backup and delete it from
+          disk.  Bacula should be able to handle this
+          automatically.  It needs to know what was put where,
+          and when, and what to migrate -- it is a bit like
+          retention periods.  Doing so would allow space to be
+          freed up for current backups while maintaining older
+          data on tape drives.
 
+  Notes:  Migration could be triggered by:
+           Number of Jobs
+           Number of Volumes
+           Age of Jobs
+           Highwater size (keep total size)
+           Lowwater mark
+=================================================
+\end{verbatim}
 
-\subsubsection*{Corporate Copyright Assignment Statement}
-\index{Copyright!Corporate Assignment}
-\index{Corporate Copyright Assignment Statement}
-\addcontentsline{toc}{subsubsection}{Corporate Copyright Assignment Statement}
 
-The following statement must be filled out by the employer, signed, and
-mailed to my address (please ask me for my address and I will email it --
-I'd prefer not to include it here).
+\subsection*{Bacula Code Submissions and Projects}
+\index{Submissions and Projects}
+\addcontentsline{toc}{subsection}{Code Submissions and Projects}
+
+Getting code implemented in Bacula works roughly as follows:
+
+\begin{itemize}
+
+\item Kern is the project manager, but prefers not to be a "gate keeper".
+
+\item  There are growing numbers of contributions (very good).
+
+\item Some contributions come in  the form of relatively small patches,
+     which Kern reviews, integrates, documents, tests, and maintains.
+
+\item All Bacula developers take full
+   responsibility for writing the code, posting as patches so that I can
+   review it as time permits, integrating it at an appropriate time,
+   responding to my requests for tweaking it (name changes, ...),
+   document it in the code, document it in the manual (even though
+   their mother tongue is not English), test it, develop and commit
+   regression scripts, and answer in a timely fashion all bug reports --
+   even occassionally accepting additional bugs :-)
+
+   This is a sustainable way of going forward with Bacula, and the
+   direction that the project will be taking more and more.  For
+   example, in the past, we have had some very dedicated programmers
+   who did major projects. However, these
+   programmers due to outside obligations (job responsibilities change of
+   job, school duties, ...) could not continue to maintain the code.  In
+   those cases, the code suffers from lack of maintenance, sometimes I
+   patch it, sometimes not.  In the end, the code gets dropped from the
+   project (there are two such contributions that are heading in that
+   direction).  When ever possible, we would like to avoid this, and 
+   ensure a continuation of the code and a sharing of the development,
+   debugging, documentation, and maintenance responsibilities.
+\end{itemize}
+
+
+\subsection*{SVN Usage}
+\index{SVN Usage}
+\addcontentsline{toc}{subsection}{SVN Usage}
+
+Please note that if you are familar with CVS, SVN is very
+similar (and better), but there can be a few surprising
+differences.
+
+The *entire* Bacula  SourceForge.net Subversion repository can be
+checked out through SVN with the following command:
+
+\begin{verbatim}
+svn checkout https://bacula.svn.sourceforge.net/svnroot/bacula bacula
+\end{verbatim}
+
+With the above command, you will get everything, which is a very large
+amount of data:
 
-\footnotesize
 \begin{verbatim}
-Copyright release and transfer statement.
-   <On company letter head>
+branches/
+  Branch-1.32a/
+  ...
+  Branch-2.0/
+  import/
+  vendor/
+tags/
+  Release-1.1/
+  ...
+  Release-2.0.2/
+trunk/
+  bacula/
+  docs/
+  gui/
+  regress/
+  rescue/
+\end{verbatim}
+
+Note, you should NEVER commit code to any checkout that you have
+done of a tag.  All tags (e.g. Release-1.1, ... Release-2.0.2) 
+should be considered read-only.
 
-   To: Kern Sibbald
-   Concerning: Copyright release and transfer
+You may commit code to the most recent item in
+branches (in the above the most recent one is Branch-2.0).  If
+you want to commit code to an older branch, then please contact
+Kern first.
 
-   <Company, Inc> is hereby agrees that <names-of-developers> and
-   other employees of <Company, Inc> are authorized to develop
-   code for and contribute code to the Bacula project for an
-   undetermined period of time.  The copyright as well as all
-   other rights to and interests in such contributed code are
-   hereby transferred to Kern Sibbald.
+You may create your own tags and/or branches, but they should
+have a name clearly distinctive from Branch-, Release-, or Beta-,
+which are official names used by the project.  If you create a
+tag, then you should NEVER commit code to it, for the same 
+reason noted above -- it should serve as a marker for something
+you released.  If you create a branch, then you are free to
+commit to it as you wish.
 
-   Signed in <City, Country> on <Date>:
+You may, of course, commit to the trunk.
 
-   <Name of Person>, <Position in Company, Inc>
+In summary:
 
+\begin{verbatim}
+branches
+  Branch-nnn
+tags
+  Release-nnn
+  Beta-nnn
+\end{verbatim}
+
+are reserved names to be created only by the project manager (or
+with his OK), where the nnn is any sequence of numbers and
+periods (e.g. 2.0, 2.0.1, ...).  
+
+In addition all tags even those that you create are read-only
+forever. Typically tags represent release points either in the
+trunc or in a branch.
+
+
+Coming back to getting source code. 
+If you only want the current Bacula source code, you could use:
+
+\begin{verbatim}
+svn checkout https://bacula.svn.sourceforge.net/svnroot/bacula/trunk/bacula bacula
+\end{verbatim}
+
+To view what is in the SVN, point your browser at the following URL:
+http://bacula.svn.sourceforge.net/viewvc/bacula/  
+
+Many of the Subversion (svn) commands are almost identical to those that
+you have used for cvs, but some (such as a checkout) can have surprising
+results, so you should take a careful look at the documentation. 
+
+Robert has kindly provided the following documentation on the new
+svn repository and how to use it:
+
+Here is the list of branches:
+\begin{verbatim}
+        Branch-1.32a
+        Branch-1.32e
+        Branch-1.34.2
+        Branch-1.34.5
+        Branch-1.36
+        Branch-1.36.1
+        Branch-1.36.2
+        Branch-1.38
+        Branch-2.0
+        import
+        vendor
+\end{verbatim}
+
+The list of tags is:
+\begin{verbatim}
+        Release-1.1     Release-1.19    Release-1.19a   Release-1.19b
+        Release-1.20    Release-1.21    Release-1.22    Release-1.23
+        Release-1.23a   Release-1.24    Release-1.25    Release-1.25a
+        Release-1.26    Release-1.27    Release-1.27a   Release-1.27b
+        Release-1.27c   Release-1.28    Release-1.29    Release-1.30
+        Release-1.31    Release-1.31a   Release-1.32    Release-1.32a
+        Release-1.32b   Release-1.32c   Release-1.32d   Release-1.32e
+        Release-1.32f   Release-1.32f-2 Release-1.32f-3 Release-1.32f-4
+        Release-1.32f-5 Release-1.34.0  Release-1.34.1  Release-1.34.3
+        Release-1.34.4  Release-1.34.5  Release-1.34.6  Release-1.35.1
+        Release-1.35.2  Release-1.35.3  Release-1.35.6  Release-1.35.7
+        Release-1.35.8  Release-1.36.0  Release-1.36.1  Release-1.36.2
+        Release-1.36.3  Release-1.38.0  Release-1.38.1  Release-1.38.10
+        Release-1.38.11 Release-1.38.2  Release-1.38.3  Release-1.38.4
+        Release-1.38.5  Release-1.38.6  Release-1.38.7  Release-1.38.8
+        Release-1.38.9  Release-1.8.1   Release-1.8.2   Release-1.8.3
+        Release-1.8.4   Release-1.8.5   Release-1.8.6   Release-2.0.0
+        Release-2.0.1   Release-2.0.2
+\end{verbatim}
+
+Here is a list of commands to get you started.  The recommended book is
+"Version Control with Subversion", by Ben Collins-Sussmann,
+Brian W. Fitzpatrick, and Michael Pilato, O'Reilly.  The book is
+Open Source, so it is also available on line at:
+
+\begin{verbatim}
+   http://svnbook.red-bean.com
 \end{verbatim}
-\normalsize
 
-This release/transfer statement must be sent to:
-Kern Sibbald
-Address-to-be-given
+Get a list of commands
 
-If you wish to retain the full rights to use the software you
-have contributed in different projects, this is not a problem. Just
-request a perpetual non-exclusive license before sending in your
-copyright assignment. See the file <bacula-source>/src/lib/tls.c
-for an example of such a license.
+\begin{verbatim}
+   svn help
+\end{verbatim}
 
+Get a help with a command
 
-\subsection*{Basic CVS Usage}
-\index{Basic CVS Usage}
-\index{CVS}
-\addcontentsline{toc}{subsection}{Basic CVS Usage}
+\begin{verbatim}
+   svn help command
+\end{verbatim}
 
-The Bacula CVS is kept at Source Forge. If you are not a developer,
-you only be able to access the public CVS, which runs about 6 hours behind
-the developer's CVS.  If you are a developer, then you will have immediate
-access to "the" CVS and any changes ("commit") that you make will be
-immediately seen by other developers.
+Checkout the HEAD revision of all modules from the project into the
+directory bacula-new
 
-For developer access to the CVS, go to the Bacula page on Source Forge
-and click on the CVS menu item.  Then follow the instructions for
-installing your SSH public key.  It may take a few hours until the
-key is actually installed, and then you will have access to the CVS.
+\begin{verbatim}
+   svn co https://bacula.svn.sourceforge.net/svnroot/bacula/trunk bacula.new
+\end{verbatim}
 
-The Bacula CVS is divided into the following CVS "projects" or "modules".
+Checkout the HEAD revision of the bacula module into the bacula subdirectory
 
 \begin{verbatim}
+   svn checkout https://bacula.svn.sourceforge.net/svnroot/bacula/trunk/bacula
+\end{verbatim}
 
-  bacula              (Bacula source code)
-  docs                (Bacula documentation)
-  gui                 (Some of the GUI programs that do not use
-                       the Bacula core code)
-  rescue              (Bacula CDROM rescue code)
-  regress             (Bacula regression scripts)
-  ryol                (Roll your own Linux -- incomplete project)
+See which files have changed in the working copy
 
+\begin{verbatim}
+   svn status
 \end{verbatim}
 
-Most of you will want either the Bacula source (bacula) and/or the
-documents (docs).
+See which files are out of date
 
-To get the source for a project, you must check it out ("checkout"), which
-you do usually once.
+\begin{verbatim}
+   svn status -u
+\end{verbatim}
 
-\subsubsection*{Public CVS Access}
-\index{Public CVS Access}
-\addcontentsline{toc}{subsubsection}{Public CVS Access}
+Add a new file file.c
 
-The first time you checkout the code for each project, you will need to
-tell the cvs program where the CVS repository is.  The procedure for
-checking out code from the public CVS is:
+\begin{verbatim}
+   svn add file.c
+\end{verbatim}
+
+Create a new directory
 
 \begin{verbatim}
-cvs -d:pserver:anonymous@cvs.sourceforge.net:/cvsroot/bacula login 
+   svn mkdir newdir
 \end{verbatim}
-Then when it prompts for the password for {\bf anonymous}, simply
-press the Enter key.  The above command is necessary only once
-the very first time you login. Then enter the following command:
+
+Delete an obsolete file
 
 \begin{verbatim}
-cvs -z3 -d:pserver:anonymous@cvs.sourceforge.net:/cvsroot/bacula co -P bacula
+   svn delete file.c
 \end{verbatim}
 
-The above will place the contents of the bacula module in a directory
-named {\bf bacula} in the current directory.  This data will come
-from the public CVS, which typically runs 6 hours to a day behind the
-developer's CVS. Once you have created a copy of the CVS, you can use 
-the commands listed below under the title CVS Usage.
+Rename a file
 
-\subsubsection*{Developer CVS Access}
-\index{Developer CVS Access}
-\addcontentsline{toc}{subsubsection}{Developer CVS Access}
+\begin{verbatim}
+   svn move file.c newfile.c
+\end{verbatim}
 
-If you are registered as a Bacula developer (contact Kern about this),
-you may access the developer's CVS using:
+Move a file to a new location
 
 \begin{verbatim}
-export CVS_RSH=ssh
-export CVSROOT=:ext:<nnnn>@cvs.bacula.sourceforge.net:/cvsroot/bacula
+   svn move file.c ../newdir/file.c
 \end{verbatim}
 
-where you replace \lt{}nnnn\gt{} by your Source Forge user name.
+Copy a file retaining the original history in the new file
 
-Then do:
+\begin{verbatim}
+   svn copy file.c newfile.c
+\end{verbatim}
+
+Update the working copy with the outstanding changes
 
 \begin{verbatim}
-cvs -z3 checkout -d <directory> bacula
+   svn update
 \end{verbatim}
 
-where you replace \lt{}directory\gt{} by the name of the directory you want
-to contain the Bacula source code.  If you want the docs, replace the
-word "bacula" on the above line by "docs" and be sure to put it in
-a different directory.  The -z3 just tells CVS to use compression during
-the transmission, which makes things go faster. There is no need to
-do the anonymous login as is the case for non-developers.
+Compare working copy with the repository
 
-The above command should generate output that looks a bit like the
-following:
+\begin{verbatim}
+   svn diff file.c
+\end{verbatim}
+
+Commit the changes in the local working copy
 
 \begin{verbatim}
-cvs checkout: Updating bacula
-U bacula/Makefile
-U bacula/bar.c
-U bacula/foo.c
-U bacula/main.c
-...
+   svn commit
 \end{verbatim}
 
-\subsubsection*{CVS Usage}
-\index{CVS Usage}
-\addcontentsline{toc}{subsubsection}{CVS Usage}
+Specify which files are ignored in the current directory
 
-The commands that follow with the exception of the {\bf commit} 
-work the same whether you are accessing the public CVS or
-the developer's CVS.
+\begin{verbatim}
+   svn propedit svn:ignore .
+\end{verbatim}
 
-Let's assume you used the name "bacula" for the directory, so your
-command was:
+Mark a file to be executable
 
 \begin{verbatim}
-cvs -z3 checkout -d bacula bacula
+   svn propset svn:executable '*' prog.sh
 \end{verbatim}
 
-When the command is done, simply do:
+Unmark a file as executable
 
 \begin{verbatim}
-cd bacula
+   svn propdel svn:executable prog.sh
+\end{verbatim}
+
+List a file's properties
+
+\begin{verbatim}
+   svn proplist file.c
+\end{verbatim}
+
+Create a branch for a new version
+
+\begin{verbatim}
+   svn copy https://bacula.svn.sourceforge.net/svnroot/bacula/trunk \
+          https://bacula.svn.sourceforge.net/svnroot/bacula/branches/Branch-2.1
 \end{verbatim}
 
+Tag a version for a new release
+
+\begin{verbatim}
+   svn copy https://bacula.svn.sourceforge.net/svnroot/bacula/branches/Branch-2.1 \
+          https://bacula.svn.sourceforge.net/svnroot/bacula/branches/Release-2.1
+\end{verbatim}
 
-and then build Bacula.  You will notice a lot of extra CVS directories
-in the source code.  Don't ever change or delete them, or you will mess up
-your copy of the project. Also, do not rename or delete any of the files
-in your copy of the repository or you may have problems.  Any files that
-you change will remain only on your system until you do a "commit", which
-is explained later.
 
 Let's say you are working in the directory scripts.  You would then do:
 
@@ -333,7 +593,7 @@ when you are happy with your changes, you can do the following:
 
 \begin{verbatim}
 cd bacula   (to your top level directory)
-cvs diff -u >my-changes.patch
+svn diff  my-changes.patch
 \end{verbatim}
 
 When the command is done, you can look in the file my-changes.patch
@@ -342,19 +602,19 @@ repository.  Make sure that you understand all the changes that
 it reports before proceeding.  If you modified files that you do
 do not want to commit to the main repository, you can simply delete
 them from your local directory, and they will be restored from the
-repository with the "cvs update" that is shown below.  Normally, you
+repository with the "svn update" that is shown below.  Normally, you
 should not find changes to files that you do not want to commit, and
 if you find yourself in that position a lot, you are probably doing
 something wrong.
 
-Let's assume that now you want to commit your changes to the main CVS
-repository.
+Let's assume that now you want to commit your changes to the main
+SVN repository.
 
 First do:
 
 \begin{verbatim}
-cvs bacula
-cvs update
+cd bacula
+svn update
 \end{verbatim}
 
 When you do this, it will pull any changes made by other developers into
@@ -365,10 +625,10 @@ you can examine the files it claims have conflicts and look for \lt{}\lt{}\lt{}\
 or look in the .rej files that it creates.  If you have problems, just ask
 on the developer's list.
 
-Note, doing the above "cvs update" is not absolutely necessary.  There are
+Note, doing the above "svn update" is not absolutely necessary.  There are
 times when you may be working on code and you want to commit it, but you
 explicitly do not want to move up to the latest version of the code in
-the CVS.  If that is the case, you can simply skip the "cvs update" and
+the SVN.  If that is the case, you can simply skip the "svn update" and
 do the commit shown below.  If the commit fails because of a conflict, it
 will tell you, and you must resolve the conflict before it will permit
 you to do the commit.
@@ -377,14 +637,14 @@ Once your local copy of the repository has been updated, you can now
 commit your changes:
 
 \begin{verbatim}
-cvs commit -m "Some comment about what you changed"
+svn commit -m "Some comment about what you changed"
 \end{verbatim}
 
 or if you really only want to commit a single file, you can
 do:
 
 \begin{verbatim}
-cvs commit -m "comment" scripts/file-I-edited
+svn commit -m "comment" scripts/file-I-edited
 \end{verbatim}
 
 Note, if you have done a build in your directory, or you have added
@@ -393,8 +653,8 @@ actually in the repository.  For example, none of the object files
 are stored in the repository, so when you do a commit, those object
 files will simply be ignored.
 
-If you want to add new files or remove files from the main CVS
-repository, and you are not experienced with CVS, please ask Kern
+If you want to add new files or remove files from the main SVN
+repository, and you are not experienced with SVN, please ask Kern
 to do it.  If you follow the simple steps above, it is unlikely that
 you will do any damage to the repository, and if you do, it is always
 possible for us to recover, but it can be painful.
@@ -409,131 +669,55 @@ doing your commits, your commit will effect only that directory.  As
 long as you are careful only to change files that you want changed,
 you have little to worry about.
 
-\subsection*{The Development Cycle}
-\index{Developement Cycle}
-\index{Cycle!Developement}
-\addcontentsline{toc}{subsubsection}{Development Cycle}
-
-As I noted in the 1.38 ReleaseNotes, version 1.38 was different from prior
-versions because it had a lot more contributions.  I expect that this trend
-will continue.  As a consequence, I am going to modify how I normally do
-development, and instead of making a list of all the features that I will
-implement in the next version, I will personally sign up for one (maybe
-two) projects at a time, and when they are complete, I will release a new
-version.
-
-The difference is that I will have more time to review the new code that is
-being contributed, and will be able to devote more time to a smaller number
-of projects (1.38 had too many new features for me to handle correctly).
-
-I expect that future release schedules will be much the same, and the
-number of new features will also be much the same providing that the
-contributions continue to come -- and they show no signs of let up :-)
-
-\index{Feature Requests}
-{\bf Feature Requests:} \\
-In addition, I would like to "formalize" the feature requests a bit.
-
-Instead of me maintaining an informal list of everything I run into 
-(kernstodo), I would like to maintain a "formal" list of projects.  This 
-means that all new feature requests, including those recently discussed on 
-the email lists, must be formally submitted and approved. 
-
-Formal submission of feature requests will take two forms: \\
-1. non-mandatory, but highly recommended is to discuss proposed new features
-on the mailing list.\\
-2.  Formal submission of an Feature Request in a special format.
-I'll give an example of this below, but you can also find it on the web
-site under "Support -\gt{} Feature Requests".  Since it takes a bit of time to
-properly fill out a Feature Request form, you probably should check on the email list
-first.
-
-Once I receive the Feature Request, I will either accept it, send it back
-asking for clarification, send it to the email list asking for opinions, or
-reject it.
-
-If it is accepted, it will go in the "projects" file (a simple ASCII file) 
-maintained in the main Bacula source directory.
+\subsection*{Subversion Resources}
+\index{Subversion (svn) Resources}
+\addcontentsline{toc}{subsection}{Subversion Resources}
 
-{\bf Implementation of Feature Requests:}\\
-Any qualified developer can sign up for a project.  The project must have
-an entry in the projects file, and the developer's name will appear in the
-Status field.
-
-{\bf How Feature Requests are accepted:}\\
-Acceptance of Feature Requests depends on several things: \\
-1.  feedback from users.  If it is negative, the Feature Request will probably not be
-accepted.  \\
-2.  the difficulty of the project.  A project that is so
-difficult that I cannot imagine finding someone to implement probably won't
-be accepted. \\
- 3.  whether or not the Feature Request fits within the
-current stategy of Bacula (for example an Feature Request that requests changing the
-tape to tar format would not be accepted, ...)
-
-{\bf How Feature Requests are prioritized:}\\
-Once an Feature Request is accepted, it needs to be implemented.  If you
-can find a developer for it, or one signs up for implementing it, then the
-Feature Request becomes top priority (at least for that developer).
-
-Between releases of Bacula, I will generally solicit Feature Request input
-for the next version, and by way of this email, I suggest that you send
-discuss and send in your Feature Requests for the next release.  Please
-verify that the Feature Request is not in the current list (attached to this email).
+\begin{verbatim}
+cvs2svn Statistics:
+------------------
+Total CVS Files:              3286
+Total CVS Revisions:         28924
+Total Unique Tags:              63
+Total Unique Branches:          11
+CVS Repos Size in KB:       232421
+Total SVN Commits:            4116
+First Revision Date:    Tue Apr 23 12:42:57 2002
+Last Revision Date:     Tue Feb  6 06:37:57 2007
+\end{verbatim}
 
-Once users have had several weeks to submit Feature Requests, I will
-organize them, and request users to vote on them.  This will allow fixing
-prioritizing the Feature Requests.  Having a priority is one thing, but
-getting it implement is another thing -- I am hoping that the Bacula
-community will take more responsibility for assuring the implementation of
-accepted Feature Requests.
+The new Subversion repository size on Robert's machine:
 
-Feature Request format:
 \begin{verbatim}
-============= Empty Feature Request form ===========
-Item n:   One line summary ...
-  Date:   Date submitted
-  Origin: Name and email of originator.
-  Status:
+4.0K    bacula-tst/dav
+12K     bacula-tst/locks
+40K     bacula-tst/hooks
+16K     bacula-tst/conf
+190M    bacula-tst/db/revs
+17M     bacula-tst/db/revprops
+4.0K    bacula-tst/db/transactions
+206M    bacula-tst/db
+206M    bacula-tst
+\end{verbatim}
 
-  What:   More detailed explanation ...
 
-  Why:    Why it is important ...
+Main Subversion Web Page
+\elink{http://subversion.tigris.org}{http://subversion.tigris.org}
 
-  Notes:  Additional notes or features (omit if not used)
-============== End Feature Request form ==============
-\end{verbatim}
+Subversion Book
+\elink{http://svnbook.red-bean.com}{http://svnbook.red-bean.com}
 
-\begin{verbatim}
-============= Example Completed  Feature Request form ===========
-Item 1:   Implement a Migration job type that will move the job
-          data from one device to another.
-  Origin: Sponsored by Riege Sofware International GmbH. Contact:
-          Daniel Holtkamp <holtkamp at riege dot com>
-  Date:   28 October 2005
-  Status: Partially coded in 1.37 -- much more to do. Assigned to
-          Kern.
+Subversion Clients
+\elink{http://subversion.tigris.org/project\_packages.html}{http://subversion.tigris.org/project\_packages.html}
 
-  What:   The ability to copy, move, or archive data that is on a
-          device to another device is very important.
+ (For Windows users the TortoiseSVN package is awesome)
 
-  Why:    An ISP might want to backup to disk, but after 30 days
-          migrate the data to tape backup and delete it from
-          disk.  Bacula should be able to handle this
-          automatically.  It needs to know what was put where,
-          and when, and what to migrate -- it is a bit like
-          retention periods.  Doing so would allow space to be
-          freed up for current backups while maintaining older
-          data on tape drives.
+GUI UNIX client link
+\elink{http://rapidsvn.tigris.org/}{http://rapidsvn.tigris.org/}
+
+A nice KDE GUI client:
+kdesvn
 
-  Notes:  Migration could be triggered by:
-           Number of Jobs
-           Number of Volumes
-           Age of Jobs
-           Highwater size (keep total size)
-           Lowwater mark
-=================================================
-\end{verbatim}
 
 
 \subsection*{Developing Bacula}
@@ -799,8 +983,8 @@ so be conservative in your use of C++ features.
 \addcontentsline{toc}{subsubsection}{Do Not Use}
 
 \begin{itemize}
-\item STL -- it is totally incomprehensible. 
-   \end{itemize}
+ \item STL -- it is totally incomprehensible. 
+\end{itemize}
 
 \subsubsection*{Avoid if Possible}
 \index{Possible!Avoid if}
@@ -814,27 +998,31 @@ so be conservative in your use of C++ features.
    to the routines accepting the packet (typically callback routines).
    However, declaring "void *buf" is a bad idea.  Please use the
    correct types whenever possible.
+
 \item Using undefined storage specifications such as (short, int, long,
-   long long, size_t ...).  The problem with all these is that the number of bytes
+   long long, size\_t ...).  The problem with all these is that the number of bytes
    they allocate depends on the compiler and the system.  Instead use
-   Bacula's types (int8_t, uint8_t, int32_t, uint32_t, int64_t, and 
-   uint64_t).  This guarantees that the variables are given exactly the
-   size you want. Please try at all possible to avoid using size_t ssize_t
+   Bacula's types (int8\_t, uint8\_t, int32\_t, uint32\_t, int64\_t, and 
+   uint64\_t).  This guarantees that the variables are given exactly the
+   size you want. Please try at all possible to avoid using size\_t ssize\_t
    and the such. They are very system dependent.  However, some system
    routines may need them, so their use is often unavoidable.
+
 \item Returning a malloc'ed buffer from a subroutine --  someone will forget
    to release it. 
-\item Using reference variables -- it allows subroutines to  create side
-   effects. Reference variables are OK, if you are sure the variable 
-   *always* exists, and you are sure you can handle the side effects of
-   a subroutine changing the "pointer".
-\item Heap allocation (malloc) unless needed -- it is expensive. 
+
+\item Heap allocation (malloc) unless needed -- it is expensive. Use
+      POOL\_MEM instead.
+
 \item Templates -- they can create portability problems. 
+
 \item Fancy or tricky C or C++ code, unless you give a  good explanation of
    why you used it. 
+
 \item Too much inheritance -- it can complicate the code,  and make reading it
    difficult (unless you are in love  with colons) 
-   \end{itemize}
+
+\end{itemize}
 
 \subsubsection*{Do Use Whenever Possible}
 \index{Possible!Do Use Whenever}
@@ -843,9 +1031,17 @@ so be conservative in your use of C++ features.
 
 \begin{itemize}
 \item Locking and unlocking within a single subroutine.  
+
+\item A single point of exit from all subroutines. A goto is 
+     perfectly OK to use to get out early, but only to a label
+     named bail\_out, and possibly an ok\_out.  See current code
+     examples.
+
 \item Malloc and free within a single subroutine.  
+
 \item Comments and global explanations on what your code or  algorithm does. 
-   \end{itemize}
+
+\end{itemize}
 
 \subsubsection*{Indenting Standards}
 \index{Standards!Indenting}