summaryrefslogtreecommitdiffstats
path: root/share/FAQ/ctm.FAQ
blob: 45d5929dd295f571ba542e4dddf1db5b7c2e04d7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
This is the ftp://freefall.cdrom.com/pub/CTM/README file:

# ----------------------------------------------------------------------------
# "THE BEER-WARE LICENSE" (Revision 42):
# <phk@login.dknet.dk> wrote this file.  As long as you retain this notice you
# can do whatever you want with this stuff. If we meet some day, and you think
# this stuff is worth it, you can buy me a beer in return.   Poul-Henning Kamp
# ----------------------------------------------------------------------------
#
# Mon Feb 27 00:06:22 PST 1995
#

		Obtaining FreeBSD-current sources using CTM.
		============================================

CTM is a method for keeping a remote directory tree in sync with a
central one.  It has been developed for usage with FreeBSD's source
trees, though other people may find it useful for other purposes as
time goes by.  Little, if any, documentation currently exists at this
time on the process of creating deltas so talk to phk@FreeBSD.org for
more information should you wish to use CTM for other things.


Why should I use CTM ?
----------------------
CTM will give you a local copy of the "FreeBSD-current" sources.  If
you are an active developer on FreeBSD, but have lousy or non-existent
TCP/IP connectivity, CTM was made for you.  You will need to transfer
up to four deltas per day (or you can have them arrive in email
automatically), the sizes for which are always kept as small as
possible.  This is typically less than 5K, with the occasional (one in
ten) being 10-50K and every now and then a biggie of 100K+ or more
coming around.

You will also need to make yourself aware of the various caveats in
running "current" sources, and for this it is recommended that you
refer to the relevant FAQ: /usr/share/FAQ/current-policy.FAQ

If you have commit priviledges or are similary authorized by the
FreeBSD core team, you can also get access to the CVS repository tree
by the same means.  Contact me (phk@FreeBSD.org) for details.


NOTE:

All the "DES infected" (e.g. export controlled) source is not included.
You will get the "international" version only.  If sufficient interest
appears, we will set up a "sec-cur" sequence too.

There is a sequence of deltas for the ports collection too, but interest
has not been all that high yet.  Tell me if you want an email list for
that too and we'll consider setting it up.

What do I need to use CTM?
--------------------------

You will need two things: The "ctm" program and the initial deltas to
feed it (to get up to "current" levels).

The ctm program is in the FreeBSD-current tree from version 2.0.0 and
forward (/usr/src/usr.sbin/ctm).  If you are running an older version
of FreeBSD, you can fetch the current ctm sources directly from:

	ftp://ftp.freebsd.org/pub/FreeBSD/FreeBSD-current/src/usr.sbin/ctm/

The "deltas" you feed ctm can be had two ways, ftp or email.  If you
have general ftp access to the Internet, then the following ftp sites
support access to CTM:

	ftp://freefall.cdrom.com/pub/CTM

Ftp the the relevant directory and fetch the README file, starting
from there.

If you only have access to electronic mail or are otherwise blocked
from using ftp, then you may wish to receive your deltas via email:

Send email to majordomo@freebsd.org to subscribe to the list
"ctm-src-cur" (if you do not know how to subscribe yourself using
majordomo, send a message first containing the word `help' - it will
send you back usage instructions).

When you begin receiving your CTM updates in the mail, you may use the
ctm_rmail program to unpack and apply them with.  You can actually use
the ctm_rmail program directly from a entry in /etc/aliases if you
want.  Check the "ctm_rmail" man page for more details.


Starting off with CTM for the first time:
-----------------------------------------

Before you can start using CTM deltas, you will need to get a special
"base" delta that provides a starting point for all deltas produced
subsequently to it.  You can recognize these in two ways: One is that
they are large!  25 to 30 Megabytes of gzip'ed data being common for a
base delta.  Second, they also have an 'A' appended to the number
(src-cur.0341A.gz for instance).  Once you've picked a base delta to
start from, you will also need all deltas with higher numbers
following it.

Using CTM in your daily life:
-----------------------------

To apply the deltas, simply say

	cd /where/ever/you/want/the/stuff
	ctm -v -v /where/you/store/your/deltas/src-cur.*

Unless it feels very secure about the entire process, ctm will not
touch your tree.  To check out a delta you can also use the "-c" flag
and CTM won't actually touch your tree.

There are other options to ctm as well, look in the sources.  It's a
little bit confusing right now, but I promise to fix all of that very
shortly.

I would also be very happy if somebody could help with the "user
interface" portions, as I have realized that I can't make up my mind
on what options should do what, how and when...

CTM understands deltas which have been put through gzip, so you don't
need to gunzip them first.

That's really all there is to it.  Everytime you get a new delta, you
run it through ctm.

Don't remove the deltas, if they are hard to download again.  You just
might want to keep them around in case something bad happens.  Even if
you only have floppy disks, consider using "fdwrite" to make a copy.


Plans:
------
Tons of them.  Don't forget to tell me what you want though...


Misc. stuff:
------------
If you are a frequent or valuable contributor to FreeBSD, I will be
willing to arrange special services, one option is delivery via ftp or
rcp to a machine closer to you.  You need to have earned this, since
it takes time to do, but I'll be all the more happy to do it for you
then.

Thanks!
-------
Bruce Evans, for his pointed pen and invaluable comments.
Soren Schmidt, for patience.
Stephen McKay, wrote ctm_[rs]mail, much appreceiated.
Jordan Hubbard, for being so stubborn that I had to make it better.
All the users,  I hope you like it...

Comments ?
----------
email phk@FreeBSD.org

Poul-Henning
OpenPOWER on IntegriCloud