summaryrefslogtreecommitdiff
path: root/ext/XS-APItest/APItest.xs
diff options
context:
space:
mode:
authorAaron Crane <arc@cpan.org>2015-07-07 18:16:36 +0100
committerAaron Crane <arc@cpan.org>2015-07-15 14:26:06 +0100
commit46e58bd2391172ab5e4a73c29fb3313bebcf00bc (patch)
tree73a9c44d058a2d156c312fd951cfaf5b10569e27 /ext/XS-APItest/APItest.xs
parent638ca15aeec3bf86124489c8c913c5b42d4fee16 (diff)
downloadperl-46e58bd2391172ab5e4a73c29fb3313bebcf00bc.tar.gz
Document and ensure that sv_catpvf() does no argument ordering
sv_catpvf() and friends ultimately end up calling sv_vcatpvfn_flags() with a C-style va_list argument (rather than with an array of SV pointers). When the sprintf implementation in sv_vcatpvfn_flags() is called with a va_list it always ignores any attempt by the format string to reorder the arguments. This reasonable limitation is now documented, and the implementation throws an exception when it encounters this situation. Minimal tests for these exceptions have been added to XS::APItest.
Diffstat (limited to 'ext/XS-APItest/APItest.xs')
-rw-r--r--ext/XS-APItest/APItest.xs10
1 files changed, 10 insertions, 0 deletions
diff --git a/ext/XS-APItest/APItest.xs b/ext/XS-APItest/APItest.xs
index aef057238e..7a258deb25 100644
--- a/ext/XS-APItest/APItest.xs
+++ b/ext/XS-APItest/APItest.xs
@@ -3884,6 +3884,16 @@ test_newOP_CUSTOM()
OUTPUT:
RETVAL
+void
+test_sv_catpvf(SV *fmtsv)
+ PREINIT:
+ SV *sv;
+ char *fmt;
+ CODE:
+ fmt = SvPV_nolen(fmtsv);
+ sv = sv_2mortal(newSVpvn("", 0));
+ sv_catpvf(sv, fmt, 5, 6, 7, 8);
+
MODULE = XS::APItest PACKAGE = XS::APItest::AUTOLOADtest
int