xref: /openbsd-src/gnu/usr.bin/perl/cpan/Unicode-Collate/t/cjkrange.t (revision f2da64fbbbf1b03f09f390ab01267c93dfd77c4c)
1
2BEGIN {
3    unless ('A' eq pack('U', 0x41)) {
4	print "1..0 # Unicode::Collate cannot pack a Unicode code point\n";
5	exit 0;
6    }
7    unless (0x41 == unpack('U', 'A')) {
8	print "1..0 # Unicode::Collate cannot get a Unicode code point\n";
9	exit 0;
10    }
11    if ($ENV{PERL_CORE}) {
12	chdir('t') if -d 't';
13	@INC = $^O eq 'MacOS' ? qw(::lib) : qw(../lib);
14    }
15}
16
17use strict;
18use warnings;
19BEGIN { $| = 1; print "1..463\n"; } # 1 + 42 x @Versions
20my $count = 0;
21sub ok ($;$) {
22    my $p = my $r = shift;
23    if (@_) {
24	my $x = shift;
25	$p = !defined $x ? !defined $r : !defined $r ? 0 : $r eq $x;
26    }
27    print $p ? "ok" : "not ok", ' ', ++$count, "\n";
28}
29
30use Unicode::Collate;
31
32ok(1);
33
34#########################
35
36my $coll = Unicode::Collate->new(
37    table => 'keys.txt',
38    normalization => undef,
39);
40
41# CJK UI Ext > CJK UI.
42# [ UCA_Version 8: Ext.A < UI and BMP < Ext.B (code point order) ]
43
44# 4E00..9FA5 are CJK UI.
45# 9FA6..9FBB are CJK UI since UCA_Version 14 (Unicode 4.1).
46# 9FBC..9FC3 are CJK UI since UCA_Version 18 (Unicode 5.1).
47# 9FC4..9FCB are CJK UI since UCA_Version 20 (Unicode 5.2).
48# 9FCC       is  CJK UI since UCA_Version 24 (Unicode 6.1).
49
50# 3400..4DB5   are CJK UI Ext.A since UCA_Version 8  (Unicode 3.0).
51# 20000..2A6D6 are CJK UI Ext.B since UCA_Version 8  (Unicode 3.1).
52# 2A700..2B734 are CJK UI Ext.C since UCA_Version 20 (Unicode 5.2).
53# 2B740..2B81D are CJK UI Ext.D since UCA_Version 22 (Unicode 6.0).
54
55my @Versions = (8, 9, 11, 14, 16, 18, 20, 22, 24, 26, 28);
56
57for my $v (@Versions) {
58    $coll->change(UCA_Version => $v);
59
60    # Ext.A > UI
61    ok($coll->cmp("\x{3400}", "\x{4E00}") == ($v >=  9 ? 1 : -1)); # UI
62    ok($coll->cmp("\x{3400}", "\x{9FA5}") == ($v >=  9 ? 1 : -1)); # UI
63    ok($coll->cmp("\x{3400}", "\x{9FA6}") == ($v >= 14 ? 1 : -1)); # new
64    ok($coll->cmp("\x{3400}", "\x{9FBB}") == ($v >= 14 ? 1 : -1)); # new
65    ok($coll->cmp("\x{3400}", "\x{9FBC}") == ($v >= 18 ? 1 : -1)); # new
66    ok($coll->cmp("\x{3400}", "\x{9FC3}") == ($v >= 18 ? 1 : -1)); # new
67    ok($coll->cmp("\x{3400}", "\x{9FC4}") == ($v >= 20 ? 1 : -1)); # new
68    ok($coll->cmp("\x{3400}", "\x{9FCB}") == ($v >= 20 ? 1 : -1)); # new
69    ok($coll->cmp("\x{3400}", "\x{9FCC}") == ($v >= 24 ? 1 : -1)); # new
70    ok($coll->cmp("\x{3400}", "\x{9FCD}") == -1); # na
71    ok($coll->cmp("\x{3400}", "\x{9FFF}") == -1); # na
72
73    # UI < UI
74    ok($coll->cmp("\x{4E00}", "\x{9FA5}") == -1); # UI < UI
75    ok($coll->cmp("\x{9FA5}", "\x{9FA6}") == -1); # UI < new
76    ok($coll->cmp("\x{9FA6}", "\x{9FBB}") == -1); # new < new
77    ok($coll->cmp("\x{9FBB}", "\x{9FBC}") == -1); # new < new
78    ok($coll->cmp("\x{9FBC}", "\x{9FC3}") == -1); # new < new
79    ok($coll->cmp("\x{9FC3}", "\x{9FC4}") == -1); # new < new
80    ok($coll->cmp("\x{9FC4}", "\x{9FCB}") == -1); # new < new
81    ok($coll->cmp("\x{9FCB}", "\x{9FCC}") == -1); # new < new
82    ok($coll->cmp("\x{9FCC}", "\x{9FCD}") == -1); # new < na
83    ok($coll->cmp("\x{9FCD}", "\x{9FFF}") == -1); # na < na
84
85    # Ext.A < Ext.B
86    ok($coll->cmp("\x{3400}", "\x{20000}") == -1);
87
88    # Ext.A
89    ok($coll->cmp("\x{3400}", "\x{4DB5}") == -1); # A < A
90    ok($coll->cmp("\x{2FFF}", "\x{3400}") == ($v >= 8 ? 1 : -1)); # na > A
91    ok($coll->cmp("\x{2FFF}", "\x{4DB5}") == ($v >= 8 ? 1 : -1)); # na > A
92    ok($coll->cmp("\x{2FFF}", "\x{4DB6}") == -1); # na < na
93    ok($coll->cmp("\x{2FFF}", "\x{4DBF}") == -1); # na < na
94
95    # Ext.B
96    ok($coll->cmp("\x{20000}","\x{2A6D6}") == -1); # B < B
97    ok($coll->cmp("\x{2FFF}", "\x{20000}") == ($v >= 9 ? 1 : -1)); # na > B
98    ok($coll->cmp("\x{2FFF}", "\x{2A6D6}") == ($v >= 9 ? 1 : -1)); # na > B
99    ok($coll->cmp("\x{2FFF}", "\x{2A6D7}") == -1); # na < na
100    ok($coll->cmp("\x{2FFF}", "\x{2A6DF}") == -1); # na < na
101
102    # Ext.C
103    ok($coll->cmp("\x{2A700}","\x{2B734}") == -1); # C < C
104    ok($coll->cmp("\x{2FFF}", "\x{2A700}") == ($v >= 20 ? 1 : -1)); # na > C
105    ok($coll->cmp("\x{2FFF}", "\x{2B734}") == ($v >= 20 ? 1 : -1)); # na > C
106    ok($coll->cmp("\x{2FFF}", "\x{2B735}") == -1); # na < na
107    ok($coll->cmp("\x{2FFF}", "\x{2B73F}") == -1); # na < na
108
109    # Ext.D
110    ok($coll->cmp("\x{2B740}","\x{2B81D}") == -1); # D < D
111    ok($coll->cmp("\x{2FFF}", "\x{2B740}") == ($v >= 22 ? 1 : -1)); # na > D
112    ok($coll->cmp("\x{2FFF}", "\x{2B81D}") == ($v >= 22 ? 1 : -1)); # na > D
113    ok($coll->cmp("\x{2FFF}", "\x{2B81E}") == -1); # na < na
114    ok($coll->cmp("\x{2FFF}", "\x{2B81F}") == -1); # na < na
115}
116
117