Improved readabilty. Improved accuracy of stripBraces() function.

This commit is contained in:
pschwartau%netscape.com 2001-09-05 00:49:31 +00:00
Родитель 629bcf86ac
Коммит ded8f34015
1 изменённых файлов: 29 добавлений и 22 удалений

Просмотреть файл

@ -23,6 +23,13 @@
* See http://bugzilla.mozilla.org/show_bug.cgi?id=90596
*
* NOTE: some inefficiencies in the test are made for the sake of readability.
* For example, we quote string values like "Hi" in lines like this:
*
* actual = enumerateThis(obj);
* expect = '{prop:"Hi"}';
*
* But enumerateThis(obj) gets literal value Hi for obj.prop, not literal "Hi".
* We take care of all these details in the compactThis(), sortThis() functions.
* Sorting properties alphabetically is necessary for the test to work in Rhino.
*/
//-----------------------------------------------------------------------------
@ -31,7 +38,6 @@ var bug = 90596;
var summary = '[DontEnum] props (if overridden) should appear in for-in loops';
var cnCOMMA = ',';
var cnCOLON = ':';
var cnEMPTY = '';
var cnLBRACE = '{';
var cnRBRACE = '}';
var status = '';
@ -42,6 +48,7 @@ var expect= '';
var expectedvalues = [];
var obj = {};
status = inSection(1);
obj = {toString:9};
actual = enumerateThis(obj);
@ -189,24 +196,24 @@ function addThis()
*/
function sortThis(sList)
{
sList = formatThis(sList);
sList = compactThis(sList);
sList = stripBraces(sList);
var arr = sList.split(cnCOMMA);
arr = arr.sort();
var ret = String(arr);
return addBraces(ret);
ret = addBraces(ret);
return ret;
}
/*
* Strips out braces at beginning/end of text, and any whitespace or quotes
* Strips out any whitespace or quotes from the text -
*/
function formatThis(text)
function compactThis(text)
{
var charCode = 0;
var ret = '';
text = stripBraces(text);
for (var i=0; i<text.length; i++)
{
charCode = text.charCodeAt(i);
@ -219,21 +226,6 @@ function formatThis(text)
}
/*
* strips off braces at beginning and end of text -
*/
function stripBraces(text)
{
// remember to escape the braces...
var arr = text.match(/^\{(.*)\}$/);
// defend against a null match...
if (arr && arr[1])
return arr[1];
return cnEMPTY;
}
function isWhiteSpace(charCode)
{
switch (charCode)
@ -268,6 +260,21 @@ function isQuote(charCode)
}
/*
* strips off braces at beginning and end of text -
*/
function stripBraces(text)
{
// remember to escape the braces...
var arr = text.match(/^\{(.*)\}$/);
// defend against a null match...
if (arr != null && arr[1] != null)
return arr[1];
return text;
}
function test()
{
enterFunc ('test');