2
1
mirror of https://github.com/qpdf/qpdf.git synced 2025-01-05 08:02:11 +00:00

Make use of the new Pipeline methods in some places

This commit is contained in:
Jay Berkenbilt 2022-05-03 18:09:49 -04:00
parent f1c6bb97db
commit 21d6e3231f
9 changed files with 23 additions and 32 deletions

View File

@ -118,9 +118,7 @@ ImageProvider::provideStreamData(int objid, int generation, Pipeline* pipeline)
for (size_t i = 0; i < n_stripes; ++i) { for (size_t i = 0; i < n_stripes; ++i) {
for (size_t j = 0; j < width * stripe_height; ++j) { for (size_t j = 0; j < width * stripe_height; ++j) {
p->write( p->writeString(stripes[i]);
QUtil::unsigned_char_pointer(stripes[i].c_str()),
stripes[i].length());
} }
} }
p->finish(); p->finish();

View File

@ -348,9 +348,7 @@ Pl_DCT::decompress(void* cinfo_p, Buffer* b)
(void)jpeg_start_decompress(cinfo); (void)jpeg_start_decompress(cinfo);
while (cinfo->output_scanline < cinfo->output_height) { while (cinfo->output_scanline < cinfo->output_height) {
(void)jpeg_read_scanlines(cinfo, buffer, 1); (void)jpeg_read_scanlines(cinfo, buffer, 1);
this->getNext()->write( this->getNext()->write(buffer[0], width * sizeof(buffer[0][0]));
reinterpret_cast<unsigned char*>(buffer[0]),
width * sizeof(buffer[0][0]));
} }
(void)jpeg_finish_decompress(cinfo); (void)jpeg_finish_decompress(cinfo);
this->getNext()->finish(); this->getNext()->finish();

View File

@ -2739,7 +2739,7 @@ QPDF::pipeStreamData(
"unexpected EOF reading stream data"); "unexpected EOF reading stream data");
} }
length -= len; length -= len;
pipeline->write(QUtil::unsigned_char_pointer(buf), len); pipeline->write(buf, len);
} }
pipeline->finish(); pipeline->finish();
success = true; success = true;

View File

