summaryrefslogtreecommitdiff
path: root/ext
diff options
context:
space:
mode:
authorTony Cook <tony@develop-help.com>2001-09-06 22:35:49 +1000
committerJarkko Hietaniemi <jhi@iki.fi>2001-09-06 13:56:19 +0000
commitf397e0261018d400b509a826d2f1e196ea810bcf (patch)
tree818979d04496b6618e913f249b2dce46f9945027 /ext
parent716e3b8c0c8bbed515ed9bf0db90423d663bb79b (diff)
downloadperl-f397e0261018d400b509a826d2f1e196ea810bcf.tar.gz
Extra NUL is Data::Dumper output - patch
Message-ID: <Pine.LNX.4.10.10109061157210.9366-100000@develop-help.com> p4raw-id: //depot/perl@11916
Diffstat (limited to 'ext')
-rw-r--r--ext/Data/Dumper/Dumper.xs2
-rwxr-xr-xext/Data/Dumper/t/dumper.t17
2 files changed, 16 insertions, 3 deletions
diff --git a/ext/Data/Dumper/Dumper.xs b/ext/Data/Dumper/Dumper.xs
index b9fb54b978..8fc7ac35a1 100644
--- a/ext/Data/Dumper/Dumper.xs
+++ b/ext/Data/Dumper/Dumper.xs
@@ -137,7 +137,7 @@ esc_q_utf8(pTHX_ SV* sv, register char *src, register STRLEN slen)
r[0] = r[j++] = '"';
else
r[0] = r[j++] = '\'';
- r[j++] = '\0';
+ r[j] = '\0';
SvCUR_set(sv, SvCUR(sv) + j);
return j;
diff --git a/ext/Data/Dumper/t/dumper.t b/ext/Data/Dumper/t/dumper.t
index 10add1cedb..bf0722977f 100755
--- a/ext/Data/Dumper/t/dumper.t
+++ b/ext/Data/Dumper/t/dumper.t
@@ -61,11 +61,11 @@ sub TEST {
if (defined &Data::Dumper::Dumpxs) {
print "### XS extension loaded, will run XS tests\n";
- $TMAX = 186; $XS = 1;
+ $TMAX = 192; $XS = 1;
}
else {
print "### XS extensions not loaded, will NOT run XS tests\n";
- $TMAX = 93; $XS = 0;
+ $TMAX = 96; $XS = 0;
}
print "1..$TMAX\n";
@@ -808,3 +808,16 @@ TEST q(Data::Dumper->new([$b],['b'])->Purity(1)->Dump;);
TEST q(Data::Dumper->new([$b],['b'])->Purity(1)->Dumpxs;)
if $XS;
}
+
+{
+ $a = "\x{09c10}";
+############# 187
+## XS code was adding an extra \0
+ $WANT = <<'EOT';
+#$a = "\x{9c10}";
+EOT
+
+ TEST q(Data::Dumper->Dump([$a], ['a']));
+ TEST q(Data::Dumper->Dumpxs([$a], ['a']));
+
+}