2013-05-02 07:30:25 +08:00
|
|
|
<?xml version="1.0" encoding='UTF-8'?>
|
|
|
|
<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook V4.5//EN"
|
|
|
|
"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
|
|
|
|
|
|
|
|
<chapter id="overview" xmlns:xi="http://www.w3.org/2001/XInclude">
|
|
|
|
<title>Cygwin Overview</title>
|
2000-02-18 03:38:33 +08:00
|
|
|
|
2000-04-19 08:55:19 +08:00
|
|
|
<sect1 id="what-is-it"><title>What is it?</title>
|
2000-02-18 03:38:33 +08:00
|
|
|
|
2004-01-16 14:31:49 +08:00
|
|
|
<para>
|
|
|
|
Cygwin is a Linux-like environment for Windows. It consists of a DLL
|
|
|
|
(<filename>cygwin1.dll</filename>), which acts as an emulation layer
|
2008-07-17 19:49:45 +08:00
|
|
|
providing substantial <ulink url="http://www.pasc.org/#POSIX">POSIX</ulink>
|
|
|
|
(Portable Operating System Interface) system call functionality, and a
|
|
|
|
collection of tools, which provide a Linux look and feel. The Cygwin DLL
|
2022-11-27 21:50:19 +08:00
|
|
|
works with all AMD64 versions of Windows NT since Windows Vista/Server 2008.
|
2008-07-17 19:49:45 +08:00
|
|
|
The API follows the
|
|
|
|
<ulink url="http://www.opengroup.org/onlinepubs/009695399/nfindex.html">Single
|
2004-12-31 09:13:28 +08:00
|
|
|
Unix Specification</ulink> as much as possible, and then Linux practice.
|
2008-07-17 19:49:45 +08:00
|
|
|
The major differences between Cygwin and Linux is the C library
|
|
|
|
(<literal>newlib</literal> instead of <literal>glibc</literal>).
|
2004-01-16 14:31:49 +08:00
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
With Cygwin installed, users have access to many standard UNIX
|
|
|
|
utilities. They can be used from one of the provided shells such
|
|
|
|
as <command>bash</command> or from the Windows Command Prompt.
|
|
|
|
Additionally, programmers may write Win32 console or GUI applications
|
|
|
|
that make use of the standard Microsoft Win32 API and/or the Cygwin API.
|
|
|
|
As a result, it is possible to easily port many significant UNIX
|
|
|
|
programs without the need for extensive changes to the source code.
|
|
|
|
This includes configuring and building most of the available GNU
|
|
|
|
software (including the development tools included with the Cygwin
|
|
|
|
distribution).
|
|
|
|
</para>
|
2000-02-18 03:38:33 +08:00
|
|
|
</sect1>
|
|
|
|
|
2013-05-02 07:30:25 +08:00
|
|
|
<xi:include href="ov-ex-win.xml"/>
|
|
|
|
<xi:include href="ov-ex-unix.xml"/>
|
2004-01-16 14:31:49 +08:00
|
|
|
|
2000-04-19 08:55:19 +08:00
|
|
|
<sect1 id="are-free"><title>Are the Cygwin tools free software?</title>
|
2000-02-18 03:38:33 +08:00
|
|
|
|
2004-12-25 05:58:38 +08:00
|
|
|
<para>Yes. Parts are <ulink url="http://www.gnu.org/">GNU</ulink> software
|
2004-01-16 14:31:49 +08:00
|
|
|
(<command>gcc</command>, <command>gas</command>, <command>ld</command>, etc.),
|
|
|
|
parts are covered by the standard
|
2004-12-25 05:58:38 +08:00
|
|
|
<ulink url="http://www.x.org/Downloads_terms.html">X11 license</ulink>,
|
2004-01-16 14:31:49 +08:00
|
|
|
some of it is public domain, some of it was written by Red Hat and placed under
|
2004-12-25 05:58:38 +08:00
|
|
|
the <ulink url="http://www.gnu.org/licenses/gpl.html">GNU General Public
|
2016-05-24 17:16:39 +08:00
|
|
|
License</ulink> (GPL) or <ulink url="http://www.gnu.org/licenses/lgpl.html">
|
|
|
|
GNU Lesser General Public License</ulink> (LGPL). None of it is shareware.
|
|
|
|
You don't have to pay anyone to use it but you should be sure to read the
|
|
|
|
copyright section of the FAQ for more information on how the GNU GPL may
|
|
|
|
affect your use of these tools.</para>
|
2000-02-18 03:38:33 +08:00
|
|
|
|
|
|
|
</sect1>
|
|
|
|
|
2000-04-19 08:55:19 +08:00
|
|
|
<sect1 id="brief-history"><title>A brief history of the Cygwin project</title>
|
2000-02-18 03:38:33 +08:00
|
|
|
|
2004-01-16 14:31:49 +08:00
|
|
|
<note>
|
|
|
|
<para>
|
2008-07-17 19:49:45 +08:00
|
|
|
A historical look into the first years of Cygwin development is
|
|
|
|
Geoffrey J. Noer's 1998 paper, "Cygwin32: A Free Win32 Porting Layer for
|
|
|
|
UNIX® Applications" which can be found at the <ulink
|
2004-12-25 05:58:38 +08:00
|
|
|
url="http://www.usenix.org/publications/library/proceedings/usenix-nt98/technical.html">
|
2004-01-16 14:31:49 +08:00
|
|
|
2nd USENIX Windows NT Symposium Online Proceedings</ulink>.
|
|
|
|
</para>
|
|
|
|
</note>
|
|
|
|
<para>
|
2009-04-03 19:51:31 +08:00
|
|
|
Cygwin began development in 1995 at Cygnus Solutions (now part of Red Hat,
|
|
|
|
Inc.). The first thing done was to enhance the development tools
|
2004-01-16 14:31:49 +08:00
|
|
|
(<command>gcc</command>, <command>gdb</command>, <command>gas</command>,
|
|
|
|
etc.) so that they could generate and interpret Win32 native
|
|
|
|
object files.
|
|
|
|
The next task was to port the tools to Win NT/9x. We could have
|
2000-02-18 03:38:33 +08:00
|
|
|
done this by rewriting large portions of the source to work within the
|
|
|
|
context of the Win32 API. But this would have meant spending a huge
|
|
|
|
amount of time on each and every tool. Instead, we took a
|
|
|
|
substantially different approach by writing a shared library
|
|
|
|
(the Cygwin DLL) that adds the necessary UNIX-like functionality
|
2004-01-16 14:31:49 +08:00
|
|
|
missing from the Win32 API (<function>fork</function>,
|
|
|
|
<function>spawn</function>, <function>signals</function>,
|
|
|
|
<function>select</function>, <function>sockets</function>, etc.). We call this
|
|
|
|
new interface the Cygwin API. Once written, it was possible to build working
|
|
|
|
Win32 tools using UNIX-hosted cross-compilers, linking against this
|
|
|
|
library.</para>
|
2000-02-18 03:38:33 +08:00
|
|
|
|
2010-01-27 00:16:19 +08:00
|
|
|
<para>From this point, we pursued the goal of producing Windows-hosted tools
|
2000-02-18 03:38:33 +08:00
|
|
|
capable of rebuilding themselves under Windows 9x and NT (this is
|
|
|
|
often called self-hosting). Since neither OS ships with standard UNIX
|
|
|
|
user tools (fileutils, textutils, bash, etc...), we had to get the GNU
|
2010-01-27 00:16:19 +08:00
|
|
|
equivalents working with the Cygwin API. Many of these tools were
|
2000-02-18 03:38:33 +08:00
|
|
|
previously only built natively so we had to modify their configure
|
|
|
|
scripts to be compatible with cross-compilation. Other than the
|
|
|
|
configuration changes, very few source-level changes had to be
|
2010-01-27 00:16:19 +08:00
|
|
|
made since Cygwin provided a UNIX-like API. Running bash with the development tools and user tools in place,
|
|
|
|
Windows 9x and NT looked like a flavor of UNIX from the perspective of
|
2000-02-18 03:38:33 +08:00
|
|
|
the GNU configure mechanism. Self hosting was achieved as of the beta
|
2004-01-16 14:31:49 +08:00
|
|
|
17.1 release in October 1996.</para>
|
2000-02-18 03:38:33 +08:00
|
|
|
|
2004-01-16 14:31:49 +08:00
|
|
|
<para>
|
|
|
|
The entire Cygwin toolset was available as a monolithic install. In
|
|
|
|
April 2000, the project announced a
|
2015-02-03 21:48:43 +08:00
|
|
|
<ulink url="https://www.cygwin.com/ml/cygwin/2000-04/msg00269.html">
|
2010-01-27 00:16:19 +08:00
|
|
|
New Cygwin Net Release</ulink> which provided the native non-Cygwin Win32 program
|
2004-01-16 14:31:49 +08:00
|
|
|
<command>setup.exe</command> to install and upgrade each package
|
|
|
|
separately. Since then, the Cygwin DLL and <command>setup.exe</command>
|
|
|
|
have seen continuous development.
|
|
|
|
</para>
|
2008-07-17 19:49:45 +08:00
|
|
|
|
|
|
|
<para>
|
2016-03-19 05:52:04 +08:00
|
|
|
The biggest major improvement in this development was the 1.7 release in
|
2009-02-14 02:41:32 +08:00
|
|
|
2009, which dropped Windows 95/98/Me support in favor of using Windows
|
2008-07-17 19:49:45 +08:00
|
|
|
NT features more extensively. It adds a lot of new features like
|
|
|
|
case-sensitive filenames, NFS interoperability, IPv6 support and much
|
|
|
|
more.</para>
|
|
|
|
|
2013-04-23 23:59:21 +08:00
|
|
|
<para>The latest big improvement is the 64 bit Cygwin DLL which
|
|
|
|
allows to run natively on AMD64 Windows machines. The first release
|
2016-03-19 05:52:04 +08:00
|
|
|
available in a 64 bit version was 1.7.19.</para>
|
2013-04-23 23:59:21 +08:00
|
|
|
|
2000-02-18 03:38:33 +08:00
|
|
|
</sect1>
|
|
|
|
|
2013-05-02 07:30:25 +08:00
|
|
|
<xi:include href="highlights.xml"/>
|
|
|
|
<xi:include href="new-features.xml"/>
|
2004-01-16 14:31:49 +08:00
|
|
|
|
2000-02-18 03:38:33 +08:00
|
|
|
</chapter>
|