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
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
|
@chapter Installation Instructions
@section Contents
Unlike previous net releases such as B20.1 and earlier, there is no
monolithic "full" or "usertools" installation. Rather, you can pick and
choose the packages you wish to install, and update them individually.
The following packages are available with the current release:
@example
ash autoconf automake bash binutils bison byacc bzip2 clear cpio crypt
cvs cygrunsrv cygwin dejagnu diff expect file fileutils findutils flex
gawk gcc gdb gdbm gettext ghostscript gperf grep groff gzip inetutils
irc jbigkit jpeg less libpng login lynx m4 make man mingw mt mutt ncftp
ncurses newlib-man opengl openssh openssl patch pcre perl popt
postgresql python readline regex rxvt sed sh-utils squid ssmtp tar tcltk
tcsh termcap tetex-beta texinfo textutils tiff time unzip vim w32api
wget which xpm xpm-nox zip zlib
@end example
(This list is almost certainly out of date as new packages are added.)
Full source code is available for all packages and tools.
There is one recommended way to install Cygwin, which is to use the GUI
installer @samp{setup.exe}. There are some variations on how you go
about that.
Do it any other way, and you're on your own! That said, keep in mind
that the GUI installer is a "work in progress", so there might be a few
difficulties, especially if you are behind a firewall or have other
specific requirements. If something doesn't work right for you, and
it's not covered here or elsewhere, then by all means report it to the
mailing list.
@section Installation using the @samp{setup.exe} program
@strong{IMPORTANT: First read the README file in the @samp{latest}
directory at any ftp mirror. DO THIS NOW! Information in the README
file is not repeated here. You can find a mirror site near you from
@file{http://cygwin.com/mirrors.html}.}
The @samp{setup.exe} program is the recommended way to install Cygwin,
but it is still a work in progress. Expect features and functionality
to change. For this reason, it is a good idea to note the version and
build time reported by @code{setup.exe} when you run it. This will help
diagnose problems, should you have any. Check the cygwin mailing list
for the latest news about @code{setup.exe}.
@subsection Why not install in C:\?
The @code{setup.exe} program will prompt you for a "root" directory.
The default is @samp{C:\cygwin}, but you can change it. You are urged not to
choose something like 'C:\' (the root directory on the system drive) for
your Cygwin root. If you do, then critical Cygwin system directories
like 'etc', 'lib' and 'bin' could easily be corrupted by other (non-Cygwin)
applications or packages that use \etc, \lib or \bin. Perhaps there is
no conflict now, but who knows what you might install in the future?
It's also just good common sense to segregate your Cygwin "filesystems"
from the rest of your Windows system disk. (In the past, there had been
genuine bugs that would cause problems for people who installed in C:\,
but we believe those are gone now.)
@subsection Can I use the new setup to update a B18, B19, B20, B20.1 or CD-ROM (1.0) installation of Cygwin?
No, you must start from scratch with the new setup. The overall
structure has changed so much that it would be silly to try to
accomodate old installations of Cygwin. You'll probably be much better
off with a whole new installation anyway. You may backup or rename your
old installation first, or just install the new one somewhere else. Be
sure to make note of your current mount table, because this will be
overwritten during the new setup.
Once you've installed the latest net release, the new setup will update
just the individual packages that need it.
@subsection The README says I should turn off anti-virus software. Isn't that dangerous?
Only Network Associates (formerly McAfee) products have been reported to
"hang" when extracting Cygwin tar archives. Other products have been
reported to detect false positives in Cygwin files. Depending on how
your anti-virus software is configured, it may then delete the file(s)
without prompting you. Any problems will depend on the particular
engine and/or signature file in use, and possibly other factors. If you
don't mind @emph{this} risk, then just leave your anti-virus software
running.
Otherwise, you can download @code{setup.exe} and scan it. Then turn off
the anti-virus software, then run setup to download and extract all the
tar files. Then re-activate your anti-virus software and scan
everything in C:\cygwin (or wherever you chose to install). This should
be safe, as long as nobody substitutes a malicious @code{setup.exe}!
@subsection What packages should I download?
Just get everything, if you have room for it. But if you must be
selective:
@table @samp
@item cygwin
This is the minimum core, consisting of the cygwin1.dll and a few
commands (like @code{mount}). Not much else, and no shell!
@item bash
This is the default interactive command shell for cygwin. If you don't
install @samp{bash}, then the "Cygwin Bash Shell" shortcut that setup
creates for you won't actually do anything.
@item ash
This is often forgotten because it's not obvious that @samp{ash}
contains @code{/bin/sh}, which is essential for running scripts (and
@samp{make} and ...).
@end table
If you want to build programs, of course you'll need @samp{gcc}, but
you'll also need @samp{binutils}, probably @samp{make} and
@samp{fileutils}, and possibly lots more. (Again, consider just getting
everything!)
@subsection What if setup fails?
First, make sure that you are using the latest version of
@code{setup.exe}. It's a work in progress, with improvements and
bugfixes being made often. The latest version is always available from
the 'Install Cygwin now' link on the Cygwin Home Page at
@file{http://cygwin.com/}.
If you are downloading from the internet, setup will fail if it cannot
download the list of mirrors at
@file{http://cygwin.com/mirrors.html}. It could be that
the network is too busy. Similarly for an ftp download site that isn't
working. Try another mirror, or try again later.
If setup refuses to download a package that you know needs to be
upgraded, try deleting that package's entry from /etc/setup. If you are
reacting quickly to an announcement on the mailing list, it could be
that the mirror you are using doesn't have the latest copy yet. Try
another mirror, or try again tomorrow.
If setup has otherwise behaved strangely, check the files
@samp{setup.log} and @samp{setup.log.full} in the Cygwin root directory
(@code{C:\cygwin} by default). It may provide some clues as to what
went wrong and why.
If you're still baffled, search the Cygwin mailing list for clues.
Others may have the same problem, and a solution may be posted there.
If that search proves fruitless, send a query to the Cygwin mailing
list. You must provide complete details in your query: version of
setup, options you selected, contents of setup.log and setup.log.full,
what happened that wasn't supposed to happen, etc.
@subsection What's the difference between packages in @samp{latest} and @samp{contrib}?
There is no difference as far as @code{setup.exe} is concerned, and you
should not worry about this either. The distinction is more historical
than practical.
@subsection My Windows logon name has a space in it, will this cause problems?
Most definitely yes! UNIX shells (and thus Cygwin) use the space
character as a word delimiter. Under certain circumstances, it is
possible to get around this with various shell quoting mechanisms, but
you are much better off if you can avoid the problem entirely.
In particular, the environment variables @samp{USER} and @samp{HOME} are
set for you in /etc/profile. By default these derive from your Windows
logon name. You may edit this file and set them explicitly to something
without spaces.
(If you use the @samp{login} package or anything else that reads
/etc/passwd, you may need to make corresponding changes there. See the
README file for that package.)
@subsection How do I uninstall Cygwin?
Setup has no automatic uninstall facility. Just delete everything
manually:
@itemize @bullet
@item Cygwin shortcuts on the Desktop and Start Menu
@item The registry tree @samp{Software\Cygnus Solutions} under
@code{HKEY_LOCAL_MACHINE} and/or @code{HKEY_CURRENT_USER}.
@item Anything under the Cygwin root folder, @samp{C:\cygwin} by
default.
@item Anything created by setup in its temporary working directory.
@end itemize
It's up to you to deal with other changes you made to your system, such
as installing the inetd service, altering system paths, etc. Setup
would not have done any of these things for you.
@subsection Can I use setup to install snapshots?
No. It used to be possible, but not any more.
If experimenting with developer snapshots from
@file{http://cygwin.com/snapshots/}, you should generally install the
full @code{cygwin-inst-YYYYMMDD.tar.bz2} update, rather than just the
DLL, otherwise some components may be out of sync. Cygwin tar won't be
able to update @code{/usr/bin/cygwin1.dll}, but it should succeed with
everything else. The following steps should work:
@enumerate
@item Download the snapshot, and run:
@example
cd /
tar jxvf /posix/path/to/cygwin-inst-YYYYMMDD.tar.bz2 --exclude=usr/bin/cygwin1.dll
cd /tmp
tar jxvf /posix/path/to/cygwin-inst-YYYYMMDD.tar.bz2 usr/bin/cygwin1.dll
@end example
@item After closing all Cygwin apps (see below), use Explorer or the
Windows command shell to move @code{C:\cygwin\tmp\usr\bin\cygwin1.dll}
to @code{C:\cygwin\bin\cygwin1.dll}.
@end enumerate
The obvious warnings about updating the cygwin package and using developer
snapshots apply:
@enumerate
@item Close all Cygwin apps, including shells and services
(e.g. inetd), before updating @code{cygwin1.dll}. You may have to
restart Windows to clear the DLL from memory.
@item Snapshots are risky. They have not been tested. Use them @strong{only} if
there is a feature or bugfix that you need to try, and you are willing
to deal with any problems.
@item If you cannot download a snapshot from the main ftp distribution
site, use a mirror, and look in the @samp{snapshots} directory. You may
have to hunt for one that has a copy of the latest snapshot. Start at
@file{http://cygwin.com/mirrors.html}.
@end enumerate
|