File: ucmsort

package info (click to toggle)
libencode-perl 3.08-1%2Bdeb11u2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 11,208 kB
  • sloc: perl: 4,395; ansic: 1,077; makefile: 8
file content (35 lines) | stat: -rwxr-xr-x 695 bytes parent folder | download | duplicates (20)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
#!/usr/local/bin/perl
#
# $Id: ucmsort,v 2.2 2006/05/03 18:24:10 dankogai Exp $
#
use strict;
my @lines;
my ($head, $tail);
while (<>){
    unless (m/^<U/o){
        unless(@lines){
        $head .= $_;
    }else{ 
        $tail .= $_;
    }
    next;
    }
    chomp;
    my @words = split;
    my $u = shift @words;
    $u =~ s/^<U//o; $u =~ s/>.*//o;
    push @lines,[ $u, @words ];
}

print $head;
for (sort {
    hex($a->[0]) <=> hex($b->[0]) # Unicode descending order
    or $a->[2] cmp $b->[2] # fallback descending order
    or $a->[1] cmp $b->[1] # Encoding descending order
    }
     @lines) {
    my $u = shift @$_;
    print join(" " => "<U$u>", @$_), "\n";
}
print $tail;
__END__