Make use of Util.inherit in src/core/pdf_manager.js

While we are here, fix some incorrect function names.
This commit is contained in:
Tim van der Meij 2015-11-29 00:51:07 +01:00
parent a8279f7d60
commit 0c41866433

View File

@ -13,11 +13,10 @@
* limitations under the License. * limitations under the License.
*/ */
/* globals NotImplementedException, MissingDataException, Promise, Stream, /* globals NotImplementedException, MissingDataException, Promise, Stream,
PDFDocument, ChunkedStreamManager, createPromiseCapability */ PDFDocument, ChunkedStreamManager, createPromiseCapability, Util */
'use strict'; 'use strict';
// TODO(mack): Make use of PDFJS.Util.inherit() when it becomes available
var BasePdfManager = (function BasePdfManagerClosure() { var BasePdfManager = (function BasePdfManagerClosure() {
function BasePdfManager() { function BasePdfManager() {
throw new Error('Cannot initialize BaseManagerManager'); throw new Error('Cannot initialize BaseManagerManager');
@ -44,7 +43,7 @@ var BasePdfManager = (function BasePdfManagerClosure() {
return this.ensure(this.pdfDocument.catalog, prop, args); return this.ensure(this.pdfDocument.catalog, prop, args);
}, },
getPage: function BasePdfManager_pagePage(pageIndex) { getPage: function BasePdfManager_getPage(pageIndex) {
return this.pdfDocument.getPage(pageIndex); return this.pdfDocument.getPage(pageIndex);
}, },
@ -56,7 +55,7 @@ var BasePdfManager = (function BasePdfManagerClosure() {
return new NotImplementedException(); return new NotImplementedException();
}, },
requestRange: function BasePdfManager_ensure(begin, end) { requestRange: function BasePdfManager_requestRange(begin, end) {
return new NotImplementedException(); return new NotImplementedException();
}, },
@ -97,45 +96,40 @@ var LocalPdfManager = (function LocalPdfManagerClosure() {
this._loadedStreamCapability.resolve(stream); this._loadedStreamCapability.resolve(stream);
} }
LocalPdfManager.prototype = Object.create(BasePdfManager.prototype); Util.inherit(LocalPdfManager, BasePdfManager, {
LocalPdfManager.prototype.constructor = LocalPdfManager; ensure: function LocalPdfManager_ensure(obj, prop, args) {
return new Promise(function (resolve, reject) {
LocalPdfManager.prototype.ensure = try {
function LocalPdfManager_ensure(obj, prop, args) { var value = obj[prop];
return new Promise(function (resolve, reject) { var result;
try { if (typeof value === 'function') {
var value = obj[prop]; result = value.apply(obj, args);
var result; } else {
if (typeof value === 'function') { result = value;
result = value.apply(obj, args); }
} else { resolve(result);
result = value; } catch (e) {
reject(e);
} }
resolve(result); });
} catch (e) { },
reject(e);
}
});
};
LocalPdfManager.prototype.requestRange = requestRange: function LocalPdfManager_requestRange(begin, end) {
function LocalPdfManager_requestRange(begin, end) { return Promise.resolve();
return Promise.resolve(); },
};
LocalPdfManager.prototype.requestLoadedStream = requestLoadedStream: function LocalPdfManager_requestLoadedStream() {
function LocalPdfManager_requestLoadedStream() { return;
}; },
LocalPdfManager.prototype.onLoadedStream = onLoadedStream: function LocalPdfManager_onLoadedStream() {
function LocalPdfManager_getLoadedStream() { return this._loadedStreamCapability.promise;
return this._loadedStreamCapability.promise; },
};
LocalPdfManager.prototype.terminate = terminate: function LocalPdfManager_terminate() {
function LocalPdfManager_terminate() { return;
return; }
}; });
return LocalPdfManager; return LocalPdfManager;
})(); })();
@ -156,67 +150,60 @@ var NetworkPdfManager = (function NetworkPdfManagerClosure() {
this.streamManager = new ChunkedStreamManager(args.length, this.streamManager = new ChunkedStreamManager(args.length,
args.rangeChunkSize, args.rangeChunkSize,
args.url, params); args.url, params);
this.pdfDocument = new PDFDocument(this, this.streamManager.getStream(), this.pdfDocument = new PDFDocument(this, this.streamManager.getStream(),
args.password); args.password);
} }
NetworkPdfManager.prototype = Object.create(BasePdfManager.prototype); Util.inherit(NetworkPdfManager, BasePdfManager, {
NetworkPdfManager.prototype.constructor = NetworkPdfManager; ensure: function NetworkPdfManager_ensure(obj, prop, args) {
var pdfManager = this;
NetworkPdfManager.prototype.ensure = return new Promise(function (resolve, reject) {
function NetworkPdfManager_ensure(obj, prop, args) { function ensureHelper() {
var pdfManager = this; try {
var result;
return new Promise(function (resolve, reject) { var value = obj[prop];
function ensureHelper() { if (typeof value === 'function') {
try { result = value.apply(obj, args);
var result; } else {
var value = obj[prop]; result = value;
if (typeof value === 'function') { }
result = value.apply(obj, args); resolve(result);
} else { } catch(e) {
result = value; if (!(e instanceof MissingDataException)) {
reject(e);
return;
}
pdfManager.streamManager.requestRange(e.begin, e.end).
then(ensureHelper, reject);
} }
resolve(result);
} catch(e) {
if (!(e instanceof MissingDataException)) {
reject(e);
return;
}
pdfManager.streamManager.requestRange(e.begin, e.end).
then(ensureHelper, reject);
} }
}
ensureHelper(); ensureHelper();
}); });
}; },
NetworkPdfManager.prototype.requestRange = requestRange: function NetworkPdfManager_requestRange(begin, end) {
function NetworkPdfManager_requestRange(begin, end) { return this.streamManager.requestRange(begin, end);
return this.streamManager.requestRange(begin, end); },
};
NetworkPdfManager.prototype.requestLoadedStream = requestLoadedStream: function NetworkPdfManager_requestLoadedStream() {
function NetworkPdfManager_requestLoadedStream() { this.streamManager.requestAllChunks();
this.streamManager.requestAllChunks(); },
};
NetworkPdfManager.prototype.sendProgressiveData = sendProgressiveData:
function NetworkPdfManager_sendProgressiveData(chunk) { function NetworkPdfManager_sendProgressiveData(chunk) {
this.streamManager.onReceiveData({ chunk: chunk }); this.streamManager.onReceiveData({ chunk: chunk });
}; },
NetworkPdfManager.prototype.onLoadedStream = onLoadedStream: function NetworkPdfManager_onLoadedStream() {
function NetworkPdfManager_getLoadedStream() { return this.streamManager.onLoadedStream();
return this.streamManager.onLoadedStream(); },
};
NetworkPdfManager.prototype.terminate = terminate: function NetworkPdfManager_terminate() {
function NetworkPdfManager_terminate() { this.streamManager.abort();
this.streamManager.abort(); }
}; });
return NetworkPdfManager; return NetworkPdfManager;
})(); })();