* gettext-tools/src/format-lisp.c (nocheck_params): Don't call
add_req_type_constraint if position < 0.
* gettext-tools/tests/xgettext-lisp-5: New file.
* gettext-tools/tests/Makefile.am (TESTS): Add it.
if (params->type == PT_V)
{
int position = params->value;
- add_req_type_constraint (listp, position, FAT_CHARACTER_INTEGER_NULL);
+ if (position >= 0)
+ add_req_type_constraint (listp, position, FAT_CHARACTER_INTEGER_NULL);
}
return true;
xgettext-librep-1 xgettext-librep-2 xgettext-librep-3 \
xgettext-librep-stackovfl-1 xgettext-librep-stackovfl-2 \
xgettext-lisp-1 xgettext-lisp-2 xgettext-lisp-3 xgettext-lisp-4 \
+ xgettext-lisp-5 \
xgettext-lisp-stackovfl-1 xgettext-lisp-stackovfl-2 \
xgettext-lua-1 xgettext-lua-2 xgettext-lua-3 \
xgettext-lua-stackovfl-1 xgettext-lua-stackovfl-2 \
--- /dev/null
+#! /bin/sh
+. "${srcdir=.}/init.sh"; path_prepend_ . ../src
+
+# Test Lisp support: lisp-format string with a ~V at an unknown position.
+
+cat <<EOF > xg-ls-5.lisp
+(gettext "~@?~v!")
+EOF
+
+: ${XGETTEXT=xgettext}
+${XGETTEXT} --omit-header --no-location -d xg-ls-5.tmp xg-ls-5.lisp || Exit 1
+LC_ALL=C tr -d '\r' < xg-ls-5.tmp.po > xg-ls-5.po || Exit 1
+
+cat <<EOF > xg-ls-5.ok
+#, lisp-format
+msgid "~@?~v!"
+msgstr ""
+EOF
+
+: ${DIFF=diff}
+${DIFF} xg-ls-5.ok xg-ls-5.po
+result=$?
+
+exit $result