Suppress jsonptr byte string output when in query
diff --git a/example/jsonptr/jsonptr.cc b/example/jsonptr/jsonptr.cc
index e9ce82f..b92ada0 100644
--- a/example/jsonptr/jsonptr.cc
+++ b/example/jsonptr/jsonptr.cc
@@ -839,7 +839,7 @@
g_query.reset(g_flags.query_c_string);
- // If the query is non-empty, suprress writing to stdout until we've
+ // If the query is non-empty, suppress writing to stdout until we've
// completed the query.
g_suppress_write_dst = g_query.next_fragment() ? 1 : 0;
g_wrote_to_dst = false;
@@ -1369,6 +1369,13 @@
const char* //
write_json_output_byte_string(wuffs_base__slice_u8 s, bool finish) {
+ // This function and flush_json_output_byte_string doesn't call write_dst.
+ // Instead, they call wuffs_base__base_64__encode to write directly to g_dst.
+ // It is therefore responsible for checking g_suppress_write_dst.
+ if (g_suppress_write_dst > 0) {
+ return nullptr;
+ }
+
uint8_t* ptr = s.ptr;
size_t len = s.len;
while (len > 0) {