1998-07-06 21:36:00 +00:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Netscape Public License
|
|
|
|
* Version 1.0 (the "NPL"); you may not use this file except in
|
|
|
|
* compliance with the NPL. You may obtain a copy of the NPL at
|
|
|
|
* http://www.mozilla.org/NPL/
|
|
|
|
*
|
|
|
|
* Software distributed under the NPL is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* NPL.
|
|
|
|
*
|
|
|
|
* The Initial Developer of this code under the NPL is Netscape
|
|
|
|
* Communications Corporation. Portions created by Netscape are
|
|
|
|
* Copyright (C) 1998 Netscape Communications Corporation. All Rights
|
|
|
|
* Reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
var count = 0;
|
|
|
|
|
|
|
|
function trace(msg)
|
|
|
|
{
|
|
|
|
dump("test " + msg + " (" + count + ")\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
function dump2(msg, parent, child)
|
|
|
|
{
|
|
|
|
dump(msg);
|
|
|
|
dump(" parent=");
|
1998-07-14 18:44:44 +00:00
|
|
|
dump(parent.tagName);
|
1998-07-06 21:36:00 +00:00
|
|
|
dump(" child=");
|
1998-07-14 18:44:44 +00:00
|
|
|
dump((child.nodeType != Node.TEXT) ? child.tagName : "(text)");
|
1998-07-06 21:36:00 +00:00
|
|
|
|
|
|
|
dump(" kids: ");
|
1998-07-14 18:44:44 +00:00
|
|
|
var children = parent.childNodes;
|
|
|
|
var length = children.length;
|
|
|
|
var child = null;
|
1998-07-06 21:36:00 +00:00
|
|
|
var count = 0;
|
|
|
|
while (count < length) {
|
1998-07-14 18:44:44 +00:00
|
|
|
child = children.item(count);
|
|
|
|
dump((child.nodeType != Node.TEXT) ? child.tagName : "(text)");
|
1998-07-06 21:36:00 +00:00
|
|
|
dump(",");
|
|
|
|
count++;
|
|
|
|
}
|
|
|
|
|
|
|
|
dump("\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function firstChildOf(node)
|
|
|
|
{
|
1998-07-14 18:44:44 +00:00
|
|
|
return node.childNodes.item(0);
|
1998-07-06 21:36:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function middleChildOf(node)
|
|
|
|
{
|
1998-07-14 18:44:44 +00:00
|
|
|
var children = node.childNodes;
|
|
|
|
return children.item(Math.floor(children.length / 2));
|
1998-07-06 21:36:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function lastChildOf(node)
|
|
|
|
{
|
1998-07-14 18:44:44 +00:00
|
|
|
var children = node.childNodes;
|
|
|
|
return children.item(children.length - 1)
|
1998-07-06 21:36:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function findContainer(node, name)
|
|
|
|
{
|
1998-07-14 18:44:44 +00:00
|
|
|
dump("Looking in " + node.tagName + " for " + name + "\n");
|
|
|
|
var children = node.childNodes;
|
|
|
|
var length = children.length;
|
|
|
|
var child = null;
|
1998-07-06 21:36:00 +00:00
|
|
|
var count = 0;
|
|
|
|
while (count < length) {
|
1998-07-14 18:44:44 +00:00
|
|
|
child = children.item(count);
|
|
|
|
if (child.nodeType != Node.TEXT) {
|
|
|
|
if (child.tagName == name) {
|
1998-07-06 21:36:00 +00:00
|
|
|
return child;
|
|
|
|
}
|
|
|
|
var body = findContainer(child, name);
|
|
|
|
if (null != body) {
|
|
|
|
return body;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
count++;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
var longText = "Lots more text (this text is long so that we can verify that continuations are handled properly when they are deleted) ";
|
|
|
|
|
|
|
|
function makeTestDocument(node)
|
|
|
|
{
|
|
|
|
var blockTag = new Array(6);
|
|
|
|
blockTag[0] = "DIV";
|
|
|
|
blockTag[1] = "ADDRESS";
|
|
|
|
blockTag[2] = "BLOCKQUOTE";
|
|
|
|
blockTag[3] = "CENTER";
|
|
|
|
blockTag[4] = "H1";
|
|
|
|
blockTag[5] = "H2";
|
|
|
|
|
|
|
|
var spanTag = new Array(6);
|
|
|
|
spanTag[0] = "SPAN";
|
|
|
|
spanTag[1] = "B";
|
|
|
|
spanTag[2] = "I";
|
|
|
|
spanTag[3] = "EM";
|
|
|
|
spanTag[4] = "STRONG";
|
|
|
|
spanTag[5] = "TT";
|
|
|
|
|
|
|
|
for (b = 0; b < 6; b++) {
|
|
|
|
var block = document.createElement(blockTag[b], null);
|
|
|
|
block.insertBefore(document.createTextNode("Opening text ["), null);
|
|
|
|
for (s = 0; s < 6; s++) {
|
|
|
|
var span = document.createElement(spanTag[s], null);
|
|
|
|
block.insertBefore(span, null);
|
|
|
|
span.insertBefore(document.createTextNode("More text, "), null);
|
|
|
|
span.insertBefore(document.createTextNode("And more text, "), null);
|
|
|
|
span.insertBefore(document.createTextNode("And even more text. "), null);
|
|
|
|
span.insertBefore(document.createTextNode(longText), null);
|
|
|
|
span.insertBefore(document.createTextNode("Because more text "), null);
|
|
|
|
span.insertBefore(document.createTextNode("Is more text."), null);
|
|
|
|
}
|
|
|
|
block.insertBefore(document.createTextNode("] Closing text"), null);
|
|
|
|
|
|
|
|
// Now put that entire tree into the body
|
|
|
|
node.insertBefore(block, null);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// delete first, last, middle
|
|
|
|
function testDelete(node)
|
|
|
|
{
|
|
|
|
var kid = firstChildOf(node);
|
|
|
|
dump2("Remove first child", node, kid);
|
|
|
|
node.removeChild(kid);
|
|
|
|
|
|
|
|
kid = lastChildOf(node);
|
|
|
|
dump2("Remove last child", node, kid);
|
|
|
|
node.removeChild(kid);
|
|
|
|
|
|
|
|
kid = middleChildOf(node);
|
|
|
|
dump2("Remove middle child", node, kid);
|
|
|
|
node.removeChild(kid);
|
|
|
|
}
|
|
|
|
|
|
|
|
var body = findContainer(document.documentElement, "BODY");
|
|
|
|
makeTestDocument(body);
|
|
|
|
|
|
|
|
//var span = findContainer(body, "SPAN");
|
|
|
|
//testDelete(span);
|
|
|
|
|
|
|
|
var block = findContainer(body, "DIV");
|
|
|
|
//testDelete(block);
|
|
|
|
|
|
|
|
// delete children of the body (cuz its a pseudo)
|
|
|
|
testDelete(body);
|