@ -863,7 +863,7 @@ QPDFFormFieldObjectHelper::generateTextAppearance(
TfFinder tff; TfFinder tff;
Pl_QPDFTokenizer tok("tf", &tff); Pl_QPDFTokenizer tok("tf", &tff);
tok.write(QUtil::unsigned_char_pointer(DA.c_str()), DA.length()); tok.writeString(DA);
tok.finish(); tok.finish();
double tf = tff.getTf(); double tf = tff.getTf();
DA = tff.getDA(); DA = tff.getDA();

View File

@ -127,7 +127,7 @@ QPDFObjectHandle::TokenFilter::write(char const* data, size_t len)
return; return;
} }
if (len) { if (len) {
this->pipeline->write(QUtil::unsigned_char_pointer(data), len); this->pipeline->write(data, len);
} }
} }
@ -1857,7 +1857,7 @@ QPDFObjectHandle::pipeContentStreams(
Pl_Buffer buf("concatenated content stream buffer"); Pl_Buffer buf("concatenated content stream buffer");
for (auto stream: streams) { for (auto stream: streams) {
if (need_newline) { if (need_newline) {
buf.write(QUtil::unsigned_char_pointer("\n"), 1); buf.writeCStr("\n");
} }
LastChar lc(&buf); LastChar lc(&buf);
std::string og = QUtil::int_to_string(stream.getObjectID()) + " " + std::string og = QUtil::int_to_string(stream.getObjectID()) + " " +

View File

@ -190,7 +190,7 @@ InlineImageTracker::handleToken(QPDFTokenizer::Token const& token)
QTC::TC( QTC::TC(
"qpdf", "QPDFPageObjectHelper externalize inline image"); "qpdf", "QPDFPageObjectHelper externalize inline image");
Pl_Buffer b("image_data"); Pl_Buffer b("image_data");
b.write(QUtil::unsigned_char_pointer(image_data), len); b.writeString(image_data);
b.finish(); b.finish();
QPDFObjectHandle dict = QPDFObjectHandle dict =
convertIIDict(QPDFObjectHandle::parse(dict_str)); convertIIDict(QPDFObjectHandle::parse(dict_str));

View File

@ -961,7 +961,7 @@ QPDFWriter::writeBinary(unsigned long long val, unsigned int bytes)
void void
QPDFWriter::writeString(std::string const& str) QPDFWriter::writeString(std::string const& str)
{ {
this->m->pipeline->write(QUtil::unsigned_char_pointer(str), str.length()); this->m->pipeline->writeString(str);
} }
void void
@ -1736,7 +1736,7 @@ QPDFWriter::unparseObject(
true, true,
QUtil::unsigned_char_pointer(this->m->cur_data_key), QUtil::unsigned_char_pointer(this->m->cur_data_key),
this->m->cur_data_key.length()); this->m->cur_data_key.length());
pl.write(QUtil::unsigned_char_pointer(val), val.length()); pl.writeString(val);
pl.finish(); pl.finish();
auto buf = bufpl.getBufferSharedPointer(); auto buf = bufpl.getBufferSharedPointer();
val = QPDF_String(std::string( val = QPDF_String(std::string(

View File

@ -235,7 +235,7 @@ process_with_aes(
} }
aes.disablePadding(); aes.disablePadding();
for (unsigned int i = 0; i < repetitions; ++i) { for (unsigned int i = 0; i < repetitions; ++i) {
aes.write(QUtil::unsigned_char_pointer(data), data.length()); aes.writeString(data);
} }
aes.finish(); aes.finish();
auto bufp = buffer.getBufferSharedPointer(); auto bufp = buffer.getBufferSharedPointer();
@ -255,9 +255,9 @@ hash_V5(
QPDF::EncryptionData const& data) QPDF::EncryptionData const& data)
{ {
Pl_SHA2 hash(256); Pl_SHA2 hash(256);
hash.write(QUtil::unsigned_char_pointer(password), password.length()); hash.writeString(password);
hash.write(QUtil::unsigned_char_pointer(salt), salt.length()); hash.writeString(salt);
hash.write(QUtil::unsigned_char_pointer(udata), udata.length()); hash.writeString(udata);
hash.finish(); hash.finish();
std::string K = hash.getRawDigest(); std::string K = hash.getRawDigest();
@ -311,7 +311,7 @@ hash_V5(
E_mod_3 %= 3; E_mod_3 %= 3;
int next_hash = ((E_mod_3 == 0) ? 256 : (E_mod_3 == 1) ? 384 : 512); int next_hash = ((E_mod_3 == 0) ? 256 : (E_mod_3 == 1) ? 384 : 512);
Pl_SHA2 sha2(next_hash); Pl_SHA2 sha2(next_hash);
sha2.write(QUtil::unsigned_char_pointer(E), E.length()); sha2.writeString(E);
sha2.finish(); sha2.finish();
K = sha2.getRawDigest(); K = sha2.getRawDigest();
@ -1151,7 +1151,7 @@ QPDF::decryptString(std::string& str, int objid, int generation)
false, false,
QUtil::unsigned_char_pointer(key), QUtil::unsigned_char_pointer(key),
key.length()); key.length());
pl.write(QUtil::unsigned_char_pointer(str), str.length()); pl.writeString(str);
pl.finish(); pl.finish();
auto buf = bufpl.getBufferSharedPointer(); auto buf = bufpl.getBufferSharedPointer();
str = std::string( str = std::string(

View File

@ -477,9 +477,7 @@ test_8(QPDF& pdf, char const* arg2)
} }
Pl_Buffer p1("buffer"); Pl_Buffer p1("buffer");
Pl_Flate p2("compress", &p1, Pl_Flate::a_deflate); Pl_Flate p2("compress", &p1, Pl_Flate::a_deflate);
p2.write( p2 << "new data for stream\n";
QUtil::unsigned_char_pointer("new data for stream\n"),
20); // no null!
p2.finish(); p2.finish();
auto b = p1.getBufferSharedPointer(); auto b = p1.getBufferSharedPointer();
// This is a bogus way to use StreamDataProvider, but it does // This is a bogus way to use StreamDataProvider, but it does
@ -1021,9 +1019,7 @@ test_27(QPDF& pdf, char const* arg2)
{ {
// Local scope // Local scope
Pl_Buffer pl("buffer"); Pl_Buffer pl("buffer");
pl.write( pl.writeCStr("new data for stream\n");
QUtil::unsigned_char_pointer("new data for stream\n"),
20); // no null!
pl.finish(); pl.finish();
auto b = pl.getBufferSharedPointer(); auto b = pl.getBufferSharedPointer();
Provider* provider = new Provider(b); Provider* provider = new Provider(b);
@ -1050,9 +1046,7 @@ test_27(QPDF& pdf, char const* arg2)
{ {
// Local scope // Local scope
Pl_Buffer pl("buffer"); Pl_Buffer pl("buffer");
pl.write( pl.writeCStr("more data for stream\n");
QUtil::unsigned_char_pointer("more data for stream\n"),
21); // no null!
pl.finish(); pl.finish();
auto b = pl.getBufferSharedPointer(); auto b = pl.getBufferSharedPointer();
Provider* provider = new Provider(b); Provider* provider = new Provider(b);
@ -2648,7 +2642,8 @@ test_76(QPDF& pdf, char const* arg2)
auto efs2 = QPDFEFStreamObjectHelper::createEFStream(pdf, "from string"); auto efs2 = QPDFEFStreamObjectHelper::createEFStream(pdf, "from string");
efs2.setSubtype("text/plain"); efs2.setSubtype("text/plain");
Pl_Buffer p("buffer"); Pl_Buffer p("buffer");
p.write(QUtil::unsigned_char_pointer("from buffer"), 11); // exercise Pipeline::operator<<(std::string const&)
p << std::string("from buffer");
p.finish(); p.finish();
auto efs3 = QPDFEFStreamObjectHelper::createEFStream( auto efs3 = QPDFEFStreamObjectHelper::createEFStream(
pdf, p.getBufferSharedPointer()); pdf, p.getBufferSharedPointer());
@ -2700,7 +2695,7 @@ test_78(QPDF& pdf, char const* arg2)
// Test functional versions of replaceStreamData() // Test functional versions of replaceStreamData()
auto f1 = [](Pipeline* p) { auto f1 = [](Pipeline* p) {
p->write(QUtil::unsigned_char_pointer("potato"), 6); p->writeCStr("potato");
p->finish(); p->finish();
}; };
auto f2 = [](Pipeline* p, bool suppress_warnings, bool will_retry) { auto f2 = [](Pipeline* p, bool suppress_warnings, bool will_retry) {
@ -2712,7 +2707,7 @@ test_78(QPDF& pdf, char const* arg2)
if (!suppress_warnings) { if (!suppress_warnings) {
std::cerr << "warning" << std::endl; std::cerr << "warning" << std::endl;
} }
p->write(QUtil::unsigned_char_pointer("salad"), 5); p->writeCStr("salad");
p->finish(); p->finish();
std::cerr << "f2 done" << std::endl; std::cerr << "f2 done" << std::endl;
return true; return true;
@ -2767,7 +2762,7 @@ test_79(QPDF& pdf, char const* arg2)
// Use a provider // Use a provider
Pl_Buffer b("buffer"); Pl_Buffer b("buffer");
b.write(QUtil::unsigned_char_pointer("from buffer"), 11); b.writeCStr("from buffer");
b.finish(); b.finish();
auto bp = b.getBufferSharedPointer(); auto bp = b.getBufferSharedPointer();
auto s3 = QPDFObjectHandle::newStream(&pdf, bp); auto s3 = QPDFObjectHandle::newStream(&pdf, bp);