File: tst-printf-format.sh

package info (click to toggle)
glibc 2.41-9
  • links: PTS, VCS
  • area: main
  • in suites: experimental, sid, trixie
  • size: 300,164 kB
  • sloc: ansic: 1,050,507; asm: 238,242; makefile: 20,378; python: 13,537; sh: 11,812; cpp: 5,197; awk: 1,795; perl: 317; yacc: 292; pascal: 182; sed: 19
file content (39 lines) | stat: -rw-r--r-- 1,511 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
#!/bin/bash
# Formatted printf output test script dispatcher.
# Copyright (C) 2024-2025 Free Software Foundation, Inc.
# This file is part of the GNU C Library.

# The GNU C Library is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation; either
# version 2.1 of the License, or (at your option) any later version.

# The GNU C Library is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
# Lesser General Public License for more details.

# You should have received a copy of the GNU Lesser General Public
# License along with the GNU C Library; if not, see
# <https://www.gnu.org/licenses/>.

set -e

output=${1##*/}; shift

tmp=${output#tst-printf-format-}
tmp=${tmp%.out}

# We are given the name of the make target in $1.  With the common prefix
# and suffix both removed we are left with the inner part, which encodes
# the function under test, the conversion type, and optionally the format
# specifier, all separated with hyphens, i.e. F-T-S or F-T.  Extract them
# and call the script corresponding to the conversion type, passing the
# function under test and any format specifier as arguments.

xprintf=${tmp%%-*}; tmp=${tmp#*-}
conv=${tmp%%-*}; tmp=${tmp#${conv}}
fmt=${tmp#*-}
script=tst-printf-format-$conv.sh

exec ${BASH:-bash} $script $xprintf $fmt "$@"