mirror of
https://github.com/qpdf/qpdf.git
synced 2025-01-05 16:12:13 +00:00
cb769c62e5
This comment expands all tabs using an 8-character tab-width. You should ignore this commit when using git blame or use git blame -w. In the early days, I used to use tabs where possible for indentation, since emacs did this automatically. In recent years, I have switched to only using spaces, which means qpdf source code has been a mixture of spaces and tabs. I have avoided cleaning this up because of not wanting gratuitous whitespaces change to cloud the output of git blame, but I changed my mind after discussing with users who view qpdf source code in editors/IDEs that have other tab widths by default and in light of the fact that I am planning to start applying automatic code formatting soon.
59 lines
1.0 KiB
C++
59 lines
1.0 KiB
C++
#include <qpdf/qpdf-config.h> // include first for large file support
|
|
|
|
#include <qpdf/Pl_StdioFile.hh>
|
|
|
|
#include <qpdf/QUtil.hh>
|
|
#include <stdexcept>
|
|
#include <errno.h>
|
|
|
|
Pl_StdioFile::Members::Members(FILE* f) :
|
|
file(f)
|
|
{
|
|
}
|
|
|
|
Pl_StdioFile::Members::~Members()
|
|
{
|
|
}
|
|
|
|
Pl_StdioFile::Pl_StdioFile(char const* identifier, FILE* f) :
|
|
Pipeline(identifier, 0),
|
|
m(new Members(f))
|
|
{
|
|
}
|
|
|
|
Pl_StdioFile::~Pl_StdioFile()
|
|
{
|
|
}
|
|
|
|
void
|
|
Pl_StdioFile::write(unsigned char* buf, size_t len)
|
|
{
|
|
size_t so_far = 0;
|
|
while (len > 0)
|
|
{
|
|
so_far = fwrite(buf, 1, len, this->m->file);
|
|
if (so_far == 0)
|
|
{
|
|
QUtil::throw_system_error(
|
|
this->identifier + ": Pl_StdioFile::write");
|
|
}
|
|
else
|
|
{
|
|
buf += so_far;
|
|
len -= so_far;
|
|
}
|
|
}
|
|
}
|
|
|
|
void
|
|
Pl_StdioFile::finish()
|
|
{
|
|
if ((fflush(this->m->file) == -1) &&
|
|
(errno == EBADF))
|
|
{
|
|
throw std::logic_error(
|
|
this->identifier +
|
|
": Pl_StdioFile::finish: stream already closed");
|
|
}
|
|
}
|