* [PATCH 1/1] Teach for-each-ref about a little language called Tcl.
@ 2007-01-28 7:39 Shawn O. Pearce
2007-01-28 9:49 ` Sergey Vlasov
0 siblings, 1 reply; 4+ messages in thread
From: Shawn O. Pearce @ 2007-01-28 7:39 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git, Sergey Vlasov
Love it or hate it, some people actually still program in Tcl. Some
of those programs are meant for interfacing with Git. Programs such as
gitk and git-gui. It may be useful to have Tcl-safe output available
from for-each-ref, just like shell, Perl and Python already enjoy.
Thanks to Sergey Vlasov for pointing out the horrible flaws in the
first version of this patch, and steering me in the right direction
for Tcl value quoting.
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
---
This replaces my prior patch. As Sergey pointed out, it was
horribly broken.
Documentation/git-for-each-ref.txt | 4 ++--
builtin-for-each-ref.c | 10 ++++++++++
quote.c | 36 ++++++++++++++++++++++++++++++++++++
quote.h | 1 +
4 files changed, 49 insertions(+), 2 deletions(-)
diff --git a/Documentation/git-for-each-ref.txt b/Documentation/git-for-each-ref.txt
index 06e7ab1..da52eba 100644
--- a/Documentation/git-for-each-ref.txt
+++ b/Documentation/git-for-each-ref.txt
@@ -7,7 +7,7 @@ git-for-each-ref - Output information on each ref
SYNOPSIS
--------
-'git-for-each-ref' [--count=<count>]\* [--shell|--perl|--python] [--sort=<key>]\* [--format=<format>] [<pattern>]
+'git-for-each-ref' [--count=<count>]\* [--shell|--perl|--python|--tcl] [--sort=<key>]\* [--format=<format>] [<pattern>]
DESCRIPTION
-----------
@@ -49,7 +49,7 @@ OPTIONS
using fnmatch(3). Refs that do not match the pattern
are not shown.
---shell, --perl, --python::
+--shell, --perl, --python, --tcl::
If given, strings that substitute `%(fieldname)`
placeholders are quoted as string literals suitable for
the specified host language. This is meant to produce
diff --git a/builtin-for-each-ref.c b/builtin-for-each-ref.c
index af72a12..9d5f266 100644
--- a/builtin-for-each-ref.c
+++ b/builtin-for-each-ref.c
@@ -12,6 +12,7 @@
#define QUOTE_SHELL 1
#define QUOTE_PERL 2
#define QUOTE_PYTHON 3
+#define QUOTE_TCL 4
typedef enum { FIELD_STR, FIELD_ULONG, FIELD_TIME } cmp_type;
@@ -723,6 +724,9 @@ static void print_value(struct refinfo *ref, int atom, int quote_style)
case QUOTE_PYTHON:
python_quote_print(stdout, v->s);
break;
+ case QUOTE_TCL:
+ tcl_quote_print(stdout, v->s);
+ break;
}
}
@@ -834,6 +838,12 @@ int cmd_for_each_ref(int ac, const char **av, char *prefix)
quote_style = QUOTE_PYTHON;
continue;
}
+ if (!strcmp(arg, "--tcl") ) {
+ if (0 <= quote_style)
+ die("more than one quoting style?");
+ quote_style = QUOTE_TCL;
+ continue;
+ }
if (!strncmp(arg, "--count=", 8)) {
if (maxcount)
die("more than one --count?");
diff --git a/quote.c b/quote.c
index a418a0f..01db5e2 100644
--- a/quote.c
+++ b/quote.c
@@ -387,3 +387,39 @@ void python_quote_print(FILE *stream, const char *src)
}
fputc(sq, stream);
}
+
+void tcl_quote_print(FILE *stream, const char *src)
+{
+ char c;
+
+ fputc('"', stream);
+ while ((c = *src++)) {
+ switch (c) {
+ case '[':
+ case ']':
+ case '$':
+ case '\\':
+ case '"':
+ fputc('\\', stream);
+ default:
+ fputc(c, stream);
+ break;
+ case '\f':
+ fputs("\\f", stream);
+ break;
+ case '\r':
+ fputs("\\r", stream);
+ break;
+ case '\n':
+ fputs("\\n", stream);
+ break;
+ case '\t':
+ fputs("\\t", stream);
+ break;
+ case '\v':
+ fputs("\\v", stream);
+ break;
+ }
+ }
+ fputc('"', stream);
+}
diff --git a/quote.h b/quote.h
index b55e699..bdc3610 100644
--- a/quote.h
+++ b/quote.h
@@ -55,5 +55,6 @@ extern void write_name_quoted(const char *prefix, int prefix_len,
/* quoting as a string literal for other languages */
extern void perl_quote_print(FILE *stream, const char *src);
extern void python_quote_print(FILE *stream, const char *src);
+extern void tcl_quote_print(FILE *stream, const char *src);
#endif
--
1.5.0.rc2.gf127
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH 1/1] Teach for-each-ref about a little language called Tcl.
2007-01-28 7:39 [PATCH 1/1] Teach for-each-ref about a little language called Tcl Shawn O. Pearce
@ 2007-01-28 9:49 ` Sergey Vlasov
2007-01-28 20:58 ` Junio C Hamano
0 siblings, 1 reply; 4+ messages in thread
From: Sergey Vlasov @ 2007-01-28 9:49 UTC (permalink / raw)
To: Shawn O. Pearce; +Cc: Junio C Hamano, git
[-- Attachment #1: Type: text/plain, Size: 1775 bytes --]
On Sun, Jan 28, 2007 at 02:39:13AM -0500, Shawn O. Pearce wrote:
> Love it or hate it, some people actually still program in Tcl. Some
> of those programs are meant for interfacing with Git. Programs such as
> gitk and git-gui. It may be useful to have Tcl-safe output available
> from for-each-ref, just like shell, Perl and Python already enjoy.
>
> Thanks to Sergey Vlasov for pointing out the horrible flaws in the
> first version of this patch, and steering me in the right direction
> for Tcl value quoting.
[...]
> +void tcl_quote_print(FILE *stream, const char *src)
> +{
> + char c;
> +
> + fputc('"', stream);
> + while ((c = *src++)) {
> + switch (c) {
> + case '[':
> + case ']':
> + case '$':
> + case '\\':
> + case '"':
> + fputc('\\', stream);
> + default:
> + fputc(c, stream);
> + break;
> + case '\f':
> + fputs("\\f", stream);
> + break;
> + case '\r':
> + fputs("\\r", stream);
> + break;
> + case '\n':
> + fputs("\\n", stream);
> + break;
> + case '\t':
> + fputs("\\t", stream);
> + break;
> + case '\v':
> + fputs("\\v", stream);
> + break;
> + }
> + }
> + fputc('"', stream);
> +}
This is better; however, wrapping this format inside { ... } (which
you may want to do in the template for some uses) won't work if the
string contains unmatched braces. Quoting '{' and '}' characters with
backslashes should fix this.
BTW, escaping newline characters as done here is not strictly required
for a double-quoted string, but is very useful, because you may read
the output line by line with "gets" and get fields from each line with
"lindex"; without this escaping you will need to read the whole output
before trying to parse it as a single huge list.
[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 189 bytes --]
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH 1/1] Teach for-each-ref about a little language called Tcl.
2007-01-28 9:49 ` Sergey Vlasov
@ 2007-01-28 20:58 ` Junio C Hamano
2007-01-29 9:51 ` Sergey Vlasov
0 siblings, 1 reply; 4+ messages in thread
From: Junio C Hamano @ 2007-01-28 20:58 UTC (permalink / raw)
To: Sergey Vlasov; +Cc: git, Shawn O. Pearce
Sergey Vlasov <vsu@altlinux.ru> writes:
> This is better; however, wrapping this format inside { ... } (which
> you may want to do in the template for some uses) won't work if the
> string contains unmatched braces. Quoting '{' and '}' characters with
> backslashes should fix this.
Then I'd commit after applying this on top of Shawn's. Ok?
diff --git a/quote.c b/quote.c
index 01db5e2..fb9e4ca 100644
--- a/quote.c
+++ b/quote.c
@@ -395,11 +395,9 @@ void tcl_quote_print(FILE *stream, const char *src)
fputc('"', stream);
while ((c = *src++)) {
switch (c) {
- case '[':
- case ']':
- case '$':
- case '\\':
- case '"':
+ case '[': case ']':
+ case '{': case '}':
+ case '$': case '\\': case '"':
fputc('\\', stream);
default:
fputc(c, stream);
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH 1/1] Teach for-each-ref about a little language called Tcl.
2007-01-28 20:58 ` Junio C Hamano
@ 2007-01-29 9:51 ` Sergey Vlasov
0 siblings, 0 replies; 4+ messages in thread
From: Sergey Vlasov @ 2007-01-29 9:51 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git, Shawn O. Pearce
[-- Attachment #1: Type: text/plain, Size: 685 bytes --]
On Sun, Jan 28, 2007 at 12:58:51PM -0800, Junio C Hamano wrote:
> Then I'd commit after applying this on top of Shawn's. Ok?
>
> diff --git a/quote.c b/quote.c
> index 01db5e2..fb9e4ca 100644
> --- a/quote.c
> +++ b/quote.c
> @@ -395,11 +395,9 @@ void tcl_quote_print(FILE *stream, const char *src)
> fputc('"', stream);
> while ((c = *src++)) {
> switch (c) {
> - case '[':
> - case ']':
> - case '$':
> - case '\\':
> - case '"':
> + case '[': case ']':
> + case '{': case '}':
> + case '$': case '\\': case '"':
> fputc('\\', stream);
> default:
> fputc(c, stream);
Looks OK (still didn't have time to actually test this thing).
[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2007-01-29 9:51 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-01-28 7:39 [PATCH 1/1] Teach for-each-ref about a little language called Tcl Shawn O. Pearce
2007-01-28 9:49 ` Sergey Vlasov
2007-01-28 20:58 ` Junio C Hamano
2007-01-29 9:51 ` Sergey Vlasov
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).