How to work with bazaar on the command line: Difference between revisions

From OpenPetra Wiki
Jump to navigation Jump to search
(Replaced content with "We are not using Bazaar anymore, but Git.")
Tag: Replaced
 
(11 intermediate revisions by 3 users not shown)
Line 1: Line 1:
= Alternative: use the GUI for bazaar =
We are not using Bazaar anymore, but Git.
If the command line is not your prefered way of doing things, please see [[How to work with bazaar through the GUI on Windows]]
 
= Setup your environment =
 
Install bazaar.
 
Set your E-Mail address:
bzr whoami "John Doe <john.doe@gmail.com>"
 
Create a directory where you want to store all bazaar checkout you are using with openpetra, e.g. C:\openpetra\bzr. Especially when using Windows 7 it is recommended to create a local directory (e.g. on C:) and not one on the network as otherwise compiling with NAnt can give problems.Compiling from a network drive gave the following error on Windows 7:
System.Security.SecurityException: Request for the permission of type 'System.Security.Permissions.FileIOPermission, mscorlib, Version=2.0.0.0, ... failed
 
Go into this directory and create a shared repository for holding all branches you checkout:
C:\openpetra\bzr>bzr init-repo --no-trees ./
Shared repository (format: 2a)
Location:
  shared repository: .
C:\openpetra\bzr>
 
== Configure your account on Launchpad ==
You only need to do this once!
# First get an account on Launchpad, which is a service provided by the company Canonical, who develop Ubuntu and Bazaar: https://login.launchpad.net/+new_account
# Create a public and private key on launchpad. This is explained [https://help.launchpad.net/YourAccount/CreatingAnSSHKeyPair here]. It is quite important to execute pageant and to load the private key into pageant.
# In your bazaar, you need to tell your launchpad username: <code>bzr launchpad-login LAUNCHPADUSERID</code>
 
== Line Ending issues ==
To avoid problems with the line endings, and the code generators, on Windows create the file <code>C:\Documents and Settings\''My User''\Application Data\bazaar\2.0\rules</code> (on Windows 7: <code>C:\Users\''My User''\AppData\Roaming\bazaar\2.0\rules</code>) and on Linux <code>$BZR_HOME/.bazaar/rules</code> with this content:
<pre>
[name *.cs]
eol = native
[name *.csproj]
eol = native
[name *.sln]
eol = native
[name *.yaml]
eol = native
[name *.xml]
eol = native
[name *.config]
eol = native
[name *.build]
eol = native
[name *.js]
eol = native
[name *.html]
eol = native
[name *.htm]
eol = native
[name *.sql]
eol = native
</pre>
See also http://doc.bazaar.canonical.com/development/en/user-reference/eol-help.html
 
= Create a working branch =
Go into your shared rep directory created above, and type:
bzr branch lp:openpetraorg lp:~LAUNCHPADUSERID/openpetraorg/mytest20111115
 
This will create a branch on Launchpad based on the trunk of openpetraorg (lp:openpetraorg), that is associated with the openpetraorg project.
 
Our naming convention for branches is to use dev_0000<Mantis Issue number>_<keywords to describe the issue>. So for example it could be: dev_0000167_import_cc_hierarchy
 
You could also create branches that are unrelated to the openpetraorg project: eg. lp:~tpokorra/+junk/BRANCHNAME
 
You can branch on a specific revision by using the -r parameter, eg.
bzr branch lp:openpetraorg -r1026.1.4 lp:~LAUNCHPADUSERID/openpetraorg/mytest20111115_rel_0_2_4
 
To see all branches in OpenPetra, visit this website:
https://code.launchpad.net/openpetraorg
 
= Get files =
On the website https://code.launchpad.net/openpetraorg you could see the history of all active branches.
 
Now you could checkout a branch:
 
In the shared repo from above, e.g. C:\openpetra\bzr:
bzr checkout lp:~tpokorra/openpetraorg/mytest20111115
 
For info about your branch, execute in the directory of your checkout:
bzr info
 
= See changed files =
bzr status
 
= Graphical Interface =
 
Call the explorer in directory of the branch you are interested in:
bzr explorer ./
 
 
== Rebase branch / Merge from trunk ==
For this commands you need to be in the directory, where the checkout files are in.
 
Before doing the merge in your workspace please first commit your changes to your branch at Launchpad. This makes it easier later for the core-development team.
 
For the first rebase of the branch, you need to add the info, from where to merge:
bzr merge lp:openpetraorg
This information you see on the operation
bzr info
 
For the next rebase merges, following command is working:
bzr merge
 
Checkin the changes:
bzr commit --fixes op:<Mantis Tracker id of the bug that was fixed in this commit>
 
Summarized the order would be:
# do changes in your local workspace
# commit them to the launchpad-branch
# merge from trunk
# commit trunk changes to the launchpad-branch
# go back to 1.
 
If you want your changes to be merged into the OpenPetra bzr, use the link '''Propose for merging''' on your Launchpad code page. It is recommended to have small branches for each feature that you want to go upstream. You will not be able to reuse a branch, after it has been merged into openpetra trunk, since we want to avoid criss cross merges etc.
 
== Update a branch with the newest info from remote ==
Needed for the getting the newest changes for trunk or for branches, where more than one person is working on:
bzr update
 
 
== Resolve conflicts during merge or update ==
 
http://doc.bazaar.canonical.com/bzr.2.2/en/user-reference/conflict-types-help.html and http://doc.bazaar.canonical.com/bzr.2.2/en/user-guide/resolving_conflicts.html include an overview about problems, which could arise and how they are fixed.
 
The command
bzr conflicts
shows all conflicts, the command
bzr resolve
marks conflicts as resolved.
 
= Back out a commit =
 
Backing out a commit is done by merging. First, you should identify the revision number, e.g. 284.
Then you are able to undo the commit by merging the difference between 284 and 283:
bzr merge -r 284..283 ./
bzr commit
 
= Frequently asked questions =
* This can happen when cancelling during a commit, and probably in other situations too. You will get the error the next time your are attempting to commit.
 
Solution: open the command line console (eg. cmd.exe), and change into the directory of your branch, and run:
  bzr break-lock
 
* I you get a "bzr: ERROR: paramiko.SSHException: lost ssh-agent" error on Windows 7 64-bit then try to run pageant not as Administrator but as normal user.
 
* If you get a message like "Could not open a connection to your authentication agent" please have a look [http://forum.slicehost.com/comments.php?DiscussionID=3385 here] or [http://www.finrik.at/content/sshadd-could-not-open-connection-your-authentication-agent here]

Latest revision as of 04:35, 16 March 2023

We are not using Bazaar anymore, but Git.