@ -82,7 +82,7 @@ AbstractChainedBatch.prototype.write = function (options, callback) {
@@ -82,7 +82,7 @@ AbstractChainedBatch.prototype.write = function (options, callback) {
module . exports = AbstractChainedBatch
} ) . call ( this , require ( '_process' ) )
} , { "_process" : 37 } ] , 2 : [ function ( require , module , exports ) {
} , { "_process" : 36 } ] , 2 : [ function ( require , module , exports ) {
( function ( process ) {
/* Copyright (c) 2013 Rod Vagg, MIT License */
@ -135,7 +135,7 @@ AbstractIterator.prototype.end = function (callback) {
@@ -135,7 +135,7 @@ AbstractIterator.prototype.end = function (callback) {
module . exports = AbstractIterator
} ) . call ( this , require ( '_process' ) )
} , { "_process" : 37 } ] , 3 : [ function ( require , module , exports ) {
} , { "_process" : 36 } ] , 3 : [ function ( require , module , exports ) {
( function ( Buffer , process ) {
/* Copyright (c) 2013 Rod Vagg, MIT License */
@ -395,7 +395,7 @@ module.exports.AbstractIterator = AbstractIterator
@@ -395,7 +395,7 @@ module.exports.AbstractIterator = AbstractIterator
module . exports . AbstractChainedBatch = AbstractChainedBatch
} ) . call ( this , { "isBuffer" : require ( "../is-buffer/index.js" ) } , require ( '_process' ) )
} , { "../is-buffer/index.js" : 9 , "./abstract-chained-batch" : 1 , "./abstract-iterator" : 2 , "_process" : 37 , "xtend" : 4 } ] , 4 : [ function ( require , module , exports ) {
} , { "../is-buffer/index.js" : 10 , "./abstract-chained-batch" : 1 , "./abstract-iterator" : 2 , "_process" : 36 , "xtend" : 4 } ] , 4 : [ function ( require , module , exports ) {
module . exports = extend
function extend ( ) {
@ -2323,7 +2323,7 @@ function isnan (val) {
@@ -2323,7 +2323,7 @@ function isnan (val) {
}
} ) . call ( this , typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : { } )
} , { "base64-js" : 5 , "ieee754" : 8 , "isarray" : 10 } ] , 7 : [ function ( require , module , exports ) {
} , { "base64-js" : 5 , "ieee754" : 8 , "isarray" : 11 } ] , 7 : [ function ( require , module , exports ) {
/*global window:false, self:false, define:false, module:false */
/ * *
@ -3817,6 +3817,31 @@ exports.write = function (buffer, value, offset, isLE, mLen, nBytes) {
@@ -3817,6 +3817,31 @@ exports.write = function (buffer, value, offset, isLE, mLen, nBytes) {
}
} , { } ] , 9 : [ function ( require , module , exports ) {
if ( typeof Object . create === 'function' ) {
// implementation from standard node.js 'util' module
module . exports = function inherits ( ctor , superCtor ) {
ctor . super _ = superCtor
ctor . prototype = Object . create ( superCtor . prototype , {
constructor : {
value : ctor ,
enumerable : false ,
writable : true ,
configurable : true
}
} ) ;
} ;
} else {
// old school shim for old browsers
module . exports = function inherits ( ctor , superCtor ) {
ctor . super _ = superCtor
var TempCtor = function ( ) { }
TempCtor . prototype = superCtor . prototype
ctor . prototype = new TempCtor ( )
ctor . prototype . constructor = ctor
}
}
} , { } ] , 10 : [ function ( require , module , exports ) {
/ * !
* Determine if an object is a Buffer
*
@ -3839,14 +3864,14 @@ function isSlowBuffer (obj) {
@@ -3839,14 +3864,14 @@ function isSlowBuffer (obj) {
return typeof obj . readFloatLE === 'function' && typeof obj . slice === 'function' && isBuffer ( obj . slice ( 0 , 0 ) )
}
} , { } ] , 10 : [ function ( require , module , exports ) {
} , { } ] , 11 : [ function ( require , module , exports ) {
var toString = { } . toString ;
module . exports = Array . isArray || function ( arr ) {
return toString . call ( arr ) == '[object Array]' ;
} ;
} , { } ] , 11 : [ function ( require , module , exports ) {
} , { } ] , 12 : [ function ( require , module , exports ) {
var Buffer = require ( 'buffer' ) . Buffer ;
module . exports = isBuffer ;
@ -3856,7 +3881,7 @@ function isBuffer (o) {
@@ -3856,7 +3881,7 @@ function isBuffer (o) {
|| /\[object (.+Array|Array.+)\]/ . test ( Object . prototype . toString . call ( o ) ) ;
}
} , { "buffer" : 6 } ] , 12 : [ function ( require , module , exports ) {
} , { "buffer" : 6 } ] , 13 : [ function ( require , module , exports ) {
( function ( Buffer ) {
module . exports = Level
@ -4034,7 +4059,7 @@ var checkKeyValue = Level.prototype._checkKeyValue = function (obj, type) {
@@ -4034,7 +4059,7 @@ var checkKeyValue = Level.prototype._checkKeyValue = function (obj, type) {
}
} ) . call ( this , require ( "buffer" ) . Buffer )
} , { "./iterator" : 13 , "abstract-leveldown" : 3 , "buffer" : 6 , "idb-wrapper" : 7 , "isbuffer" : 11 , "typedarray-to-buffer" : 38 , "util" : 41 , "xtend" : 15 } ] , 13 : [ function ( require , module , exports ) {
} , { "./iterator" : 14 , "abstract-leveldown" : 3 , "buffer" : 6 , "idb-wrapper" : 7 , "isbuffer" : 12 , "typedarray-to-buffer" : 37 , "util" : 39 , "xtend" : 4 1} ] , 14 : [ function ( require , module , exports ) {
var util = require ( 'util' )
var AbstractIterator = require ( 'abstract-leveldown' ) . AbstractIterator
var ltgt = require ( 'ltgt' )
@ -4108,43 +4133,7 @@ Iterator.prototype._next = function (callback) {
@@ -4108,43 +4133,7 @@ Iterator.prototype._next = function (callback) {
this . callback = callback
}
} , { "abstract-leveldown" : 3 , "ltgt" : 16 , "util" : 41 } ] , 14 : [ function ( require , module , exports ) {
module . exports = hasKeys
function hasKeys ( source ) {
return source !== null &&
( typeof source === "object" ||
typeof source === "function" )
}
} , { } ] , 15 : [ function ( require , module , exports ) {
var Keys = require ( "object-keys" )
var hasKeys = require ( "./has-keys" )
module . exports = extend
function extend ( ) {
var target = { }
for ( var i = 0 ; i < arguments . length ; i ++ ) {
var source = arguments [ i ]
if ( ! hasKeys ( source ) ) {
continue
}
var keys = Keys ( source )
for ( var j = 0 ; j < keys . length ; j ++ ) {
var name = keys [ j ]
target [ name ] = source [ name ]
}
}
return target
}
} , { "./has-keys" : 14 , "object-keys" : 18 } ] , 16 : [ function ( require , module , exports ) {
} , { "abstract-leveldown" : 3 , "ltgt" : 15 , "util" : 39 } ] , 15 : [ function ( require , module , exports ) {
( function ( Buffer ) {
exports . compare = function ( a , b ) {
@ -4294,7 +4283,7 @@ exports.filter = function (range, compare) {
@@ -4294,7 +4283,7 @@ exports.filter = function (range, compare) {
}
} ) . call ( this , { "isBuffer" : require ( "../is-buffer/index.js" ) } )
} , { "../is-buffer/index.js" : 9 } ] , 17 : [ function ( require , module , exports ) {
} , { "../is-buffer/index.js" : 10 } ] , 16 : [ function ( require , module , exports ) {
var hasOwn = Object . prototype . hasOwnProperty ;
var toString = Object . prototype . toString ;
@ -4336,11 +4325,11 @@ module.exports = function forEach(obj, fn) {
@@ -4336,11 +4325,11 @@ module.exports = function forEach(obj, fn) {
} ;
} , { } ] , 18 : [ function ( require , module , exports ) {
} , { } ] , 17 : [ function ( require , module , exports ) {
module . exports = Object . keys || require ( './shim' ) ;
} , { "./shim" : 20 } ] , 19 : [ function ( require , module , exports ) {
} , { "./shim" : 19 } ] , 18 : [ function ( require , module , exports ) {
var toString = Object . prototype . toString ;
module . exports = function isArguments ( value ) {
@ -4358,7 +4347,7 @@ module.exports = function isArguments(value) {
@@ -4358,7 +4347,7 @@ module.exports = function isArguments(value) {
} ;
} , { } ] , 20 : [ function ( require , module , exports ) {
} , { } ] , 19 : [ function ( require , module , exports ) {
( function ( ) {
"use strict" ;
@ -4422,7 +4411,7 @@ module.exports = function isArguments(value) {
@@ -4422,7 +4411,7 @@ module.exports = function isArguments(value) {
} ( ) ) ;
} , { "./foreach" : 17 , "./isArguments" : 19 } ] , 21 : [ function ( require , module , exports ) {
} , { "./foreach" : 16 , "./isArguments" : 18 } ] , 20 : [ function ( require , module , exports ) {
// Top level file is just a mixin of submodules & constants
'use strict' ;
@ -4438,7 +4427,7 @@ assign(pako, deflate, inflate, constants);
@@ -4438,7 +4427,7 @@ assign(pako, deflate, inflate, constants);
module . exports = pako ;
} , { "./lib/deflate" : 22 , "./lib/inflate" : 23 , "./lib/utils/common" : 24 , "./lib/zlib/constants" : 27 } ] , 22 : [ function ( require , module , exports ) {
} , { "./lib/deflate" : 21 , "./lib/inflate" : 22 , "./lib/utils/common" : 23 , "./lib/zlib/constants" : 26 } ] , 21 : [ function ( require , module , exports ) {
'use strict' ;
@ -4840,7 +4829,7 @@ exports.deflate = deflate;
@@ -4840,7 +4829,7 @@ exports.deflate = deflate;
exports . deflateRaw = deflateRaw ;
exports . gzip = gzip ;
} , { "./utils/common" : 24 , "./utils/strings" : 25 , "./zlib/deflate" : 29 , "./zlib/messages" : 34 , "./zlib/zstream" : 36 } ] , 23 : [ function ( require , module , exports ) {
} , { "./utils/common" : 23 , "./utils/strings" : 24 , "./zlib/deflate" : 28 , "./zlib/messages" : 33 , "./zlib/zstream" : 35 } ] , 22 : [ function ( require , module , exports ) {
'use strict' ;
@ -5260,7 +5249,7 @@ exports.inflate = inflate;
@@ -5260,7 +5249,7 @@ exports.inflate = inflate;
exports . inflateRaw = inflateRaw ;
exports . ungzip = inflate ;
} , { "./utils/common" : 24 , "./utils/strings" : 25 , "./zlib/constants" : 27 , "./zlib/gzheader" : 30 , "./zlib/inflate" : 32 , "./zlib/messages" : 34 , "./zlib/zstream" : 36 } ] , 24 : [ function ( require , module , exports ) {
} , { "./utils/common" : 23 , "./utils/strings" : 24 , "./zlib/constants" : 26 , "./zlib/gzheader" : 29 , "./zlib/inflate" : 31 , "./zlib/messages" : 33 , "./zlib/zstream" : 35 } ] , 23 : [ function ( require , module , exports ) {
'use strict' ;
@ -5364,7 +5353,7 @@ exports.setTyped = function (on) {
@@ -5364,7 +5353,7 @@ exports.setTyped = function (on) {
exports . setTyped ( TYPED _OK ) ;
} , { } ] , 25 : [ function ( require , module , exports ) {
} , { } ] , 24 : [ function ( require , module , exports ) {
// String encode/decode helpers
'use strict' ;
@ -5551,7 +5540,7 @@ exports.utf8border = function (buf, max) {
@@ -5551,7 +5540,7 @@ exports.utf8border = function (buf, max) {
return ( pos + _utf8len [ buf [ pos ] ] > max ) ? pos : max ;
} ;
} , { "./common" : 24 } ] , 26 : [ function ( require , module , exports ) {
} , { "./common" : 23 } ] , 25 : [ function ( require , module , exports ) {
'use strict' ;
// Note: adler32 takes 12% for level 0 and 2% for level 6.
@ -5585,7 +5574,7 @@ function adler32(adler, buf, len, pos) {
@@ -5585,7 +5574,7 @@ function adler32(adler, buf, len, pos) {
module . exports = adler32 ;
} , { } ] , 27 : [ function ( require , module , exports ) {
} , { } ] , 26 : [ function ( require , module , exports ) {
'use strict' ;
@ -5637,7 +5626,7 @@ module.exports = {
@@ -5637,7 +5626,7 @@ module.exports = {
//Z_NULL: null // Use -1 or null inline, depending on var type
} ;
} , { } ] , 28 : [ function ( require , module , exports ) {
} , { } ] , 27 : [ function ( require , module , exports ) {
'use strict' ;
// Note: we can't get significant speed boost here.
@ -5680,7 +5669,7 @@ function crc32(crc, buf, len, pos) {
@@ -5680,7 +5669,7 @@ function crc32(crc, buf, len, pos) {
module . exports = crc32 ;
} , { } ] , 29 : [ function ( require , module , exports ) {
} , { } ] , 28 : [ function ( require , module , exports ) {
'use strict' ;
var utils = require ( '../utils/common' ) ;
@ -7537,7 +7526,7 @@ exports.deflatePrime = deflatePrime;
@@ -7537,7 +7526,7 @@ exports.deflatePrime = deflatePrime;
exports . deflateTune = deflateTune ;
* /
} , { "../utils/common" : 24 , "./adler32" : 26 , "./crc32" : 28 , "./messages" : 34 , "./trees" : 35 } ] , 30 : [ function ( require , module , exports ) {
} , { "../utils/common" : 23 , "./adler32" : 25 , "./crc32" : 27 , "./messages" : 33 , "./trees" : 34 } ] , 29 : [ function ( require , module , exports ) {
'use strict' ;
@ -7579,7 +7568,7 @@ function GZheader() {
@@ -7579,7 +7568,7 @@ function GZheader() {
module . exports = GZheader ;
} , { } ] , 31 : [ function ( require , module , exports ) {
} , { } ] , 30 : [ function ( require , module , exports ) {
'use strict' ;
// See state defs from inflate.js
@ -7907,7 +7896,7 @@ module.exports = function inflate_fast(strm, start) {
@@ -7907,7 +7896,7 @@ module.exports = function inflate_fast(strm, start) {
return ;
} ;
} , { } ] , 32 : [ function ( require , module , exports ) {
} , { } ] , 31 : [ function ( require , module , exports ) {
'use strict' ;
@ -9447,7 +9436,7 @@ exports.inflateSyncPoint = inflateSyncPoint;
@@ -9447,7 +9436,7 @@ exports.inflateSyncPoint = inflateSyncPoint;
exports . inflateUndermine = inflateUndermine ;
* /
} , { "../utils/common" : 24 , "./adler32" : 26 , "./crc32" : 28 , "./inffast" : 31 , "./inftrees" : 33 } ] , 33 : [ function ( require , module , exports ) {
} , { "../utils/common" : 23 , "./adler32" : 25 , "./crc32" : 27 , "./inffast" : 30 , "./inftrees" : 32 } ] , 32 : [ function ( require , module , exports ) {
'use strict' ;
@ -9776,7 +9765,7 @@ module.exports = function inflate_table(type, lens, lens_index, codes, table, ta
@@ -9776,7 +9765,7 @@ module.exports = function inflate_table(type, lens, lens_index, codes, table, ta
return 0 ;
} ;
} , { "../utils/common" : 24 } ] , 34 : [ function ( require , module , exports ) {
} , { "../utils/common" : 23 } ] , 33 : [ function ( require , module , exports ) {
'use strict' ;
module . exports = {
@ -9791,7 +9780,7 @@ module.exports = {
@@ -9791,7 +9780,7 @@ module.exports = {
'-6' : 'incompatible version' /* Z_VERSION_ERROR (-6) */
} ;
} , { } ] , 35 : [ function ( require , module , exports ) {
} , { } ] , 34 : [ function ( require , module , exports ) {
'use strict' ;
@ -10995,7 +10984,7 @@ exports._tr_flush_block = _tr_flush_block;
@@ -10995,7 +10984,7 @@ exports._tr_flush_block = _tr_flush_block;
exports . _tr _tally = _tr _tally ;
exports . _tr _align = _tr _align ;
} , { "../utils/common" : 24 } ] , 36 : [ function ( require , module , exports ) {
} , { "../utils/common" : 23 } ] , 35 : [ function ( require , module , exports ) {
'use strict' ;
@ -11026,7 +11015,7 @@ function ZStream() {
@@ -11026,7 +11015,7 @@ function ZStream() {
module . exports = ZStream ;
} , { } ] , 37 : [ function ( require , module , exports ) {
} , { } ] , 36 : [ function ( require , module , exports ) {
// shim for using process in browser
var process = module . exports = { } ;
@ -11208,7 +11197,7 @@ process.chdir = function (dir) {
@@ -11208,7 +11197,7 @@ process.chdir = function (dir) {
} ;
process . umask = function ( ) { return 0 ; } ;
} , { } ] , 38 : [ function ( require , module , exports ) {
} , { } ] , 37 : [ function ( require , module , exports ) {
( function ( Buffer ) {
/ * *
* Convert a typed array to a Buffer without a copy
@ -11231,39 +11220,14 @@ module.exports = function (arr) {
@@ -11231,39 +11220,14 @@ module.exports = function (arr) {
}
} ) . call ( this , require ( "buffer" ) . Buffer )
} , { "buffer" : 6 } ] , 39 : [ function ( require , module , exports ) {
if ( typeof Object . create === 'function' ) {
// implementation from standard node.js 'util' module
module . exports = function inherits ( ctor , superCtor ) {
ctor . super _ = superCtor
ctor . prototype = Object . create ( superCtor . prototype , {
constructor : {
value : ctor ,
enumerable : false ,
writable : true ,
configurable : true
}
} ) ;
} ;
} else {
// old school shim for old browsers
module . exports = function inherits ( ctor , superCtor ) {
ctor . super _ = superCtor
var TempCtor = function ( ) { }
TempCtor . prototype = superCtor . prototype
ctor . prototype = new TempCtor ( )
ctor . prototype . constructor = ctor
}
}
} , { } ] , 40 : [ function ( require , module , exports ) {
} , { "buffer" : 6 } ] , 38 : [ function ( require , module , exports ) {
module . exports = function isBuffer ( arg ) {
return arg && typeof arg === 'object'
&& typeof arg . copy === 'function'
&& typeof arg . fill === 'function'
&& typeof arg . readUInt8 === 'function' ;
}
} , { } ] , 41 : [ function ( require , module , exports ) {
} , { } ] , 39 : [ function ( require , module , exports ) {
( function ( process , global ) {
// Copyright Joyent, Inc. and other Node contributors.
//
@ -11853,39 +11817,70 @@ function hasOwnProperty(obj, prop) {
@@ -11853,39 +11817,70 @@ function hasOwnProperty(obj, prop) {
}
} ) . call ( this , require ( '_process' ) , typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : { } )
} , { "./support/isBuffer" : 40 , "_process" : 37 , "inherits" : 3 9} ] , 42 : [ function ( require , module , exports ) {
'use strict' ;
} , { "./support/isBuffer" : 38 , "_process" : 36 , "inherits" : 9 } ] , 40 : [ function ( require , module , exports ) {
module . exports = hasKeys
var leveljs = require ( 'level-js' ) ;
var db = typeof indexedDB === 'undefined' ? { open : function open ( _ , cb ) {
return cb ( true ) ;
} } : leveljs ( './tessdata2' ) ;
function hasKeys ( source ) {
return source !== null &&
( typeof source === "object" ||
typeof source === "function" )
}
var langdata = require ( '../common/langdata.json' ) ;
} , { } ] , 41 : [ function ( require , module , exports ) {
var Keys = require ( "object-keys" )
var hasKeys = require ( "./has-keys" )
module . exports = function getLanguageData ( req , res , cb ) {
var lang = req . options . lang ;
module . exports = extend
function saveDataFile ( data ) {
db . put ( lang , data , function ( err ) {
return console . log ( 'cached' , lang , err ) ;
} ) ;
cb ( data ) ;
function extend ( ) {
var target = { }
for ( var i = 0 ; i < arguments . length ; i ++ ) {
var source = arguments [ i ]
if ( ! hasKeys ( source ) ) {
continue
}
var keys = Keys ( source )
for ( var j = 0 ; j < keys . length ; j ++ ) {
var name = keys [ j ]
target [ name ] = source [ name ]
}
}
return target
}
} , { "./has-keys" : 40 , "object-keys" : 17 } ] , 42 : [ function ( require , module , exports ) {
var leveljs = require ( 'level-js' )
var db = typeof indexedDB === 'undefined' ? { open : ( _ , cb ) => cb ( true ) } : leveljs ( './tessdata2' )
var langdata = require ( '../common/langdata.json' )
module . exports = function getLanguageData ( req , res , cb ) {
var lang = req . options . lang ;
function saveDataFile ( data ) {
db . put ( lang , data , err => console . log ( 'cached' , lang , err ) )
cb ( data )
}
db . open ( { compression : false } , function ( err ) {
db . open ( { compression : false } , err => {
if ( err ) return fetchLanguageData ( req , res , cb ) ;
db . get ( lang , function ( err , data ) {
db . get ( lang , ( err , data ) => {
if ( err ) return fetchLanguageData ( req , res , saveDataFile ) ;
res . progress ( { status : 'found in cache ' + lang + '.traineddata' } ) ;
cb ( data ) ;
} ) ;
} ) ;
} ;
res . progress ( { status : 'found in cache ' + lang + '.traineddata' } )
cb ( data )
} )
} )
}
var ungzip = require ( 'pako' ) . ungzip ;
function fetchLanguageData ( req , res , cb ) {
function fetchLanguageData ( req , res , cb ) {
var lang = req . options . lang ;
var langfile = lang + '.traineddata.gz' ;
var url = req . workerOptions . langPath + langfile ;
@ -11893,134 +11888,114 @@ function fetchLanguageData(req, res, cb) {
@@ -11893,134 +11888,114 @@ function fetchLanguageData(req, res, cb) {
var xhr = new XMLHttpRequest ( ) ;
xhr . open ( 'GET' , url , true ) ;
xhr . responseType = 'arraybuffer' ;
xhr . onerror = function ( e ) {
xhr . onprogress = xhr . onload = null ;
cb ( xhr , null ) ;
} ;
xhr . onprogress = function ( e ) {
return res . progress ( {
xhr . onerror = e => {
xhr . onprogress = xhr . onload = null
cb ( xhr , null )
}
xhr . onprogress = e =>
res . progress ( {
status : 'downloading ' + langfile ,
loaded : e . loaded ,
progress : Math . min ( 1 , e . loaded / langdata [ lang ] )
} ) ;
} ;
xhr . onload = function ( e ) {
if ( ! ( xhr . status == 200 || xhr . status == 0 && xhr . response ) ) return res . reject ( 'Error downloading language ' + url ) ;
res . progress ( { status : 'unzipping ' + langfile } ) ;
xhr . onload = e => {
if ( ! ( xhr . status == 200 || ( xhr . status == 0 && xhr . response ) ) ) return res . reject ( 'Error downloading language ' + url ) ;
res . progress ( { status : 'unzipping ' + langfile } )
// in case the gzips are already ungzipped or extra gzipped
var response = new Uint8Array ( xhr . response ) ;
var response = new Uint8Array ( xhr . response )
try {
while ( response [ 0 ] == 0x1f && response [ 1 ] == 0x8b ) {
response = ungzip ( response ) ;
}
while ( response [ 0 ] == 0x1f && response [ 1 ] == 0x8b ) response = ungzip ( response ) ;
} catch ( err ) {
return res . reject ( 'Error unzipping language file ' + langfile + '\n' + err . message ) ;
return res . reject ( 'Error unzipping language file ' + langfile + '\n' + err . message )
}
cb ( response ) ;
} ;
xhr . send ( ) ;
cb ( response )
}
xhr . send ( )
}
} , { "../common/langdata.json" : 46 , "level-js" : 12 , "pako" : 21 } ] , 43 : [ function ( require , module , exports ) {
( function ( process , global ) {
'use strict' ;
} , { "../common/langdata.json" : 46 , "level-js" : 13 , "pako" : 20 } ] , 43 : [ function ( require , module , exports ) {
( function ( global ) {
"use strict" ;
var workerUtils = require ( '../common/worker.js' ) ;
var workerUtils = require ( '../common/worker.js' )
if ( process . env . NODE _ENV === "development" ) {
console . debug ( 'Using Development Worker' ) ;
}
global . addEventListener ( 'message' , function ( e ) {
global . addEventListener ( 'message' , function ( e ) {
var packet = e . data ;
workerUtils . dispatchHandlers ( packet , function ( obj ) {
return postMessage ( obj ) ;
} ) ;
} ) ;
workerUtils . dispatchHandlers ( packet , obj => postMessage ( obj ) )
} )
exports . getCore = function ( req , res ) {
if ( ! global . TesseractCore ) {
res . progress ( { status : 'loading tesseract core' , progress : 0 } ) ;
importScripts ( req . workerOptions . corePath ) ;
res . progress ( { status : 'loading tesseract core' , progress : 1 } ) ;
exports . getCore = function ( req , res ) {
if ( ! global . TesseractCore ) {
res . progress ( { status : 'loading tesseract core' } )
importScripts ( req . workerOptions . tesseractPath )
res . progress ( { status : 'loaded tesseract core' } )
}
return TesseractCore ;
} ;
return TesseractCore
}
exports . getLanguageData = require ( './lang.js' ) ;
exports . getLanguageData = require ( './lang.js' )
workerUtils . setAdapter ( module . exports ) ;
} ) . call ( this , require ( '_process' ) , typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : { } )
} , { "../common/worker.js" : 47 , "./lang.js" : 42 , "_process" : 37 } ] , 44 : [ function ( require , module , exports ) {
'use strict' ;
} ) . call ( this , typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : { } )
} , { "../common/worker.js" : 47 , "./lang.js" : 42 } ] , 44 : [ function ( require , module , exports ) {
// This converts an image to grayscale
module . exports = function desaturate ( image ) {
module . exports = function desaturate ( image ) {
var width , height ;
if ( image . data ) {
var src = image . data ;
width = image . width , height = image . height ;
var dst = new Uint8Array ( width * height ) ;
var srcLength = src . length | 0 ,
srcLength _16 = srcLength - 16 | 0 ;
if ( image . data ) {
var src = image . data ;
width = image . width ,
height = image . height ;
var dst = new Uint8Array ( width * height ) ;
var srcLength = src . length | 0 , srcLength _16 = ( srcLength - 16 ) | 0 ;
for ( var i = 0 , j = 0 ; i <= srcLength _16 ; i += 16 , j += 4 ) {
// convert to grayscale 4 pixels at a time; eveything with alpha gets put in front of 50% gray
dst [ j ] = ( src [ i ] * 77 + src [ i + 1 ] * 151 + src [ i + 2 ] * 28 ) * src [ i + 3 ] + ( 255 - src [ i + 3 ] << 15 ) + 32768 >> 16 ;
dst [ j + 1 ] = ( src [ i + 4 ] * 77 + src [ i + 5 ] * 151 + src [ i + 6 ] * 28 ) * src [ i + 7 ] + ( 255 - src [ i + 7 ] << 15 ) + 32768 >> 16 ;
dst [ j + 2 ] = ( src [ i + 8 ] * 77 + src [ i + 9 ] * 151 + src [ i + 10 ] * 28 ) * src [ i + 11 ] + ( 255 - src [ i + 11 ] << 15 ) + 32768 >> 16 ;
dst [ j + 3 ] = ( src [ i + 12 ] * 77 + src [ i + 13 ] * 151 + src [ i + 14 ] * 28 ) * src [ i + 15 ] + ( 255 - src [ i + 15 ] << 15 ) + 32768 >> 16 ;
dst [ j ] = ( ( ( src [ i ] * 77 + src [ i + 1 ] * 151 + src [ i + 2 ] * 28 ) * src [ i + 3 ] ) + ( ( 255 - src [ i + 3 ] ) << 15 ) + 32768 ) >> 16
dst [ j + 1 ] = ( ( ( src [ i + 4 ] * 77 + src [ i + 5 ] * 151 + src [ i + 6 ] * 28 ) * src [ i + 7 ] ) + ( ( 255 - src [ i + 7 ] ) << 15 ) + 32768 ) >> 16
dst [ j + 2 ] = ( ( ( src [ i + 8 ] * 77 + src [ i + 9 ] * 151 + src [ i + 10 ] * 28 ) * src [ i + 11 ] ) + ( ( 255 - src [ i + 11 ] ) << 15 ) + 32768 ) >> 16
dst [ j + 3 ] = ( ( ( src [ i + 12 ] * 77 + src [ i + 13 ] * 151 + src [ i + 14 ] * 28 ) * src [ i + 15 ] ) + ( ( 255 - src [ i + 15 ] ) << 15 ) + 32768 ) >> 16
}
for ( ; i < srcLength ; i += 4 , ++ j ) {
//finish up
dst [ j ] = ( src [ i ] * 77 + src [ i + 1 ] * 151 + src [ i + 2 ] * 28 ) * src [ i + 3 ] + ( 255 - src [ i + 3 ] << 15 ) + 32768 >> 16 ;
} image = dst ;
} else {
throw 'Invalid ImageData' ;
}
return image ;
} ;
for ( ; i < srcLength ; i += 4 , ++ j ) //finish up
dst [ j ] = ( ( ( src [ i ] * 77 + src [ i + 1 ] * 151 + src [ i + 2 ] * 28 ) * src [ i + 3 ] ) + ( ( 255 - src [ i + 3 ] ) << 15 ) + 32768 ) >> 16
image = dst ;
} else { throw 'Invalid ImageData' }
return image
}
} , { } ] , 45 : [ function ( require , module , exports ) {
'use strict' ;
module . exports = function DumpLiterallyEverything ( Module , base ) {
module . exports = function DumpLiterallyEverything ( Module , base ) {
var ri = base . GetIterator ( ) ;
var blocks = [ ] ;
var block , para , textline , word , symbol ;
function enumToString ( value , prefix ) {
return Object . keys ( Module ) . filter ( function ( e ) {
return e . substr ( 0 , prefix . length + 1 ) == prefix + '_' ;
} ) . filter ( function ( e ) {
return Module [ e ] === value ;
} ) . map ( function ( e ) {
return e . slice ( prefix . length + 1 ) ;
} ) [ 0 ] ;
function enumToString ( value , prefix ) {
return ( Object . keys ( Module )
. filter ( function ( e ) { return e . substr ( 0 , prefix . length + 1 ) == prefix + '_' } )
. filter ( function ( e ) { return Module [ e ] === value } )
. map ( function ( e ) { return e . slice ( prefix . length + 1 ) } ) [ 0 ] )
}
ri . Begin ( ) ;
ri . Begin ( )
do {
if ( ri . IsAtBeginningOf ( Module . RIL _BLOCK ) ) {
if ( ri . IsAtBeginningOf ( Module . RIL _BLOCK ) ) {
var poly = ri . BlockPolygon ( ) ;
var polygon = null ;
// BlockPolygon() returns null when automatic page segmentation is off
if ( Module . getPointer ( poly ) > 0 ) {
if ( Module . getPointer ( poly ) > 0 ) {
var n = poly . get _n ( ) ,
px = poly . get _x ( ) ,
py = poly . get _y ( ) ,
polygon = [ ] ;
for ( var i = 0 ; i < n ; i ++ ) {
for ( var i = 0 ; i < n ; i ++ ) {
polygon . push ( [ px . getValue ( i ) , py . getValue ( i ) ] ) ;
}
Module . _ptaDestroy ( Module . getPointer ( poly ) ) ;
Module . _ptaDestroy ( Module . getPointer ( poly ) ) ;
}
block = {
paragraphs : [ ] ,
@ -12031,10 +12006,10 @@ module.exports = function DumpLiterallyEverything(Module, base) {
@@ -12031,10 +12006,10 @@ module.exports = function DumpLiterallyEverything(Module, base) {
blocktype : enumToString ( ri . BlockType ( ) , 'PT' ) ,
polygon : polygon
} ;
blocks . push ( block ) ;
}
blocks . push ( block )
}
if ( ri . IsAtBeginningOf ( Module . RIL _PARA ) ) {
if ( ri . IsAtBeginningOf ( Module . RIL _PARA ) ) {
para = {
lines : [ ] ,
@ -12044,10 +12019,10 @@ module.exports = function DumpLiterallyEverything(Module, base) {
@@ -12044,10 +12019,10 @@ module.exports = function DumpLiterallyEverything(Module, base) {
bbox : ri . getBoundingBox ( Module . RIL _PARA ) ,
is _ltr : ! ! ri . ParagraphIsLtr ( )
} ;
block . paragraphs . push ( para ) ;
}
block . paragraphs . push ( para )
}
if ( ri . IsAtBeginningOf ( Module . RIL _TEXTLINE ) ) {
if ( ri . IsAtBeginningOf ( Module . RIL _TEXTLINE ) ) {
textline = {
words : [ ] ,
@ -12055,10 +12030,10 @@ module.exports = function DumpLiterallyEverything(Module, base) {
@@ -12055,10 +12030,10 @@ module.exports = function DumpLiterallyEverything(Module, base) {
confidence : ri . Confidence ( Module . RIL _TEXTLINE ) ,
baseline : ri . getBaseline ( Module . RIL _TEXTLINE ) ,
bbox : ri . getBoundingBox ( Module . RIL _TEXTLINE )
} ;
para . lines . push ( textline ) ;
}
para . lines . push ( textline )
}
if ( ri . IsAtBeginningOf ( Module . RIL _WORD ) ) {
if ( ri . IsAtBeginningOf ( Module . RIL _WORD ) ) {
var fontInfo = ri . getWordFontAttributes ( ) ,
wordDir = ri . WordDirection ( ) ;
word = {
@ -12083,25 +12058,25 @@ module.exports = function DumpLiterallyEverything(Module, base) {
@@ -12083,25 +12058,25 @@ module.exports = function DumpLiterallyEverything(Module, base) {
is _smallcaps : fontInfo . is _smallcaps ,
font _size : fontInfo . pointsize ,
font _id : fontInfo . font _id ,
font _name : fontInfo . font _name
} ;
font _name : fontInfo . font _name ,
}
var wc = new Module . WordChoiceIterator ( ri ) ;
do {
word . choices . push ( {
text : wc . GetUTF8Text ( ) ,
confidence : wc . Confidence ( )
} ) ;
} )
} while ( wc . Next ( ) ) ;
Module . destroy ( wc ) ;
textline . words . push ( word ) ;
Module . destroy ( wc )
textline . words . push ( word )
}
var image = null ;
// var pix = ri.GetBinaryImage(Module.RIL_SYMBOL)
// var image = pix2array(pix);
// // for some reason it seems that things stop working if you destroy pics
// Module._pixDestroy(Module.getPointer(pix));
if ( ri . IsAtBeginningOf ( Module . RIL _SYMBOL ) ) {
if ( ri . IsAtBeginningOf ( Module . RIL _SYMBOL ) ) {
symbol = {
choices : [ ] ,
image : image ,
@ -12113,20 +12088,20 @@ module.exports = function DumpLiterallyEverything(Module, base) {
@@ -12113,20 +12088,20 @@ module.exports = function DumpLiterallyEverything(Module, base) {
is _superscript : ! ! ri . SymbolIsSuperscript ( ) ,
is _subscript : ! ! ri . SymbolIsSubscript ( ) ,
is _dropcap : ! ! ri . SymbolIsDropcap ( )
} ;
word . symbols . push ( symbol ) ;
is _dropcap : ! ! ri . SymbolIsDropcap ( ) ,
}
word . symbols . push ( symbol )
var ci = new Module . ChoiceIterator ( ri ) ;
do {
symbol . choices . push ( {
text : ci . GetUTF8Text ( ) ,
confidence : ci . Confidence ( )
} ) ;
} )
} while ( ci . Next ( ) ) ;
Module . destroy ( ci ) ;
Module . destroy ( ci )
}
} while ( ri . Next ( Module . RIL _SYMBOL ) ) ;
Module . destroy ( ri ) ;
Module . destroy ( ri )
return {
text : base . GetUTF8Text ( ) ,
@ -12138,117 +12113,120 @@ module.exports = function DumpLiterallyEverything(Module, base) {
@@ -12138,117 +12113,120 @@ module.exports = function DumpLiterallyEverything(Module, base) {
psm : enumToString ( base . GetPageSegMode ( ) , 'PSM' ) ,
oem : enumToString ( base . oem ( ) , 'OEM' ) ,
version : base . Version ( )
} ;
} ;
version : base . Version ( ) ,
}
}
// the generated HOCR is excessively indented, so
// we get rid of that indentation
function deindent ( html ) {
var lines = html . split ( '\n' ) ;
if ( lines [ 0 ] . substring ( 0 , 2 ) === " " ) {
function deindent ( html ) {
var lines = html . split ( '\n' )
if ( lines [ 0 ] . substring ( 0 , 2 ) === " " ) {
for ( var i = 0 ; i < lines . length ; i ++ ) {
if ( lines [ i ] . substring ( 0 , 2 ) === " " ) {
lines [ i ] = lines [ i ] . slice ( 2 ) ;
if ( lines [ i ] . substring ( 0 , 2 ) === " " ) {
lines [ i ] = lines [ i ] . slice ( 2 )
}
} ;
}
return lines . join ( '\n' ) ;
return lines . join ( '\n' )
}
} , { } ] , 46 : [ function ( require , module , exports ) {
module . exports = { "afr" : 1079573 , "ara" : 1701536 , "aze" : 1420865 , "bel" : 1276820 , "ben" : 6772012 , "bul" : 1605615 , "cat" : 1652368 , "ces" : 1035441 , "chi_sim" : 17710414 , "chi_tra" : 24717749 , "chr" : 320649 , "dan-frak" : 677656 , "dan" : 1972936 , "deu-frak" : 822644 , "deu" : 991656 , "ell" : 859719 , "eng" : 9453554 , "enm" : 619254 , "epo" : 1241212 , "equ" : 821130 , "est" : 1905040 , "eus" : 1641190 , "fin" : 979418 , "fra" : 1376221 , "frk" : 5912963 , "frm" : 5147082 , "glg" : 1674938 , "grc" : 3012615 , "heb" : 1051501 , "hin" : 6590065 , "hrv" : 1926995 , "hun" : 3074473 , "ind" : 1874776 , "isl" : 1634041 , "ita" : 948593 , "ita_old" : 3436571 , "jpn" : 13507168 , "kan" : 4390317 , "kor" : 5353098 , "lav" : 1843944 , "lit" : 1779240 , "mal" : 5966263 , "meme" : 88453 , "mkd" : 1163087 , "mlt" : 1463001 , "msa" : 1665427 , "nld" : 1134708 , "nor" : 2191610 , "osd" : 4274649 , "pol" : 7024662 , "por" : 909359 , "ron" : 915680 , "rus" : 5969957 , "slk-frak" : 289885 , "slk" : 2217342 , "slv" : 1611338 , "spa" : 883170 , "spa_old" : 5647453 , "sqi" : 1667041 , "srp" : 1770244 , "swa" : 757916 , "swe" : 2451917 , "tam" : 3498763 , "tel" : 5795246 , "tgl" : 1496256 , "tha" : 3811136 , "tur" : 3563264 , "ukr" : 937566 , "vie" : 2195922 }
} , { } ] , 47 : [ function ( require , module , exports ) {
'use strict' ;
var latestJob ;
var Module ;
var base ;
var adapter = { } ;
function dispatchHandlers ( packet , send ) {
function respond ( status , data ) {
function dispatchHandlers ( packet , send ) {
function respond ( status , data ) {
send ( {
jobId : packet . jobId ,
status : status ,
action : packet . action ,
data : data
} ) ;
} )
}
respond . resolve = respond . bind ( this , 'resolve' ) ;
respond . reject = respond . bind ( this , 'reject' ) ;
respond . progress = respond . bind ( this , 'progress' ) ;
respond . resolve = respond . bind ( this , 'resolve' )
respond . reject = respond . bind ( this , 'reject' )
respond . progress = respond . bind ( this , 'progress' )
latestJob = respond ;
if ( packet . action === 'recognize' ) {
handleRecognize ( packet . payload , respond ) ;
} else if ( packet . action === 'detect' ) {
handleDetect ( packet . payload , respond ) ;
if ( packet . action === 'recognize' ) {
handleRecognize ( packet . payload , respond )
} else if ( packet . action === 'detect' ) {
handleDetect ( packet . payload , respond )
}
}
exports . dispatchHandlers = dispatchHandlers ;
exports . setAdapter = function setAdapter ( impl ) {
exports . setAdapter = function setAdapter ( impl ) {
adapter = impl ;
} ;
}
function handleInit ( req , res ) {
if ( ! Module ) {
function handleInit ( req , res ) {
if ( ! Module ) {
var Core = adapter . getCore ( req , res ) ;
res . progress ( { status : 'initializing tesseract' , progress : 0 } ) ;
res . progress ( { status : 'initializing tesseract api ' } )
Module = Core ( {
TOTAL _MEMORY : req . memory ,
TesseractProgress : function TesseractProgress ( percent ) {
latestJob . progress ( { status : 'recognizing text' , progress : Math . max ( 0 , ( percent - 30 ) / 70 ) } ) ;
TesseractProgress ( percent ) {
latestJob . progress ( { status : 'recognizing text' , progress : Math . max ( 0 , ( percent - 30 ) / 70 ) } )
} ,
onRuntimeInitialized : function onRuntimeInitialized ( ) { }
} ) ;
Module . FS _createPath ( "/" , "tessdata" , true , true ) ;
base = new Module . TessBaseAPI ( ) ;
res . progress ( { status : 'initializing tesseract' , progress : 1 } ) ;
onRuntimeInitialized ( ) { }
} )
Module . FS _createPath ( "/" , "tessdata" , true , true )
base = new Module . TessBaseAPI ( )
res . progress ( { status : 'initialized tesseract api' } )
}
}
var dump = require ( './dump.js' ) ;
var desaturate = require ( './desaturate.js' ) ;
function setImage ( Module , base , image ) {
var dump = require ( './dump.js' )
var desaturate = require ( './desaturate.js' )
function setImage ( Module , base , image ) {
var imgbin = desaturate ( image ) ,
width = image . width ,
height = image . height ;
var ptr = Module . allocate ( imgbin , 'i8' , Module . ALLOC _NORMAL ) ;
base . SetImage ( Module . wrapPointer ( ptr ) , width , height , 1 , width ) ;
base . SetRectangle ( 0 , 0 , width , height ) ;
base . SetRectangle ( 0 , 0 , width , height )
return ptr ;
}
function loadLanguage ( req , res , cb ) {
function loadLanguage ( req , res , cb ) {
var lang = req . options . lang ;
if ( ! Module . _loadedLanguages ) Module . _loadedLanguages = { } ;
if ( lang in Module . _loadedLanguages ) return cb ( ) ;
if ( ! Module . _loadedLanguages ) Module . _loadedLanguages = { } ;
if ( lang in Module . _loadedLanguages ) return cb ( ) ;
adapter . getLanguageData ( req , res , function ( data ) {
adapter . getLanguageData ( req , res , function ( data ) {
Module . FS _createDataFile ( 'tessdata' , lang + ".traineddata" , data , true , false ) ;
res . progress ( { status : 'loading ' + lang + '.traineddata' , progress : 1 } ) ;
res . progress ( { status : 'loaded ' + lang + '.traineddata' } )
Module . _loadedLanguages [ lang ] = true ;
cb ( ) ;
} ) ;
cb ( )
} )
}
function handleRecognize ( req , res ) {
handleInit ( req , res ) ;
loadLanguage ( req , res , function ( ) {
function handleRecognize ( req , res ) {
handleInit ( req , res )
loadLanguage ( req , res , function ( ) {
var lang = req . options . lang ;
res . progress ( { status : 'initializing api' , progress : 0 } ) ;
base . Init ( null , lang ) ;
res . progress ( { status : 'initializing api' , progress : 0.3 } ) ;
base . Init ( null , lang )
res . progress ( { status : 'initialized with language' } )
var options = req . options ;
for ( var option in options ) {
@ -12257,41 +12235,39 @@ function handleRecognize(req, res) {
@@ -12257,41 +12235,39 @@ function handleRecognize(req, res) {
}
}
res . progress ( { status : 'initializing api' , progress : 0.6 } ) ;
var ptr = setImage ( Module , base , req . image ) ;
res . progress ( { status : 'initializing api' , progress : 1 } ) ;
base . Recognize ( null ) ;
var result = dump ( Module , base ) ;
base . Recognize ( null )
var result = dump ( Module , base )
base . End ( ) ;
Module . _free ( ptr ) ;
Module . _free ( ptr ) ;
res . resolve ( result ) ;
} ) ;
} )
}
function handleDetect ( req , res ) {
handleInit ( req , res ) ;
req . options . lang = 'osd' ;
loadLanguage ( req , res , function ( ) {
base . Init ( null , 'osd' ) ;
base . SetPageSegMode ( Module . PSM _OSD _ONLY ) ;
function handleDetect ( req , res ) {
handleInit ( req , res )
req . options . lang = 'osd' ;
loadLanguage ( req , res , function ( ) {
base . Init ( null , 'osd' )
base . SetPageSegMode ( Module . PSM _OSD _ONLY )
var ptr = setImage ( Module , base , req . image ) ;
var results = new Module . OSResults ( ) ;
var success = base . DetectOS ( results ) ;
if ( ! success ) {
if ( ! success ) {
base . End ( ) ;
Module . _free ( ptr ) ;
res . reject ( "failed to detect os" ) ;
res . reject ( "failed to detect os" )
} else {
var charset = results . get _unicharset ( ) ;
var best = results . get _best _result ( ) ;
var charset = results . get _unicharset ( )
var best = results . get _best _result ( )
var oid = best . get _orientation _id ( ) ,
sid = best . get _script _id ( ) ;
@ -12301,14 +12277,14 @@ function handleDetect(req, res) {
@@ -12301,14 +12277,14 @@ function handleDetect(req, res) {
script _confidence : best . get _sconfidence ( ) ,
orientation _degrees : [ 0 , 270 , 180 , 90 ] [ oid ] ,
orientation _confidence : best . get _oconfidence ( )
} ;
}
base . End ( ) ;
Module . _free ( ptr ) ;
res . resolve ( result ) ;
res . resolve ( result )
}
} ) ;
} )
}
} , { "./desaturate.js" : 44 , "./dump.js" : 45 } ] } , { } , [ 43 ] ) ;