mirror of
https://github.com/qpdf/qpdf.git
synced 2025-01-05 08:02:11 +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.
48 lines
1.1 KiB
C++
48 lines
1.1 KiB
C++
#include <qpdf/Pl_RunLength.hh>
|
|
#include <qpdf/Pl_StdioFile.hh>
|
|
#include <qpdf/QUtil.hh>
|
|
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <iostream>
|
|
#include <stdlib.h>
|
|
|
|
int main(int argc, char* argv[])
|
|
{
|
|
if (argc != 4)
|
|
{
|
|
std::cerr << "Usage: runlength {-encode|-decode} infile outfile"
|
|
<< std::endl;
|
|
exit(2);
|
|
}
|
|
|
|
bool encode = (strcmp("-encode", argv[1]) == 0);
|
|
char* infilename = argv[2];
|
|
char* outfilename = argv[3];
|
|
|
|
FILE* infile = QUtil::safe_fopen(infilename, "rb");
|
|
FILE* outfile = QUtil::safe_fopen(outfilename, "wb");
|
|
Pl_StdioFile out("stdout", outfile);
|
|
unsigned char buf[100];
|
|
bool done = false;
|
|
Pl_RunLength rl(
|
|
"runlength", &out,
|
|
(encode ? Pl_RunLength::a_encode : Pl_RunLength::a_decode));
|
|
while (! done)
|
|
{
|
|
size_t len = fread(buf, 1, sizeof(buf), infile);
|
|
if (len <= 0)
|
|
{
|
|
done = true;
|
|
}
|
|
else
|
|
{
|
|
rl.write(buf, len);
|
|
}
|
|
}
|
|
rl.finish();
|
|
fclose(infile);
|
|
fclose(outfile);
|
|
return 0;
|
|
}
|