require './test.pl';
}
-plan tests => 20;
+plan tests => 24;
my $a = chr(0x100);
}
my $c = chr(0x100);
+my $c2 = chr(0x2c7); # a unicode character that doesn't fold
+utf8::encode(my $c2_utf8 = $c2);
{
use bytes;
- if (ord('A') == 193) { # EBCDIC?
+ if ($::IS_EBCDIC) { # EBCDIC?
is(ord($c), 0x8c, "ord under use bytes looks at the 1st byte");
} else {
is(ord($c), 0xc4, "ord under use bytes looks at the 1st byte");
}
is(length($c), 2, "length under use bytes looks at bytes");
is(bytes::length($c), 2, "bytes::length under use bytes looks at bytes");
- if (ord('A') == 193) { # EBCDIC?
+ if ($::IS_EBCDIC) { # EBCDIC?
is(bytes::ord($c), 0x8c, "bytes::ord under use bytes looks at the 1st byte");
} else {
is(bytes::ord($c), 0xc4, "bytes::ord under use bytes looks at the 1st byte");
}
# In z/OS \x41,\x8c are the codepoints corresponding to \x80,\xc4 respectively under ASCII platform
- if (ord('A') == 193) { # EBCDIC?
+ if ($::IS_EBCDIC) { # EBCDIC?
is(bytes::substr($c, 0, 1), "\x8c", "bytes::substr under use bytes looks at bytes");
is(bytes::index($c, "\x41"), 1, "bytes::index under use bytes looks at bytes");
is(bytes::rindex($c, "\x8c"), 0, "bytes::rindex under use bytes looks at bytes");
is(bytes::rindex($c, "\xc4"), 0, "bytes::rindex under use bytes looks at bytes");
}
+ # [perl #117355] [lu]cfirst don't respect 'use bytes'
+ # and if there's other tests for lc/uc under bytes I didn't find them
+ is(lc($c2), $c2_utf8, "lc under use bytes returns bytes");
+ is(uc($c2), $c2_utf8, "uc under use bytes returns bytes");
+ is(lcfirst($c2), $c2_utf8, "lcfirst under use bytes returns bytes");
+ is(ucfirst($c2), $c2_utf8, "unfirst under use bytes returns bytes");
}
{