2018-10-23 04:53:20 +00:00
|
|
|
# This function is compatible with clang, clang++, and variations thereof, and is shared
|
|
|
|
# by clang.fish and clang++.fish.
|
|
|
|
# We dynamically query the head at `(commandline -o)[1]` to get the correct completions.
|
2020-01-22 14:17:37 +00:00
|
|
|
function __fish_complete_clang
|
2019-05-05 10:09:25 +00:00
|
|
|
# If the result is for a value, clang only prints the value, so completions
|
|
|
|
# for `-std=` print `c++11` and not `-std=c++11` like we need. See #4174.
|
|
|
|
set -l prefix (commandline -ct | string replace -fr -- '^(.*=)[^=]*' '$1')
|
2018-10-23 04:53:20 +00:00
|
|
|
|
2019-05-05 10:09:25 +00:00
|
|
|
# Don't hard-code the name of the clang binary
|
|
|
|
set -l clang (commandline -o)[1]
|
|
|
|
# first get the completions from clang, with the prefix separated from the value by a comma
|
2019-11-16 06:50:54 +00:00
|
|
|
$clang --autocomplete=(commandline -ct | string unescape | string replace -- "$prefix" "$prefix,") 2>/dev/null |
|
2020-08-17 09:43:02 +00:00
|
|
|
# and put it in a format that fish understands
|
|
|
|
string replace -r -- '^([^ ]+)\s*(.*)' "$prefix\$1\t\$2"
|
2018-10-23 04:53:20 +00:00
|
|
|
end
|