From 11e005abf51a40305366028d517d0cad57580cc5 Mon Sep 17 00:00:00 2001 From: suVene Date: Fri, 19 Dec 2008 18:24:47 +0000 Subject: * get absolute path of , . * mod $U.pathToURL git-svn-id: http://svn.coderepos.org/share/lang/javascript/vimperator-plugins/trunk@27108 d0d07461-0603-4401-acd4-de1884942a52 --- multi_requester.js | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) (limited to 'multi_requester.js') diff --git a/multi_requester.js b/multi_requester.js index 8d1e2bc..03b6da2 100644 --- a/multi_requester.js +++ b/multi_requester.js @@ -5,12 +5,12 @@ var PLUGIN_INFO = request, and the result is displayed to the buffer. リクエストの結果をバッファに出力する。 suVene - 0.4.5 + 0.4.6 2.0pre 2.0pre ' + extractLink; - var url = $U.pathToURL(el[0]); + var url = $U.pathToURL(el[0], res.req.url); var req = new libly.Request(url, null, $U.extend(res.req.options, {extractLink: true})); req.addEventListener('onException', $U.bind(this, this.onException)); req.addEventListener('onSuccess', $U.bind(this, this.onSuccess)); @@ -372,7 +372,7 @@ var MultiRequester = { MultiRequester.doProcess = false; } - var url, escapedUrl, xpath, doc, html, extractLink; + var url, escapedUrl, xpath, doc, html, extractLink, ignoreTags; try { @@ -387,11 +387,23 @@ var MultiRequester = { this.extractLink(res, extractLink); return; } - var ignoreTags = ['script'].concat(libly.$U.A(res.req.options.siteinfo.ignoreTags)); + ignoreTags = ['script'].concat(libly.$U.A(res.req.options.siteinfo.ignoreTags)); doc = document.createElementNS(null, 'div'); - res.getHTMLDocument(xpath, null, ignoreTags, function(node, i) { doc.appendChild(node) } ); + res.getHTMLDocument(xpath, null, ignoreTags, function(node, i) { + if (node.tagName.toLowerCase() != 'html') + doc.appendChild(node); + }); if (!doc) throw 'XPath result is undefined or null.: XPath -> ' + xpath; + $U.getNodesFromXPath('descendant-or-self::a | descendant-or-self::img', doc, function(node) { + var tagName = node.tagName.toLowerCase(); + if (tagName == 'a') { + node.href = $U.pathToURL(node, url, res.doc); + } else if (tagName == 'img') { + node.src = $U.pathToURL(node, url, res.doc); + } + }); + html = '' + escapedUrl + '' + $U.xmlSerialize(doc); -- cgit v1.2.3