繁体中文: mount -t vfat /dev/hda1 /mnt/1 -o codepage=950,iocharset=cp936
有趣的是,由于GBK包含了全部的GB2312/Big5/JIS的内码,所以使用936的Codepage也可以显示Big5的文件名.
制作codepage950支持的是台湾的 cosmos先生,
主页为 http://www.cis.nctu.edu.tw:8080/~is84086/Project/kernel_cp950/
制作GBK的cp936支持的是TurboLinux的中文研发小组的 方汉和 陈向阳
#!/bin/sh
cat $1 | awk '{if(index($1,"#")==0)print $0}' | awk 'BEGIN{FS="0x"}{print $2 $3}' |
awk '{if(length($1)==length($2))print $1,$2}'
1 #!/usr/bin/perl
2
3 @code = (
4 "00", "01", "02", "03", "04", "05", "06", "07",
5 "08", "09", "0A", "0B", "0C", "0D", "0E", "0F",
6 "10", "11", "12", "13", "14", "15", "16", "17",
7 "18", "19", "1A", "1B", "1C", "1D", "1E", "1F",
8 "20", "21", "22", "23", "24", "25", "26", "27",
9 "28", "29", "2A", "2B", "2C", "2D", "2E", "2F",
10 "30", "31", "32", "33", "34", "35", "36", "37",
11 "38", "39", "3A", "3B", "3C", "3D", "3E", "3F",
12 "40", "41", "42", "43", "44", "45", "46", "47",
13 "48", "49", "4A", "4B", "4C", "4D", "4E", "4F",
14 "50", "51", "52", "53", "54", "55", "56", "57",
15 "58", "59", "5A", "5B", "5C", "5D", "5E", "5F",
16 "60", "61", "62", "63", "64", "65", "66", "67",
17 "68", "69", "6A", "6B", "6C", "6D", "6E", "6F",
18 "70", "71", "72", "73", "74", "75", "76", "77",
19 "78", "79", "7A", "7B", "7C", "7D", "7E", "7F",
20 "80", "81", "82", "83", "84", "85", "86", "87",
21 "88", "89", "8A", "8B", "8C", "8D", "8E", "8F",
22 "90", "91", "92", "93", "94", "95", "96", "97",
23 "98", "99", "9A", "9B", "9C", "9D", "9E", "9F",
24 "A0", "A1", "A2", "A3", "A4", "A5", "A6", "A7",
25 "A8", "A9", "AA", "AB", "AC", "AD", "AE", "AF",
26 "B0", "B1", "B2", "B3", "B4", "B5", "B6", "B7",
27 "B8", "B9", "BA", "BB", "BC", "BD", "BE", "BF",
28 "C0", "C1", "C2", "C3", "C4", "C5", "C6", "C7",
29 "C8", "C9", "CA", "CB", "CC", "CD", "CE", "CF",
30 "D0", "D1", "D2", "D3", "D4", "D5", "D6", "D7",
31 "D8", "D9", "DA", "DB", "DC", "DD", "DE", "DF",
32 "E0", "E1", "E2", "E3", "E4", "E5", "E6", "E7",
33 "E8", "E9", "EA", "EB", "EC", "ED", "EE", "EF",
34 "F0", "F1", "F2", "F3", "F4", "F5", "F6", "F7",
35 "F8", "F9", "FA", "FB", "FC", "FD", "FE", "FF");
36
37 while (<STDIN>){
38 ($unicode, $big5) = split;
39 ($high, $low) = $unicode =~ /(..)(..)/;
40 $table2{$high}{$low} = $big5;
41 ($high, $low) = $big5 =~ /(..)(..)/;
42 $table{$high}{$low} = $unicode;
43 }
44
45 print <<EOF;
46 /*
47 * linux/fs/nls_cp874.c
48 *
49 * Charset cp874 translation tables.
50 * Generated automatically from the Unicode and charset
51 * tables from the Unicode Organization (www.unicode.org).
52 * The Unicode to charset table has only exact mappings.
53 */
54
55 #include <linux/module.h>
56 #include <linux/kernel.h>
57 #include <linux/string.h>
58 #include <linux/nls.h>
59
60 /* A1 - F9*/
61 static struct nls_unicode charset2uni[(0xF9-0xA1+1)*(0x100-0x60)] = {
62 EOF
63
64 for ($high=0xA1; $high <= 0xF9; $high++){
65 for ($low=0x40; $low <= 0x7F; $low++){
66 $unicode = $table2{$code[$high]}{$code[$low]};
67 $unicode = "0000" if (!(defined $unicode));
68 print "\n\t" if ($low%4 == 0);
69 print "/* $code[$high]$code[$low]*/\n\t" if ($low%0x10 == 0);
70 ($uhigh, $ulow) = $unicode =~ /(..)(..)/;
71 printf("{0x%2s, 0x%2s}, ", $ulow, $uhigh);
72 }
73 for ($low=0xA0; $low <= 0xFF; $low++){
74 $unicode = $table2{$code[$high]}{$code[$low]};
75 $unicode = "0000" if (!(defined $unicode));
76 print "\n\t" if ($low%4 == 0);
77 print "/* $code[$high]$code[$low]*/\n\t" if ($low%0x10 == 0);
78 ($uhigh, $ulow) = $unicode =~ /(..)(..)/;
79 printf("{0x%2s, 0x%2s}, ", $ulow, $uhigh);
80 }
81 }
82
83 print "\n};\n\n";
84 for ($high=1; $high <= 255;$high++){
85 if (defined $table{$code[$high]}){
86 print "static unsigned char page$code[$high]\[512\] = {\n\t";
87 for ($low=0; $low<=255;$low++){
88 &nb