| Filename | /usr/libdata/perl5/amd64-openbsd/Compress/Raw/Zlib.pm |
| Statements | Executed 793 statements in 9.80ms |
| Calls | P | F | Exclusive Time |
Inclusive Time |
Subroutine |
|---|---|---|---|---|---|
| 2 | 1 | 1 | 602µs | 995µs | Compress::Raw::Zlib::Parameters::parse |
| 26 | 2 | 1 | 320µs | 367µs | Compress::Raw::Zlib::Parameters::_checkType |
| 8 | 4 | 2 | 227µs | 294µs | Compress::Raw::Zlib::AUTOLOAD |
| 2 | 1 | 1 | 190µs | 1.67ms | Compress::Raw::Zlib::Inflate::new |
| 2 | 1 | 1 | 181µs | 1.20ms | Compress::Raw::Zlib::ParseParameters |
| 2 | 1 | 1 | 170µs | 170µs | Compress::Raw::Zlib::inflateStream::inflate (xsub) |
| 2 | 1 | 1 | 160µs | 160µs | Compress::Raw::Zlib::_inflateInit (xsub) |
| 18 | 8 | 1 | 120µs | 120µs | Compress::Raw::Zlib::Parameters::value |
| 22 | 9 | 2 | 113µs | 113µs | Compress::Raw::Zlib::__ANON__[:114] |
| 18 | 2 | 1 | 63µs | 63µs | Compress::Raw::Zlib::CORE:subst (opcode) |
| 1 | 1 | 1 | 50µs | 446µs | Compress::Raw::Zlib::BEGIN@6 |
| 1 | 1 | 1 | 48µs | 150µs | Compress::Raw::Zlib::BEGIN@106 |
| 10 | 2 | 1 | 47µs | 47µs | Compress::Raw::Zlib::CORE:match (opcode) |
| 1 | 1 | 1 | 45µs | 396µs | Compress::Raw::Zlib::BEGIN@105 |
| 1 | 1 | 1 | 40µs | 46µs | Compress::Raw::Zlib::BEGIN@8 |
| 1 | 1 | 1 | 34µs | 141µs | Compress::Raw::Zlib::BEGIN@138 |
| 8 | 1 | 1 | 31µs | 31µs | Compress::Raw::Zlib::constant (xsub) |
| 1 | 1 | 1 | 31µs | 127µs | Compress::Raw::Zlib::BEGIN@150 |
| 1 | 1 | 1 | 28µs | 32µs | Compress::Raw::Zlib::BEGIN@10 |
| 1 | 1 | 1 | 27µs | 118µs | Compress::Raw::Zlib::BEGIN@120 |
| 1 | 1 | 1 | 26µs | 503µs | Compress::Raw::Zlib::BEGIN@113 |
| 2 | 1 | 1 | 24µs | 24µs | Compress::Raw::Zlib::inflateStream::DESTROY (xsub) |
| 2 | 1 | 1 | 24µs | 24µs | Compress::Raw::Zlib::Parameters::new |
| 1 | 1 | 1 | 21µs | 108µs | Compress::Raw::Zlib::BEGIN@146 |
| 1 | 1 | 1 | 21µs | 33µs | Compress::Raw::Zlib::BEGIN@9 |
| 1 | 1 | 1 | 20µs | 119µs | Compress::Raw::Zlib::BEGIN@121 |
| 1 | 1 | 1 | 19µs | 93µs | Compress::Raw::Zlib::BEGIN@145 |
| 1 | 1 | 1 | 16µs | 117µs | Compress::Raw::Zlib::BEGIN@118 |
| 1 | 1 | 1 | 15µs | 105µs | Compress::Raw::Zlib::BEGIN@136 |
| 1 | 1 | 1 | 15µs | 91µs | Compress::Raw::Zlib::BEGIN@137 |
| 1 | 1 | 1 | 15µs | 105µs | Compress::Raw::Zlib::BEGIN@119 |
| 1 | 1 | 1 | 15µs | 90µs | Compress::Raw::Zlib::BEGIN@122 |
| 1 | 1 | 1 | 14µs | 86µs | Compress::Raw::Zlib::BEGIN@149 |
| 1 | 1 | 1 | 14µs | 101µs | Compress::Raw::Zlib::BEGIN@139 |
| 1 | 1 | 1 | 14µs | 87µs | Compress::Raw::Zlib::BEGIN@147 |
| 1 | 1 | 1 | 12µs | 84µs | Compress::Raw::Zlib::BEGIN@148 |
| 0 | 0 | 0 | 0s | 0s | Compress::Raw::Zlib::Deflate::new |
| 0 | 0 | 0 | 0s | 0s | Compress::Raw::Zlib::InflateScan::new |
| 0 | 0 | 0 | 0s | 0s | Compress::Raw::Zlib::Parameters::parsed |
| 0 | 0 | 0 | 0s | 0s | Compress::Raw::Zlib::Parameters::setError |
| 0 | 0 | 0 | 0s | 0s | Compress::Raw::Zlib::deflateStream::STORABLE_freeze |
| 0 | 0 | 0 | 0s | 0s | Compress::Raw::Zlib::deflateStream::STORABLE_thaw |
| 0 | 0 | 0 | 0s | 0s | Compress::Raw::Zlib::deflateStream::deflateParams |
| 0 | 0 | 0 | 0s | 0s | Compress::Raw::Zlib::inflateScanStream::createDeflateStream |
| 0 | 0 | 0 | 0s | 0s | Compress::Raw::Zlib::inflateScanStream::inflate |
| 0 | 0 | 0 | 0s | 0s | Compress::Raw::Zlib::inflateStream::STORABLE_freeze |
| 0 | 0 | 0 | 0s | 0s | Compress::Raw::Zlib::inflateStream::STORABLE_thaw |
| Line | State ments |
Time on line |
Calls | Time in subs |
Code |
|---|---|---|---|---|---|
| 1 | |||||
| 2 | package Compress::Raw::Zlib; | ||||
| 3 | |||||
| 4 | 1 | 25µs | require 5.006 ; | ||
| 5 | 1 | 2µs | require Exporter; | ||
| 6 | 2 | 141µs | 2 | 842µs | # spent 446µs (50+396) within Compress::Raw::Zlib::BEGIN@6 which was called:
# once (50µs+396µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 6 # spent 446µs making 1 call to Compress::Raw::Zlib::BEGIN@6
# spent 396µs making 1 call to Exporter::import |
| 7 | |||||
| 8 | 2 | 48µs | 2 | 51µs | # spent 46µs (40+6) within Compress::Raw::Zlib::BEGIN@8 which was called:
# once (40µs+6µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 8 # spent 46µs making 1 call to Compress::Raw::Zlib::BEGIN@8
# spent 6µs making 1 call to strict::import |
| 9 | 2 | 100µs | 2 | 46µs | # spent 33µs (21+12) within Compress::Raw::Zlib::BEGIN@9 which was called:
# once (21µs+12µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 9 # spent 33µs making 1 call to Compress::Raw::Zlib::BEGIN@9
# spent 12µs making 1 call to warnings::import |
| 10 | 2 | 991µs | 2 | 36µs | # spent 32µs (28+4) within Compress::Raw::Zlib::BEGIN@10 which was called:
# once (28µs+4µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 10 # spent 32µs making 1 call to Compress::Raw::Zlib::BEGIN@10
# spent 4µs making 1 call to bytes::import |
| 11 | our ($VERSION, $XS_VERSION, @ISA, @EXPORT, %EXPORT_TAGS, @EXPORT_OK, $AUTOLOAD, %DEFLATE_CONSTANTS, @DEFLATE_CONSTANTS); | ||||
| 12 | |||||
| 13 | 1 | 1µs | $VERSION = '2.069'; | ||
| 14 | 1 | 1µs | $XS_VERSION = $VERSION; | ||
| 15 | 1 | 27µs | $VERSION = eval $VERSION; # spent 7µs executing statements in string eval | ||
| 16 | |||||
| 17 | 1 | 19µs | @ISA = qw(Exporter); | ||
| 18 | 1 | 14µs | %EXPORT_TAGS = ( flush => [qw{ | ||
| 19 | Z_NO_FLUSH | ||||
| 20 | Z_PARTIAL_FLUSH | ||||
| 21 | Z_SYNC_FLUSH | ||||
| 22 | Z_FULL_FLUSH | ||||
| 23 | Z_FINISH | ||||
| 24 | Z_BLOCK | ||||
| 25 | }], | ||||
| 26 | level => [qw{ | ||||
| 27 | Z_NO_COMPRESSION | ||||
| 28 | Z_BEST_SPEED | ||||
| 29 | Z_BEST_COMPRESSION | ||||
| 30 | Z_DEFAULT_COMPRESSION | ||||
| 31 | }], | ||||
| 32 | strategy => [qw{ | ||||
| 33 | Z_FILTERED | ||||
| 34 | Z_HUFFMAN_ONLY | ||||
| 35 | Z_RLE | ||||
| 36 | Z_FIXED | ||||
| 37 | Z_DEFAULT_STRATEGY | ||||
| 38 | }], | ||||
| 39 | status => [qw{ | ||||
| 40 | Z_OK | ||||
| 41 | Z_STREAM_END | ||||
| 42 | Z_NEED_DICT | ||||
| 43 | Z_ERRNO | ||||
| 44 | Z_STREAM_ERROR | ||||
| 45 | Z_DATA_ERROR | ||||
| 46 | Z_MEM_ERROR | ||||
| 47 | Z_BUF_ERROR | ||||
| 48 | Z_VERSION_ERROR | ||||
| 49 | }], | ||||
| 50 | ); | ||||
| 51 | |||||
| 52 | 1 | 5µs | %DEFLATE_CONSTANTS = %EXPORT_TAGS; | ||
| 53 | |||||
| 54 | # Items to export into callers namespace by default. Note: do not export | ||||
| 55 | # names by default without a very good reason. Use EXPORT_OK instead. | ||||
| 56 | # Do not simply export all your public functions/methods/constants. | ||||
| 57 | 1 | 16µs | @DEFLATE_CONSTANTS = | ||
| 58 | @EXPORT = qw( | ||||
| 59 | ZLIB_VERSION | ||||
| 60 | ZLIB_VERNUM | ||||
| 61 | |||||
| 62 | |||||
| 63 | OS_CODE | ||||
| 64 | |||||
| 65 | MAX_MEM_LEVEL | ||||
| 66 | MAX_WBITS | ||||
| 67 | |||||
| 68 | Z_ASCII | ||||
| 69 | Z_BEST_COMPRESSION | ||||
| 70 | Z_BEST_SPEED | ||||
| 71 | Z_BINARY | ||||
| 72 | Z_BLOCK | ||||
| 73 | Z_BUF_ERROR | ||||
| 74 | Z_DATA_ERROR | ||||
| 75 | Z_DEFAULT_COMPRESSION | ||||
| 76 | Z_DEFAULT_STRATEGY | ||||
| 77 | Z_DEFLATED | ||||
| 78 | Z_ERRNO | ||||
| 79 | Z_FILTERED | ||||
| 80 | Z_FIXED | ||||
| 81 | Z_FINISH | ||||
| 82 | Z_FULL_FLUSH | ||||
| 83 | Z_HUFFMAN_ONLY | ||||
| 84 | Z_MEM_ERROR | ||||
| 85 | Z_NEED_DICT | ||||
| 86 | Z_NO_COMPRESSION | ||||
| 87 | Z_NO_FLUSH | ||||
| 88 | Z_NULL | ||||
| 89 | Z_OK | ||||
| 90 | Z_PARTIAL_FLUSH | ||||
| 91 | Z_RLE | ||||
| 92 | Z_STREAM_END | ||||
| 93 | Z_STREAM_ERROR | ||||
| 94 | Z_SYNC_FLUSH | ||||
| 95 | Z_TREES | ||||
| 96 | Z_UNKNOWN | ||||
| 97 | Z_VERSION_ERROR | ||||
| 98 | |||||
| 99 | WANT_GZIP | ||||
| 100 | WANT_GZIP_OR_ZLIB | ||||
| 101 | ); | ||||
| 102 | |||||
| 103 | 1 | 2µs | push @EXPORT, qw(crc32 adler32 DEF_WBITS); | ||
| 104 | |||||
| 105 | 2 | 124µs | 2 | 747µs | # spent 396µs (45+351) within Compress::Raw::Zlib::BEGIN@105 which was called:
# once (45µs+351µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 105 # spent 396µs making 1 call to Compress::Raw::Zlib::BEGIN@105
# spent 351µs making 1 call to constant::import |
| 106 | 2 | 152µs | 2 | 251µs | # spent 150µs (48+101) within Compress::Raw::Zlib::BEGIN@106 which was called:
# once (48µs+101µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 106 # spent 150µs making 1 call to Compress::Raw::Zlib::BEGIN@106
# spent 101µs making 1 call to constant::import |
| 107 | |||||
| 108 | # spent 294µs (227+67) within Compress::Raw::Zlib::AUTOLOAD which was called 8 times, avg 37µs/call:
# 5 times (148µs+47µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 377, avg 39µs/call
# once (28µs+12µs) by IO::Uncompress::Adapter::Inflate::uncompr at line 66 of IO/Uncompress/Adapter/Inflate.pm
# once (32µs+5µs) by IO::Uncompress::Adapter::Inflate::mkUncompObject at line 42 of IO/Uncompress/Adapter/Inflate.pm
# once (19µs+3µs) by IO::Uncompress::Adapter::Inflate::uncompr at line 72 of IO/Uncompress/Adapter/Inflate.pm | ||||
| 109 | 8 | 6µs | my($constname); | ||
| 110 | 8 | 91µs | 8 | 36µs | ($constname = $AUTOLOAD) =~ s/.*:://; # spent 36µs making 8 calls to Compress::Raw::Zlib::CORE:subst, avg 4µs/call |
| 111 | 8 | 73µs | 8 | 31µs | my ($error, $val) = constant($constname); # spent 31µs making 8 calls to Compress::Raw::Zlib::constant, avg 4µs/call |
| 112 | 8 | 6µs | Carp::croak $error if $error; | ||
| 113 | 2 | 236µs | 2 | 981µs | # spent 503µs (26+478) within Compress::Raw::Zlib::BEGIN@113 which was called:
# once (26µs+478µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 113 # spent 503µs making 1 call to Compress::Raw::Zlib::BEGIN@113
# spent 478µs making 1 call to strict::unimport |
| 114 | 30 | 187µs | # spent 113µs within Compress::Raw::Zlib::__ANON__[/usr/libdata/perl5/amd64-openbsd/Compress/Raw/Zlib.pm:114] which was called 22 times, avg 5µs/call:
# 8 times (21µs+0s) by IO::Uncompress::Adapter::Inflate::mkUncompObject or IO::Uncompress::Adapter::Inflate::uncompr or IO::Uncompress::RawInflate::BEGIN@8 at line 115, avg 3µs/call
# 3 times (16µs+0s) by IO::Uncompress::Adapter::Inflate::uncompr at line 66 of IO/Uncompress/Adapter/Inflate.pm, avg 5µs/call
# 2 times (34µs+0s) by IO::Uncompress::Adapter::Inflate::mkUncompObject at line 34 of IO/Uncompress/Adapter/Inflate.pm, avg 17µs/call
# 2 times (5µs+0s) by Compress::Raw::Zlib::Inflate::new at line 465, avg 2µs/call
# 2 times (4µs+0s) by IO::Uncompress::Adapter::Inflate::uncompr at line 73 of IO/Uncompress/Adapter/Inflate.pm, avg 2µs/call
# 2 times (4µs+0s) by IO::Uncompress::Adapter::Inflate::uncompr at line 74 of IO/Uncompress/Adapter/Inflate.pm, avg 2µs/call
# once (21µs+0s) by IO::Uncompress::Adapter::Inflate::mkUncompObject at line 42 of IO/Uncompress/Adapter/Inflate.pm
# once (6µs+0s) by IO::Uncompress::Adapter::Inflate::uncompr at line 72 of IO/Uncompress/Adapter/Inflate.pm
# once (2µs+0s) by IO::Uncompress::RawInflate::BEGIN@8 at line 434 | ||
| 115 | 8 | 75µs | 8 | 21µs | goto &{$AUTOLOAD}; # spent 21µs making 8 calls to Compress::Raw::Zlib::__ANON__[Compress/Raw/Zlib.pm:114], avg 3µs/call |
| 116 | } | ||||
| 117 | |||||
| 118 | 2 | 52µs | 2 | 218µs | # spent 117µs (16+101) within Compress::Raw::Zlib::BEGIN@118 which was called:
# once (16µs+101µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 118 # spent 117µs making 1 call to Compress::Raw::Zlib::BEGIN@118
# spent 101µs making 1 call to constant::import |
| 119 | 2 | 68µs | 2 | 196µs | # spent 105µs (15+91) within Compress::Raw::Zlib::BEGIN@119 which was called:
# once (15µs+91µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 119 # spent 105µs making 1 call to Compress::Raw::Zlib::BEGIN@119
# spent 91µs making 1 call to constant::import |
| 120 | 2 | 60µs | 2 | 209µs | # spent 118µs (27+91) within Compress::Raw::Zlib::BEGIN@120 which was called:
# once (27µs+91µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 120 # spent 118µs making 1 call to Compress::Raw::Zlib::BEGIN@120
# spent 91µs making 1 call to constant::import |
| 121 | 2 | 80µs | 2 | 218µs | # spent 119µs (20+99) within Compress::Raw::Zlib::BEGIN@121 which was called:
# once (20µs+99µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 121 # spent 119µs making 1 call to Compress::Raw::Zlib::BEGIN@121
# spent 99µs making 1 call to constant::import |
| 122 | 2 | 178µs | 2 | 165µs | # spent 90µs (15+75) within Compress::Raw::Zlib::BEGIN@122 which was called:
# once (15µs+75µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 122 # spent 90µs making 1 call to Compress::Raw::Zlib::BEGIN@122
# spent 75µs making 1 call to constant::import |
| 123 | |||||
| 124 | eval { | ||||
| 125 | 1 | 2µs | require XSLoader; | ||
| 126 | 1 | 806µs | 1 | 785µs | XSLoader::load('Compress::Raw::Zlib', $XS_VERSION); # spent 785µs making 1 call to XSLoader::load |
| 127 | 1 | 2µs | 1; | ||
| 128 | } | ||||
| 129 | 1 | 2µs | or do { | ||
| 130 | require DynaLoader; | ||||
| 131 | local @ISA = qw(DynaLoader); | ||||
| 132 | bootstrap Compress::Raw::Zlib $XS_VERSION ; | ||||
| 133 | }; | ||||
| 134 | |||||
| 135 | |||||
| 136 | 2 | 54µs | 2 | 196µs | # spent 105µs (15+90) within Compress::Raw::Zlib::BEGIN@136 which was called:
# once (15µs+90µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 136 # spent 105µs making 1 call to Compress::Raw::Zlib::BEGIN@136
# spent 90µs making 1 call to constant::import |
| 137 | 2 | 71µs | 2 | 167µs | # spent 91µs (15+76) within Compress::Raw::Zlib::BEGIN@137 which was called:
# once (15µs+76µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 137 # spent 91µs making 1 call to Compress::Raw::Zlib::BEGIN@137
# spent 76µs making 1 call to constant::import |
| 138 | 2 | 49µs | 2 | 249µs | # spent 141µs (34+107) within Compress::Raw::Zlib::BEGIN@138 which was called:
# once (34µs+107µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 138 # spent 141µs making 1 call to Compress::Raw::Zlib::BEGIN@138
# spent 107µs making 1 call to constant::import |
| 139 | 2 | 62µs | 2 | 188µs | # spent 101µs (14+87) within Compress::Raw::Zlib::BEGIN@139 which was called:
# once (14µs+87µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 139 # spent 101µs making 1 call to Compress::Raw::Zlib::BEGIN@139
# spent 87µs making 1 call to constant::import |
| 140 | #use constant Parse_string => 0x10; | ||||
| 141 | #use constant Parse_custom => 0x12; | ||||
| 142 | |||||
| 143 | #use constant Parse_store_ref => 0x100 ; | ||||
| 144 | |||||
| 145 | 2 | 45µs | 2 | 166µs | # spent 93µs (19+74) within Compress::Raw::Zlib::BEGIN@145 which was called:
# once (19µs+74µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 145 # spent 93µs making 1 call to Compress::Raw::Zlib::BEGIN@145
# spent 74µs making 1 call to constant::import |
| 146 | 2 | 74µs | 2 | 194µs | # spent 108µs (21+86) within Compress::Raw::Zlib::BEGIN@146 which was called:
# once (21µs+86µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 146 # spent 108µs making 1 call to Compress::Raw::Zlib::BEGIN@146
# spent 86µs making 1 call to constant::import |
| 147 | 2 | 44µs | 2 | 161µs | # spent 87µs (14+74) within Compress::Raw::Zlib::BEGIN@147 which was called:
# once (14µs+74µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 147 # spent 87µs making 1 call to Compress::Raw::Zlib::BEGIN@147
# spent 74µs making 1 call to constant::import |
| 148 | 2 | 43µs | 2 | 155µs | # spent 84µs (12+71) within Compress::Raw::Zlib::BEGIN@148 which was called:
# once (12µs+71µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 148 # spent 84µs making 1 call to Compress::Raw::Zlib::BEGIN@148
# spent 71µs making 1 call to constant::import |
| 149 | 2 | 63µs | 2 | 157µs | # spent 86µs (14+72) within Compress::Raw::Zlib::BEGIN@149 which was called:
# once (14µs+72µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 149 # spent 86µs making 1 call to Compress::Raw::Zlib::BEGIN@149
# spent 72µs making 1 call to constant::import |
| 150 | 2 | 3.93ms | 2 | 222µs | # spent 127µs (31+96) within Compress::Raw::Zlib::BEGIN@150 which was called:
# once (31µs+96µs) by IO::Uncompress::RawInflate::BEGIN@8 at line 150 # spent 127µs making 1 call to Compress::Raw::Zlib::BEGIN@150
# spent 96µs making 1 call to constant::import |
| 151 | |||||
| - - | |||||
| 154 | sub ParseParameters | ||||
| 155 | # spent 1.20ms (181µs+1.02) within Compress::Raw::Zlib::ParseParameters which was called 2 times, avg 600µs/call:
# 2 times (181µs+1.02ms) by Compress::Raw::Zlib::Inflate::new at line 450, avg 600µs/call | ||||
| 156 | 2 | 2µs | my $level = shift || 0 ; | ||
| 157 | |||||
| 158 | 2 | 43µs | my $sub = (caller($level + 1))[3] ; | ||
| 159 | #local $Carp::CarpLevel = 1 ; | ||||
| 160 | 2 | 20µs | 2 | 24µs | my $p = new Compress::Raw::Zlib::Parameters() ; # spent 24µs making 2 calls to Compress::Raw::Zlib::Parameters::new, avg 12µs/call |
| 161 | 2 | 10µs | 2 | 995µs | $p->parse(@_) # spent 995µs making 2 calls to Compress::Raw::Zlib::Parameters::parse, avg 498µs/call |
| 162 | or croak "$sub: $p->{Error}" ; | ||||
| 163 | |||||
| 164 | 2 | 10µs | return $p; | ||
| 165 | } | ||||
| 166 | |||||
| 167 | |||||
| 168 | sub Compress::Raw::Zlib::Parameters::new | ||||
| 169 | # spent 24µs within Compress::Raw::Zlib::Parameters::new which was called 2 times, avg 12µs/call:
# 2 times (24µs+0s) by Compress::Raw::Zlib::ParseParameters at line 160, avg 12µs/call | ||||
| 170 | 2 | 2µs | my $class = shift ; | ||
| 171 | |||||
| 172 | 2 | 15µs | my $obj = { Error => '', | ||
| 173 | Got => {}, | ||||
| 174 | } ; | ||||
| 175 | |||||
| 176 | #return bless $obj, ref($class) || $class || __PACKAGE__ ; | ||||
| 177 | 2 | 45µs | return bless $obj, 'Compress::Raw::Zlib::Parameters' ; | ||
| 178 | } | ||||
| 179 | |||||
| 180 | sub Compress::Raw::Zlib::Parameters::setError | ||||
| 181 | { | ||||
| 182 | my $self = shift ; | ||||
| 183 | my $error = shift ; | ||||
| 184 | my $retval = @_ ? shift : undef ; | ||||
| 185 | |||||
| 186 | $self->{Error} = $error ; | ||||
| 187 | return $retval; | ||||
| 188 | } | ||||
| 189 | |||||
| 190 | #sub getError | ||||
| 191 | #{ | ||||
| 192 | # my $self = shift ; | ||||
| 193 | # return $self->{Error} ; | ||||
| 194 | #} | ||||
| 195 | |||||
| 196 | sub Compress::Raw::Zlib::Parameters::parse | ||||
| 197 | # spent 995µs (602+394) within Compress::Raw::Zlib::Parameters::parse which was called 2 times, avg 498µs/call:
# 2 times (602µs+394µs) by Compress::Raw::Zlib::ParseParameters at line 161, avg 498µs/call | ||||
| 198 | 2 | 2µs | my $self = shift ; | ||
| 199 | |||||
| 200 | 2 | 2µs | my $default = shift ; | ||
| 201 | |||||
| 202 | 2 | 5µs | my $got = $self->{Got} ; | ||
| 203 | 2 | 4µs | my $firstTime = keys %{ $got } == 0 ; | ||
| 204 | |||||
| 205 | 2 | 2µs | my (@Bad) ; | ||
| 206 | 2 | 3µs | my @entered = () ; | ||
| 207 | |||||
| 208 | # Allow the options to be passed as a hash reference or | ||||
| 209 | # as the complete hash. | ||||
| 210 | 2 | 5µs | if (@_ == 0) { | ||
| 211 | @entered = () ; | ||||
| 212 | } | ||||
| 213 | elsif (@_ == 1) { | ||||
| 214 | my $href = $_[0] ; | ||||
| 215 | return $self->setError("Expected even number of parameters, got 1") | ||||
| 216 | if ! defined $href or ! ref $href or ref $href ne "HASH" ; | ||||
| 217 | |||||
| 218 | foreach my $key (keys %$href) { | ||||
| 219 | push @entered, $key ; | ||||
| 220 | push @entered, \$href->{$key} ; | ||||
| 221 | } | ||||
| 222 | } | ||||
| 223 | else { | ||||
| 224 | 2 | 2µs | my $count = @_; | ||
| 225 | 2 | 2µs | return $self->setError("Expected even number of parameters, got $count") | ||
| 226 | if $count % 2 != 0 ; | ||||
| 227 | |||||
| 228 | 2 | 22µs | for my $i (0.. $count / 2 - 1) { | ||
| 229 | 10 | 12µs | push @entered, $_[2* $i] ; | ||
| 230 | 10 | 17µs | push @entered, \$_[2* $i+1] ; | ||
| 231 | } | ||||
| 232 | } | ||||
| 233 | |||||
| 234 | |||||
| 235 | 2 | 74µs | while (my ($key, $v) = each %$default) | ||
| 236 | { | ||||
| 237 | 16 | 13µs | croak "need 4 params [@$v]" | ||
| 238 | if @$v != 4 ; | ||||
| 239 | |||||
| 240 | 16 | 25µs | my ($first_only, $sticky, $type, $value) = @$v ; | ||
| 241 | 16 | 11µs | my $x ; | ||
| 242 | 16 | 75µs | 16 | 191µs | $self->_checkType($key, \$value, $type, 0, \$x) # spent 191µs making 16 calls to Compress::Raw::Zlib::Parameters::_checkType, avg 12µs/call |
| 243 | or return undef ; | ||||
| 244 | |||||
| 245 | 16 | 18µs | $key = lc $key; | ||
| 246 | |||||
| 247 | 16 | 74µs | if ($firstTime || ! $sticky) { | ||
| 248 | $got->{$key} = [0, $type, $value, $x, $first_only, $sticky] ; | ||||
| 249 | } | ||||
| 250 | |||||
| 251 | 16 | 18µs | $got->{$key}[OFF_PARSED] = 0 ; | ||
| 252 | } | ||||
| 253 | |||||
| 254 | 2 | 7µs | for my $i (0.. @entered / 2 - 1) { | ||
| 255 | 10 | 10µs | my $key = $entered[2* $i] ; | ||
| 256 | 10 | 9µs | my $value = $entered[2* $i+1] ; | ||
| 257 | |||||
| 258 | #print "Key [$key] Value [$value]" ; | ||||
| 259 | #print defined $$value ? "[$$value]\n" : "[undef]\n"; | ||||
| 260 | |||||
| 261 | 10 | 74µs | 10 | 27µs | $key =~ s/^-// ; # spent 27µs making 10 calls to Compress::Raw::Zlib::CORE:subst, avg 3µs/call |
| 262 | 10 | 11µs | my $canonkey = lc $key; | ||
| 263 | |||||
| 264 | 10 | 35µs | if ($got->{$canonkey} && ($firstTime || | ||
| 265 | ! $got->{$canonkey}[OFF_FIRST_ONLY] )) | ||||
| 266 | { | ||||
| 267 | 10 | 10µs | my $type = $got->{$canonkey}[OFF_TYPE] ; | ||
| 268 | 10 | 6µs | my $s ; | ||
| 269 | 10 | 29µs | 10 | 176µs | $self->_checkType($key, $value, $type, 1, \$s) # spent 176µs making 10 calls to Compress::Raw::Zlib::Parameters::_checkType, avg 18µs/call |
| 270 | or return undef ; | ||||
| 271 | #$value = $$value unless $type & Parse_store_ref ; | ||||
| 272 | 10 | 7µs | $value = $$value ; | ||
| 273 | 10 | 19µs | $got->{$canonkey} = [1, $type, $value, $s] ; | ||
| 274 | } | ||||
| 275 | else | ||||
| 276 | { push (@Bad, $key) } | ||||
| 277 | } | ||||
| 278 | |||||
| 279 | 2 | 2µs | if (@Bad) { | ||
| 280 | my ($bad) = join(", ", @Bad) ; | ||||
| 281 | return $self->setError("unknown key value(s) @Bad") ; | ||||
| 282 | } | ||||
| 283 | |||||
| 284 | 2 | 10µs | return 1; | ||
| 285 | } | ||||
| 286 | |||||
| 287 | sub Compress::Raw::Zlib::Parameters::_checkType | ||||
| 288 | { | ||||
| 289 | 26 | 20µs | my $self = shift ; | ||
| 290 | |||||
| 291 | 26 | 20µs | my $key = shift ; | ||
| 292 | 26 | 20µs | my $value = shift ; | ||
| 293 | 26 | 18µs | my $type = shift ; | ||
| 294 | 26 | 18µs | my $validate = shift ; | ||
| 295 | 26 | 18µs | my $output = shift; | ||
| 296 | |||||
| 297 | #local $Carp::CarpLevel = $level ; | ||||
| 298 | #print "PARSE $type $key $value $validate $sub\n" ; | ||||
| 299 | # if ( $type & Parse_store_ref) | ||||
| 300 | # { | ||||
| 301 | # #$value = $$value | ||||
| 302 | # # if ref ${ $value } ; | ||||
| 303 | # | ||||
| 304 | # $$output = $value ; | ||||
| 305 | # return 1; | ||||
| 306 | # } | ||||
| 307 | |||||
| 308 | 26 | 20µs | $value = $$value ; | ||
| 309 | |||||
| 310 | 26 | 27µs | if ($type & Parse_any) | ||
| 311 | { | ||||
| 312 | 2 | 2µs | $$output = $value ; | ||
| 313 | 2 | 10µs | return 1; | ||
| 314 | } | ||||
| 315 | elsif ($type & Parse_unsigned) | ||||
| 316 | { | ||||
| 317 | 2 | 2µs | return $self->setError("Parameter '$key' must be an unsigned int, got 'undef'") | ||
| 318 | if $validate && ! defined $value ; | ||||
| 319 | 2 | 2µs | return $self->setError("Parameter '$key' must be an unsigned int, got '$value'") | ||
| 320 | if $validate && $value !~ /^\d+$/; | ||||
| 321 | |||||
| 322 | 2 | 2µs | $$output = defined $value ? $value : 0 ; | ||
| 323 | 2 | 7µs | return 1; | ||
| 324 | } | ||||
| 325 | elsif ($type & Parse_signed) | ||||
| 326 | { | ||||
| 327 | 4 | 4µs | return $self->setError("Parameter '$key' must be a signed int, got 'undef'") | ||
| 328 | if $validate && ! defined $value ; | ||||
| 329 | 4 | 14µs | 2 | 5µs | return $self->setError("Parameter '$key' must be a signed int, got '$value'") # spent 5µs making 2 calls to Compress::Raw::Zlib::CORE:match, avg 2µs/call |
| 330 | if $validate && $value !~ /^-?\d+$/; | ||||
| 331 | |||||
| 332 | 4 | 4µs | $$output = defined $value ? $value : 0 ; | ||
| 333 | 4 | 13µs | return 1 ; | ||
| 334 | } | ||||
| 335 | elsif ($type & Parse_boolean) | ||||
| 336 | { | ||||
| 337 | 18 | 78µs | 8 | 42µs | return $self->setError("Parameter '$key' must be an int, got '$value'") # spent 42µs making 8 calls to Compress::Raw::Zlib::CORE:match, avg 5µs/call |
| 338 | if $validate && defined $value && $value !~ /^\d*$/; | ||||
| 339 | 18 | 16µs | $$output = defined $value ? $value != 0 : 0 ; | ||
| 340 | 18 | 69µs | return 1; | ||
| 341 | } | ||||
| 342 | # elsif ($type & Parse_string) | ||||
| 343 | # { | ||||
| 344 | # $$output = defined $value ? $value : "" ; | ||||
| 345 | # return 1; | ||||
| 346 | # } | ||||
| 347 | |||||
| 348 | $$output = $value ; | ||||
| 349 | return 1; | ||||
| 350 | } | ||||
| 351 | |||||
| - - | |||||
| 354 | sub Compress::Raw::Zlib::Parameters::parsed | ||||
| 355 | { | ||||
| 356 | my $self = shift ; | ||||
| 357 | my $name = shift ; | ||||
| 358 | |||||
| 359 | return $self->{Got}{lc $name}[OFF_PARSED] ; | ||||
| 360 | } | ||||
| 361 | |||||
| 362 | sub Compress::Raw::Zlib::Parameters::value | ||||
| 363 | # spent 120µs within Compress::Raw::Zlib::Parameters::value which was called 18 times, avg 7µs/call:
# 4 times (18µs+0s) by Compress::Raw::Zlib::Inflate::new at line 468, avg 5µs/call
# 2 times (34µs+0s) by Compress::Raw::Zlib::Inflate::new at line 452, avg 17µs/call
# 2 times (18µs+0s) by Compress::Raw::Zlib::Inflate::new at line 457, avg 9µs/call
# 2 times (10µs+0s) by Compress::Raw::Zlib::Inflate::new at line 458, avg 5µs/call
# 2 times (10µs+0s) by Compress::Raw::Zlib::Inflate::new at line 460, avg 5µs/call
# 2 times (10µs+0s) by Compress::Raw::Zlib::Inflate::new at line 464, avg 5µs/call
# 2 times (10µs+0s) by Compress::Raw::Zlib::Inflate::new at line 461, avg 5µs/call
# 2 times (10µs+0s) by Compress::Raw::Zlib::Inflate::new at line 459, avg 5µs/call | ||||
| 364 | 18 | 14µs | my $self = shift ; | ||
| 365 | 18 | 23µs | my $name = shift ; | ||
| 366 | |||||
| 367 | 18 | 14µs | if (@_) | ||
| 368 | { | ||||
| 369 | $self->{Got}{lc $name}[OFF_PARSED] = 1; | ||||
| 370 | $self->{Got}{lc $name}[OFF_DEFAULT] = $_[0] ; | ||||
| 371 | $self->{Got}{lc $name}[OFF_FIXED] = $_[0] ; | ||||
| 372 | } | ||||
| 373 | |||||
| 374 | 18 | 80µs | return $self->{Got}{lc $name}[OFF_FIXED] ; | ||
| 375 | } | ||||
| 376 | |||||
| 377 | 1 | 52µs | 5 | 194µs | our $OPTIONS_deflate = # spent 194µs making 5 calls to Compress::Raw::Zlib::AUTOLOAD, avg 39µs/call |
| 378 | { | ||||
| 379 | 'AppendOutput' => [1, 1, Parse_boolean, 0], | ||||
| 380 | 'CRC32' => [1, 1, Parse_boolean, 0], | ||||
| 381 | 'ADLER32' => [1, 1, Parse_boolean, 0], | ||||
| 382 | 'Bufsize' => [1, 1, Parse_unsigned, 4096], | ||||
| 383 | |||||
| 384 | 'Level' => [1, 1, Parse_signed, Z_DEFAULT_COMPRESSION()], | ||||
| 385 | 'Method' => [1, 1, Parse_unsigned, Z_DEFLATED()], | ||||
| 386 | 'WindowBits' => [1, 1, Parse_signed, MAX_WBITS()], | ||||
| 387 | 'MemLevel' => [1, 1, Parse_unsigned, MAX_MEM_LEVEL()], | ||||
| 388 | 'Strategy' => [1, 1, Parse_unsigned, Z_DEFAULT_STRATEGY()], | ||||
| 389 | 'Dictionary' => [1, 1, Parse_any, ""], | ||||
| 390 | }; | ||||
| 391 | |||||
| 392 | sub Compress::Raw::Zlib::Deflate::new | ||||
| 393 | { | ||||
| 394 | my $pkg = shift ; | ||||
| 395 | my ($got) = ParseParameters(0, $OPTIONS_deflate, @_); | ||||
| 396 | |||||
| 397 | croak "Compress::Raw::Zlib::Deflate::new: Bufsize must be >= 1, you specified " . | ||||
| 398 | $got->value('Bufsize') | ||||
| 399 | unless $got->value('Bufsize') >= 1; | ||||
| 400 | |||||
| 401 | my $flags = 0 ; | ||||
| 402 | $flags |= FLAG_APPEND if $got->value('AppendOutput') ; | ||||
| 403 | $flags |= FLAG_CRC if $got->value('CRC32') ; | ||||
| 404 | $flags |= FLAG_ADLER if $got->value('ADLER32') ; | ||||
| 405 | |||||
| 406 | my $windowBits = $got->value('WindowBits'); | ||||
| 407 | $windowBits += MAX_WBITS() | ||||
| 408 | if ($windowBits & MAX_WBITS()) == 0 ; | ||||
| 409 | |||||
| 410 | _deflateInit($flags, | ||||
| 411 | $got->value('Level'), | ||||
| 412 | $got->value('Method'), | ||||
| 413 | $windowBits, | ||||
| 414 | $got->value('MemLevel'), | ||||
| 415 | $got->value('Strategy'), | ||||
| 416 | $got->value('Bufsize'), | ||||
| 417 | $got->value('Dictionary')) ; | ||||
| 418 | |||||
| 419 | } | ||||
| 420 | |||||
| 421 | sub Compress::Raw::Zlib::deflateStream::STORABLE_freeze | ||||
| 422 | { | ||||
| 423 | my $type = ref shift; | ||||
| 424 | croak "Cannot freeze $type object\n"; | ||||
| 425 | } | ||||
| 426 | |||||
| 427 | sub Compress::Raw::Zlib::deflateStream::STORABLE_thaw | ||||
| 428 | { | ||||
| 429 | my $type = ref shift; | ||||
| 430 | croak "Cannot thaw $type object\n"; | ||||
| 431 | } | ||||
| 432 | |||||
| 433 | |||||
| 434 | 1 | 13µs | 1 | 2µs | our $OPTIONS_inflate = # spent 2µs making 1 call to Compress::Raw::Zlib::__ANON__[Compress/Raw/Zlib.pm:114] |
| 435 | { | ||||
| 436 | 'AppendOutput' => [1, 1, Parse_boolean, 0], | ||||
| 437 | 'LimitOutput' => [1, 1, Parse_boolean, 0], | ||||
| 438 | 'CRC32' => [1, 1, Parse_boolean, 0], | ||||
| 439 | 'ADLER32' => [1, 1, Parse_boolean, 0], | ||||
| 440 | 'ConsumeInput' => [1, 1, Parse_boolean, 1], | ||||
| 441 | 'Bufsize' => [1, 1, Parse_unsigned, 4096], | ||||
| 442 | |||||
| 443 | 'WindowBits' => [1, 1, Parse_signed, MAX_WBITS()], | ||||
| 444 | 'Dictionary' => [1, 1, Parse_any, ""], | ||||
| 445 | } ; | ||||
| 446 | |||||
| 447 | sub Compress::Raw::Zlib::Inflate::new | ||||
| 448 | # spent 1.67ms (190µs+1.48) within Compress::Raw::Zlib::Inflate::new which was called 2 times, avg 837µs/call:
# 2 times (190µs+1.48ms) by IO::Uncompress::Adapter::Inflate::mkUncompObject at line 34 of IO/Uncompress/Adapter/Inflate.pm, avg 837µs/call | ||||
| 449 | 2 | 12µs | my $pkg = shift ; | ||
| 450 | 2 | 68µs | 2 | 1.20ms | my ($got) = ParseParameters(0, $OPTIONS_inflate, @_); # spent 1.20ms making 2 calls to Compress::Raw::Zlib::ParseParameters, avg 600µs/call |
| 451 | |||||
| 452 | 2 | 28µs | 2 | 34µs | croak "Compress::Raw::Zlib::Inflate::new: Bufsize must be >= 1, you specified " . # spent 34µs making 2 calls to Compress::Raw::Zlib::Parameters::value, avg 17µs/call |
| 453 | $got->value('Bufsize') | ||||
| 454 | unless $got->value('Bufsize') >= 1; | ||||
| 455 | |||||
| 456 | 2 | 2µs | my $flags = 0 ; | ||
| 457 | 2 | 7µs | 2 | 18µs | $flags |= FLAG_APPEND if $got->value('AppendOutput') ; # spent 18µs making 2 calls to Compress::Raw::Zlib::Parameters::value, avg 9µs/call |
| 458 | 2 | 7µs | 2 | 10µs | $flags |= FLAG_CRC if $got->value('CRC32') ; # spent 10µs making 2 calls to Compress::Raw::Zlib::Parameters::value, avg 5µs/call |
| 459 | 2 | 7µs | 2 | 10µs | $flags |= FLAG_ADLER if $got->value('ADLER32') ; # spent 10µs making 2 calls to Compress::Raw::Zlib::Parameters::value, avg 5µs/call |
| 460 | 2 | 7µs | 2 | 10µs | $flags |= FLAG_CONSUME_INPUT if $got->value('ConsumeInput') ; # spent 10µs making 2 calls to Compress::Raw::Zlib::Parameters::value, avg 5µs/call |
| 461 | 2 | 7µs | 2 | 10µs | $flags |= FLAG_LIMIT_OUTPUT if $got->value('LimitOutput') ; # spent 10µs making 2 calls to Compress::Raw::Zlib::Parameters::value, avg 5µs/call |
| 462 | |||||
| 463 | |||||
| 464 | 2 | 7µs | 2 | 10µs | my $windowBits = $got->value('WindowBits'); # spent 10µs making 2 calls to Compress::Raw::Zlib::Parameters::value, avg 5µs/call |
| 465 | 2 | 7µs | 2 | 5µs | $windowBits += MAX_WBITS() # spent 5µs making 2 calls to Compress::Raw::Zlib::__ANON__[Compress/Raw/Zlib.pm:114], avg 2µs/call |
| 466 | if ($windowBits & MAX_WBITS()) == 0 ; | ||||
| 467 | |||||
| 468 | 2 | 211µs | 6 | 178µs | _inflateInit($flags, $windowBits, $got->value('Bufsize'), # spent 160µs making 2 calls to Compress::Raw::Zlib::_inflateInit, avg 80µs/call
# spent 18µs making 4 calls to Compress::Raw::Zlib::Parameters::value, avg 5µs/call |
| 469 | $got->value('Dictionary')) ; | ||||
| 470 | } | ||||
| 471 | |||||
| 472 | sub Compress::Raw::Zlib::inflateStream::STORABLE_freeze | ||||
| 473 | { | ||||
| 474 | my $type = ref shift; | ||||
| 475 | croak "Cannot freeze $type object\n"; | ||||
| 476 | } | ||||
| 477 | |||||
| 478 | sub Compress::Raw::Zlib::inflateStream::STORABLE_thaw | ||||
| 479 | { | ||||
| 480 | my $type = ref shift; | ||||
| 481 | croak "Cannot thaw $type object\n"; | ||||
| 482 | } | ||||
| 483 | |||||
| 484 | sub Compress::Raw::Zlib::InflateScan::new | ||||
| 485 | { | ||||
| 486 | my $pkg = shift ; | ||||
| 487 | my ($got) = ParseParameters(0, | ||||
| 488 | { | ||||
| 489 | 'CRC32' => [1, 1, Parse_boolean, 0], | ||||
| 490 | 'ADLER32' => [1, 1, Parse_boolean, 0], | ||||
| 491 | 'Bufsize' => [1, 1, Parse_unsigned, 4096], | ||||
| 492 | |||||
| 493 | 'WindowBits' => [1, 1, Parse_signed, -MAX_WBITS()], | ||||
| 494 | 'Dictionary' => [1, 1, Parse_any, ""], | ||||
| 495 | }, @_) ; | ||||
| 496 | |||||
| 497 | |||||
| 498 | croak "Compress::Raw::Zlib::InflateScan::new: Bufsize must be >= 1, you specified " . | ||||
| 499 | $got->value('Bufsize') | ||||
| 500 | unless $got->value('Bufsize') >= 1; | ||||
| 501 | |||||
| 502 | my $flags = 0 ; | ||||
| 503 | #$flags |= FLAG_APPEND if $got->value('AppendOutput') ; | ||||
| 504 | $flags |= FLAG_CRC if $got->value('CRC32') ; | ||||
| 505 | $flags |= FLAG_ADLER if $got->value('ADLER32') ; | ||||
| 506 | #$flags |= FLAG_CONSUME_INPUT if $got->value('ConsumeInput') ; | ||||
| 507 | |||||
| 508 | _inflateScanInit($flags, $got->value('WindowBits'), $got->value('Bufsize'), | ||||
| 509 | '') ; | ||||
| 510 | } | ||||
| 511 | |||||
| 512 | sub Compress::Raw::Zlib::inflateScanStream::createDeflateStream | ||||
| 513 | { | ||||
| 514 | my $pkg = shift ; | ||||
| 515 | my ($got) = ParseParameters(0, | ||||
| 516 | { | ||||
| 517 | 'AppendOutput' => [1, 1, Parse_boolean, 0], | ||||
| 518 | 'CRC32' => [1, 1, Parse_boolean, 0], | ||||
| 519 | 'ADLER32' => [1, 1, Parse_boolean, 0], | ||||
| 520 | 'Bufsize' => [1, 1, Parse_unsigned, 4096], | ||||
| 521 | |||||
| 522 | 'Level' => [1, 1, Parse_signed, Z_DEFAULT_COMPRESSION()], | ||||
| 523 | 'Method' => [1, 1, Parse_unsigned, Z_DEFLATED()], | ||||
| 524 | 'WindowBits' => [1, 1, Parse_signed, - MAX_WBITS()], | ||||
| 525 | 'MemLevel' => [1, 1, Parse_unsigned, MAX_MEM_LEVEL()], | ||||
| 526 | 'Strategy' => [1, 1, Parse_unsigned, Z_DEFAULT_STRATEGY()], | ||||
| 527 | }, @_) ; | ||||
| 528 | |||||
| 529 | croak "Compress::Raw::Zlib::InflateScan::createDeflateStream: Bufsize must be >= 1, you specified " . | ||||
| 530 | $got->value('Bufsize') | ||||
| 531 | unless $got->value('Bufsize') >= 1; | ||||
| 532 | |||||
| 533 | my $flags = 0 ; | ||||
| 534 | $flags |= FLAG_APPEND if $got->value('AppendOutput') ; | ||||
| 535 | $flags |= FLAG_CRC if $got->value('CRC32') ; | ||||
| 536 | $flags |= FLAG_ADLER if $got->value('ADLER32') ; | ||||
| 537 | |||||
| 538 | $pkg->_createDeflateStream($flags, | ||||
| 539 | $got->value('Level'), | ||||
| 540 | $got->value('Method'), | ||||
| 541 | $got->value('WindowBits'), | ||||
| 542 | $got->value('MemLevel'), | ||||
| 543 | $got->value('Strategy'), | ||||
| 544 | $got->value('Bufsize'), | ||||
| 545 | ) ; | ||||
| 546 | |||||
| 547 | } | ||||
| 548 | |||||
| 549 | sub Compress::Raw::Zlib::inflateScanStream::inflate | ||||
| 550 | { | ||||
| 551 | my $self = shift ; | ||||
| 552 | my $buffer = $_[1]; | ||||
| 553 | my $eof = $_[2]; | ||||
| 554 | |||||
| 555 | my $status = $self->scan(@_); | ||||
| 556 | |||||
| 557 | if ($status == Z_OK() && $_[2]) { | ||||
| 558 | my $byte = ' '; | ||||
| 559 | |||||
| 560 | $status = $self->scan(\$byte, $_[1]) ; | ||||
| 561 | } | ||||
| 562 | |||||
| 563 | return $status ; | ||||
| 564 | } | ||||
| 565 | |||||
| 566 | sub Compress::Raw::Zlib::deflateStream::deflateParams | ||||
| 567 | { | ||||
| 568 | my $self = shift ; | ||||
| 569 | my ($got) = ParseParameters(0, { | ||||
| 570 | 'Level' => [1, 1, Parse_signed, undef], | ||||
| 571 | 'Strategy' => [1, 1, Parse_unsigned, undef], | ||||
| 572 | 'Bufsize' => [1, 1, Parse_unsigned, undef], | ||||
| 573 | }, | ||||
| 574 | @_) ; | ||||
| 575 | |||||
| 576 | croak "Compress::Raw::Zlib::deflateParams needs Level and/or Strategy" | ||||
| 577 | unless $got->parsed('Level') + $got->parsed('Strategy') + | ||||
| 578 | $got->parsed('Bufsize'); | ||||
| 579 | |||||
| 580 | croak "Compress::Raw::Zlib::Inflate::deflateParams: Bufsize must be >= 1, you specified " . | ||||
| 581 | $got->value('Bufsize') | ||||
| 582 | if $got->parsed('Bufsize') && $got->value('Bufsize') <= 1; | ||||
| 583 | |||||
| 584 | my $flags = 0; | ||||
| 585 | $flags |= 1 if $got->parsed('Level') ; | ||||
| 586 | $flags |= 2 if $got->parsed('Strategy') ; | ||||
| 587 | $flags |= 4 if $got->parsed('Bufsize') ; | ||||
| 588 | |||||
| 589 | $self->_deflateParams($flags, $got->value('Level'), | ||||
| 590 | $got->value('Strategy'), $got->value('Bufsize')); | ||||
| 591 | |||||
| 592 | } | ||||
| 593 | |||||
| 594 | |||||
| 595 | 1 | 62µs | 1; | ||
| 596 | __END__ | ||||
sub Compress::Raw::Zlib::CORE:match; # opcode | |||||
sub Compress::Raw::Zlib::CORE:subst; # opcode | |||||
# spent 160µs within Compress::Raw::Zlib::_inflateInit which was called 2 times, avg 80µs/call:
# 2 times (160µs+0s) by Compress::Raw::Zlib::Inflate::new at line 468, avg 80µs/call | |||||
# spent 31µs within Compress::Raw::Zlib::constant which was called 8 times, avg 4µs/call:
# 8 times (31µs+0s) by Compress::Raw::Zlib::AUTOLOAD at line 111, avg 4µs/call | |||||
# spent 24µs within Compress::Raw::Zlib::inflateStream::DESTROY which was called 2 times, avg 12µs/call:
# 2 times (24µs+0s) by OpenBSD::PackageLocation::deref at line 285 of OpenBSD/PackageLocation.pm, avg 12µs/call | |||||
# spent 170µs within Compress::Raw::Zlib::inflateStream::inflate which was called 2 times, avg 85µs/call:
# 2 times (170µs+0s) by IO::Uncompress::Adapter::Inflate::uncompr at line 63 of IO/Uncompress/Adapter/Inflate.pm, avg 85µs/call |