From 0fbb8e87c499516530c1d6ce54b1bd7ebc845c7b Mon Sep 17 00:00:00 2001 From: =?utf8?q?Aleksander=20=C5=81ukasz?= Date: Fri, 5 Jul 2013 15:52:43 +0200 Subject: [PATCH] traversing --- modules/documentCanvas/canvas/canvas.test3.js | 59 ++++++++++++++++--- .../documentCanvas/canvas/documentElement.js | 13 ++-- 2 files changed, 56 insertions(+), 16 deletions(-) diff --git a/modules/documentCanvas/canvas/canvas.test3.js b/modules/documentCanvas/canvas/canvas.test3.js index f270328..4ed6ce1 100644 --- a/modules/documentCanvas/canvas/canvas.test3.js +++ b/modules/documentCanvas/canvas/canvas.test3.js @@ -21,7 +21,7 @@ describe('Canvas', function() { }); }); - describe('document api', function() { + describe('document representation api', function() { describe('document root element', function() { var c = canvas.fromXML('
'); it('exists', function() { @@ -32,14 +32,55 @@ describe('Canvas', function() { }); }); - it('a', function() { - var c = canvas.fromXML('
'), - children = c.doc().children(); - expect(children.length).to.equal(3); - expect(children[0]).to.be.instanceOf(documentElement.DocumentTextElement); - expect(children[1]).to.be.instanceOf(documentElement.DocumentNodeElement); - expect(children[2]).to.be.instanceOf(documentElement.DocumentTextElement); - }); + describe('traversing', function() { + it('reports element nodes', function() { + var c = canvas.fromXML('
'), + children = c.doc().children(); + expect(children.length).to.equal(1); + expect(children[0]).to.be.instanceOf(documentElement.DocumentNodeElement); + }); + it('reports text nodes', function() { + var c = canvas.fromXML('
Alice
'), + children = c.doc().children(); + expect(children.length).to.equal(1); + expect(children[0]).to.be.instanceOf(documentElement.DocumentTextElement); + }); + describe('free text handling', function() { + it('sees free text', function() { + var c = canvas.fromXML('
Alice has a cat
'), + children = c.doc().children(); + expect(children.length).to.equal(3); + expect(children[0]).to.be.instanceOf(documentElement.DocumentTextElement); + expect(children[1]).to.be.instanceOf(documentElement.DocumentNodeElement); + expect(children[2]).to.be.instanceOf(documentElement.DocumentTextElement); + }); + }); + describe('white characters handling', function() { + it('says empty element node has no children', function() { + var c = canvas.fromXML('
'); + expect(c.doc().children().length).to.equal(0); + }); + it('says element node with one space has one DocumentTextElement', function() { + var c = canvas.fromXML('
'); + expect(c.doc().children().length).to.equal(1); + expect(c.doc().children()[0]).to.be.instanceOf(documentElement.DocumentTextElement); + }); + it('ignores white space surrounding block elements', function() { + var c = canvas.fromXML('
'); + var children = c.doc().children(); + expect(children.length).to.equal(1); + expect(children[0]).to.be.instanceOf(documentElement.DocumentNodeElement); + }); + it('ignores white space between block elements', function() { + var c = canvas.fromXML('
'); + var children = c.doc().children(); + expect(children.length === 2); + [0,1].forEach(function(idx) { + expect(children[idx]).to.be.instanceOf(documentElement.DocumentNodeElement); + }); + }); + }); + }) }); }); diff --git a/modules/documentCanvas/canvas/documentElement.js b/modules/documentCanvas/canvas/documentElement.js index 50e680d..ed5613e 100644 --- a/modules/documentCanvas/canvas/documentElement.js +++ b/modules/documentCanvas/canvas/documentElement.js @@ -22,14 +22,13 @@ $.extend(DocumentElement.prototype, { var elementContent = this.$element.contents(); elementContent.each(function(idx) { var element = documentElementFromHTMLElement(this); - if( - (toret.length === 0 && (element instanceof DocumentNodeElement)) || - (toret.length > 0 && (toret[toret.length -1] instanceof DocumentNodeElement) && (element instanceof DocumentNodeElement)) - ) - toret.push(documentElementFromHTMLElement(document.createTextNode())); + if(idx === 0 && elementContent.length > 1 && elementContent[1].nodeType === Node.ELEMENT_NODE && $.trim($(this).text()) === '') + return true; + if(idx > 0 && element instanceof DocumentTextElement) { + if(toret[toret.length-1] instanceof DocumentNodeElement && $.trim($(this).text()) === '') + return true; + } toret.push(element); - if((idx === elementContent.length - 1) && (element instanceof DocumentNodeElement)) - toret.push(documentElementFromHTMLElement(document.createTextNode())); }); return toret; } -- 2.20.1