2016-05-03 08:22:44 +08:00
|
|
|
// Functions having to do with parser keywords, like testing if a function is a block command.
|
2007-04-22 17:50:26 +08:00
|
|
|
#ifndef FISH_PARSER_KEYWORD_H
|
|
|
|
#define FISH_PARSER_KEYWORD_H
|
|
|
|
|
2015-07-25 23:14:25 +08:00
|
|
|
#include "common.h"
|
|
|
|
|
2016-05-03 08:22:44 +08:00
|
|
|
/// Tests if the specified commands parameters should be interpreted as another command, which will
|
|
|
|
/// be true if the command is either 'command', 'exec', 'if', 'while', or 'builtin'. This does not
|
|
|
|
/// handle "else if" which is more complicated.
|
|
|
|
///
|
|
|
|
/// \param cmd The command name to test
|
|
|
|
/// \return 1 of the command parameter is a command, 0 otherwise
|
2012-11-19 08:30:30 +08:00
|
|
|
bool parser_keywords_is_subcommand(const wcstring &cmd);
|
2007-04-22 17:50:26 +08:00
|
|
|
|
2016-05-03 08:22:44 +08:00
|
|
|
/// Tests if the specified command is a reserved word, i.e. if it is the name of one of the builtin
|
|
|
|
/// functions that change the block or command scope, like 'for', 'end' or 'command' or 'exec'.
|
|
|
|
/// These functions may not be overloaded, so their names are reserved.
|
|
|
|
///
|
|
|
|
/// \param word The command name to test
|
|
|
|
/// \return 1 of the command parameter is a command, 0 otherwise
|
2012-11-19 08:30:30 +08:00
|
|
|
bool parser_keywords_is_reserved(const wcstring &word);
|
2007-04-22 17:50:26 +08:00
|
|
|
|
2016-05-03 08:22:44 +08:00
|
|
|
/// Test if the specified string is command that opens a new block.
|
2012-11-19 08:30:30 +08:00
|
|
|
bool parser_keywords_is_block(const wcstring &word);
|
2007-04-22 17:50:26 +08:00
|
|
|
|
2016-05-03 08:22:44 +08:00
|
|
|
/// Check if the specified command is one of the builtins that cannot have arguments, any followin
|
|
|
|
/// argument is interpreted as a new command.
|
2012-11-19 08:30:30 +08:00
|
|
|
bool parser_keywords_skip_arguments(const wcstring &cmd);
|
2007-04-22 17:50:26 +08:00
|
|
|
|
|
|
|
#endif
|