xref: /freebsd/contrib/bc/include/dc.h (revision 7fdf597e96a02165cfe22ff357b857d5fa15ed8a)
1 /*
2  * *****************************************************************************
3  *
4  * SPDX-License-Identifier: BSD-2-Clause
5  *
6  * Copyright (c) 2018-2024 Gavin D. Howard and contributors.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions are met:
10  *
11  * * Redistributions of source code must retain the above copyright notice, this
12  *   list of conditions and the following disclaimer.
13  *
14  * * Redistributions in binary form must reproduce the above copyright notice,
15  *   this list of conditions and the following disclaimer in the documentation
16  *   and/or other materials provided with the distribution.
17  *
18  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
22  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28  * POSSIBILITY OF SUCH DAMAGE.
29  *
30  * *****************************************************************************
31  *
32  * Definitions for dc only.
33  *
34  */
35 
36 #ifndef BC_DC_H
37 #define BC_DC_H
38 
39 #if DC_ENABLED
40 
41 #include <status.h>
42 #include <lex.h>
43 #include <parse.h>
44 
45 /**
46  * The main function for dc. It just sets variables and passes its arguments
47  * through to @a bc_vm_boot().
48  * @return  A status.
49  */
50 BcStatus
51 dc_main(int argc, const char* argv[]);
52 
53 // A reference to the dc help text.
54 extern const char dc_help[];
55 
56 /**
57  * The @a BcLexNext function for dc. (See include/lex.h for a definition of
58  * @a BcLexNext.)
59  * @param l  The lexer.
60  */
61 void
62 dc_lex_token(BcLex* l);
63 
64 /**
65  * Returns true if the negative char `_` should be treated as a command or not.
66  * dc considers negative a command if it does *not* immediately proceed a
67  * number. Otherwise, it's just considered a negative.
68  * @param l  The lexer.
69  * @return   True if a negative should be treated as a command, false if it
70  *           should be treated as a negative sign on a number.
71  */
72 bool
73 dc_lex_negCommand(BcLex* l);
74 
75 // References to the signal message and its length.
76 extern const char dc_sig_msg[];
77 extern const uchar dc_sig_msg_len;
78 
79 // References to an array and its length. This array is an array of lex tokens
80 // that, when encountered, should be treated as commands that take a register.
81 extern const uint8_t dc_lex_regs[];
82 extern const size_t dc_lex_regs_len;
83 
84 // References to an array of tokens and its length. This array corresponds to
85 // the ASCII table, starting at double quotes. This makes it easy to look up
86 // tokens for characters.
87 extern const uint8_t dc_lex_tokens[];
88 extern const uint8_t dc_parse_insts[];
89 
90 /**
91  * The @a BcParseParse function for dc. (See include/parse.h for a definition of
92  * @a BcParseParse.)
93  * @param p  The parser.
94  */
95 void
96 dc_parse_parse(BcParse* p);
97 
98 /**
99  * The @a BcParseExpr function for dc. (See include/parse.h for a definition of
100  * @a BcParseExpr.)
101  * @param p      The parser.
102  * @param flags  Flags that define the requirements that the parsed code must
103  *               meet or an error will result. See @a BcParseExpr for more info.
104  */
105 void
106 dc_parse_expr(BcParse* p, uint8_t flags);
107 
108 #endif // DC_ENABLED
109 
110 #endif // BC_DC_H
111