source: tailor/README @ 198

Revision 198, 5.9 KB checked in by lele@…, 8 years ago (diff)

Expanded a little the note on conflicts

Line 
1About
2=====
3
4tailor.py is a tool to migrate changesets between CVS, Subversion, and
5darcs repositories.
6
7This script makes it easier to keep the upstream changes merged in
8a branch of a product, storing needed information such as the upstream
9URI and revision in special properties on the branched directory.
10
11The following ascii-art illustrates the usual scenario::
12
13                           +------------+            +------------+
14  +--------------+         | Immutable  |            | Working    |
15  | Upstream CVS |-------->| darcs      |----------->| darcs      |
16  | repository   | tailor  | repository | darcs pull | repository |
17  +--------------+         +------------+            +------------+
18                                                           |^         
19                                                           ||
20                                                           ||
21                                                           v|
22                                                          User
23
24Ideally you should be able to swap and replace "CVS server" and "darcs
25repository" with any combination of `CVS`, `Subversion` and `darcs`.
26
27
28Installation
29============
30
31tailor.py is written in Python, and thus Python must be installed on
32your system to use it. Since it relays on external tools to do the
33real work such as `cvs`, `darcs` and `svn`, they need to be installed
34as well.
35
36Make tailor.py executable::
37
38 $ chmod +x tailor.py
39
40You can either run tailor.py where it is currently located, or move it
41along with the vcpx directory to a location in your PATH.
42
43
44Examples
45========
46
471. Bootstrap a new tailored project, starting at upstream revision 10::
48
49  $ tailor.py -b -s svn -R http://svn.server/Product -r 10 ~/darcs/MyProduct
50
512. Bootstrap a new product, fetching from CVS and storing under SVN:
52   this will create the directory "~/svnwc/cmfcore"; "~/svnwc" must be
53   already under SVN::
54
55  $ tailor.py --source-kind cvs --target-kind svn --bootstrap \
56              --repository :pserver:cvs.zope.org:/cvs-repository \
57              --module CMF/CMFCore ~/svnwc/cmfcore
58 
593. Showing each command bootstrap a new DARCS repos in
60   "~/darcs/cmftopic" under which the upstream module will be
61   extracted as "CMFTopic" (ie, the last component of the module
62   name)::
63
64  $ tailor.py -D -b -R :pserver:anonymous@cvs.zope.org:/cvs-repository/ \
65              -m CMF/CMFTopic ~/darcs/cmftopic
66             
674. Merge upstream changes since last update/bootstrap::
68
69  $ tailor.py ~/svnwc/MyProduct
70
71
72Resolving conflicts
73===================
74
75Should one of the replayed changes generate any conflict, tailor.py
76will prompt the user to correct them. This is done after the upstream
77patch has been applied and before the final commit on the target
78system, so that manually tweaking the conflict can produce a clean
79patch.
80
81
82Tailor's metadata
83=================
84
85To do its work, tailor needs some information about your source tree,
86such as the upstream repository URL and the current revision of the
87sources on your harddisk.
88
89In the simpler case, tailor keeps this information in a file called
90`tailor.info`, one for each tailored project, that is a very simple
91text document, with the following information, one per line:
92
931. Upstream repository kind (either "cvs", "darcs" or "svn)
942. Target repository kind (the same as above)
953. The name of the "module" that's been tailored
964. The URL of the upstream repository (that may not be an URL, for cvs...)
975. The current revision, from the upstream point of view, of the sources
986. The subdirectory that contains the checked out upstream tree,
99   either that given with with the `--subdir` option or computed
100   taking the last part of the module name.
101
102This is everything tailor needs, to be able to keep going from where it
103left last time.
104
105
106Config file format
107------------------
108
109When your project is composed by multiple upstream modules, it is
110easier to collect such information in a single file. This is done by
111specifying the `--configfile` option with a file name as argument. In
112this case, tailor will read/write the above information from a
113standard Python dictionary stored in the given file.
114
115The dictionary is keyed on the relative position of each project, and
116each entry carries the same information described above.
117
118Here's an example config file entry::
119
120 {'plone/atcontenttypes': {'module': 'ATContentTypes',
121                           'source_kind': 'cvs',
122                           'subdir': 'ATContentTypes',
123                           'target_kind': 'darcs',
124                           'upstream_repos': ':ext:cvs.sourceforge.net:/cvsroot/collective',
125                           'upstream_revision': '2004-11-24 19:42:06 by ctheune'}}
126
127By convention, config files are named with the extension ".tailor",
128but this is not enforced.
129
130In the example above, 'plone/atcontenttypes' is a directory where the
131target source will be stored. The keys such 'module', 'source_kind',
132etc correspond to options of the same name.
133
134When using a config file, tailor will perform its job on each project
135contained in the dictionary.
136
137
138Further help
139============
140
141See the output of tailor.py -h for some further tips.  There's also a
142`wiki page`_ that may give you some other hints.
143
144.. _wiki page:
145   http://www.scannedinavian.org/DarcsWiki/ConvertingFromSubversion
146
147I will be more than happy to answer any doubt, question or suggestion
148you may have on it. I'm usually hanging as "lelit" on the IRC channel
149devoted to darcs on the `freenode.net` network. Do not hesitate to
150contact me either by email or chatting there.
151
152
153Author
154======
155
156Lele Gaifax <lele@nautilus.homeip.net>
157
158
159About this document
160===================
161
162This document and most of the internal documention use the
163reStructuredText format so that it can be easily converted into other
164formats, such as HTML.  For more information about this, please see:
165
166  http://docutils.sourceforge.net/rst.html
167
168
169.. vim:ft=rest
170.. Local Variables:
171.. mode: rst
172.. End:
Note: See TracBrowser for help on using the repository browser.