From: Eitan Adler <lists@eitanadler.com>
To: zsh-workers@zsh.org
Cc: Eitan Adler <lists@eitanadler.com>
Subject: [PATCH] _gcc: Improve completer for _clang and _gcc
Date: Mon, 18 Jun 2018 05:14:46 +0000 [thread overview]
Message-ID: <20180618051446.69512-1-lists@eitanadler.com> (raw)
clang - add additional sanitizers
both - add additional standards (basically, aliases)
both - fix -flto
Signed-off-by: Eitan Adler <lists@eitanadler.com>
---
Completion/Unix/Command/_gcc | 22 ++++++++++++++++++----
1 file changed, 18 insertions(+), 4 deletions(-)
diff --git a/Completion/Unix/Command/_gcc b/Completion/Unix/Command/_gcc
index a552bb2db..9690df79f 100644
--- a/Completion/Unix/Command/_gcc
+++ b/Completion/Unix/Command/_gcc
@@ -338,16 +338,31 @@ h8/300)
;;
esac
+local -a sanitizers
if [[ "$service" = clang* ]]; then
args=(
$args
- -flto -emit-llvm
+ "-flto=-[generate output files suitable for link time optimization]::style:(full thin)"
+ -emit-llvm
"-Qunused-arguments[don't emit warning for unused driver arguments]"
--analyze
-fshow-column -fshow-source-location -fcaret-diagnostics -fdiagnostics-fixit-info
-fdiagnostics-parseable-fixits -fdiagnostics-print-source-range-info
-fprint-source-range-info -fdiagnostics-show-option -fmessage-length
)
+ sanitizers=(
+ address alignment bool bounds enum float-cast-overflow float-divide-by-zero
+ integer-divide-by-zero memory nonnull-attribute null nullability-arg nullability-assign
+ nullability-return object-size pointer-overflow return unsigned-integer-overflow
+ returns-nonnull-attribute shift signed-integer-overflow unreachable vla-bound vptr
+ )
+else
+ args=(
+ '-flto=-[Enable link-time optimization]::jobs:'
+ )
+ sanitizers=(
+ address memory
+ )
fi
local -a languages
@@ -399,7 +414,7 @@ args+=(
'-print-file-name=-[Display the full path to library <library>]:library:->library'
'-print-prog-name=-[Display the full path to compiler component <program>]:program:'
'*-specs=-[Override built-in specs with the contents of <file>]:file:_files'
- '-std=-[assume that the input sources are for specified standard]:standard:(c90 c89 c99 c11 gnu90 gnu89 gnu99 gnu11 c++98 c++03 gnu++98 gnu++03 c++11 gnu++11 c++1y gnu++1y c++14 gnu++14 c++1z gnu++1z c++17 gnu++17 c++2a gnu++2a)'
+ '-std=-[assume that the input sources are for specified standard]:standard:(c90 c89 iso9899:1990 iso9899:199409 c99 iso9899:1999 c11 iso9899:2011 gnu90 gnu89 gnu99 gnu11 c++98 c++03 gnu++98 gnu++03 c++11 gnu++11 c++1y gnu++1y c++14 gnu++14 c++1z gnu++1z c++17 iso9899:2017 gnu++17 c++2a gnu++2a)'
'*-include:include file:_files -g \*.h\(-.\)'
'*-imacros:macro input file:_files -g \*.h\(-.\)'
'*-idirafter:second include path directory:_files -/'
@@ -1034,7 +1049,6 @@ args+=(
'-flto-odr-type-merging[Merge C++ types using One Definition Rule]'
'-flto-partition=-[Partition symbols and vars at linktime based on object files they originate from]:partitioning algorithm:(1to1 balanced max one none)'
'-flto-report[Report various link-time optimization statistics]'
- '-flto=-[Enable link-time optimization]::jobs:'
'-fmax-errors=-[Maximum number of errors to report]:errors: '
'-fmem-report-wpa[Report on permanent memory allocation in WPA only]'
'-fmem-report[Report on permanent memory allocation]'
@@ -1061,7 +1075,7 @@ args+=(
'-freciprocal-math[Same as -fassociative-math for expressions which include division]'
'-frecord-gcc-switches[Record gcc command line switches in the object file]'
'-free[Turn on Redundant Extensions Elimination pass]'
- '-fsanitize=-[Enable AddressSanitizer, a memory error detector]:style:(address thread)'
+ "-fsanitize=-[Enable AddressSanitizer, a memory error detector]:style:($sanitizers)"
'-fsched-stalled-insns-dep=-[Set dependence distance checking in premature scheduling of queued insns]:instructions: '
'-fsched-stalled-insns=-[Set number of queued insns that can be prematurely scheduled]:instructions: '
'-fsched-verbose=-[Set the verbosity level of the scheduler]:verbosity: '
--
2.17.1
next reply other threads:[~2018-06-18 6:24 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-06-18 5:14 Eitan Adler [this message]
2018-06-18 7:44 ` Mikael Magnusson
2018-06-18 7:49 ` Eitan Adler
2018-06-18 12:37 ` Mikael Magnusson
2018-06-19 5:27 ` Eitan Adler
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20180618051446.69512-1-lists@eitanadler.com \
--to=lists@eitanadler.com \
--cc=zsh-workers@zsh.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.vuxu.org/mirror/zsh/
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).