2022-05-09 21:00:23 +00:00
|
|
|
// Code generated by 'ccgo langinfo/gen.c -crt-import-path "" -export-defines "" -export-enums "" -export-externs X -export-fields F -export-structs "" -export-typedefs "" -header -hide _OSSwapInt16,_OSSwapInt32,_OSSwapInt64 -ignore-unsupported-alignment -o langinfo/langinfo_openbsd_amd64.go -pkgname langinfo', DO NOT EDIT.
|
2022-01-30 23:27:37 +00:00
|
|
|
|
|
|
|
package langinfo
|
|
|
|
|
|
|
|
import (
|
|
|
|
"math"
|
|
|
|
"reflect"
|
|
|
|
"sync/atomic"
|
|
|
|
"unsafe"
|
|
|
|
)
|
|
|
|
|
|
|
|
var _ = math.Pi
|
|
|
|
var _ reflect.Kind
|
|
|
|
var _ atomic.Value
|
|
|
|
var _ unsafe.Pointer
|
|
|
|
|
|
|
|
const (
|
2022-05-09 21:00:23 +00:00
|
|
|
ABDAY_1 = 13 // langinfo.h:29:1:
|
|
|
|
ABDAY_2 = 14 // langinfo.h:30:1:
|
|
|
|
ABDAY_3 = 15 // langinfo.h:31:1:
|
|
|
|
ABDAY_4 = 16 // langinfo.h:32:1:
|
|
|
|
ABDAY_5 = 17 // langinfo.h:33:1:
|
|
|
|
ABDAY_6 = 18 // langinfo.h:34:1:
|
|
|
|
ABDAY_7 = 19 // langinfo.h:35:1:
|
|
|
|
ABMON_1 = 32 // langinfo.h:50:1:
|
|
|
|
ABMON_10 = 41 // langinfo.h:59:1:
|
|
|
|
ABMON_11 = 42 // langinfo.h:60:1:
|
|
|
|
ABMON_12 = 43 // langinfo.h:61:1:
|
|
|
|
ABMON_2 = 33 // langinfo.h:51:1:
|
|
|
|
ABMON_3 = 34 // langinfo.h:52:1:
|
|
|
|
ABMON_4 = 35 // langinfo.h:53:1:
|
|
|
|
ABMON_5 = 36 // langinfo.h:54:1:
|
|
|
|
ABMON_6 = 37 // langinfo.h:55:1:
|
|
|
|
ABMON_7 = 38 // langinfo.h:56:1:
|
|
|
|
ABMON_8 = 39 // langinfo.h:57:1:
|
|
|
|
ABMON_9 = 40 // langinfo.h:58:1:
|
|
|
|
AM_STR = 4 // langinfo.h:18:1:
|
|
|
|
CODESET = 51 // langinfo.h:71:1:
|
|
|
|
CRNCYSTR = 50 // langinfo.h:69:1:
|
|
|
|
DAY_1 = 6 // langinfo.h:21:1:
|
|
|
|
DAY_2 = 7 // langinfo.h:22:1:
|
|
|
|
DAY_3 = 8 // langinfo.h:23:1:
|
|
|
|
DAY_4 = 9 // langinfo.h:24:1:
|
|
|
|
DAY_5 = 10 // langinfo.h:25:1:
|
|
|
|
DAY_6 = 11 // langinfo.h:26:1:
|
|
|
|
DAY_7 = 12 // langinfo.h:27:1:
|
|
|
|
D_FMT = 1 // langinfo.h:15:1:
|
|
|
|
D_T_FMT = 0 // langinfo.h:14:1:
|
|
|
|
MON_1 = 20 // langinfo.h:37:1:
|
|
|
|
MON_10 = 29 // langinfo.h:46:1:
|
|
|
|
MON_11 = 30 // langinfo.h:47:1:
|
|
|
|
MON_12 = 31 // langinfo.h:48:1:
|
|
|
|
MON_2 = 21 // langinfo.h:38:1:
|
|
|
|
MON_3 = 22 // langinfo.h:39:1:
|
|
|
|
MON_4 = 23 // langinfo.h:40:1:
|
|
|
|
MON_5 = 24 // langinfo.h:41:1:
|
|
|
|
MON_6 = 25 // langinfo.h:42:1:
|
|
|
|
MON_7 = 26 // langinfo.h:43:1:
|
|
|
|
MON_8 = 27 // langinfo.h:44:1:
|
|
|
|
MON_9 = 28 // langinfo.h:45:1:
|
|
|
|
NL_CAT_LOCALE = 1 // nl_types.h:76:1:
|
|
|
|
NL_SETD = 1 // nl_types.h:75:1:
|
|
|
|
NOEXPR = 49 // langinfo.h:68:1:
|
|
|
|
NOSTR = 48 // langinfo.h:67:1:
|
|
|
|
PM_STR = 5 // langinfo.h:19:1:
|
|
|
|
RADIXCHAR = 44 // langinfo.h:63:1:
|
|
|
|
THOUSEP = 45 // langinfo.h:64:1:
|
|
|
|
T_FMT = 2 // langinfo.h:16:1:
|
|
|
|
T_FMT_AMPM = 3 // langinfo.h:17:1:
|
|
|
|
YESEXPR = 47 // langinfo.h:66:1:
|
|
|
|
YESSTR = 46 // langinfo.h:65:1:
|
|
|
|
X_FILE_OFFSET_BITS = 64 // <builtin>:25:1:
|
|
|
|
X_LANGINFO_H_ = 0 // langinfo.h:10:1:
|
|
|
|
X_LOCALE_T_DEFINED_ = 0 // langinfo.h:75:1:
|
|
|
|
X_LP64 = 1 // <predefined>:1:1:
|
|
|
|
X_MACHINE_CDEFS_H_ = 0 // cdefs.h:9:1:
|
|
|
|
X_NL_TYPES_H_ = 0 // nl_types.h:34:1:
|
|
|
|
X_RET_PROTECTOR = 1 // <predefined>:2:1:
|
|
|
|
X_SYS_CDEFS_H_ = 0 // cdefs.h:39:1:
|
|
|
|
Unix = 1 // <predefined>:340:1:
|
2022-01-30 23:27:37 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type Ptrdiff_t = int64 /* <builtin>:3:26 */
|
|
|
|
|
|
|
|
type Size_t = uint64 /* <builtin>:9:23 */
|
|
|
|
|
|
|
|
type Wchar_t = int32 /* <builtin>:15:24 */
|
|
|
|
|
|
|
|
type X__int128_t = struct {
|
|
|
|
Flo int64
|
|
|
|
Fhi int64
|
|
|
|
} /* <builtin>:21:43 */ // must match modernc.org/mathutil.Int128
|
|
|
|
type X__uint128_t = struct {
|
|
|
|
Flo uint64
|
|
|
|
Fhi uint64
|
|
|
|
} /* <builtin>:22:44 */ // must match modernc.org/mathutil.Int128
|
|
|
|
|
|
|
|
type X__builtin_va_list = uintptr /* <builtin>:46:14 */
|
|
|
|
type X__float128 = float64 /* <builtin>:47:21 */
|
|
|
|
|
|
|
|
// $OpenBSD: langinfo.h,v 1.8 2017/09/05 03:16:13 schwarze Exp $
|
|
|
|
// $NetBSD: langinfo.h,v 1.3 1995/04/28 23:30:54 jtc Exp $
|
|
|
|
|
|
|
|
// Written by J.T. Conklin <jtc@netbsd.org>
|
|
|
|
// Public domain.
|
|
|
|
|
|
|
|
// $OpenBSD: nl_types.h,v 1.8 2008/06/26 05:42:04 ray Exp $
|
|
|
|
// $NetBSD: nl_types.h,v 1.6 1996/05/13 23:11:15 jtc Exp $
|
|
|
|
|
|
|
|
// -
|
|
|
|
// Copyright (c) 1996 The NetBSD Foundation, Inc.
|
|
|
|
// All rights reserved.
|
|
|
|
//
|
|
|
|
// This code is derived from software contributed to The NetBSD Foundation
|
|
|
|
// by J.T. Conklin.
|
|
|
|
//
|
|
|
|
// 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 REGENTS 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.
|
|
|
|
|
|
|
|
// $OpenBSD: cdefs.h,v 1.43 2018/10/29 17:10:40 guenther Exp $
|
|
|
|
// $NetBSD: cdefs.h,v 1.16 1996/04/03 20:46:39 christos Exp $
|
|
|
|
|
|
|
|
// Copyright (c) 1991, 1993
|
|
|
|
// The Regents of the University of California. All rights reserved.
|
|
|
|
//
|
|
|
|
// This code is derived from software contributed to Berkeley by
|
|
|
|
// Berkeley Software Design, Inc.
|
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
// 3. Neither the name of the University nor the names of its contributors
|
|
|
|
// may be used to endorse or promote products derived from this software
|
|
|
|
// without specific prior written permission.
|
|
|
|
//
|
|
|
|
// THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
|
|
|
|
//
|
|
|
|
// @(#)cdefs.h 8.7 (Berkeley) 1/21/94
|
|
|
|
|
|
|
|
// $OpenBSD: cdefs.h,v 1.3 2013/03/28 17:30:45 martynas Exp $
|
|
|
|
|
|
|
|
// Written by J.T. Conklin <jtc@wimsey.com> 01/17/95.
|
|
|
|
// Public domain.
|
|
|
|
|
|
|
|
// Macro to test if we're using a specific version of gcc or later.
|
|
|
|
|
|
|
|
// The __CONCAT macro is used to concatenate parts of symbol names, e.g.
|
|
|
|
// with "#define OLD(foo) __CONCAT(old,foo)", OLD(foo) produces oldfoo.
|
|
|
|
// The __CONCAT macro is a bit tricky -- make sure you don't put spaces
|
|
|
|
// in between its arguments. Do not use __CONCAT on double-quoted strings,
|
|
|
|
// such as those from the __STRING macro: to concatenate strings just put
|
|
|
|
// them next to each other.
|
|
|
|
|
|
|
|
// GCC1 and some versions of GCC2 declare dead (non-returning) and
|
|
|
|
// pure (no side effects) functions using "volatile" and "const";
|
|
|
|
// unfortunately, these then cause warnings under "-ansi -pedantic".
|
|
|
|
// GCC >= 2.5 uses the __attribute__((attrs)) style. All of these
|
|
|
|
// work for GNU C++ (modulo a slight glitch in the C++ grammar in
|
|
|
|
// the distribution version of 2.5.5).
|
|
|
|
|
|
|
|
// __returns_twice makes the compiler not assume the function
|
|
|
|
// only returns once. This affects registerisation of variables:
|
|
|
|
// even local variables need to be in memory across such a call.
|
|
|
|
// Example: setjmp()
|
|
|
|
|
|
|
|
// __only_inline makes the compiler only use this function definition
|
|
|
|
// for inlining; references that can't be inlined will be left as
|
|
|
|
// external references instead of generating a local copy. The
|
|
|
|
// matching library should include a simple extern definition for
|
|
|
|
// the function to handle those references. c.f. ctype.h
|
|
|
|
|
|
|
|
// GNU C version 2.96 adds explicit branch prediction so that
|
|
|
|
// the CPU back-end can hint the processor and also so that
|
|
|
|
// code blocks can be reordered such that the predicted path
|
|
|
|
// sees a more linear flow, thus improving cache behavior, etc.
|
|
|
|
//
|
|
|
|
// The following two macros provide us with a way to utilize this
|
|
|
|
// compiler feature. Use __predict_true() if you expect the expression
|
|
|
|
// to evaluate to true, and __predict_false() if you expect the
|
|
|
|
// expression to evaluate to false.
|
|
|
|
//
|
|
|
|
// A few notes about usage:
|
|
|
|
//
|
|
|
|
// * Generally, __predict_false() error condition checks (unless
|
|
|
|
// you have some _strong_ reason to do otherwise, in which case
|
|
|
|
// document it), and/or __predict_true() `no-error' condition
|
|
|
|
// checks, assuming you want to optimize for the no-error case.
|
|
|
|
//
|
|
|
|
// * Other than that, if you don't know the likelihood of a test
|
|
|
|
// succeeding from empirical or other `hard' evidence, don't
|
|
|
|
// make predictions.
|
|
|
|
//
|
|
|
|
// * These are meant to be used in places that are run `a lot'.
|
|
|
|
// It is wasteful to make predictions in code that is run
|
|
|
|
// seldomly (e.g. at subsystem initialization time) as the
|
|
|
|
// basic block reordering that this affects can often generate
|
|
|
|
// larger code.
|
|
|
|
|
|
|
|
// Delete pseudo-keywords wherever they are not available or needed.
|
|
|
|
|
|
|
|
// The __packed macro indicates that a variable or structure members
|
|
|
|
// should have the smallest possible alignment, despite any host CPU
|
|
|
|
// alignment requirements.
|
|
|
|
//
|
|
|
|
// The __aligned(x) macro specifies the minimum alignment of a
|
|
|
|
// variable or structure.
|
|
|
|
//
|
|
|
|
// These macros together are useful for describing the layout and
|
|
|
|
// alignment of messages exchanged with hardware or other systems.
|
|
|
|
|
|
|
|
// "The nice thing about standards is that there are so many to choose from."
|
|
|
|
// There are a number of "feature test macros" specified by (different)
|
|
|
|
// standards that determine which interfaces and types the header files
|
|
|
|
// should expose.
|
|
|
|
//
|
|
|
|
// Because of inconsistencies in these macros, we define our own
|
|
|
|
// set in the private name space that end in _VISIBLE. These are
|
|
|
|
// always defined and so headers can test their values easily.
|
|
|
|
// Things can get tricky when multiple feature macros are defined.
|
|
|
|
// We try to take the union of all the features requested.
|
|
|
|
//
|
|
|
|
// The following macros are guaranteed to have a value after cdefs.h
|
|
|
|
// has been included:
|
|
|
|
// __POSIX_VISIBLE
|
|
|
|
// __XPG_VISIBLE
|
|
|
|
// __ISO_C_VISIBLE
|
|
|
|
// __BSD_VISIBLE
|
|
|
|
|
|
|
|
// X/Open Portability Guides and Single Unix Specifications.
|
|
|
|
// _XOPEN_SOURCE XPG3
|
|
|
|
// _XOPEN_SOURCE && _XOPEN_VERSION = 4 XPG4
|
|
|
|
// _XOPEN_SOURCE && _XOPEN_SOURCE_EXTENDED = 1 XPG4v2
|
|
|
|
// _XOPEN_SOURCE == 500 XPG5
|
|
|
|
// _XOPEN_SOURCE == 520 XPG5v2
|
|
|
|
// _XOPEN_SOURCE == 600 POSIX 1003.1-2001 with XSI
|
|
|
|
// _XOPEN_SOURCE == 700 POSIX 1003.1-2008 with XSI
|
|
|
|
//
|
|
|
|
// The XPG spec implies a specific value for _POSIX_C_SOURCE.
|
|
|
|
|
|
|
|
// POSIX macros, these checks must follow the XOPEN ones above.
|
|
|
|
//
|
|
|
|
// _POSIX_SOURCE == 1 1003.1-1988 (superseded by _POSIX_C_SOURCE)
|
|
|
|
// _POSIX_C_SOURCE == 1 1003.1-1990
|
|
|
|
// _POSIX_C_SOURCE == 2 1003.2-1992
|
|
|
|
// _POSIX_C_SOURCE == 199309L 1003.1b-1993
|
|
|
|
// _POSIX_C_SOURCE == 199506L 1003.1c-1995, 1003.1i-1995,
|
|
|
|
// and the omnibus ISO/IEC 9945-1:1996
|
|
|
|
// _POSIX_C_SOURCE == 200112L 1003.1-2001
|
|
|
|
// _POSIX_C_SOURCE == 200809L 1003.1-2008
|
|
|
|
//
|
|
|
|
// The POSIX spec implies a specific value for __ISO_C_VISIBLE, though
|
|
|
|
// this may be overridden by the _ISOC99_SOURCE macro later.
|
|
|
|
|
|
|
|
// _ANSI_SOURCE means to expose ANSI C89 interfaces only.
|
|
|
|
// If the user defines it in addition to one of the POSIX or XOPEN
|
|
|
|
// macros, assume the POSIX/XOPEN macro(s) should take precedence.
|
|
|
|
|
|
|
|
// _ISOC99_SOURCE, _ISOC11_SOURCE, __STDC_VERSION__, and __cplusplus
|
|
|
|
// override any of the other macros since they are non-exclusive.
|
|
|
|
|
|
|
|
// Finally deal with BSD-specific interfaces that are not covered
|
|
|
|
// by any standards. We expose these when none of the POSIX or XPG
|
|
|
|
// macros is defined or if the user explicitly asks for them.
|
|
|
|
|
|
|
|
// Default values.
|
|
|
|
|
|
|
|
type X_nl_catd = struct {
|
|
|
|
F__data uintptr
|
|
|
|
F__size int32
|
|
|
|
F__ccgo_pad1 [4]byte
|
|
|
|
} /* nl_types.h:78:9 */
|
|
|
|
|
|
|
|
// $OpenBSD: langinfo.h,v 1.8 2017/09/05 03:16:13 schwarze Exp $
|
|
|
|
// $NetBSD: langinfo.h,v 1.3 1995/04/28 23:30:54 jtc Exp $
|
|
|
|
|
|
|
|
// Written by J.T. Conklin <jtc@netbsd.org>
|
|
|
|
// Public domain.
|
|
|
|
|
|
|
|
// $OpenBSD: nl_types.h,v 1.8 2008/06/26 05:42:04 ray Exp $
|
|
|
|
// $NetBSD: nl_types.h,v 1.6 1996/05/13 23:11:15 jtc Exp $
|
|
|
|
|
|
|
|
// -
|
|
|
|
// Copyright (c) 1996 The NetBSD Foundation, Inc.
|
|
|
|
// All rights reserved.
|
|
|
|
//
|
|
|
|
// This code is derived from software contributed to The NetBSD Foundation
|
|
|
|
// by J.T. Conklin.
|
|
|
|
//
|
|
|
|
// 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 REGENTS 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.
|
|
|
|
|
|
|
|
// $OpenBSD: cdefs.h,v 1.43 2018/10/29 17:10:40 guenther Exp $
|
|
|
|
// $NetBSD: cdefs.h,v 1.16 1996/04/03 20:46:39 christos Exp $
|
|
|
|
|
|
|
|
// Copyright (c) 1991, 1993
|
|
|
|
// The Regents of the University of California. All rights reserved.
|
|
|
|
//
|
|
|
|
// This code is derived from software contributed to Berkeley by
|
|
|
|
// Berkeley Software Design, Inc.
|
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
// 3. Neither the name of the University nor the names of its contributors
|
|
|
|
// may be used to endorse or promote products derived from this software
|
|
|
|
// without specific prior written permission.
|
|
|
|
//
|
|
|
|
// THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
|
|
|
|
//
|
|
|
|
// @(#)cdefs.h 8.7 (Berkeley) 1/21/94
|
|
|
|
|
|
|
|
// $OpenBSD: cdefs.h,v 1.3 2013/03/28 17:30:45 martynas Exp $
|
|
|
|
|
|
|
|
// Written by J.T. Conklin <jtc@wimsey.com> 01/17/95.
|
|
|
|
// Public domain.
|
|
|
|
|
|
|
|
// Macro to test if we're using a specific version of gcc or later.
|
|
|
|
|
|
|
|
// The __CONCAT macro is used to concatenate parts of symbol names, e.g.
|
|
|
|
// with "#define OLD(foo) __CONCAT(old,foo)", OLD(foo) produces oldfoo.
|
|
|
|
// The __CONCAT macro is a bit tricky -- make sure you don't put spaces
|
|
|
|
// in between its arguments. Do not use __CONCAT on double-quoted strings,
|
|
|
|
// such as those from the __STRING macro: to concatenate strings just put
|
|
|
|
// them next to each other.
|
|
|
|
|
|
|
|
// GCC1 and some versions of GCC2 declare dead (non-returning) and
|
|
|
|
// pure (no side effects) functions using "volatile" and "const";
|
|
|
|
// unfortunately, these then cause warnings under "-ansi -pedantic".
|
|
|
|
// GCC >= 2.5 uses the __attribute__((attrs)) style. All of these
|
|
|
|
// work for GNU C++ (modulo a slight glitch in the C++ grammar in
|
|
|
|
// the distribution version of 2.5.5).
|
|
|
|
|
|
|
|
// __returns_twice makes the compiler not assume the function
|
|
|
|
// only returns once. This affects registerisation of variables:
|
|
|
|
// even local variables need to be in memory across such a call.
|
|
|
|
// Example: setjmp()
|
|
|
|
|
|
|
|
// __only_inline makes the compiler only use this function definition
|
|
|
|
// for inlining; references that can't be inlined will be left as
|
|
|
|
// external references instead of generating a local copy. The
|
|
|
|
// matching library should include a simple extern definition for
|
|
|
|
// the function to handle those references. c.f. ctype.h
|
|
|
|
|
|
|
|
// GNU C version 2.96 adds explicit branch prediction so that
|
|
|
|
// the CPU back-end can hint the processor and also so that
|
|
|
|
// code blocks can be reordered such that the predicted path
|
|
|
|
// sees a more linear flow, thus improving cache behavior, etc.
|
|
|
|
//
|
|
|
|
// The following two macros provide us with a way to utilize this
|
|
|
|
// compiler feature. Use __predict_true() if you expect the expression
|
|
|
|
// to evaluate to true, and __predict_false() if you expect the
|
|
|
|
// expression to evaluate to false.
|
|
|
|
//
|
|
|
|
// A few notes about usage:
|
|
|
|
//
|
|
|
|
// * Generally, __predict_false() error condition checks (unless
|
|
|
|
// you have some _strong_ reason to do otherwise, in which case
|
|
|
|
// document it), and/or __predict_true() `no-error' condition
|
|
|
|
// checks, assuming you want to optimize for the no-error case.
|
|
|
|
//
|
|
|
|
// * Other than that, if you don't know the likelihood of a test
|
|
|
|
// succeeding from empirical or other `hard' evidence, don't
|
|
|
|
// make predictions.
|
|
|
|
//
|
|
|
|
// * These are meant to be used in places that are run `a lot'.
|
|
|
|
// It is wasteful to make predictions in code that is run
|
|
|
|
// seldomly (e.g. at subsystem initialization time) as the
|
|
|
|
// basic block reordering that this affects can often generate
|
|
|
|
// larger code.
|
|
|
|
|
|
|
|
// Delete pseudo-keywords wherever they are not available or needed.
|
|
|
|
|
|
|
|
// The __packed macro indicates that a variable or structure members
|
|
|
|
// should have the smallest possible alignment, despite any host CPU
|
|
|
|
// alignment requirements.
|
|
|
|
//
|
|
|
|
// The __aligned(x) macro specifies the minimum alignment of a
|
|
|
|
// variable or structure.
|
|
|
|
//
|
|
|
|
// These macros together are useful for describing the layout and
|
|
|
|
// alignment of messages exchanged with hardware or other systems.
|
|
|
|
|
|
|
|
// "The nice thing about standards is that there are so many to choose from."
|
|
|
|
// There are a number of "feature test macros" specified by (different)
|
|
|
|
// standards that determine which interfaces and types the header files
|
|
|
|
// should expose.
|
|
|
|
//
|
|
|
|
// Because of inconsistencies in these macros, we define our own
|
|
|
|
// set in the private name space that end in _VISIBLE. These are
|
|
|
|
// always defined and so headers can test their values easily.
|
|
|
|
// Things can get tricky when multiple feature macros are defined.
|
|
|
|
// We try to take the union of all the features requested.
|
|
|
|
//
|
|
|
|
// The following macros are guaranteed to have a value after cdefs.h
|
|
|
|
// has been included:
|
|
|
|
// __POSIX_VISIBLE
|
|
|
|
// __XPG_VISIBLE
|
|
|
|
// __ISO_C_VISIBLE
|
|
|
|
// __BSD_VISIBLE
|
|
|
|
|
|
|
|
// X/Open Portability Guides and Single Unix Specifications.
|
|
|
|
// _XOPEN_SOURCE XPG3
|
|
|
|
// _XOPEN_SOURCE && _XOPEN_VERSION = 4 XPG4
|
|
|
|
// _XOPEN_SOURCE && _XOPEN_SOURCE_EXTENDED = 1 XPG4v2
|
|
|
|
// _XOPEN_SOURCE == 500 XPG5
|
|
|
|
// _XOPEN_SOURCE == 520 XPG5v2
|
|
|
|
// _XOPEN_SOURCE == 600 POSIX 1003.1-2001 with XSI
|
|
|
|
// _XOPEN_SOURCE == 700 POSIX 1003.1-2008 with XSI
|
|
|
|
//
|
|
|
|
// The XPG spec implies a specific value for _POSIX_C_SOURCE.
|
|
|
|
|
|
|
|
// POSIX macros, these checks must follow the XOPEN ones above.
|
|
|
|
//
|
|
|
|
// _POSIX_SOURCE == 1 1003.1-1988 (superseded by _POSIX_C_SOURCE)
|
|
|
|
// _POSIX_C_SOURCE == 1 1003.1-1990
|
|
|
|
// _POSIX_C_SOURCE == 2 1003.2-1992
|
|
|
|
// _POSIX_C_SOURCE == 199309L 1003.1b-1993
|
|
|
|
// _POSIX_C_SOURCE == 199506L 1003.1c-1995, 1003.1i-1995,
|
|
|
|
// and the omnibus ISO/IEC 9945-1:1996
|
|
|
|
// _POSIX_C_SOURCE == 200112L 1003.1-2001
|
|
|
|
// _POSIX_C_SOURCE == 200809L 1003.1-2008
|
|
|
|
//
|
|
|
|
// The POSIX spec implies a specific value for __ISO_C_VISIBLE, though
|
|
|
|
// this may be overridden by the _ISOC99_SOURCE macro later.
|
|
|
|
|
|
|
|
// _ANSI_SOURCE means to expose ANSI C89 interfaces only.
|
|
|
|
// If the user defines it in addition to one of the POSIX or XOPEN
|
|
|
|
// macros, assume the POSIX/XOPEN macro(s) should take precedence.
|
|
|
|
|
|
|
|
// _ISOC99_SOURCE, _ISOC11_SOURCE, __STDC_VERSION__, and __cplusplus
|
|
|
|
// override any of the other macros since they are non-exclusive.
|
|
|
|
|
|
|
|
// Finally deal with BSD-specific interfaces that are not covered
|
|
|
|
// by any standards. We expose these when none of the POSIX or XPG
|
|
|
|
// macros is defined or if the user explicitly asks for them.
|
|
|
|
|
|
|
|
// Default values.
|
|
|
|
|
|
|
|
type Nl_catd = uintptr /* nl_types.h:81:3 */
|
|
|
|
|
|
|
|
type Nl_item = int64 /* nl_types.h:83:14 */
|
|
|
|
|
|
|
|
type Locale_t = uintptr /* langinfo.h:76:14 */
|
|
|
|
|
|
|
|
var _ int8 /* gen.c:2:13: */
|