mirror of https://github.com/koreader/koreader
Merge remote branch 'hwhw/master'
* hwhw/master: Password input, handling for broken documents factored pages count out, better error and password handling factored pages counter out of document structpull/2/merge
commit
fd6c6dbe60
@ -1,9 +1,32 @@
|
|||||||
require "unireader"
|
require "unireader"
|
||||||
|
require "inputbox"
|
||||||
|
|
||||||
PDFReader = UniReader:new{}
|
PDFReader = UniReader:new{}
|
||||||
|
|
||||||
-- open a PDF file and its settings store
|
-- open a PDF file and its settings store
|
||||||
function PDFReader:open(filename, password)
|
function PDFReader:open(filename)
|
||||||
self.doc = pdf.openDocument(filename, password or "")
|
-- muPDF manages its own cache, set second parameter
|
||||||
return self:loadSettings(filename)
|
-- to the maximum size you want it to grow
|
||||||
|
local ok
|
||||||
|
ok, self.doc = pcall(pdf.openDocument, filename, 64*1024*1024)
|
||||||
|
if not ok then
|
||||||
|
return false, self.doc -- will contain error message
|
||||||
|
end
|
||||||
|
if self.doc:needsPassword() then
|
||||||
|
local password = InputBox:input(height-100, 100, "Pass:")
|
||||||
|
if not password or not self.doc:authenticatePassword(password) then
|
||||||
|
self.doc:close()
|
||||||
|
self.doc = nil
|
||||||
|
return false, "wrong or missing password"
|
||||||
|
end
|
||||||
|
-- password wrong or not entered
|
||||||
|
end
|
||||||
|
local ok, err = pcall(self.doc.getPages, self.doc)
|
||||||
|
if not ok then
|
||||||
|
-- for PDFs, they might trigger errors later when accessing page tree
|
||||||
|
self.doc:close()
|
||||||
|
self.doc = nil
|
||||||
|
return false, "damaged page tree"
|
||||||
|
end
|
||||||
|
return true
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue