blob: 1c8717de78e2c5cbb85520f4d0710d3aeba695b5 [file] [log] [blame]
b.liue9582032025-04-17 19:18:16 +08001/* SPDX-License-Identifier: GPL-2.0-only */
2/*
3 * Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>
4 */
5
6#ifndef LKC_H
7#define LKC_H
8
9#include <assert.h>
10#include <stdio.h>
11#include <stdlib.h>
12
13#include "expr.h"
14
15#ifdef __cplusplus
16extern "C" {
17#endif
18
19#include "lkc_proto.h"
20
21#define SRCTREE "srctree"
22
23#ifndef CONFIG_
24#define CONFIG_ "CONFIG_"
25#endif
26static inline const char *CONFIG_prefix(void)
27{
28 return getenv( "CONFIG_" ) ?: CONFIG_;
29}
30#undef CONFIG_
31#define CONFIG_ CONFIG_prefix()
32
33extern int yylineno;
34void zconfdump(FILE *out);
35void zconf_starthelp(void);
36FILE *zconf_fopen(const char *name);
37void zconf_initscan(const char *name);
38void zconf_nextfile(const char *name);
39int zconf_lineno(void);
40const char *zconf_curname(void);
41extern int recursive_is_error;
42
43/* confdata.c */
44const char *conf_get_configname(void);
45void set_all_choice_values(struct symbol *csym);
46
47/* confdata.c and expr.c */
48static inline void xfwrite(const void *str, size_t len, size_t count, FILE *out)
49{
50 assert(len != 0);
51
52 if (fwrite(str, len, count, out) != count)
53 fprintf(stderr, "Error in writing or end of file.\n");
54}
55
56/* util.c */
57struct file *file_lookup(const char *name);
58void *xmalloc(size_t size);
59void *xcalloc(size_t nmemb, size_t size);
60void *xrealloc(void *p, size_t size);
61char *xstrdup(const char *s);
62char *xstrndup(const char *s, size_t n);
63
64/* lexer.l */
65int yylex(void);
66
67struct gstr {
68 size_t len;
69 char *s;
70 /*
71 * when max_width is not zero long lines in string s (if any) get
72 * wrapped not to exceed the max_width value
73 */
74 int max_width;
75};
76struct gstr str_new(void);
77void str_free(struct gstr *gs);
78void str_append(struct gstr *gs, const char *s);
79void str_printf(struct gstr *gs, const char *fmt, ...);
80char *str_get(struct gstr *gs);
81
82/* menu.c */
83void _menu_init(void);
84void menu_warn(struct menu *menu, const char *fmt, ...);
85struct menu *menu_add_menu(void);
86void menu_end_menu(void);
87void menu_add_entry(struct symbol *sym);
88void menu_add_dep(struct expr *dep);
89void menu_add_visibility(struct expr *dep);
90struct property *menu_add_prop(enum prop_type type, struct expr *expr, struct expr *dep);
91struct property *menu_add_prompt(enum prop_type type, char *prompt, struct expr *dep);
92void menu_add_expr(enum prop_type type, struct expr *expr, struct expr *dep);
93void menu_add_symbol(enum prop_type type, struct symbol *sym, struct expr *dep);
94void menu_finalize(struct menu *parent);
95void menu_set_type(int type);
96
97extern struct menu rootmenu;
98
99bool menu_is_empty(struct menu *menu);
100bool menu_is_visible(struct menu *menu);
101bool menu_has_prompt(struct menu *menu);
102const char *menu_get_prompt(struct menu *menu);
103struct menu *menu_get_parent_menu(struct menu *menu);
104bool menu_has_help(struct menu *menu);
105const char *menu_get_help(struct menu *menu);
106int get_jump_key_char(void);
107struct gstr get_relations_str(struct symbol **sym_arr, struct list_head *head);
108void menu_get_ext_help(struct menu *menu, struct gstr *help);
109
110/* symbol.c */
111void sym_clear_all_valid(void);
112struct symbol *sym_choice_default(struct symbol *sym);
113struct property *sym_get_range_prop(struct symbol *sym);
114const char *sym_get_string_default(struct symbol *sym);
115struct symbol *sym_check_deps(struct symbol *sym);
116struct symbol *prop_get_symbol(struct property *prop);
117
118static inline tristate sym_get_tristate_value(struct symbol *sym)
119{
120 return sym->curr.tri;
121}
122
123
124static inline struct symbol *sym_get_choice_value(struct symbol *sym)
125{
126 return (struct symbol *)sym->curr.val;
127}
128
129static inline bool sym_is_choice(struct symbol *sym)
130{
131 return sym->flags & SYMBOL_CHOICE ? true : false;
132}
133
134static inline bool sym_is_choice_value(struct symbol *sym)
135{
136 return sym->flags & SYMBOL_CHOICEVAL ? true : false;
137}
138
139static inline bool sym_is_optional(struct symbol *sym)
140{
141 return sym->flags & SYMBOL_OPTIONAL ? true : false;
142}
143
144static inline bool sym_has_value(struct symbol *sym)
145{
146 return sym->flags & SYMBOL_DEF_USER ? true : false;
147}
148
149#ifdef __cplusplus
150}
151#endif
152
153#endif /* LKC_H */