@@ -24,26 +24,26 @@ using llvm::StringRef;
24
24
// https://stackoverflow.com/a/33799784/751061
25
25
void print_str_escape_json (ios_t *stream, StringRef s)
26
26
{
27
- ios_printf (stream, " \" " );
27
+ ios_putc ( ' " ' , stream );
28
28
for (auto c = s.begin (); c != s.end (); c++) {
29
29
switch (*c) {
30
- case ' "' : ios_printf (stream, " \\\" " ); break ;
31
- case ' \\ ' : ios_printf (stream, " \\\\ " ); break ;
32
- case ' \b ' : ios_printf (stream, " \\ b" ); break ;
33
- case ' \f ' : ios_printf (stream, " \\ f" ); break ;
34
- case ' \n ' : ios_printf (stream, " \\ n" ); break ;
35
- case ' \r ' : ios_printf (stream, " \\ r" ); break ;
36
- case ' \t ' : ios_printf (stream, " \\ t" ); break ;
30
+ case ' "' : ios_write (stream, " \\\" " , 2 ); break ;
31
+ case ' \\ ' : ios_write (stream, " \\\\ " , 2 ); break ;
32
+ case ' \b ' : ios_write (stream, " \\ b" , 2 ); break ;
33
+ case ' \f ' : ios_write (stream, " \\ f" , 2 ); break ;
34
+ case ' \n ' : ios_write (stream, " \\ n" , 2 ); break ;
35
+ case ' \r ' : ios_write (stream, " \\ r" , 2 ); break ;
36
+ case ' \t ' : ios_write (stream, " \\ t" , 2 ); break ;
37
37
default :
38
- if (' \x00 ' <= *c && *c <= ' \x1f ' ) {
38
+ if (( ' \x00 ' <= *c) & ( *c <= ' \x1f ' ) ) {
39
39
ios_printf (stream, " \\ u%04x" , (int )*c);
40
40
}
41
41
else {
42
- ios_printf (stream, " %c " , *c );
42
+ ios_putc (*c, stream );
43
43
}
44
44
}
45
45
}
46
- ios_printf (stream, " \" " );
46
+ ios_putc ( ' " ' , stream );
47
47
}
48
48
49
49
@@ -469,14 +469,14 @@ void serialize_heap_snapshot(ios_t *stream, HeapSnapshot &snapshot, char all_one
469
469
ios_printf (stream, " ," );
470
470
}
471
471
// ["type","name","id","self_size","edge_count","trace_node_id","detachedness"]
472
- ios_printf (stream, " %zu" , from_node. type );
473
- ios_printf (stream, " ,%zu " , from_node.name );
474
- ios_printf (stream, " ,%zu " , from_node.id );
475
- ios_printf (stream, " ,%zu " , all_one ? ( size_t ) 1 : from_node.self_size );
476
- ios_printf (stream, " ,%zu " , from_node.edges . size ());
477
- ios_printf (stream, " ,%zu " , from_node.trace_node_id );
478
- ios_printf (stream, " ,%d " , from_node.detachedness );
479
- ios_printf (stream, " \n " );
472
+ ios_printf (stream, " %zu,%zu,%zu,%zu,%zu,%zu,%d \n " ,
473
+ from_node.type ,
474
+ from_node.name ,
475
+ from_node.id ,
476
+ all_one ? ( size_t ) 1 : from_node.self_size ,
477
+ from_node.edges . size (),
478
+ from_node.trace_node_id ,
479
+ from_node. detachedness );
480
480
}
481
481
ios_printf (stream, " ],\n " );
482
482
@@ -490,10 +490,10 @@ void serialize_heap_snapshot(ios_t *stream, HeapSnapshot &snapshot, char all_one
490
490
else {
491
491
ios_printf (stream, " ," );
492
492
}
493
- ios_printf (stream, " %zu" , edge. type );
494
- ios_printf (stream, " ,%zu " , edge.name_or_index );
495
- ios_printf (stream, " ,%zu " , edge. to_node * k_node_number_of_fields);
496
- ios_printf (stream, " \n " );
493
+ ios_printf (stream, " %zu,%zu,%zu \n " ,
494
+ edge.type ,
495
+ edge. name_or_index ,
496
+ edge. to_node * k_node_number_of_fields );
497
497
}
498
498
}
499
499
ios_printf (stream, " ],\n " ); // end "edges"
0 commit comments