|
|
@ -232,10 +232,11 @@ function nextPage(task, loadError) { |
|
|
|
var failure = loadError || ''; |
|
|
|
var failure = loadError || ''; |
|
|
|
|
|
|
|
|
|
|
|
if (!task.pdfDoc) { |
|
|
|
if (!task.pdfDoc) { |
|
|
|
sendTaskResult(canvasToDataURL(), task, failure); |
|
|
|
sendTaskResult(canvasToDataURL(), task, failure, function () { |
|
|
|
log('done' + (failure ? ' (failed !: ' + failure + ')' : '') + '\n'); |
|
|
|
log('done' + (failure ? ' (failed !: ' + failure + ')' : '') + '\n'); |
|
|
|
++currentTaskIdx; |
|
|
|
++currentTaskIdx; |
|
|
|
nextTask(); |
|
|
|
nextTask(); |
|
|
|
|
|
|
|
}); |
|
|
|
return; |
|
|
|
return; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -332,18 +333,12 @@ function nextPage(task, loadError) { |
|
|
|
function snapshotCurrentPage(task, failure) { |
|
|
|
function snapshotCurrentPage(task, failure) { |
|
|
|
log('done, snapshotting... '); |
|
|
|
log('done, snapshotting... '); |
|
|
|
|
|
|
|
|
|
|
|
sendTaskResult(canvasToDataURL(), task, failure); |
|
|
|
sendTaskResult(canvasToDataURL(), task, failure, function () { |
|
|
|
log('done' + (failure ? ' (failed !: ' + failure + ')' : '') + '\n'); |
|
|
|
log('done' + (failure ? ' (failed !: ' + failure + ')' : '') + '\n'); |
|
|
|
|
|
|
|
|
|
|
|
// Set up the next request
|
|
|
|
|
|
|
|
var backoff = (inFlightRequests > 0) ? inFlightRequests * 10 : 0; |
|
|
|
|
|
|
|
setTimeout( |
|
|
|
|
|
|
|
function snapshotCurrentPageSetTimeout() { |
|
|
|
|
|
|
|
++task.pageNum; |
|
|
|
++task.pageNum; |
|
|
|
nextPage(task); |
|
|
|
nextPage(task); |
|
|
|
}, |
|
|
|
}); |
|
|
|
backoff |
|
|
|
|
|
|
|
); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function sendQuitRequest() { |
|
|
|
function sendQuitRequest() { |
|
|
@ -373,10 +368,8 @@ function done() { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function sendTaskResult(snapshot, task, failure, result) { |
|
|
|
function sendTaskResult(snapshot, task, failure, callback) { |
|
|
|
// Optional result argument is for retrying XHR requests - see below
|
|
|
|
var result = JSON.stringify({ |
|
|
|
if (!result) { |
|
|
|
|
|
|
|
result = JSON.stringify({ |
|
|
|
|
|
|
|
browser: browser, |
|
|
|
browser: browser, |
|
|
|
id: task.id, |
|
|
|
id: task.id, |
|
|
|
numPages: task.pdfDoc ? |
|
|
|
numPages: task.pdfDoc ? |
|
|
@ -389,12 +382,11 @@ function sendTaskResult(snapshot, task, failure, result) { |
|
|
|
snapshot: snapshot, |
|
|
|
snapshot: snapshot, |
|
|
|
stats: task.stats.times |
|
|
|
stats: task.stats.times |
|
|
|
}); |
|
|
|
}); |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
send('/submit_task_results', result); |
|
|
|
send('/submit_task_results', result, callback); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function send(url, message) { |
|
|
|
function send(url, message, callback) { |
|
|
|
var r = new XMLHttpRequest(); |
|
|
|
var r = new XMLHttpRequest(); |
|
|
|
// (The POST URI is ignored atm.)
|
|
|
|
// (The POST URI is ignored atm.)
|
|
|
|
r.open('POST', url, true); |
|
|
|
r.open('POST', url, true); |
|
|
@ -408,6 +400,9 @@ function send(url, message) { |
|
|
|
send(url, message); |
|
|
|
send(url, message); |
|
|
|
}); |
|
|
|
}); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
if (callback) { |
|
|
|
|
|
|
|
callback(); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
}; |
|
|
|
}; |
|
|
|
document.getElementById('inFlightCount').innerHTML = inFlightRequests++; |
|
|
|
document.getElementById('inFlightCount').innerHTML = inFlightRequests++; |
|
|
|