Loading...
1/*
2 * Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>
3 * Released under the terms of the GNU GPL v2.0.
4 */
5
6#ifndef LKC_H
7#define LKC_H
8
9#include "expr.h"
10
11#ifndef KBUILD_NO_NLS
12# include <libintl.h>
13#else
14static inline const char *gettext(const char *txt) { return txt; }
15static inline void textdomain(const char *domainname) {}
16static inline void bindtextdomain(const char *name, const char *dir) {}
17static inline char *bind_textdomain_codeset(const char *dn, char *c) { return c; }
18#endif
19
20#ifdef __cplusplus
21extern "C" {
22#endif
23
24#define P(name,type,arg) extern type name arg
25#include "lkc_proto.h"
26#undef P
27
28#define SRCTREE "srctree"
29
30#ifndef PACKAGE
31#define PACKAGE "linux"
32#endif
33
34#define LOCALEDIR "/usr/share/locale"
35
36#define _(text) gettext(text)
37#define N_(text) (text)
38
39#ifndef CONFIG_
40#define CONFIG_ "CONFIG_"
41#endif
42
43#define TF_COMMAND 0x0001
44#define TF_PARAM 0x0002
45#define TF_OPTION 0x0004
46
47enum conf_def_mode {
48 def_default,
49 def_yes,
50 def_mod,
51 def_no,
52 def_random
53};
54
55#define T_OPT_MODULES 1
56#define T_OPT_DEFCONFIG_LIST 2
57#define T_OPT_ENV 3
58
59struct kconf_id {
60 int name;
61 int token;
62 unsigned int flags;
63 enum symbol_type stype;
64};
65
66extern int zconfdebug;
67
68int zconfparse(void);
69void zconfdump(FILE *out);
70void zconf_starthelp(void);
71FILE *zconf_fopen(const char *name);
72void zconf_initscan(const char *name);
73void zconf_nextfile(const char *name);
74int zconf_lineno(void);
75const char *zconf_curname(void);
76
77/* confdata.c */
78const char *conf_get_configname(void);
79const char *conf_get_autoconfig_name(void);
80char *conf_get_default_confname(void);
81void sym_set_change_count(int count);
82void sym_add_change_count(int count);
83void conf_set_all_new_symbols(enum conf_def_mode mode);
84
85struct conf_printer {
86 void (*print_symbol)(FILE *, struct symbol *, const char *, void *);
87 void (*print_comment)(FILE *, const char *, void *);
88};
89
90/* confdata.c and expr.c */
91static inline void xfwrite(const void *str, size_t len, size_t count, FILE *out)
92{
93 assert(len != 0);
94
95 if (fwrite(str, len, count, out) != count)
96 fprintf(stderr, "Error in writing or end of file.\n");
97}
98
99/* menu.c */
100void _menu_init(void);
101void menu_warn(struct menu *menu, const char *fmt, ...);
102struct menu *menu_add_menu(void);
103void menu_end_menu(void);
104void menu_add_entry(struct symbol *sym);
105void menu_end_entry(void);
106void menu_add_dep(struct expr *dep);
107void menu_add_visibility(struct expr *dep);
108struct property *menu_add_prop(enum prop_type type, char *prompt, struct expr *expr, struct expr *dep);
109struct property *menu_add_prompt(enum prop_type type, char *prompt, struct expr *dep);
110void menu_add_expr(enum prop_type type, struct expr *expr, struct expr *dep);
111void menu_add_symbol(enum prop_type type, struct symbol *sym, struct expr *dep);
112void menu_add_option(int token, char *arg);
113void menu_finalize(struct menu *parent);
114void menu_set_type(int type);
115
116/* util.c */
117struct file *file_lookup(const char *name);
118int file_write_dep(const char *name);
119
120struct gstr {
121 size_t len;
122 char *s;
123 /*
124 * when max_width is not zero long lines in string s (if any) get
125 * wrapped not to exceed the max_width value
126 */
127 int max_width;
128};
129struct gstr str_new(void);
130struct gstr str_assign(const char *s);
131void str_free(struct gstr *gs);
132void str_append(struct gstr *gs, const char *s);
133void str_printf(struct gstr *gs, const char *fmt, ...);
134const char *str_get(struct gstr *gs);
135
136/* symbol.c */
137extern struct expr *sym_env_list;
138
139void sym_init(void);
140void sym_clear_all_valid(void);
141void sym_set_all_changed(void);
142void sym_set_changed(struct symbol *sym);
143struct symbol *sym_choice_default(struct symbol *sym);
144const char *sym_get_string_default(struct symbol *sym);
145struct symbol *sym_check_deps(struct symbol *sym);
146struct property *prop_alloc(enum prop_type type, struct symbol *sym);
147struct symbol *prop_get_symbol(struct property *prop);
148struct property *sym_get_env_prop(struct symbol *sym);
149
150static inline tristate sym_get_tristate_value(struct symbol *sym)
151{
152 return sym->curr.tri;
153}
154
155
156static inline struct symbol *sym_get_choice_value(struct symbol *sym)
157{
158 return (struct symbol *)sym->curr.val;
159}
160
161static inline bool sym_set_choice_value(struct symbol *ch, struct symbol *chval)
162{
163 return sym_set_tristate_value(chval, yes);
164}
165
166static inline bool sym_is_choice(struct symbol *sym)
167{
168 return sym->flags & SYMBOL_CHOICE ? true : false;
169}
170
171static inline bool sym_is_choice_value(struct symbol *sym)
172{
173 return sym->flags & SYMBOL_CHOICEVAL ? true : false;
174}
175
176static inline bool sym_is_optional(struct symbol *sym)
177{
178 return sym->flags & SYMBOL_OPTIONAL ? true : false;
179}
180
181static inline bool sym_has_value(struct symbol *sym)
182{
183 return sym->flags & SYMBOL_DEF_USER ? true : false;
184}
185
186#ifdef __cplusplus
187}
188#endif
189
190#endif /* LKC_H */
1/* SPDX-License-Identifier: GPL-2.0 */
2/*
3 * Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>
4 */
5
6#ifndef LKC_H
7#define LKC_H
8
9#include "expr.h"
10
11#ifdef __cplusplus
12extern "C" {
13#endif
14
15#include "lkc_proto.h"
16
17#define SRCTREE "srctree"
18
19#ifndef PACKAGE
20#define PACKAGE "linux"
21#endif
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
33enum conf_def_mode {
34 def_default,
35 def_yes,
36 def_mod,
37 def_y2m,
38 def_m2y,
39 def_no,
40 def_random
41};
42
43extern int yylineno;
44void zconfdump(FILE *out);
45void zconf_starthelp(void);
46FILE *zconf_fopen(const char *name);
47void zconf_initscan(const char *name);
48void zconf_nextfile(const char *name);
49int zconf_lineno(void);
50const char *zconf_curname(void);
51
52/* confdata.c */
53const char *conf_get_configname(void);
54void sym_set_change_count(int count);
55void sym_add_change_count(int count);
56bool conf_set_all_new_symbols(enum conf_def_mode mode);
57void conf_rewrite_mod_or_yes(enum conf_def_mode mode);
58void set_all_choice_values(struct symbol *csym);
59
60/* confdata.c and expr.c */
61static inline void xfwrite(const void *str, size_t len, size_t count, FILE *out)
62{
63 assert(len != 0);
64
65 if (fwrite(str, len, count, out) != count)
66 fprintf(stderr, "Error in writing or end of file.\n");
67}
68
69/* util.c */
70struct file *file_lookup(const char *name);
71void *xmalloc(size_t size);
72void *xcalloc(size_t nmemb, size_t size);
73void *xrealloc(void *p, size_t size);
74char *xstrdup(const char *s);
75char *xstrndup(const char *s, size_t n);
76
77/* lexer.l */
78int yylex(void);
79
80struct gstr {
81 size_t len;
82 char *s;
83 /*
84 * when max_width is not zero long lines in string s (if any) get
85 * wrapped not to exceed the max_width value
86 */
87 int max_width;
88};
89struct gstr str_new(void);
90void str_free(struct gstr *gs);
91void str_append(struct gstr *gs, const char *s);
92void str_printf(struct gstr *gs, const char *fmt, ...);
93const char *str_get(struct gstr *gs);
94
95/* menu.c */
96void _menu_init(void);
97void menu_warn(struct menu *menu, const char *fmt, ...);
98struct menu *menu_add_menu(void);
99void menu_end_menu(void);
100void menu_add_entry(struct symbol *sym);
101void menu_add_dep(struct expr *dep);
102void menu_add_visibility(struct expr *dep);
103struct property *menu_add_prompt(enum prop_type type, char *prompt, struct expr *dep);
104void menu_add_expr(enum prop_type type, struct expr *expr, struct expr *dep);
105void menu_add_symbol(enum prop_type type, struct symbol *sym, struct expr *dep);
106void menu_add_option_modules(void);
107void menu_add_option_defconfig_list(void);
108void menu_add_option_allnoconfig_y(void);
109void menu_finalize(struct menu *parent);
110void menu_set_type(int type);
111
112extern struct menu rootmenu;
113
114bool menu_is_empty(struct menu *menu);
115bool menu_is_visible(struct menu *menu);
116bool menu_has_prompt(struct menu *menu);
117const char *menu_get_prompt(struct menu *menu);
118struct menu *menu_get_root_menu(struct menu *menu);
119struct menu *menu_get_parent_menu(struct menu *menu);
120bool menu_has_help(struct menu *menu);
121const char *menu_get_help(struct menu *menu);
122struct gstr get_relations_str(struct symbol **sym_arr, struct list_head *head);
123void menu_get_ext_help(struct menu *menu, struct gstr *help);
124
125/* symbol.c */
126void sym_clear_all_valid(void);
127struct symbol *sym_choice_default(struct symbol *sym);
128struct property *sym_get_range_prop(struct symbol *sym);
129const char *sym_get_string_default(struct symbol *sym);
130struct symbol *sym_check_deps(struct symbol *sym);
131struct symbol *prop_get_symbol(struct property *prop);
132
133static inline tristate sym_get_tristate_value(struct symbol *sym)
134{
135 return sym->curr.tri;
136}
137
138
139static inline struct symbol *sym_get_choice_value(struct symbol *sym)
140{
141 return (struct symbol *)sym->curr.val;
142}
143
144static inline bool sym_set_choice_value(struct symbol *ch, struct symbol *chval)
145{
146 return sym_set_tristate_value(chval, yes);
147}
148
149static inline bool sym_is_choice(struct symbol *sym)
150{
151 return sym->flags & SYMBOL_CHOICE ? true : false;
152}
153
154static inline bool sym_is_choice_value(struct symbol *sym)
155{
156 return sym->flags & SYMBOL_CHOICEVAL ? true : false;
157}
158
159static inline bool sym_is_optional(struct symbol *sym)
160{
161 return sym->flags & SYMBOL_OPTIONAL ? true : false;
162}
163
164static inline bool sym_has_value(struct symbol *sym)
165{
166 return sym->flags & SYMBOL_DEF_USER ? true : false;
167}
168
169#ifdef __cplusplus
170}
171#endif
172
173#endif /* LKC_H */