* [PATCH] Fix '\%o' for printf from coreutils
@ 2013-10-31 11:51 Kacper Kornet
2013-10-31 16:49 ` Jeff King
0 siblings, 1 reply; 2+ messages in thread
From: Kacper Kornet @ 2013-10-31 11:51 UTC (permalink / raw)
To: git; +Cc: Jeff King, Junio C Hamano
The printf utility provided by coreutils when interpreting '\%o' format
does not recognize %o as formatting directive. For example
printf '\%o 0 returns \%o and warning: ignoring excess arguments,
starting with ‘0’, which results in failed tests in
t5309-pack-delta-cycles.sh. In most shells the test ends with success as
the printf is a builtin utility.
Fix it by using '\\%o' which is interpreted consistently in all versions
of printf.
Signed-off-by: Kacper Kornet <draenog@pld-linux.org>
---
I've found it while testing v1.8.5-rc0 with mksh which does not
provide a builtin printf.
Kacper
t/lib-pack.sh | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/t/lib-pack.sh b/t/lib-pack.sh
index 7e8685b..b96e125 100644
--- a/t/lib-pack.sh
+++ b/t/lib-pack.sh
@@ -12,10 +12,10 @@
# Print the big-endian 4-byte octal representation of $1
uint32_octal () {
n=$1
- printf '\%o' $(($n / 16777216)); n=$((n % 16777216))
- printf '\%o' $(($n / 65536)); n=$((n % 65536))
- printf '\%o' $(($n / 256)); n=$((n % 256))
- printf '\%o' $(($n ));
+ printf '\\%o' $(($n / 16777216)); n=$((n % 16777216))
+ printf '\\%o' $(($n / 65536)); n=$((n % 65536))
+ printf '\\%o' $(($n / 256)); n=$((n % 256))
+ printf '\\%o' $(($n ));
}
# Print the big-endian 4-byte binary representation of $1
--
1.8.4.2
--
Kacper Kornet
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH] Fix '\%o' for printf from coreutils
2013-10-31 11:51 [PATCH] Fix '\%o' for printf from coreutils Kacper Kornet
@ 2013-10-31 16:49 ` Jeff King
0 siblings, 0 replies; 2+ messages in thread
From: Jeff King @ 2013-10-31 16:49 UTC (permalink / raw)
To: Kacper Kornet; +Cc: git, Junio C Hamano
On Thu, Oct 31, 2013 at 12:51:32PM +0100, Kacper Kornet wrote:
> The printf utility provided by coreutils when interpreting '\%o' format
> does not recognize %o as formatting directive. For example
> printf '\%o 0 returns \%o and warning: ignoring excess arguments,
> starting with ‘0’, which results in failed tests in
> t5309-pack-delta-cycles.sh. In most shells the test ends with success as
> the printf is a builtin utility.
>
> Fix it by using '\\%o' which is interpreted consistently in all versions
> of printf.
Thanks, this makes sense. POSIX says:
[description of \n, \r, etc...]
The interpretation of a backslash followed by any other
sequence of characters is unspecified.
so we were wrong to rely on an unknown backslash-escape
being left alone. A quick grep seems indicate that this is
the only spot with the problem.
-Peff
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2013-10-31 16:49 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-10-31 11:51 [PATCH] Fix '\%o' for printf from coreutils Kacper Kornet
2013-10-31 16:49 ` Jeff King
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).