summaryrefslogtreecommitdiff
path: root/intro.texi
blob: bc00f3da9e0337157d01a7db4f9bdf51890459fd (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
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
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
\input texinfo
@c $Id$
@setfilename intro.info
@settitle Introduction
@iftex
@c The include file "texiplus.tex" is in the texinfo/cygnus dir, and
@c implements Cygnus modifications to the texinfo manual style.
@input texiplus
@c The include file "smpklug.texi" is a kluge to deal with local
@c document production issues at Cygnus; it's safe to comment out this
@c line if you don't have (or don't want) the file.
@input smpklug.texi
@smallbook
@cropmarks
@finalout
@c We don't actually want a titlepage; HEADINGSon is usually called by
@c @end titlepage to turn on footers and headers.
@setchapternewpage odd
@HEADINGSon
@end iftex

@node Top,,,
@unnumbered Introduction

This Developer's Kit puts at your disposal, in a single coordinated
and tested release, some of the best software development tools
available:

@table @t
@item gcc
C compiler

@item g++
C++ compiler

@item gdb
Debugger

@item make
Automates building and installing your programs

@item gprof
Performance analyzer

@item byacc
Parser generator

@item flex
Fast lexical analyzer generator

@item libg++.a
Class library for C++

@item send_pr
Script to send structured problem reports to Cygnus

@item diff
Compares source files

@item patch
Installs source fixes

@item info
@itemx makeinfo
Online documentation tools

@item texinfo.tex
@itemx texindex
Documentation printing tools
@end table

On most host systems, the following are also included (to see if
they are available on your host, @pxref{Contents, Release Contents,
Release Contents, README.info, Installation Notes}).

@table @t
@item gas
Assembler

@item ld
Linker

@item ar
Manages object code archives

@item nm
Lists object file symbol tables

@item objdump
Displays object file information

@item ranlib
Generates archive index

@item size
Lists section and total sizes

@item strip
Discards symbols
@end table

These tools are free software; most of them are from the GNU project,
produced by the Free Software Foundation (FSF).  ``GNU'' is the name of
the FSF's evolving system (in speech, the `G' is sounded).  Cygnus
Support collaborates with the FSF in developing these tools.  In this,
our @dfn{Progressive} product, we've assembled the most recent forms of
the development tools, tested them, made sure they work well together,
made them easy to install---the installation tape comes with binaries
already compiled for your system---and made them easy to reconfigure and
recompile from source.

Cygnus Support exists to help our clients exploit their freedom in
using, adapting, or enhancing this software.  @xref{Cygnus,,About Cygnus
Support}, for more information.

@page
@node Copying,,,
@section Free Software
If you find our Developer's Kit useful, please feel free to give or sell
copies of the software and documentation to anyone you like.

Cygnus products are @dfn{free software}, protected by the @sc{gnu} General
Public License (GPL).  The GPL gives you the freedom to copy or adapt any
program it licenses---but every person getting a copy also gets with it the
freedom to modify that copy (which means that they must get access to
the source code), and the freedom to distribute further copies.  Typical
software companies use copyrights to limit your freedoms; the GPL is
designed to preserve your freedoms.

Fundamentally, the General Public License is a license which grants you
these freedoms, and only imposes restrictions to ensure that no one can
take these freedoms away from anyone else.

For full details, see the @strong{LICENSE} section in this manual
set.

@page
@node Manuals,,,
@section Manuals
@noindent
These printed manuals are included in your Cygnus Progressive Release:
@display

@cite{Using the @sc{gnu} C Compiler}

@cite{The C Preprocessor}

@cite{GDB: The @sc{gnu} Source-Level Debugger}

@cite{Using @code{as}: The @sc{gnu} Assembler}

@cite{The @sc{gnu} Binary Utilities}

@cite{@code{gld}, the @sc{gnu} Linker}

@cite{@sc{gnu} Make: A Program for Directing Recompilation}

@cite{User's Guide to the @sc{GNU} C++ Class Library}

@end display

The manuals are designed for easy online browsing (@pxref{Info,,Online
Documentation}).  For online use, the accompanying software distribution
tape includes all the printed manuals, and also the following documents:

@table @emph
@item FLEX: A Fast Lexical Analyzer Generator
Generates lexical analyzers suitable for GCC and other compilers.

@item Info: Documentation Browsing System
Full details on the @code{info} browser.

@item Texinfo: The @sc{gnu} Documentation Format
How you can use @TeX{} to print these manuals, and how to write your own
manuals in this style.

@item Using and Porting @sc{gnu cc}
Detailed information about what's needed to put @sc{gnu cc} on different
platforms, or to modify @sc{gnu cc}.  Also includes all the
information in the printed manual @cite{Using the @sc{gnu} C Compiler}.
@end table

@noindent
Finally, @code{man} pages are included for all the programs in the release.

You have the freedom to copy the manuals, like the software they cover;
each manual's copyright statement includes the necessary permissions.
The manuals themselves are also free software, and the source for them
is also available on the tape.

@node Info,,,
@section Using Online Documentation

You can browse through the online documentation using either @sc{gnu} Emacs,
or the program @code{info} included on the accompanying tape.
Online, the manuals are organized into @dfn{nodes}, which correspond to
the chapters and sections of a printed book.  You can follow them in
sequence, if you wish, just like in the printed book---but there are
also other choices.  The documents have menus that let you go quickly to
the node that has the information you need.  @code{info} has ``hot''
references; if one section refers to another, you can tell @code{info}
to take you immediately to that other section---and you can get back
again easily to take up your reading where you left off.  Naturally, you
can also search for particular words or phrases.

The best way to get started with the online documentation system is to
run the browser @code{info}.  After the Progressive Release is installed on
your system, you can get into @code{info} by just typing its name---no
options or arguments are necessary---at your shell's prompt (shown as
@samp{eg%} here):
@example
eg% info
@end example

@noindent
@code{info} will display its first screen, a menu of the documentation
available, and will await your input.  Typing the single letter
@example
h
@end example
@noindent
requests a tutorial, designed to teach you how to use @code{info}.

If you already use Emacs, you may want to get into the documentation
browsing mode, instead, by typing @kbd{C-h i} inside Emacs.

You can get out of @code{info} at any time by typing the single letter
@kbd{q}.  

@page
Here is a summary of all the @code{info} commands; @code{info} itself
can display a summary like this at any time, when you type the single
character @kbd{?}.

@smallexample
@cartouche
h       @r{Invoke the Info tutorial.}
q       @r{Quit Info}

@i{Selecting other nodes:}
n       @r{Move to the ``next'' node of this node.}
p       @r{Move to the ``previous'' node of this node.}
u       @r{Move ``up'' from this node.}
m       @r{Pick menu item specified by name (or abbreviation).}
        @r{Picking a menu item moves to the corresponding node.}
f       @r{Follow a cross reference.  Reads name of reference.}
l       @r{Move to the last node you were looking at.}

@i{Moving within a node:}
Space   @r{scroll forward a page.}
DEL     @r{scroll backward a page.}
b       @r{Go to beginning of this node.}

