op.h revision 1.20 1 1.20 rillig /* $NetBSD: op.h,v 1.20 2022/06/15 18:29:21 rillig Exp $ */
2 1.2 cgd
3 1.1 cgd /*
4 1.1 cgd * Copyright (c) 1994, 1995 Jochen Pohl
5 1.1 cgd * All Rights Reserved.
6 1.1 cgd *
7 1.1 cgd * Redistribution and use in source and binary forms, with or without
8 1.1 cgd * modification, are permitted provided that the following conditions
9 1.1 cgd * are met:
10 1.1 cgd * 1. Redistributions of source code must retain the above copyright
11 1.1 cgd * notice, this list of conditions and the following disclaimer.
12 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 cgd * notice, this list of conditions and the following disclaimer in the
14 1.1 cgd * documentation and/or other materials provided with the distribution.
15 1.1 cgd * 3. All advertising materials mentioning features or use of this software
16 1.1 cgd * must display the following acknowledgement:
17 1.1 cgd * This product includes software developed by Jochen Pohl for
18 1.1 cgd * The NetBSD Project.
19 1.1 cgd * 4. The name of the author may not be used to endorse or promote products
20 1.1 cgd * derived from this software without specific prior written permission.
21 1.1 cgd *
22 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
23 1.1 cgd * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
24 1.1 cgd * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
25 1.1 cgd * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
26 1.1 cgd * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
27 1.1 cgd * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 1.1 cgd * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 1.1 cgd * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 1.1 cgd * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
31 1.1 cgd * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 1.1 cgd */
33 1.1 cgd
34 1.8 rillig #include <stdbool.h>
35 1.8 rillig
36 1.1 cgd /*
37 1.20 rillig * Various information about operators; see ops.def.
38 1.1 cgd */
39 1.1 cgd typedef struct {
40 1.13 rillig bool m_binary: 1;
41 1.13 rillig bool m_returns_bool: 1;
42 1.13 rillig bool m_takes_bool: 1;
43 1.20 rillig bool m_compares_with_zero: 1;
44 1.13 rillig bool m_requires_integer: 1;
45 1.13 rillig bool m_requires_integer_or_complex: 1;
46 1.13 rillig bool m_requires_arith: 1;
47 1.13 rillig bool m_requires_scalar: 1;
48 1.13 rillig bool m_fold_constant_operands: 1;
49 1.18 rillig bool m_value_context: 1;
50 1.13 rillig bool m_balance_operands: 1;
51 1.13 rillig bool m_has_side_effect: 1;
52 1.13 rillig bool m_warn_if_left_unsigned_in_c90: 1;
53 1.13 rillig bool m_warn_if_right_unsigned_in_c90: 1;
54 1.13 rillig bool m_possible_precedence_confusion: 1;
55 1.13 rillig bool m_comparison: 1;
56 1.13 rillig bool m_valid_on_enum: 1;
57 1.13 rillig bool m_bad_on_enum: 1;
58 1.13 rillig bool m_warn_if_operand_eq: 1;
59 1.13 rillig const char *m_name;
60 1.1 cgd } mod_t;
61 1.1 cgd
62 1.15 rillig extern const mod_t modtab[];
63 1.6 christos
64 1.10 rillig #define begin_ops() typedef enum {
65 1.10 rillig #define op(name, repr, \
66 1.17 rillig is_binary, is_logical, takes_bool, requires_bool, \
67 1.17 rillig is_integer, is_complex, is_arithmetic, is_scalar, \
68 1.19 rillig can_fold, is_value, unused, balances_operands, \
69 1.17 rillig side_effects, left_unsigned, right_unsigned, \
70 1.17 rillig precedence_confusion, is_comparison, \
71 1.17 rillig valid_on_enum, bad_on_enum, warn_if_eq) \
72 1.10 rillig name,
73 1.10 rillig #define end_ops() } op_t;
74 1.10 rillig #include "ops.def"
75