File: templatereply.cpp

package info (click to toggle)
grantlee5 5.3.1-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 4,004 kB
  • sloc: cpp: 25,617; javascript: 6,043; python: 299; sh: 97; perl: 37; ruby: 24; makefile: 20
file content (93 lines) | stat: -rw-r--r-- 2,804 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/*
  This file is part of the Grantlee template system.

  Copyright (c) 2011 Stephen Kelly <steveire@gmail.com>

  This library is free software; you can redistribute it and/or
  modify it under the terms of the GNU Lesser General Public
  License as published by the Free Software Foundation; either version
  2.1 of the Licence, or (at your option) any later version.

  This library is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  Lesser General Public License for more details.

  You should have received a copy of the GNU Lesser General Public
  License along with this library.  If not, see <http://www.gnu.org/licenses/>.

*/

#include "templatereply.h"

#include <grantlee/outputstream.h>

#include <QtCore/QDebug>

TemplateReply::TemplateReply(const QNetworkRequest &req,
                             const QNetworkAccessManager::Operation op,
                             Grantlee::Template t, Grantlee::Context c,
                             QObject *parent)
    : QNetworkReply(parent), m_t(t), m_c(c), m_buffer(new QBuffer(this))
{
  setRequest(req);
  setUrl(req.url());
  setOperation(op);
}

bool TemplateReply::atEnd() const { return m_buffer->atEnd(); }

qint64 TemplateReply::bytesAvailable() const
{
  return m_buffer->bytesAvailable() + QNetworkReply::bytesAvailable();
}

bool TemplateReply::canReadLine() const { return m_buffer->canReadLine(); }

void TemplateReply::close() { QNetworkReply::close(); }

bool TemplateReply::isSequential() const { return m_buffer->isSequential(); }

bool TemplateReply::open(QIODevice::OpenMode mode)
{
  m_buffer->open(QIODevice::ReadWrite);
  QString s;
  QTextStream ts(&s);
  Grantlee::OutputStream stream(&ts);
  m_t->render(&stream, &m_c);
  setHeader(QNetworkRequest::ContentTypeHeader, "text/html;charset=utf-8");
  m_buffer->write(s.toUtf8());
  m_buffer->seek(0);
  bool b = QNetworkReply::open(mode);
  QMetaObject::invokeMethod(this, "readyRead", Qt::QueuedConnection);
  QMetaObject::invokeMethod(this, "finished", Qt::QueuedConnection);
  return b;
}

qint64 TemplateReply::pos() const { return m_buffer->pos(); }

bool TemplateReply::reset() { return m_buffer->reset(); }

bool TemplateReply::seek(qint64 pos) { return m_buffer->seek(pos); }

void TemplateReply::setReadBufferSize(qint64 size)
{
  QNetworkReply::setReadBufferSize(size);
}

qint64 TemplateReply::size() const
{
  return m_buffer->size() + QNetworkReply::size();
}

bool TemplateReply::waitForReadyRead(int msecs)
{
  return m_buffer->waitForReadyRead(msecs);
}

void TemplateReply::abort() { m_buffer->buffer().clear(); }

qint64 TemplateReply::readData(char *data, qint64 maxlen)
{
  return m_buffer->read(data, maxlen);
}