blob: 5a5b6f970521ff0e1a87bb827840ef7bede69acc (
plain)
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
var jis0208CPs = []; // index is unicode cp, value is pointer
for (var p = 0; p < jis0208.length; p++) {
if (jis0208[p] != null && jis0208CPs[jis0208[p]] == null) {
jis0208CPs[jis0208[p]] = p;
}
}
function chars2cps(chars) {
// this is needed because of javascript's handling of supplementary characters
// char: a string of unicode characters
// returns an array of decimal code point values
var haut = 0;
var out = [];
for (var i = 0; i < chars.length; i++) {
var b = chars.charCodeAt(i);
if (b < 0 || b > 0xffff) {
alert(
"Error in chars2cps: byte out of range " + b.toString(16) + "!"
);
}
if (haut != 0) {
if (0xdc00 <= b && b <= 0xdfff) {
out.push(0x10000 + ((haut - 0xd800) << 10) + (b - 0xdc00));
haut = 0;
continue;
} else {
alert(
"Error in chars2cps: surrogate out of range " +
haut.toString(16) +
"!"
);
haut = 0;
}
}
if (0xd800 <= b && b <= 0xdbff) {
haut = b;
} else {
out.push(b);
}
}
return out;
}
function eucjpEncoder(stream) {
var cps = chars2cps(stream);
var out = "";
var cp;
var finished = false;
while (!finished) {
if (cps.length == 0) {
finished = true;
continue;
} else cp = cps.shift();
if (cp >= 0x00 && cp <= 0x7f) {
// ASCII
out += " " + cp.toString(16).toUpperCase();
continue;
}
if (cp == 0xa5) {
out += " 5C";
continue;
}
if (cp == 0x203e) {
out += " 7E";
continue;
}
if (cp >= 0xff61 && cp <= 0xff9f) {
var temp = cp - 0xff61 + 0xa1;
out += " 8E " + temp.toString(16).toUpperCase();
continue;
}
if (cp == 0x2212) {
cp = 0xff0d;
}
var ptr = jis0208CPs[cp];
if (ptr == null) {
return null;
// out += ' &#'+cp+';'
// continue
}
var lead = Math.floor(ptr / 94) + 0xa1;
var trail = ptr % 94 + 0xa1;
out +=
" " +
lead.toString(16).toUpperCase() +
" " +
trail.toString(16).toUpperCase();
}
return out.trim();
}
function convertToHex(str) {
// converts a string of ASCII characters to hex byte codes
var out = "";
var result;
for (var c = 0; c < str.length; c++) {
result =
str
.charCodeAt(c)
.toString(16)
.toUpperCase() + " ";
out += result;
}
return out;
}
function normalizeStr(str) {
var out = "";
for (var c = 0; c < str.length; c++) {
if (str.charAt(c) == "%") {
out += String.fromCodePoint(
parseInt(str.charAt(c + 1) + str.charAt(c + 2), 16)
);
c += 2;
} else out += str.charAt(c);
}
var result = "";
for (var o = 0; o < out.length; o++) {
result +=
"%" +
out
.charCodeAt(o)
.toString(16)
.toUpperCase();
}
return result.replace(/%1B%28%42$/, "");
}
|