init version.
[bush.git] / src / alias.h
blob7f8171ba988de9e1003fcb9857af9a6165fb7428
1 /* alias.h -- structure definitions. */
3 /* Copyright (C) 1987-2020 Free Software Foundation, Inc.
5 This file is part of GNU Bush, the Bourne Again SHell.
7 Bush is free software: you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation, either version 3 of the License, or
10 (at your option) any later version.
12 Bush is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with Bush. If not, see <http://www.gnu.org/licenses/>.
21 #if !defined (_ALIAS_H_)
22 #define _ALIAS_H_
24 #include "stdc.h"
26 #include "hashlib.h"
28 typedef struct alias {
29 char *name;
30 char *value;
31 char flags;
32 } alias_t;
34 /* Values for `flags' member of struct alias. */
35 #define AL_EXPANDNEXT 0x1
36 #define AL_BEINGEXPANDED 0x2
38 /* The list of known aliases. */
39 extern HASH_TABLE *aliases;
41 extern void initialize_aliases PARAMS((void));
43 /* Scan the list of aliases looking for one with NAME. Return NULL
44 if the alias doesn't exist, else a pointer to the alias. */
45 extern alias_t *find_alias PARAMS((char *));
47 /* Return the value of the alias for NAME, or NULL if there is none. */
48 extern char *get_alias_value PARAMS((char *));
50 /* Make a new alias from NAME and VALUE. If NAME can be found,
51 then replace its value. */
52 extern void add_alias PARAMS((char *, char *));
54 /* Remove the alias with name NAME from the alias list. Returns
55 the index of the removed alias, or -1 if the alias didn't exist. */
56 extern int remove_alias PARAMS((char *));
58 /* Remove all aliases. */
59 extern void delete_all_aliases PARAMS((void));
61 /* Return an array of all defined aliases. */
62 extern alias_t **all_aliases PARAMS((void));
64 /* Expand a single word for aliases. */
65 extern char *alias_expand_word PARAMS((char *));
67 /* Return a new line, with any aliases expanded. */
68 extern char *alias_expand PARAMS((char *));
70 /* Helper definition for the parser */
71 extern void clear_string_list_expander PARAMS((alias_t *));
73 #endif /* _ALIAS_H_ */