forked from mirrors/gecko-dev
		
	# ignore-this-changeset Differential Revision: https://phabricator.services.mozilla.com/D36052 --HG-- extra : source : b5be5b4f4b47c256e28a29f665dc754f6407ee7f
		
			
				
	
	
		
			55 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/* This Source Code Form is subject to the terms of the Mozilla Public
 | 
						|
 * License, v. 2.0. If a copy of the MPL was not distributed with this file,
 | 
						|
 * You can obtain one at http://mozilla.org/MPL/2.0/. */
 | 
						|
 | 
						|
/* eslint-env mozilla/chrome-worker */
 | 
						|
 | 
						|
"use strict";
 | 
						|
 | 
						|
/**
 | 
						|
 * A worker dedicated to handle parsing documents for reader view.
 | 
						|
 */
 | 
						|
 | 
						|
importScripts(
 | 
						|
  "resource://gre/modules/workers/require.js",
 | 
						|
  "resource://gre/modules/reader/JSDOMParser.js",
 | 
						|
  "resource://gre/modules/reader/Readability.js"
 | 
						|
);
 | 
						|
 | 
						|
var PromiseWorker = require("resource://gre/modules/workers/PromiseWorker.js");
 | 
						|
 | 
						|
const DEBUG = false;
 | 
						|
 | 
						|
var worker = new PromiseWorker.AbstractWorker();
 | 
						|
worker.dispatch = function(method, args = []) {
 | 
						|
  return Agent[method](...args);
 | 
						|
};
 | 
						|
worker.postMessage = function(result, ...transfers) {
 | 
						|
  self.postMessage(result, ...transfers);
 | 
						|
};
 | 
						|
worker.close = function() {
 | 
						|
  self.close();
 | 
						|
};
 | 
						|
worker.log = function(...args) {
 | 
						|
  if (DEBUG) {
 | 
						|
    dump("ReaderWorker: " + args.join(" ") + "\n");
 | 
						|
  }
 | 
						|
};
 | 
						|
 | 
						|
self.addEventListener("message", msg => worker.handleMessage(msg));
 | 
						|
 | 
						|
var Agent = {
 | 
						|
  /**
 | 
						|
   * Parses structured article data from a document.
 | 
						|
   *
 | 
						|
   * @param {object} uri URI data for the document.
 | 
						|
   * @param {string} serializedDoc The serialized document.
 | 
						|
   * @param {object} options Options object to pass to Readability.
 | 
						|
   *
 | 
						|
   * @return {object} Article object returned from Readability.
 | 
						|
   */
 | 
						|
  parseDocument(uri, serializedDoc, options) {
 | 
						|
    let doc = new JSDOMParser().parse(serializedDoc, uri.spec);
 | 
						|
    return new Readability(doc, options).parse();
 | 
						|
  },
 | 
						|
};
 |