mirror of
https://github.com/YACReader/yacreader
synced 2025-07-17 20:44:32 -04:00
Creada provisionalmente clase Comic2 que evita los problemas de gesti?n de memoria
This commit is contained in:
@ -3,37 +3,62 @@
|
||||
#include "../static.h"
|
||||
|
||||
#include "comic.h"
|
||||
#include "comiccontroller.h"
|
||||
#include <QDataStream>
|
||||
#include <QPointer>
|
||||
|
||||
PageController::PageController() {}
|
||||
|
||||
void PageController::service(HttpRequest& request, HttpResponse& response)
|
||||
{
|
||||
|
||||
|
||||
HttpSession session=Static::sessionStore->getSession(request,response);
|
||||
|
||||
QStringList pathElements = ((QString)request.getPath()).split('/');
|
||||
QString libraryName = pathElements.at(2);
|
||||
qulonglong comicId = pathElements.at(4).toULongLong();
|
||||
quint16 page = pathElements.at(6).toUInt();
|
||||
unsigned int page = pathElements.at(6).toUInt();
|
||||
|
||||
Comic * comicFile = session.getCurrentComic();
|
||||
if((comicFile != 0) && comicId == session.getCurrentComicId())
|
||||
Comic2 * comicFile = session.getCurrentComic();
|
||||
if(session.getCurrentComicId() != 0 && !QPointer<Comic2>(comicFile).isNull())
|
||||
{
|
||||
response.setHeader("Content-Type", "image/page");
|
||||
QByteArray pageData = comicFile->getRawPage(page);
|
||||
response.write(pageData);
|
||||
if(comicId == session.getCurrentComicId() && page < comicFile->numPages())
|
||||
{
|
||||
if(comicFile->pageIsLoaded(page))
|
||||
{
|
||||
response.setHeader("Content-Type", "yacreader/page");
|
||||
QByteArray pageData = comicFile->getRawPage(page);
|
||||
QDataStream data(pageData);
|
||||
int i=0;
|
||||
char buffer[65536];
|
||||
while (!data.atEnd()) {
|
||||
int len = data.readRawData(buffer,65536);
|
||||
response.write(QByteArray(buffer,len));
|
||||
}
|
||||
//response.write(pageData);
|
||||
}
|
||||
else
|
||||
{
|
||||
response.setStatus(404,"not found"); //TODO qu<71> mensaje enviar
|
||||
response.write("404 not found",true);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if(comicId != session.getCurrentComicId())
|
||||
{
|
||||
//delete comicFile;
|
||||
session.dismissCurrentComic();
|
||||
}
|
||||
response.setStatus(404,"not found"); //TODO qu<71> mensaje enviar
|
||||
response.write("404 not found",true);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
delete comicFile;
|
||||
response.setStatus(404,"not found");
|
||||
response.write("404 not found",true);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
//response.write(t.toLatin1(),true);
|
||||
|
||||
}
|
Reference in New Issue
Block a user