xref: /dragonfly/share/man/man3/intro.3 (revision 678e8cc6)
1.\" Copyright (c) 1980, 1991, 1993
2.\"	The Regents of the University of California.  All rights reserved.
3.\"
4.\" Redistribution and use in source and binary forms, with or without
5.\" modification, are permitted provided that the following conditions
6.\" are met:
7.\" 1. Redistributions of source code must retain the above copyright
8.\"    notice, this list of conditions and the following disclaimer.
9.\" 2. Redistributions in binary form must reproduce the above copyright
10.\"    notice, this list of conditions and the following disclaimer in the
11.\"    documentation and/or other materials provided with the distribution.
12.\" 3. All advertising materials mentioning features or use of this software
13.\"    must display the following acknowledgement:
14.\"	This product includes software developed by the University of
15.\"	California, Berkeley and its contributors.
16.\" 4. Neither the name of the University nor the names of its contributors
17.\"    may be used to endorse or promote products derived from this software
18.\"    without specific prior written permission.
19.\"
20.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
21.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
24.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30.\" SUCH DAMAGE.
31.\"
32.\"     @(#)intro.3	8.1 (Berkeley) 6/5/93
33.\" $FreeBSD: src/share/man/man3/intro.3,v 1.9.2.4 2001/08/17 13:08:36 ru Exp $
34.\"
35.Dd May 29, 2010
36.Dt INTRO 3
37.Os
38.Sh NAME
39.Nm intro
40.Nd introduction to the C libraries
41.Sh DESCRIPTION
42This section provides an overview of the C
43library functions, their error returns and other
44common definitions and concepts.
45Most of these functions are available from the C library,
46.Em libc .
47.\" (see
48.\" .Xr libc 3 ) .
49Other libraries, such as the math library,
50.Em libm ,
51must be indicated at compile time with the
52.Fl l
53option of the compiler.
54.\" .Pp
55.\" A subset of the
56.\" .Em libc functions
57.\" are available from Fortran;
58.\" they are described separately in
59.\" .Xr intro 3f .
60.Pp
61The various libraries (followed by the loader flag):
62.Bl -tag -width ".Em libc Pq Fl l Ns Ar c"
63.It Em libc Pq Fl l Ns Ar c
64Standard C library functions.
65.\" (See
66.\" .Xr libc 3 . )
67When using the C compiler
68.Xr cc 1 ,
69it is not necessary
70to supply the loader flag
71.Fl l Ns Ar c
72for these functions.
73There are several `libraries' or groups of functions included inside of
74.Em libc :
75the standard
76.Tn I/O
77routines,
78database routines,
79bit operators,
80string operators,
81character tests and character operators,
82des encryption routines,
83storage allocation, time functions, signal handling and more.
84.It Em libcurses Pq Fl l Ns Ar curses Fl l Ns Ar termcap
85Terminal independent screen management routines
86for two dimensional non-bitmap display terminals.
87(See
88.Xr ncurses 3 . )
89.It Em libcompat Pq Fl l Ns Ar compat
90Functions which are obsolete but are available for compatibility with
91.Bx 4.3 .
92In particular,
93a number of system call interfaces provided in previous releases of
94.Bx
95have been included for source code compatibility.
96Use of these routines should, for the most part, be avoided.
97The manual page entry for each compatibility routine
98indicates the proper interface to use.
99.It Em libkvm Pq Fl l Ns Ar kvm
100Functions used to access kernel memory are in this library.  They can be used
101against both a running system and a crash dump.
102(See
103.Xr kvm 3 . )
104.It Em libl Pq Fl l Ns Ar l
105The library for
106.Xr lex 1 .
107.\" .It Em libln
108.It Em libm Pq Fl l Ns Ar m
109The math library,
110.Em libm .
111The math library is loaded as needed by the Pascal compiler,
112.\" .Xr pc 1 ,
113but not by the C compiler which requires the
114.Fl l Ns Ar m
115flag.
116(See
117.Xr math 3 . )
118.It Em libmp Pq Fl l Ns Ar mp
119.\" .It Em libom
120.\" Old math library.
121.\" .It Em libplot Pq Fl l Ns Ar plot
122.\" Device independent plotting functions.
123.\" (See
124.\" .Xr plot 3 . )
125.\" .It Em libplotf77 Pq Fl l Ns Ar plotf77
126.\" The device independent plotting functions for fortran.
127.\" (See
128.\" .Xr plot 3 . )
129.\" .It Em libresolv Pq Fl l Ns Ar resolv
130.\" Routines for network address resolution.
131.It Em libtermcap Pq Fl l Ns Ar termcap
132The terminal independent operation library package.
133(See
134.Xr termcap 3 . )
135.\" .It libvt0.a
136.It Em liby Pq Fl l Ns Ar y
137The library for
138.Xr yacc 1 .
139.El
140.Sh FILES
141.Bl -tag -width /usr/lib/profile/libc.a -compact
142.It Pa /usr/lib/libc.a
143the C library
144.It Pa /usr/lib/profile/libc.a
145the C library compiled for profiling
146.It Pa /usr/lib/libm.a
147the math library
148.It Pa /usr/lib/profile/libm.a
149the math library compiled for profiling
150.El
151.Sh SEE ALSO
152.\" .Xr libc 3 ,
153.Xr cc 1 ,
154.Xr ld 1 ,
155.Xr nm 1 ,
156.Xr intro 2 ,
157.Xr math 3 ,
158.Xr stdio 3
159.\" .Sh LIST OF FUNCTIONS
160.\" .Bl -column "strncasecmpxxx" "system"
161.\" .Sy Name	Description
162.\" .El
163.Sh HISTORY
164An
165.Nm
166manual appeared in
167.At v7 .
168