mirror of https://github.com/tc39/test262.git
87 lines
2.2 KiB
JavaScript
87 lines
2.2 KiB
JavaScript
|
// Copyright 2009 the Sputnik authors. All rights reserved.
|
||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||
|
|
||
|
/*---
|
||
|
info: >
|
||
|
If B = 110xxxxx (n = 2) and C != 10xxxxxx (C - first of octets after B),
|
||
|
throw URIError
|
||
|
es5id: 15.1.3.1_A1.13_T1
|
||
|
description: Complex tests. B = [0xC0 - 0xDF], C = [0x00, 0x7F]
|
||
|
---*/
|
||
|
|
||
|
var errorCount = 0;
|
||
|
var count = 0;
|
||
|
var indexP;
|
||
|
var indexO = 0;
|
||
|
|
||
|
for (var indexB = 0xC0; indexB <= 0xDF; indexB++) {
|
||
|
count++;
|
||
|
var hexB = decimalToHexString(indexB);
|
||
|
var result = true;
|
||
|
for (var indexC = 0x00; indexC <= 0x7F; indexC++) {
|
||
|
var hexC = decimalToHexString(indexC);
|
||
|
try {
|
||
|
decodeURI("%" + hexB.substring(2) + "%" + hexC.substring(2));
|
||
|
} catch (e) {
|
||
|
if ((e instanceof URIError) === true) continue;
|
||
|
}
|
||
|
result = false;
|
||
|
}
|
||
|
if (result !== true) {
|
||
|
if (indexO === 0) {
|
||
|
indexO = indexB;
|
||
|
} else {
|
||
|
if ((indexB - indexP) !== 1) {
|
||
|
if ((indexP - indexO) !== 0) {
|
||
|
var hexP = decimalToHexString(indexP);
|
||
|
var hexO = decimalToHexString(indexO);
|
||
|
$ERROR('#' + hexO + '-' + hexP + ' ');
|
||
|
}
|
||
|
else {
|
||
|
var hexP = decimalToHexString(indexP);
|
||
|
$ERROR('#' + hexP + ' ');
|
||
|
}
|
||
|
indexO = indexB;
|
||
|
}
|
||
|
}
|
||
|
indexP = indexB;
|
||
|
errorCount++;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (errorCount > 0) {
|
||
|
if ((indexP - indexO) !== 0) {
|
||
|
var hexP = decimalToHexString(indexP);
|
||
|
var hexO = decimalToHexString(indexO);
|
||
|
$ERROR('#' + hexO + '-' + hexP + ' ');
|
||
|
} else {
|
||
|
var hexP = decimalToHexString(indexP);
|
||
|
$ERROR('#' + hexP + ' ');
|
||
|
}
|
||
|
$ERROR('Total error: ' + errorCount + ' bad Unicode character in ' + count + ' ');
|
||
|
}
|
||
|
|
||
|
function decimalToHexString(n) {
|
||
|
n = Number(n);
|
||
|
var h = "";
|
||
|
for (var i = 3; i >= 0; i--) {
|
||
|
if (n >= Math.pow(16, i)) {
|
||
|
var t = Math.floor(n / Math.pow(16, i));
|
||
|
n -= t * Math.pow(16, i);
|
||
|
if ( t >= 10 ) {
|
||
|
if ( t == 10 ) { h += "A"; }
|
||
|
if ( t == 11 ) { h += "B"; }
|
||
|
if ( t == 12 ) { h += "C"; }
|
||
|
if ( t == 13 ) { h += "D"; }
|
||
|
if ( t == 14 ) { h += "E"; }
|
||
|
if ( t == 15 ) { h += "F"; }
|
||
|
} else {
|
||
|
h += String(t);
|
||
|
}
|
||
|
} else {
|
||
|
h += "0";
|
||
|
}
|
||
|
}
|
||
|
return h;
|
||
|
}
|