From: Moumita <dhar61595@gmail.com>
To: git@vger.kernel.org
Cc: Moumita <dhar61595@gmail.com>, "Johannes Sixt" <j6t@kdbg.org>,
"Eric Sunshine" <sunshine@sunshineco.com>,
"Junio C Hamano" <gitster@pobox.com>
Subject:
Date: Sun, 11 May 2025 18:58:01 +0530 [thread overview]
Message-ID: <20250511132802.16338-1-dhar61595@gmail.com> (raw)
In-Reply-To: <20250511125809.14180-1-dhar61595@gmail.com>
Subject: [PATCH v6 0/1] Added the newline after the test in t/4018
Sorry , I forgot to add the newline after the test in t/4018 again so I had send the patch agaain.
Moumita Dhar (1):
userdiff: extend Bash pattern to cover more shell function forms
t/t4018/bash-bashism-style-multiline-function | 4 ++
.../bash-hunk-header-complete-line-capture | 4 ++
t/t4018/bash-posix-style-multiline-function | 4 ++
.../bash-posix-style-single-command-function | 3 ++
t/t4034-diff-words.sh | 1 +
t/t4034/bash/expect | 38 +++++++++++++++++++
t/t4034/bash/post | 33 ++++++++++++++++
t/t4034/bash/pre | 33 ++++++++++++++++
userdiff.c | 28 ++++++++++----
9 files changed, 140 insertions(+), 8 deletions(-)
create mode 100644 t/t4018/bash-bashism-style-multiline-function
create mode 100644 t/t4018/bash-hunk-header-complete-line-capture
create mode 100644 t/t4018/bash-posix-style-multiline-function
create mode 100644 t/t4018/bash-posix-style-single-command-function
create mode 100644 t/t4034/bash/expect
create mode 100644 t/t4034/bash/post
create mode 100644 t/t4034/bash/pre
Range-diff against v5:
1: 40cffd3b4a ! 1: 464cb8a1eb userdiff: extend Bash pattern to cover more shell function forms
@@ Commit message
`x () echo hello`.
Replacing the function body matching logic with `.*$`, ensures
- that everything on the function definition line is captured,
- aligning with other userdiff drivers and improving hunk headers in
- `git diff`.
+ that everything on the function definition line is captured.
Additionally, the word regex is refined to better recognize shell
syntax, including additional parameter expansion operators and
- command-line options, improving syntax-aware diffs.
+ command-line options.
Signed-off-by: Moumita Dhar <dhar61595@gmail.com>
@@ t/t4018/bash-bashism-style-multiline-function (new)
+function RIGHT \
+{
+ echo 'ChangeMe'
++}
+
+ ## t/t4018/bash-hunk-header-complete-line-capture (new) ##
+@@
++func() { # RIGHT
++
++ ChangeMe
+}
## t/t4018/bash-posix-style-multiline-function (new) ##
@@ t/t4034/bash/expect (new)
+<BOLD>index 09ac008..60ba6a2 100644<RESET>
+<BOLD>--- a/pre<RESET>
+<BOLD>+++ b/post<RESET>
-+<CYAN>@@ -1,25 +1,25 @@<RESET>
++<CYAN>@@ -1,33 +1,33 @@<RESET>
+<RED>my_var<RESET><GREEN>new_var<RESET>=10
+x=<RED>123<RESET><GREEN>456<RESET>
+y=<RED>3.14<RESET><GREEN>2.71<RESET>
+z=<RED>.5<RESET><GREEN>.75<RESET>
+echo <RED>$USER<RESET><GREEN>$USERNAME<RESET>
+${<RED>HOME<RESET><GREEN>HOMEDIR<RESET>}
-+if [ "<RED>$a<RESET><GREEN>$x<RESET>" == "<RED>$b<RESET><GREEN>$y<RESET>" ] || [ "<RED>$c<RESET><GREEN>$x<RESET>" != "<RED>$d<RESET><GREEN>$y<RESET>" ]; then echo "OK"; fi
-+((<RED>a<RESET><GREEN>x<RESET>+=<RED>b<RESET><GREEN>y<RESET>))
-+((<RED>a<RESET><GREEN>x<RESET>-=<RED>b<RESET><GREEN>y<RESET>))
-+$((<RED>a<RESET><GREEN>x<RESET><<<RED>b<RESET><GREEN>y<RESET>))
-+$((<RED>a<RESET><GREEN>x<RESET>>><RED>b<RESET><GREEN>y<RESET>))
-+${<RED>a<RESET><GREEN>x<RESET>:-<RED>b<RESET><GREEN>y<RESET>}
-+${<RED>a<RESET><GREEN>x<RESET>:=<RED>b<RESET><GREEN>y<RESET>}
-+${<RED>a<RESET><GREEN>x<RESET>##*/}
-+${<RED>a<RESET><GREEN>x<RESET>%.*}
-+${<RED>a<RESET><GREEN>x<RESET>%%.*}
-+${<RED>a<RESET><GREEN>x<RESET>^^}
-+${<RED>a<RESET><GREEN>x<RESET>,}
-+${<RED>a<RESET><GREEN>x<RESET>,,}
-+${!<RED>a<RESET><GREEN>x<RESET>}
-+${<RED>a<RESET><GREEN>x<RESET>[@]}
-+${<RED>a<RESET><GREEN>x<RESET>:?error message}
-+${<RED>a<RESET><GREEN>x<RESET>:2:3}
++((a<RED>+<RESET><GREEN>+=<RESET>b))
++((a<RED>*<RESET><GREEN>*=<RESET>b))
++((a<RED>/<RESET><GREEN>/=<RESET>b))
++((a<RED>%<RESET><GREEN>%=<RESET>b))
++((a<RED>|<RESET><GREEN>|=<RESET>b))
++((a<RED>^<RESET><GREEN>^=<RESET>b))
++((a<RED>=<RESET><GREEN>==<RESET>b))
++((a<RED>!<RESET><GREEN>!=<RESET>b))
++((a<RED><<RESET><GREEN><=<RESET>b))
++((a<RED>><RESET><GREEN>>=<RESET>b))
++$((a<RED><<RESET><GREEN><<<RESET>b))
++$((a<RED>><RESET><GREEN>>><RESET>b))
++$((a<RED>&<RESET><GREEN>&&<RESET>b))
++$((a<RED>|<RESET><GREEN>||<RESET>b))
++${a<RED>:<RESET><GREEN>:-<RESET>b}
++${a<RED>:<RESET><GREEN>:=<RESET>b}
++${a<RED>:<RESET><GREEN>:+<RESET>b}
++${a<RED>:<RESET><GREEN>:?<RESET>b}
++${a<RED>#<RESET><GREEN>##<RESET>*/}
++${a<RED>%<RESET><GREEN>%%<RESET>.*}
++${a<RED>^<RESET><GREEN>^^<RESET>}
++${a<RED>,<RESET><GREEN>,,<RESET>}
++${<GREEN>!<RESET>a}
++${a[<RED>*<RESET><GREEN>@<RESET>]}
++${a<RED>:2:3<RESET><GREEN>:4:6<RESET>}
+ls <RED>-a<RESET><GREEN>-x<RESET>
+ls <RED>--a<RESET><GREEN>--x<RESET>
@@ t/t4034/bash/post (new)
+z=.75
+echo $USERNAME
+${HOMEDIR}
-+if [ "$x" == "$y" ] || [ "$x" != "$y" ]; then echo "OK"; fi
-+((x+=y))
-+((x-=y))
-+$((x<<y))
-+$((x>>y))
-+${x:-y}
-+${x:=y}
-+${x##*/}
-+${x%.*}
-+${x%%.*}
-+${x^^}
-+${x,}
-+${x,,}
-+${!x}
-+${x[@]}
-+${x:?error message}
-+${x:2:3}
++((a+=b))
++((a*=b))
++((a/=b))
++((a%=b))
++((a|=b))
++((a^=b))
++((a==b))
++((a!=b))
++((a<=b))
++((a>=b))
++$((a<<b))
++$((a>>b))
++$((a&&b))
++$((a||b))
++${a:-b}
++${a:=b}
++${a:+b}
++${a:?b}
++${a##*/}
++${a%%.*}
++${a^^}
++${a,,}
++${!a}
++${a[@]}
++${a:4:6}
+ls -x
+ls --x
@@ t/t4034/bash/pre (new)
+z=.5
+echo $USER
+${HOME}
-+if [ "$a" == "$b" ] || [ "$c" != "$d" ]; then echo "OK"; fi
-+((a+=b))
-+((a-=b))
-+$((a << b))
-+$((a >> b))
-+${a:-b}
-+${a:=b}
-+${a##*/}
++((a+b))
++((a*b))
++((a/b))
++((a%b))
++((a|b))
++((a^b))
++((a=b))
++((a!b))
++((a<b))
++((a>b))
++$((a<b))
++$((a>b))
++$((a&b))
++$((a|b))
++${a:b}
++${a:b}
++${a:b}
++${a:b}
++${a#*/}
+${a%.*}
-+${a%%.*}
-+${a^^}
++${a^}
+${a,}
-+${a,,}
-+${!a}
-+${a[@]}
-+${a:?error message}
++${a}
++${a[*]}
+${a:2:3}
+ls -a
+ls --a
## userdiff.c ##
@@ userdiff.c: PATTERNS("bash",
+ "("
+ "("
+ /* POSIX identifier with mandatory parentheses */
+- "[a-zA-Z_][a-zA-Z0-9_]*[ \t]*\\([ \t]*\\))"
++ "([a-zA-Z_][a-zA-Z0-9_]*[ \t]*\\([ \t]*\\))"
+ "|"
/* Bashism identifier with optional parentheses */
- "(function[ \t]+[a-zA-Z_][a-zA-Z0-9_]*(([ \t]*\\([ \t]*\\))|([ \t]+))"
+- "(function[ \t]+[a-zA-Z_][a-zA-Z0-9_]*(([ \t]*\\([ \t]*\\))|([ \t]+))"
++ "(function[ \t]+[a-zA-Z_][a-zA-Z0-9_]*(([ \t]*\\([ \t]*\\))|([ \t]+)))"
")"
- /* Optional whitespace */
- "[ \t]*"
@@ userdiff.c: PATTERNS("bash",
+ /* Assignment and arithmetic operators */
+ "|[-+*/%&|^!=<>]=?"
+ /* Additional parameter expansion operators */
-+ "|:?=|:-|:\\+|:\\?|:|#|##|%|%%|/[a-zA-Z0-9_-]+|\\^\\^?|,|,,?|!|@|:[0-9]+(:[0-9]+)?"
++ "|:?=|:-|:\\+|:\\?|:|#|##|%|%%|\\^\\^?|,|,,?|!|@|:[0-9]+(:[0-9]+)?"
+ /* Command-line options (to avoid splitting -option) */
+ "|--?[a-zA-Z0-9_-]+"
+ /* Brackets and grouping symbols */
--
2.48.0
next prev parent reply other threads:[~2025-05-11 13:28 UTC|newest]
Thread overview: 37+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-02-11 11:46 [PATCH 0/1] [GSOC 2025] [Newbie] userdiff: add built-in pattern for shell scripts Moumita
2025-02-11 11:46 ` [PATCH 1/1] Added built in function recognition for shell Moumita
2025-02-15 14:37 ` Johannes Sixt
2025-02-18 15:35 ` [PATCH v2 0/1] [PATCH v2 0/1] [GSOC 2025] [Newbie] userdiff: add built-in pattern for shell scripts Moumita
2025-02-18 15:35 ` [PATCH v2 1/1] userdiff: extend Bash pattern to cover more shell function forms Moumita
2025-02-18 19:30 ` Junio C Hamano
2025-02-22 18:15 ` Johannes Sixt
2025-02-24 16:28 ` Junio C Hamano
2025-02-18 23:38 ` Junio C Hamano
2025-02-22 18:14 ` Johannes Sixt
2025-02-18 17:30 ` [PATCH v2 0/1] [PATCH v2 0/1] [GSOC 2025] [Newbie] userdiff: add built-in pattern for shell scripts Eric Sunshine
2025-03-28 20:05 ` [PATCH v3 0/1] userdiff: improve Bash function and word regex patterns Moumita
2025-03-28 20:05 ` [PATCH v3 1/1] userdiff: extend Bash pattern to cover more shell function forms Moumita
2025-03-29 19:26 ` [PATCH v3 0/1] userdiff: improve Bash function and word regex patterns Junio C Hamano
2025-03-30 12:28 ` MOUMITA DHAR
2025-03-30 13:39 ` [PATCH v4 0/1][GSOC] userdiff:Added newlines at the end of the test cases Moumita
2025-03-30 13:39 ` [PATCH v4 1/1][GSOC] userdiff: extend Bash pattern to cover more shell function forms Moumita
2025-05-02 21:27 ` Junio C Hamano
2025-05-06 16:30 ` Johannes Sixt
2025-05-10 11:37 ` MOUMITA DHAR
2025-05-10 12:40 ` Johannes Sixt
2025-05-11 12:58 ` [PATCH v5 0/1] Added the closing ")" to make sure is not unbalanced and corrected the tests for word diff Moumita
2025-05-11 12:58 ` [PATCH v5 1/1] userdiff: extend Bash pattern to cover more shell function forms Moumita
2025-05-11 13:28 ` Moumita [this message]
2025-05-11 13:28 ` Moumita
2025-05-11 13:37 ` Moumita
2025-05-11 14:11 ` [PATCH v6 0/1] Added the newline after the test in t/4018 Moumita
2025-05-11 14:11 ` [PATCH v6 1/1] userdiff: extend Bash pattern to cover more shell function forms Moumita
2025-05-13 18:50 ` Junio C Hamano
2025-05-14 6:33 ` MOUMITA DHAR
2025-05-16 7:25 ` Johannes Sixt
2025-05-17 13:09 ` Junio C Hamano
2025-05-18 7:41 ` Johannes Sixt
2025-05-16 14:45 ` [PATCH v7 0/1] Updated the word diff regex for Bash scripts Moumita
2025-05-16 14:45 ` [PATCH v7 1/1] userdiff: extend Bash pattern to cover more shell function forms Moumita
2025-05-16 17:45 ` Johannes Sixt
2025-05-16 21:56 ` Junio C Hamano
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=20250511132802.16338-1-dhar61595@gmail.com \
--to=dhar61595@gmail.com \
--cc=git@vger.kernel.org \
--cc=gitster@pobox.com \
--cc=j6t@kdbg.org \
--cc=sunshine@sunshineco.com \
/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.
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).