mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-11-27 23:51:56 +00:00
[GSoC] Shell autocompletion for clang
Summary: This is a first patch for GSoC project, bash-completion for clang. To use this on bash, please run `source clang/utils/bash-autocomplete.sh`. bash-autocomplete.sh is code for bash-completion. Simple flag completion and path completion is available in this patch. Reviewers: teemperor, v.g.vassilev, ruiu, Bigcheese, efriedma Subscribers: llvm-commits Differential Revision: https://reviews.llvm.org/D33237 llvm-svn: 303670
This commit is contained in:
parent
7b0a6aa642
commit
c8068dbb07
@ -359,6 +359,10 @@ if (NOT LLVM_INSTALL_TOOLCHAIN_ONLY)
|
||||
PATTERN "*.inc"
|
||||
PATTERN "*.h"
|
||||
)
|
||||
|
||||
install(PROGRAMS utils/bash-autocomplete.sh
|
||||
DESTINATION share/clang
|
||||
)
|
||||
endif()
|
||||
|
||||
add_definitions( -D_GNU_SOURCE )
|
||||
|
@ -469,6 +469,7 @@ def arch__errors__fatal : Flag<["-"], "arch_errors_fatal">;
|
||||
def arch : Separate<["-"], "arch">, Flags<[DriverOption]>;
|
||||
def arch__only : Separate<["-"], "arch_only">;
|
||||
def a : Joined<["-"], "a">;
|
||||
def autocomplete : Joined<["--"], "autocomplete=">;
|
||||
def bind__at__load : Flag<["-"], "bind_at_load">;
|
||||
def bundle__loader : Separate<["-"], "bundle_loader">;
|
||||
def bundle : Flag<["-"], "bundle">;
|
||||
|
@ -1216,6 +1216,13 @@ bool Driver::HandleImmediateArgs(const Compilation &C) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (Arg *A = C.getArgs().getLastArg(options::OPT_autocomplete)) {
|
||||
// Print out all options that start with a given argument. This is used for
|
||||
// shell autocompletion.
|
||||
llvm::outs() << llvm::join(Opts->findByPrefix(A->getValue()), " ") << '\n';
|
||||
return false;
|
||||
}
|
||||
|
||||
if (C.getArgs().hasArg(options::OPT_print_libgcc_file_name)) {
|
||||
ToolChain::RuntimeLibType RLT = TC.GetRuntimeLibType(C.getArgs());
|
||||
switch (RLT) {
|
||||
|
6
clang/test/Driver/autocomplete.c
Normal file
6
clang/test/Driver/autocomplete.c
Normal file
@ -0,0 +1,6 @@
|
||||
// RUN: %clang --autocomplete=-fsyn | FileCheck %s -check-prefix=FSYN
|
||||
// FSYN: -fsyntax-only
|
||||
// RUN: %clang --autocomplete=-s | FileCheck %s -check-prefix=STD
|
||||
// STD: -std={{.*}}-stdlib=
|
||||
// RUN: %clang --autocomplete=foo | not FileCheck %s -check-prefix=NONE
|
||||
// NONE: foo
|
14
clang/utils/bash-autocomplete.sh
Normal file
14
clang/utils/bash-autocomplete.sh
Normal file
@ -0,0 +1,14 @@
|
||||
# Please add "source /path/to/bash-autocomplete.sh" to your .bashrc to use this.
|
||||
_clang()
|
||||
{
|
||||
local cur prev words cword flags
|
||||
_init_completion -n : || return
|
||||
|
||||
flags=$( clang --autocomplete="$cur" )
|
||||
if [[ "$flags" == "" || "$cur" == "" ]]; then
|
||||
_filedir
|
||||
else
|
||||
COMPREPLY=( $( compgen -W "$flags" -- "$cur" ) )
|
||||
fi
|
||||
}
|
||||
complete -F _clang clang
|
@ -113,6 +113,14 @@ public:
|
||||
return getInfo(id).MetaVar;
|
||||
}
|
||||
|
||||
/// Find flags from OptTable which starts with Cur.
|
||||
///
|
||||
/// \param [in] Cur - String prefix that all returned flags need
|
||||
// to start with.
|
||||
///
|
||||
/// \return The vector of flags which start with Cur.
|
||||
std::vector<std::string> findByPrefix(StringRef Cur) const;
|
||||
|
||||
/// \brief Parse a single argument; returning the new argument and
|
||||
/// updating Index.
|
||||
///
|
||||
|
@ -186,6 +186,20 @@ static unsigned matchOption(const OptTable::Info *I, StringRef Str,
|
||||
return 0;
|
||||
}
|
||||
|
||||
std::vector<std::string> OptTable::findByPrefix(StringRef Cur) const {
|
||||
std::vector<std::string> Ret;
|
||||
for (const Info &In : OptionInfos.slice(FirstSearchableIndex)) {
|
||||
if (!In.Prefixes)
|
||||
continue;
|
||||
for (int I = 0; In.Prefixes[I]; I++) {
|
||||
std::string S = std::string(In.Prefixes[I]) + std::string(In.Name);
|
||||
if (StringRef(S).startswith(Cur))
|
||||
Ret.push_back(S);
|
||||
}
|
||||
}
|
||||
return Ret;
|
||||
}
|
||||
|
||||
Arg *OptTable::ParseOneArg(const ArgList &Args, unsigned &Index,
|
||||
unsigned FlagsToInclude,
|
||||
unsigned FlagsToExclude) const {
|
||||
|
Loading…
Reference in New Issue
Block a user