@i{Advanced commands:}
1       @r{Pick first item in node's menu.}
2 - 5   @r{Pick second ... fifth item in node's menu.}
g       @r{Move to node specified by name.}
        @r{You may include a filename as well, as @code{(@var{FILENAME})@var{NODENAME}}.}
s       @r{Search through this Info file for a specified string,}
        @r{and select the node in which the next occurrence is found.}
Ctl-p   @r{Print the contents of this node using @samp{lpr}.}
@end cartouche
@end smallexample

@page
@node Bugs,,,
@section Reporting Trouble
We've tried to make the programs in your Progressive Release as
trouble-free as possible.  If you do encounter trouble, however, we'd
like to be able to diagnose and fix the problem as quickly as possible.
You can help us do that by using the script @code{send_pr} to send us your
problem reports.

@code{send_pr} invokes an editor on a problem report form (after
trying to fill in some fields with reasonable default values). After
you exit the editor, @code{send_pr} sends the filled out form to the
problem report management system (PRMS) at Cygnus Support.  You can
use the environment variable @code{EDITOR} to specify what editor to
use (the default is @code{vi}).

@code{send_pr} attempts to send your problem report to Cygnus via
electronic mail.  If your site cannot support this, you can still use
the problem report form: use @samp{send_pr -p} to capture a copy of the
blank problem-report form and fill it in.  (You can also photocopy the
blank form at the end of this section to fill in.)  In either case you
can FAX the problem report to Cygnus at @w{+1 415 322 3270}.

At Cygnus Support, the problem report is assigned a unique number and is
stored in the PRMS database according to its category and your
customer-id.  PRMS automatically replies with an acknowledgement, citing
the category and the PR number.  As the next step, Cygnus staff inspects
the bugreport (if you've marked your report as high priority, we respond
with an analysis of the problem in less than one business day).  We'll
offer a solution as soon as possible, and await your feedback.  As a
matter of policy, we do not consider your problem report closed until
you've agreed with a solution we offer.

To ensure that a problem report is handled promptly, it must contain
your (unique) customer-id and one of the available categories, shown as
comments in the problem report form, to identify the problem area. As a
Cygnus Support customer, you can obtain your customer-id by invoking
@code{send_pr} with the @samp{-request-id} option.

@page
@subsection Filling out a problem report
Problem reports are structured so that a program can manage them. When
filling out the form, please remember the following guidelines:

@itemize @bullet
@item
Each PR needs a valid customer-id and category.

@item
Describe only one problem with one PR.

@item
For follow-up mail, use the same subject line as the one in the
automatic acknowledgent. It shows the category, the PR number and the
original synopsis line.  This allows Cygnus Support to make sure mail on
the same problem report stays together.

@item 
Please try to make the subject or synopsis line as informative
as possible.  For misbehaving software, you might use a sentence of
the form ``with input foo, component xyz produces bar''.

@item
You don't need to delete the comment lines while editing the PR form;
this is done by @code{send_pr}.  Put your information before or
after the comment.
@end itemize

@page
For full details on @code{send_pr} and the supporting form, see the man
page @code{send_pr}(1).  Here is a sample blank problem-report form; if
electronic mail from your site does not reach Cygnus, you can send us
problem reports by photocopying this sample, filling it out, and sending
it by FAX to @w{+1 415 322 3270}.

@iftex
@widen{28pt}
@end iftex

@smallexample
SEND_PR: Choose from the following categories:
SEND_PR:
SEND_PR: bfd       binutils  bison     clib      config    cvs
SEND_PR: diff      doc       emacs     g++       gas       gcc       
SEND_PR: gdb       grep      ispell    ld        libg++    libiberty
SEND_PR: libiberty make      rcs       readline  send_pr   texinfo
SEND_PR: other
SEND_PR:

To: cygnus-bugs@@cygnus.com 

Subject: 

From: 

Reply-To: 

X-send-pr-version: send_pr: 1.15


>Customer-Id:

>Originator:    <name of the PR author (one line)>

>Organization:  <organization of PR author (multiple lines)>



>Confidential:  <[ yes | no ] (one line)>

>Synopsis:	<synopsis of the problem (one line)>

>Severity:	<[ non-critical | serious | critical ] (one line)>

>Priority:	<[ low | medium | high ] (one line)>

>Category: 	<name of the product (one line)>

>Class:		<[ sw-bug | doc-bug | change-request | support ] (one line)>

>Release:	<release number or tag (one line)>

>Environment:
        <machine, os, target, libraries (multiple lines)>



>Description:	 
        <precise description of the problem (multiple lines)>






>How-To-Repeat:	 
        <code/input/activities to reproduce the problem (multiple lines)>
@end smallexample

@iftex
@widen{-28pt}
@end iftex

@page
@node Cygnus,,,
@section About Cygnus Support
Cygnus Support was founded in 1989 to provide commercial support for
free software.  Cygnus supplies products and services that benefit
advanced development groups by allowing them to use state-of-the-art
tools without having to maintain them.  With Cygnus Support, sites that
once were forced to do their own tool support can recover that valuable
staff time.  Former users of proprietary software now may choose
supported free software, combining the advantages of both worlds.

Free software is faster, more powerful, and more portable than its
proprietary counterparts.  It evolves faster because users who want to
make improvements are free to do so.  Cygnus tracks these
improvements and integrates them into tested, stable versions ready
for commercial use, then backs this software with comprehensive
support.

With Cygnus Support as your partner, you will have the software and
the support you need to meet your business objectives.  Cygnus
is intimately familiar with this software from extensive experience
using, debugging, and implementing it.  You get direct access to the
most qualified support people: the authors of that software.

We provide up-to-the minute ``progressive'' releases, for those who need
the very latest version---or ``vintage'' releases: stable versions which
have been through extensive use and testing.

Because all our improvements are also free software, you can
distribute them widely within your organization, or to your customers,
without extra cost.

@sp 4

@display
Cygnus Support
814 University Avenue
Palo Alto, CA 94301, USA

+1 415 322 3811

email: @code{info@@cygnus.com}
fax: +1 415 322 3270
@end display

@bye