NetBSD/usr.bin/compile_et/compile_et.1

155 lines
4.7 KiB
Groff

.\" $NetBSD: compile_et.1,v 1.6 2011/04/28 15:01:27 wiz Exp $
.\"
.\" Copyright (c) 2001 The NetBSD Foundation, Inc.
.\" All rights reserved.
.\"
.\" This code is derived from software contributed to The NetBSD Foundation
.\" by Gregory McGarry.
.\"
.\" Redistribution and use in source and binary forms, with or without
.\" modification, are permitted provided that the following conditions
.\" are met:
.\" 1. Redistributions of source code must retain the above copyright
.\" notice, this list of conditions and the following disclaimer.
.\" 2. Redistributions in binary form must reproduce the above copyright
.\" notice, this list of conditions and the following disclaimer in the
.\" documentation and/or other materials provided with the distribution.
.\"
.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
.\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
.\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
.\" PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
.\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
.\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
.\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
.\" POSSIBILITY OF SUCH DAMAGE.
.\"
.Dd November 9, 2001
.Dt COMPILE_ET 1
.Os
.Sh NAME
.Nm compile_et
.Nd error table compiler
.Sh SYNOPSIS
.Nm
.Op Fl Fl help
.Op Fl Fl version
.Ar file
.Sh DESCRIPTION
The
.Nm
utility reads the table describing error-code names and their
associated messages in the file
.Ar file
and generates a C source file suitable for use with the
.Xr com_err 3
library.
The source file
.Ar file
must end with a suffix of
.Dq .et
and
.Nm
writes a C header file
.Pa file.h
which contains definitions of the numerical values of the error codes
defined in the error table and a C source file
.Pa file.c
which should be compiled and linked with the executable.
.Pp
The source file is a plain ASCII text file.
A
.Dq \&#
in the source file
is treated as a comment character, and all remaining text to the end
of the source line will be ignored.
The source file consists of the following declarations:
.Bl -tag -offset indent -width XXXXXX
.It id [ Em base ] Em string
Defines an identification string (such as a version string) which is
recorded in the generated files.
It is mandatory and must be the first declaration in the source
file.
.It et Em name
Specifies the name of the error table to be
.Em name .
It is mandatory and must be declared after the id declaration and
before all other declarations.
The name of table is limited to four ASCII characters.
The optional argument
.Em base
specifies the base value of error codes the table.
.Pp
The name of the table is used to construct the name of a function
.Fn initialize_<name>_error_table
which must be called to register the error table with the
.Xr com_err 3
library.
A re-entrant (thread-safe) version called
.Fn initialize_<name>_error_table_r
is also defined.
.It prefix Op Em string
Defines a prefix to be applied to all error code names.
If no string is specified, the prefix is not defined.
It is an optional declaration and can appear more than once.
.It index Em val
Specifies the index
.Em val
in the error table for the following error code declaration.
Subsequent error codes are allocated sequentially from the same value.
It is an optional declaration and can appear more than once.
.It ec Em cname , Em msg
Defines an error code with the name
.Em cname
and its associated error message
.Em msg .
The error codes are assigned sequentially increasing numbers.
The name is placed into the C header file as an enumerated type.
.It end
Indicates the end of the error table.
.El
.Pp
To maintain compatibility, new codes should be added to the end of an
existing table, and codes should not be removed from tables.
.Sh EXAMPLES
A short sample error table might be
.Pa test_err.et :
.Pp
.Bd -literal
# example error table source file
id "\e$Id\e$"
et test
prefix TEST
ec PERM, "Operation not permitted"
ec IO, "I/O error"
ec NOMEM, "Out of memory"
ec INVAL, "Invalid argument"
end
.Ed
.Pp
Compiling the source file
.Pa test_err.et
with
.Nm
will create a C header file
.Pa test_err.h
containing the enumerated type
.Va test_error_number
with values
.Dv TEST_PERM ,
.Dv TEST_IO ,
.Dv TEST_NOMEM
and
.Dv TEST_INVAL ,
and a C source file
.Pa test_err.c
containing the
.Xr com_err 3
initialisation function
.Fn initialize_test_error_table .
.Sh SEE ALSO
.Xr com_err 3