Enhance gcc completion to gcc9
OBS-URL: https://build.opensuse.org/package/show/shells/bash-completion?expand=0&rev=100
This commit is contained in:
parent
c686172e8a
commit
d34f86a079
@ -12,7 +12,7 @@
|
|||||||
# license that conforms to the Open Source Definition (Version 1.9)
|
# license that conforms to the Open Source Definition (Version 1.9)
|
||||||
# published by the Open Source Initiative.
|
# published by the Open Source Initiative.
|
||||||
|
|
||||||
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
# Please submit bugfixes or comments via http://bugs.opensuse.org/
|
||||||
#
|
#
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Fri Apr 26 08:44:42 UTC 2019 - Dr. Werner Fink <werner@suse.de>
|
||||||
|
|
||||||
|
- Add patch gcc-564d068.patch from pull request 564d068 of
|
||||||
|
Martin to upstream of bash-completion
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Fri Mar 29 20:13:38 UTC 2019 - Martin Wilck <mwilck@suse.com>
|
Fri Mar 29 20:13:38 UTC 2019 - Martin Wilck <mwilck@suse.com>
|
||||||
|
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
# license that conforms to the Open Source Definition (Version 1.9)
|
# license that conforms to the Open Source Definition (Version 1.9)
|
||||||
# published by the Open Source Initiative.
|
# published by the Open Source Initiative.
|
||||||
|
|
||||||
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
# Please submit bugfixes or comments via http://bugs.opensuse.org/
|
||||||
#
|
#
|
||||||
|
|
||||||
|
|
||||||
@ -54,6 +54,8 @@ Patch10: backticks-bsc963140.patch
|
|||||||
Patch11: sh-script-completion-boo977336.patch
|
Patch11: sh-script-completion-boo977336.patch
|
||||||
# PATCH-FIX-SUSE boo#1090515
|
# PATCH-FIX-SUSE boo#1090515
|
||||||
Patch12: bash-completion-2.7-unRAR-remove.patch
|
Patch12: bash-completion-2.7-unRAR-remove.patch
|
||||||
|
# PATCH-ENHANCE-SUSE from pull request 564d068 of Martin to upstream of bash-completion
|
||||||
|
Patch13: gcc-564d068.patch
|
||||||
%if %build_doc
|
%if %build_doc
|
||||||
BuildRequires: asciidoc
|
BuildRequires: asciidoc
|
||||||
BuildRequires: libxslt-tools
|
BuildRequires: libxslt-tools
|
||||||
@ -108,6 +110,7 @@ package bash-completion.
|
|||||||
%patch10 -b .p10 -p1
|
%patch10 -b .p10 -p1
|
||||||
%patch11 -b .p11 -p0
|
%patch11 -b .p11 -p0
|
||||||
%patch12 -b .p12 -p0
|
%patch12 -b .p12 -p0
|
||||||
|
%patch13 -b .p13 -p0
|
||||||
|
|
||||||
%build
|
%build
|
||||||
%configure
|
%configure
|
||||||
|
108
gcc-564d068.patch
Normal file
108
gcc-564d068.patch
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
From 564d068cb890dc7dbca9c566fd7fab227558efd6 Mon Sep 17 00:00:00 2001
|
||||||
|
From: marxin <mliska@suse.cz>
|
||||||
|
Date: Mon, 14 May 2018 15:35:57 +0200
|
||||||
|
Subject: [PATCH] Add support for GCC --completion= option.
|
||||||
|
|
||||||
|
---
|
||||||
|
completions/gcc | 83 +++++++++++++++++++++++++++++++-------------------------
|
||||||
|
1 file changed, 47 insertions(+), 36 deletions(-)
|
||||||
|
|
||||||
|
--- completions/gcc
|
||||||
|
+++ completions/gcc 2019-04-26 08:40:48.199351068 +0000
|
||||||
|
@@ -1,49 +1,60 @@
|
||||||
|
# gcc(1) completion -*- shell-script -*-
|
||||||
|
-#
|
||||||
|
-# The only unusual feature is that we don't parse "gcc --help -v" output
|
||||||
|
-# directly, because that would include the options of all the other backend
|
||||||
|
-# tools (linker, assembler, preprocessor, etc) without any indication that
|
||||||
|
-# you cannot feed such options to the gcc driver directly. (For example, the
|
||||||
|
-# linker takes a -z option, but you must type -Wl,-z for gcc.) Instead, we
|
||||||
|
-# ask the driver ("g++") for the name of the compiler ("cc1"), and parse the
|
||||||
|
-# --help output of the compiler.
|
||||||
|
|
||||||
|
_gcc()
|
||||||
|
{
|
||||||
|
- local cur prev words cword
|
||||||
|
+ local cur prev prev2 words cword argument prefix prefix_length
|
||||||
|
_init_completion || return
|
||||||
|
+ _expand || return
|
||||||
|
|
||||||
|
- local cc backend
|
||||||
|
+ # Test that GCC is recent enough and if not fallback to
|
||||||
|
+ # parsing of --completion option.
|
||||||
|
+ $1 --completion=" " 2> /dev/null
|
||||||
|
+ if ! $1 --completion=" " 2>/dev/null; then
|
||||||
|
+ if [[ "$cur" == -* ]]; then
|
||||||
|
+ local cc=$( $1 -print-prog-name=cc1 2> /dev/null )
|
||||||
|
+ [[ $cc ]] || return
|
||||||
|
+ COMPREPLY=( $( compgen -W "$( $cc --help 2> /dev/null | tr '\t' ' ' |\
|
||||||
|
+ command sed -e '/^ *-/!d' -e 's/ *-\([^][ <>]*\).*/-\1/' )" -- "$cur" ) )
|
||||||
|
+ [[ $COMPREPLY == *= ]] && compopt -o nospace
|
||||||
|
+ return
|
||||||
|
+ else
|
||||||
|
+ _filedir
|
||||||
|
+ return
|
||||||
|
+ fi
|
||||||
|
+ fi
|
||||||
|
|
||||||
|
- case $1 in
|
||||||
|
- gcj)
|
||||||
|
- backend=jc1
|
||||||
|
- ;;
|
||||||
|
- gpc)
|
||||||
|
- backend=gpc1
|
||||||
|
- ;;
|
||||||
|
- *77)
|
||||||
|
- backend=f771
|
||||||
|
- ;;
|
||||||
|
- *95)
|
||||||
|
- backend=f951
|
||||||
|
- ;;
|
||||||
|
- *)
|
||||||
|
- backend=cc1 # (near-)universal backend
|
||||||
|
- ;;
|
||||||
|
- esac
|
||||||
|
+ # extract also for situations like: -fsanitize=add
|
||||||
|
+ if [[ $cword > 2 ]]; then
|
||||||
|
+ prev2="${COMP_WORDS[$cword - 2]}"
|
||||||
|
+ fi
|
||||||
|
|
||||||
|
+ # sample: -fsan
|
||||||
|
if [[ "$cur" == -* ]]; then
|
||||||
|
- cc=$( $1 -print-prog-name=$backend 2>/dev/null )
|
||||||
|
- [[ $cc ]] || return
|
||||||
|
- # sink stderr:
|
||||||
|
- # for C/C++/ObjectiveC it's useless
|
||||||
|
- # for FORTRAN/Java it's an error
|
||||||
|
- COMPREPLY=( $( compgen -W "$( $cc --help 2>/dev/null | tr '\t' ' ' |\
|
||||||
|
- command sed -e '/^ *-/!d' -e 's/ *-\([^][ <>]*\).*/-\1/' )" -- "$cur" ) )
|
||||||
|
- [[ $COMPREPLY == *= ]] && compopt -o nospace
|
||||||
|
- else
|
||||||
|
+ argument=$cur
|
||||||
|
+ prefix=""
|
||||||
|
+ # sample: -fsanitize=
|
||||||
|
+ elif [[ "$cur" == "=" && $prev == -* ]]; then
|
||||||
|
+ argument=$prev$cur
|
||||||
|
+ prefix=$prev$cur
|
||||||
|
+ # sample: -fsanitize=add
|
||||||
|
+ elif [[ "$prev" == "=" && $prev2 == -* ]]; then
|
||||||
|
+ argument=$prev2$prev$cur
|
||||||
|
+ prefix=$prev2$prev
|
||||||
|
+ # sample: --param lto-
|
||||||
|
+ elif [[ "$prev" == "--param" ]]; then
|
||||||
|
+ argument="$prev $cur"
|
||||||
|
+ prefix="$prev "
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ if [[ "$argument" == "" ]]; then
|
||||||
|
_filedir
|
||||||
|
+ else
|
||||||
|
+ # In situation like '-fsanitize=add' $cur is equal to last token.
|
||||||
|
+ # Thus we need to strip the beginning of suggested option.
|
||||||
|
+ prefix_length=`expr length "$prefix" + 1`
|
||||||
|
+ local flags=$( gcc --completion="$argument" 2> /dev/null | cut -c $prefix_length-)
|
||||||
|
+ [[ "${flags: -1}" == '=' ]] && compopt -o nospace 2> /dev/null
|
||||||
|
+ COMPREPLY=( $( compgen -W "$flags" -- "") )
|
||||||
|
fi
|
||||||
|
} &&
|
||||||
|
complete -F _gcc gcc g++ gfortran g77 g95 gcj gpc &&
|
Loading…
Reference in New Issue
Block a user