@alienkarma/exceljs 4.4.0-fork.12 → 4.4.0-fork.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +22 -22
- package/README.md +3024 -3024
- package/README_zh.md +2878 -2878
- package/excel.js +13 -13
- package/index.d.ts +2040 -2040
- package/lib/csv/csv.js +191 -191
- package/lib/csv/line-buffer.js +74 -74
- package/lib/csv/stream-converter.js +135 -135
- package/lib/doc/anchor.js +91 -91
- package/lib/doc/cell.js +1124 -1124
- package/lib/doc/column.js +320 -320
- package/lib/doc/data/theme1.json +234 -234
- package/lib/doc/data-validations.js +19 -19
- package/lib/doc/defined-names.js +196 -196
- package/lib/doc/enums.js +48 -48
- package/lib/doc/image.js +59 -59
- package/lib/doc/modelcontainer.js +18 -18
- package/lib/doc/note.js +65 -65
- package/lib/doc/pivot-table.js +132 -132
- package/lib/doc/range.js +257 -257
- package/lib/doc/row.js +415 -415
- package/lib/doc/table.js +465 -465
- package/lib/doc/workbook.js +224 -224
- package/lib/doc/worksheet.js +949 -949
- package/lib/exceljs.bare.js +13 -13
- package/lib/exceljs.browser.js +36 -36
- package/lib/exceljs.nodejs.js +14 -14
- package/lib/stream/xlsx/hyperlink-reader.js +83 -83
- package/lib/stream/xlsx/sheet-comments-writer.js +121 -121
- package/lib/stream/xlsx/sheet-rels-writer.js +119 -119
- package/lib/stream/xlsx/workbook-reader.js +337 -337
- package/lib/stream/xlsx/workbook-writer.js +372 -366
- package/lib/stream/xlsx/worksheet-reader.js +374 -374
- package/lib/stream/xlsx/worksheet-writer.js +717 -717
- package/lib/utils/auto-drain.js +15 -15
- package/lib/utils/browser-buffer-decode.js +14 -14
- package/lib/utils/browser-buffer-encode.js +15 -15
- package/lib/utils/cell-matrix.js +165 -165
- package/lib/utils/col-cache.js +287 -287
- package/lib/utils/copy-style.js +43 -43
- package/lib/utils/encryptor.js +55 -55
- package/lib/utils/iterate-stream.js +48 -48
- package/lib/utils/parse-sax.js +30 -30
- package/lib/utils/shared-formula.js +44 -44
- package/lib/utils/shared-strings.js +35 -35
- package/lib/utils/stream-base64.js +72 -72
- package/lib/utils/stream-buf.js +364 -364
- package/lib/utils/string-buf.js +82 -82
- package/lib/utils/string-builder.js +35 -35
- package/lib/utils/stuttered-pipe.js +67 -67
- package/lib/utils/typed-stack.js +24 -24
- package/lib/utils/under-dash.js +184 -184
- package/lib/utils/utils.js +205 -205
- package/lib/utils/xml-stream.js +169 -169
- package/lib/utils/zip-stream.js +87 -87
- package/lib/xlsx/.rels +10 -10
- package/lib/xlsx/calcChain.xml +5 -5
- package/lib/xlsx/core.xml +6 -6
- package/lib/xlsx/defaultnumformats.js +153 -153
- package/lib/xlsx/rel-type.js +20 -20
- package/lib/xlsx/styles.xml +40 -40
- package/lib/xlsx/workbook.xml +16 -16
- package/lib/xlsx/xform/base-xform.js +145 -145
- package/lib/xlsx/xform/book/defined-name-xform.js +91 -91
- package/lib/xlsx/xform/book/sheet-xform.js +34 -34
- package/lib/xlsx/xform/book/workbook-calc-properties-xform.js +26 -26
- package/lib/xlsx/xform/book/workbook-pivot-cache-xform.js +29 -29
- package/lib/xlsx/xform/book/workbook-properties-xform.js +29 -29
- package/lib/xlsx/xform/book/workbook-view-xform.js +53 -53
- package/lib/xlsx/xform/book/workbook-xform.js +259 -259
- package/lib/xlsx/xform/comment/comment-xform.js +105 -105
- package/lib/xlsx/xform/comment/comments-xform.js +82 -82
- package/lib/xlsx/xform/comment/style/vml-position-xform.js +39 -39
- package/lib/xlsx/xform/comment/style/vml-protection-xform.js +36 -36
- package/lib/xlsx/xform/comment/vml-anchor-xform.js +60 -60
- package/lib/xlsx/xform/comment/vml-client-data-xform.js +95 -95
- package/lib/xlsx/xform/comment/vml-notes-xform.js +107 -107
- package/lib/xlsx/xform/comment/vml-shape-xform.js +95 -95
- package/lib/xlsx/xform/comment/vml-textbox-xform.js +64 -64
- package/lib/xlsx/xform/composite-xform.js +56 -56
- package/lib/xlsx/xform/core/app-heading-pairs-xform.js +32 -32
- package/lib/xlsx/xform/core/app-titles-of-parts-xform.js +28 -28
- package/lib/xlsx/xform/core/app-xform.js +100 -100
- package/lib/xlsx/xform/core/content-types-xform.js +135 -135
- package/lib/xlsx/xform/core/core-xform.js +136 -136
- package/lib/xlsx/xform/core/relationship-xform.js +25 -25
- package/lib/xlsx/xform/core/relationships-xform.js +73 -73
- package/lib/xlsx/xform/drawing/base-cell-anchor-xform.js +48 -48
- package/lib/xlsx/xform/drawing/blip-fill-xform.js +71 -71
- package/lib/xlsx/xform/drawing/blip-xform.js +42 -42
- package/lib/xlsx/xform/drawing/c-nv-pic-pr-xform.js +38 -38
- package/lib/xlsx/xform/drawing/c-nv-pr-xform.js +68 -68
- package/lib/xlsx/xform/drawing/cell-position-xform.js +77 -77
- package/lib/xlsx/xform/drawing/drawing-xform.js +109 -109
- package/lib/xlsx/xform/drawing/ext-lst-xform.js +43 -43
- package/lib/xlsx/xform/drawing/ext-xform.js +44 -44
- package/lib/xlsx/xform/drawing/hlink-click-xform.js +41 -41
- package/lib/xlsx/xform/drawing/nv-pic-pr-xform.js +65 -65
- package/lib/xlsx/xform/drawing/one-cell-anchor-xform.js +63 -63
- package/lib/xlsx/xform/drawing/pic-xform.js +77 -77
- package/lib/xlsx/xform/drawing/sp-pr.js +17 -17
- package/lib/xlsx/xform/drawing/two-cell-anchor-xform.js +62 -62
- package/lib/xlsx/xform/list-xform.js +95 -95
- package/lib/xlsx/xform/pivot-table/cache-field.js +43 -43
- package/lib/xlsx/xform/pivot-table/pivot-cache-definition-xform.js +77 -77
- package/lib/xlsx/xform/pivot-table/pivot-cache-records-xform.js +103 -103
- package/lib/xlsx/xform/pivot-table/pivot-table-xform.js +189 -189
- package/lib/xlsx/xform/sheet/auto-filter-xform.js +38 -38
- package/lib/xlsx/xform/sheet/cell-xform.js +498 -498
- package/lib/xlsx/xform/sheet/cf/cf-rule-xform.js +301 -301
- package/lib/xlsx/xform/sheet/cf/cfvo-xform.js +27 -27
- package/lib/xlsx/xform/sheet/cf/color-scale-xform.js +45 -45
- package/lib/xlsx/xform/sheet/cf/conditional-formatting-xform.js +48 -48
- package/lib/xlsx/xform/sheet/cf/conditional-formattings-xform.js +92 -92
- package/lib/xlsx/xform/sheet/cf/databar-xform.js +49 -49
- package/lib/xlsx/xform/sheet/cf/ext-lst-ref-xform.js +87 -87
- package/lib/xlsx/xform/sheet/cf/formula-xform.js +25 -25
- package/lib/xlsx/xform/sheet/cf/icon-set-xform.js +47 -47
- package/lib/xlsx/xform/sheet/cf-ext/cf-icon-ext-xform.js +27 -27
- package/lib/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.js +98 -98
- package/lib/xlsx/xform/sheet/cf-ext/cfvo-ext-xform.js +43 -43
- package/lib/xlsx/xform/sheet/cf-ext/conditional-formatting-ext-xform.js +62 -62
- package/lib/xlsx/xform/sheet/cf-ext/conditional-formattings-ext-xform.js +50 -50
- package/lib/xlsx/xform/sheet/cf-ext/databar-ext-xform.js +98 -98
- package/lib/xlsx/xform/sheet/cf-ext/f-ext-xform.js +25 -25
- package/lib/xlsx/xform/sheet/cf-ext/icon-set-ext-xform.js +73 -73
- package/lib/xlsx/xform/sheet/cf-ext/sqref-ext-xform.js +25 -25
- package/lib/xlsx/xform/sheet/col-xform.js +86 -86
- package/lib/xlsx/xform/sheet/data-validations-xform.js +257 -257
- package/lib/xlsx/xform/sheet/dimension-xform.js +29 -29
- package/lib/xlsx/xform/sheet/drawing-xform.js +33 -33
- package/lib/xlsx/xform/sheet/ext-lst-xform.js +86 -86
- package/lib/xlsx/xform/sheet/header-footer-xform.js +146 -146
- package/lib/xlsx/xform/sheet/hyperlink-xform.js +54 -54
- package/lib/xlsx/xform/sheet/merge-cell-xform.js +27 -27
- package/lib/xlsx/xform/sheet/merges.js +56 -56
- package/lib/xlsx/xform/sheet/outline-properties-xform.js +43 -43
- package/lib/xlsx/xform/sheet/page-breaks-xform.js +27 -27
- package/lib/xlsx/xform/sheet/page-margins-xform.js +49 -49
- package/lib/xlsx/xform/sheet/page-setup-properties-xform.js +35 -35
- package/lib/xlsx/xform/sheet/page-setup-xform.js +103 -103
- package/lib/xlsx/xform/sheet/picture-xform.js +33 -33
- package/lib/xlsx/xform/sheet/print-options-xform.js +49 -49
- package/lib/xlsx/xform/sheet/row-breaks-xform.js +39 -39
- package/lib/xlsx/xform/sheet/row-xform.js +142 -142
- package/lib/xlsx/xform/sheet/sheet-format-properties-xform.js +55 -55
- package/lib/xlsx/xform/sheet/sheet-properties-xform.js +90 -90
- package/lib/xlsx/xform/sheet/sheet-protection-xform.js +89 -89
- package/lib/xlsx/xform/sheet/sheet-view-xform.js +202 -202
- package/lib/xlsx/xform/sheet/table-part-xform.js +33 -33
- package/lib/xlsx/xform/sheet/worksheet-xform.js +548 -548
- package/lib/xlsx/xform/simple/boolean-xform.js +31 -31
- package/lib/xlsx/xform/simple/date-xform.js +66 -66
- package/lib/xlsx/xform/simple/float-xform.js +51 -51
- package/lib/xlsx/xform/simple/integer-xform.js +57 -57
- package/lib/xlsx/xform/simple/string-xform.js +51 -51
- package/lib/xlsx/xform/static-xform.js +64 -64
- package/lib/xlsx/xform/strings/phonetic-text-xform.js +98 -98
- package/lib/xlsx/xform/strings/rich-text-xform.js +101 -101
- package/lib/xlsx/xform/strings/shared-string-xform.js +102 -102
- package/lib/xlsx/xform/strings/shared-strings-xform.js +127 -127
- package/lib/xlsx/xform/strings/text-xform.js +44 -44
- package/lib/xlsx/xform/style/alignment-xform.js +172 -172
- package/lib/xlsx/xform/style/border-xform.js +207 -207
- package/lib/xlsx/xform/style/color-xform.js +63 -63
- package/lib/xlsx/xform/style/dxf-xform.js +111 -111
- package/lib/xlsx/xform/style/fill-xform.js +364 -364
- package/lib/xlsx/xform/style/font-xform.js +102 -102
- package/lib/xlsx/xform/style/numfmt-xform.js +63 -63
- package/lib/xlsx/xform/style/protection-xform.js +60 -60
- package/lib/xlsx/xform/style/style-xform.js +125 -125
- package/lib/xlsx/xform/style/styles-xform.js +527 -527
- package/lib/xlsx/xform/style/underline-xform.js +47 -47
- package/lib/xlsx/xform/table/auto-filter-xform.js +81 -81
- package/lib/xlsx/xform/table/custom-filter-xform.js +33 -33
- package/lib/xlsx/xform/table/filter-column-xform.js +96 -96
- package/lib/xlsx/xform/table/filter-xform.js +31 -31
- package/lib/xlsx/xform/table/table-column-xform.js +44 -44
- package/lib/xlsx/xform/table/table-style-info-xform.js +41 -41
- package/lib/xlsx/xform/table/table-xform.js +131 -131
- package/lib/xlsx/xlsx.js +774 -774
- package/lib/xlsx/xml/theme1.js +3 -3
- package/lib/xlsx/xml/theme1.xml +317 -317
- package/package.json +1 -1
- package/dist/LICENSE +0 -22
- package/dist/es5/csv/csv.js +0 -182
- package/dist/es5/csv/csv.js.map +0 -1
- package/dist/es5/csv/line-buffer.js +0 -68
- package/dist/es5/csv/line-buffer.js.map +0 -1
- package/dist/es5/csv/stream-converter.js +0 -110
- package/dist/es5/csv/stream-converter.js.map +0 -1
- package/dist/es5/doc/anchor.js +0 -73
- package/dist/es5/doc/anchor.js.map +0 -1
- package/dist/es5/doc/cell.js +0 -960
- package/dist/es5/doc/cell.js.map +0 -1
- package/dist/es5/doc/column.js +0 -274
- package/dist/es5/doc/column.js.map +0 -1
- package/dist/es5/doc/data-validations.js +0 -18
- package/dist/es5/doc/data-validations.js.map +0 -1
- package/dist/es5/doc/defined-names.js +0 -173
- package/dist/es5/doc/defined-names.js.map +0 -1
- package/dist/es5/doc/enums.js +0 -49
- package/dist/es5/doc/enums.js.map +0 -1
- package/dist/es5/doc/image.js +0 -69
- package/dist/es5/doc/image.js.map +0 -1
- package/dist/es5/doc/modelcontainer.js +0 -16
- package/dist/es5/doc/modelcontainer.js.map +0 -1
- package/dist/es5/doc/note.js +0 -64
- package/dist/es5/doc/note.js.map +0 -1
- package/dist/es5/doc/pivot-table.js +0 -137
- package/dist/es5/doc/pivot-table.js.map +0 -1
- package/dist/es5/doc/range.js +0 -229
- package/dist/es5/doc/range.js.map +0 -1
- package/dist/es5/doc/row.js +0 -382
- package/dist/es5/doc/row.js.map +0 -1
- package/dist/es5/doc/table.js +0 -441
- package/dist/es5/doc/table.js.map +0 -1
- package/dist/es5/doc/workbook.js +0 -205
- package/dist/es5/doc/workbook.js.map +0 -1
- package/dist/es5/doc/worksheet.js +0 -918
- package/dist/es5/doc/worksheet.js.map +0 -1
- package/dist/es5/exceljs.bare.js +0 -14
- package/dist/es5/exceljs.bare.js.map +0 -1
- package/dist/es5/exceljs.browser.js +0 -36
- package/dist/es5/exceljs.browser.js.map +0 -1
- package/dist/es5/exceljs.nodejs.js +0 -15
- package/dist/es5/exceljs.nodejs.js.map +0 -1
- package/dist/es5/index.js +0 -15
- package/dist/es5/stream/xlsx/hyperlink-reader.js +0 -90
- package/dist/es5/stream/xlsx/hyperlink-reader.js.map +0 -1
- package/dist/es5/stream/xlsx/sheet-comments-writer.js +0 -94
- package/dist/es5/stream/xlsx/sheet-comments-writer.js.map +0 -1
- package/dist/es5/stream/xlsx/sheet-rels-writer.js +0 -94
- package/dist/es5/stream/xlsx/sheet-rels-writer.js.map +0 -1
- package/dist/es5/stream/xlsx/workbook-reader.js +0 -362
- package/dist/es5/stream/xlsx/workbook-reader.js.map +0 -1
- package/dist/es5/stream/xlsx/workbook-writer.js +0 -347
- package/dist/es5/stream/xlsx/workbook-writer.js.map +0 -1
- package/dist/es5/stream/xlsx/worksheet-reader.js +0 -392
- package/dist/es5/stream/xlsx/worksheet-reader.js.map +0 -1
- package/dist/es5/stream/xlsx/worksheet-writer.js +0 -652
- package/dist/es5/stream/xlsx/worksheet-writer.js.map +0 -1
- package/dist/es5/utils/auto-drain.js +0 -18
- package/dist/es5/utils/auto-drain.js.map +0 -1
- package/dist/es5/utils/browser-buffer-decode.js +0 -15
- package/dist/es5/utils/browser-buffer-decode.js.map +0 -1
- package/dist/es5/utils/browser-buffer-encode.js +0 -18
- package/dist/es5/utils/browser-buffer-encode.js.map +0 -1
- package/dist/es5/utils/cell-matrix.js +0 -149
- package/dist/es5/utils/cell-matrix.js.map +0 -1
- package/dist/es5/utils/col-cache.js +0 -258
- package/dist/es5/utils/col-cache.js.map +0 -1
- package/dist/es5/utils/copy-style.js +0 -43
- package/dist/es5/utils/copy-style.js.map +0 -1
- package/dist/es5/utils/encryptor.js +0 -58
- package/dist/es5/utils/encryptor.js.map +0 -1
- package/dist/es5/utils/iterate-stream.js +0 -46
- package/dist/es5/utils/iterate-stream.js.map +0 -1
- package/dist/es5/utils/parse-sax.js +0 -47
- package/dist/es5/utils/parse-sax.js.map +0 -1
- package/dist/es5/utils/shared-formula.js +0 -42
- package/dist/es5/utils/shared-formula.js.map +0 -1
- package/dist/es5/utils/shared-strings.js +0 -32
- package/dist/es5/utils/shared-strings.js.map +0 -1
- package/dist/es5/utils/stream-base64.js +0 -66
- package/dist/es5/utils/stream-base64.js.map +0 -1
- package/dist/es5/utils/stream-buf.js +0 -343
- package/dist/es5/utils/stream-buf.js.map +0 -1
- package/dist/es5/utils/string-buf.js +0 -73
- package/dist/es5/utils/string-buf.js.map +0 -1
- package/dist/es5/utils/string-builder.js +0 -32
- package/dist/es5/utils/string-builder.js.map +0 -1
- package/dist/es5/utils/stuttered-pipe.js +0 -61
- package/dist/es5/utils/stuttered-pipe.js.map +0 -1
- package/dist/es5/utils/typed-stack.js +0 -23
- package/dist/es5/utils/typed-stack.js.map +0 -1
- package/dist/es5/utils/under-dash.js +0 -168
- package/dist/es5/utils/under-dash.js.map +0 -1
- package/dist/es5/utils/utils.js +0 -204
- package/dist/es5/utils/utils.js.map +0 -1
- package/dist/es5/utils/xml-stream.js +0 -151
- package/dist/es5/utils/xml-stream.js.map +0 -1
- package/dist/es5/utils/zip-stream.js +0 -79
- package/dist/es5/utils/zip-stream.js.map +0 -1
- package/dist/es5/xlsx/defaultnumformats.js +0 -230
- package/dist/es5/xlsx/defaultnumformats.js.map +0 -1
- package/dist/es5/xlsx/rel-type.js +0 -21
- package/dist/es5/xlsx/rel-type.js.map +0 -1
- package/dist/es5/xlsx/xform/base-xform.js +0 -139
- package/dist/es5/xlsx/xform/base-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/book/defined-name-xform.js +0 -85
- package/dist/es5/xlsx/xform/book/defined-name-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/book/sheet-xform.js +0 -32
- package/dist/es5/xlsx/xform/book/sheet-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/book/workbook-calc-properties-xform.js +0 -24
- package/dist/es5/xlsx/xform/book/workbook-calc-properties-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/book/workbook-pivot-cache-xform.js +0 -27
- package/dist/es5/xlsx/xform/book/workbook-pivot-cache-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/book/workbook-properties-xform.js +0 -27
- package/dist/es5/xlsx/xform/book/workbook-properties-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/book/workbook-view-xform.js +0 -51
- package/dist/es5/xlsx/xform/book/workbook-view-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/book/workbook-xform.js +0 -241
- package/dist/es5/xlsx/xform/book/workbook-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/comment/comment-xform.js +0 -103
- package/dist/es5/xlsx/xform/comment/comment-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/comment/comments-xform.js +0 -76
- package/dist/es5/xlsx/xform/comment/comments-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/comment/style/vml-position-xform.js +0 -35
- package/dist/es5/xlsx/xform/comment/style/vml-position-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/comment/style/vml-protection-xform.js +0 -32
- package/dist/es5/xlsx/xform/comment/style/vml-protection-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/comment/vml-anchor-xform.js +0 -53
- package/dist/es5/xlsx/xform/comment/vml-anchor-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/comment/vml-client-data-xform.js +0 -97
- package/dist/es5/xlsx/xform/comment/vml-client-data-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/comment/vml-notes-xform.js +0 -107
- package/dist/es5/xlsx/xform/comment/vml-notes-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/comment/vml-shape-xform.js +0 -92
- package/dist/es5/xlsx/xform/comment/vml-shape-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/comment/vml-textbox-xform.js +0 -61
- package/dist/es5/xlsx/xform/comment/vml-textbox-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/composite-xform.js +0 -51
- package/dist/es5/xlsx/xform/composite-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/core/app-heading-pairs-xform.js +0 -30
- package/dist/es5/xlsx/xform/core/app-heading-pairs-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/core/app-titles-of-parts-xform.js +0 -27
- package/dist/es5/xlsx/xform/core/app-titles-of-parts-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/core/app-xform.js +0 -93
- package/dist/es5/xlsx/xform/core/app-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/core/content-types-xform.js +0 -127
- package/dist/es5/xlsx/xform/core/content-types-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/core/core-xform.js +0 -158
- package/dist/es5/xlsx/xform/core/core-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/core/relationship-xform.js +0 -23
- package/dist/es5/xlsx/xform/core/relationship-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/core/relationships-xform.js +0 -65
- package/dist/es5/xlsx/xform/core/relationships-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/base-cell-anchor-xform.js +0 -47
- package/dist/es5/xlsx/xform/drawing/base-cell-anchor-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/blip-fill-xform.js +0 -61
- package/dist/es5/xlsx/xform/drawing/blip-fill-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/blip-xform.js +0 -39
- package/dist/es5/xlsx/xform/drawing/blip-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/c-nv-pic-pr-xform.js +0 -35
- package/dist/es5/xlsx/xform/drawing/c-nv-pic-pr-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/c-nv-pr-xform.js +0 -62
- package/dist/es5/xlsx/xform/drawing/c-nv-pr-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/cell-position-xform.js +0 -82
- package/dist/es5/xlsx/xform/drawing/cell-position-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/drawing-xform.js +0 -98
- package/dist/es5/xlsx/xform/drawing/drawing-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/ext-lst-xform.js +0 -40
- package/dist/es5/xlsx/xform/drawing/ext-lst-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/ext-xform.js +0 -38
- package/dist/es5/xlsx/xform/drawing/ext-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/hlink-click-xform.js +0 -38
- package/dist/es5/xlsx/xform/drawing/hlink-click-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/nv-pic-pr-xform.js +0 -59
- package/dist/es5/xlsx/xform/drawing/nv-pic-pr-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/one-cell-anchor-xform.js +0 -63
- package/dist/es5/xlsx/xform/drawing/one-cell-anchor-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/pic-xform.js +0 -67
- package/dist/es5/xlsx/xform/drawing/pic-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/sp-pr.js +0 -30
- package/dist/es5/xlsx/xform/drawing/sp-pr.js.map +0 -1
- package/dist/es5/xlsx/xform/drawing/two-cell-anchor-xform.js +0 -62
- package/dist/es5/xlsx/xform/drawing/two-cell-anchor-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/list-xform.js +0 -91
- package/dist/es5/xlsx/xform/list-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/pivot-table/cache-field.js +0 -48
- package/dist/es5/xlsx/xform/pivot-table/cache-field.js.map +0 -1
- package/dist/es5/xlsx/xform/pivot-table/pivot-cache-definition-xform.js +0 -73
- package/dist/es5/xlsx/xform/pivot-table/pivot-cache-definition-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/pivot-table/pivot-cache-records-xform.js +0 -93
- package/dist/es5/xlsx/xform/pivot-table/pivot-cache-records-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/pivot-table/pivot-table-xform.js +0 -176
- package/dist/es5/xlsx/xform/pivot-table/pivot-table-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/auto-filter-xform.js +0 -40
- package/dist/es5/xlsx/xform/sheet/auto-filter-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cell-xform.js +0 -450
- package/dist/es5/xlsx/xform/sheet/cell-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf/cf-rule-xform.js +0 -275
- package/dist/es5/xlsx/xform/sheet/cf/cf-rule-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf/cfvo-xform.js +0 -25
- package/dist/es5/xlsx/xform/sheet/cf/cfvo-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf/color-scale-xform.js +0 -38
- package/dist/es5/xlsx/xform/sheet/cf/color-scale-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf/conditional-formatting-xform.js +0 -45
- package/dist/es5/xlsx/xform/sheet/cf/conditional-formatting-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf/conditional-formattings-xform.js +0 -77
- package/dist/es5/xlsx/xform/sheet/cf/conditional-formattings-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf/databar-xform.js +0 -42
- package/dist/es5/xlsx/xform/sheet/cf/databar-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf/ext-lst-ref-xform.js +0 -71
- package/dist/es5/xlsx/xform/sheet/cf/ext-lst-ref-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf/formula-xform.js +0 -22
- package/dist/es5/xlsx/xform/sheet/cf/formula-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf/icon-set-xform.js +0 -43
- package/dist/es5/xlsx/xform/sheet/cf/icon-set-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf-ext/cf-icon-ext-xform.js +0 -28
- package/dist/es5/xlsx/xform/sheet/cf-ext/cf-icon-ext-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.js +0 -88
- package/dist/es5/xlsx/xform/sheet/cf-ext/cf-rule-ext-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf-ext/cfvo-ext-xform.js +0 -38
- package/dist/es5/xlsx/xform/sheet/cf-ext/cfvo-ext-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf-ext/conditional-formatting-ext-xform.js +0 -52
- package/dist/es5/xlsx/xform/sheet/cf-ext/conditional-formatting-ext-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf-ext/conditional-formattings-ext-xform.js +0 -43
- package/dist/es5/xlsx/xform/sheet/cf-ext/conditional-formattings-ext-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf-ext/databar-ext-xform.js +0 -75
- package/dist/es5/xlsx/xform/sheet/cf-ext/databar-ext-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf-ext/f-ext-xform.js +0 -22
- package/dist/es5/xlsx/xform/sheet/cf-ext/f-ext-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf-ext/icon-set-ext-xform.js +0 -66
- package/dist/es5/xlsx/xform/sheet/cf-ext/icon-set-ext-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/cf-ext/sqref-ext-xform.js +0 -22
- package/dist/es5/xlsx/xform/sheet/cf-ext/sqref-ext-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/col-xform.js +0 -78
- package/dist/es5/xlsx/xform/sheet/col-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/data-validations-xform.js +0 -247
- package/dist/es5/xlsx/xform/sheet/data-validations-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/dimension-xform.js +0 -28
- package/dist/es5/xlsx/xform/sheet/dimension-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/drawing-xform.js +0 -32
- package/dist/es5/xlsx/xform/sheet/drawing-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/ext-lst-xform.js +0 -69
- package/dist/es5/xlsx/xform/sheet/ext-lst-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/header-footer-xform.js +0 -126
- package/dist/es5/xlsx/xform/sheet/header-footer-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/hyperlink-xform.js +0 -50
- package/dist/es5/xlsx/xform/sheet/hyperlink-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/merge-cell-xform.js +0 -26
- package/dist/es5/xlsx/xform/sheet/merge-cell-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/merges.js +0 -52
- package/dist/es5/xlsx/xform/sheet/merges.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/outline-properties-xform.js +0 -35
- package/dist/es5/xlsx/xform/sheet/outline-properties-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/page-breaks-xform.js +0 -24
- package/dist/es5/xlsx/xform/sheet/page-breaks-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/page-margins-xform.js +0 -46
- package/dist/es5/xlsx/xform/sheet/page-margins-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/page-setup-properties-xform.js +0 -32
- package/dist/es5/xlsx/xform/sheet/page-setup-properties-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/page-setup-xform.js +0 -99
- package/dist/es5/xlsx/xform/sheet/page-setup-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/picture-xform.js +0 -32
- package/dist/es5/xlsx/xform/sheet/picture-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/print-options-xform.js +0 -45
- package/dist/es5/xlsx/xform/sheet/print-options-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/row-breaks-xform.js +0 -37
- package/dist/es5/xlsx/xform/sheet/row-breaks-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/row-xform.js +0 -128
- package/dist/es5/xlsx/xform/sheet/row-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/sheet-format-properties-xform.js +0 -51
- package/dist/es5/xlsx/xform/sheet/sheet-format-properties-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/sheet-properties-xform.js +0 -83
- package/dist/es5/xlsx/xform/sheet/sheet-properties-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/sheet-protection-xform.js +0 -84
- package/dist/es5/xlsx/xform/sheet/sheet-protection-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/sheet-view-xform.js +0 -190
- package/dist/es5/xlsx/xform/sheet/sheet-view-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/table-part-xform.js +0 -32
- package/dist/es5/xlsx/xform/sheet/table-part-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/sheet/worksheet-xform.js +0 -522
- package/dist/es5/xlsx/xform/sheet/worksheet-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/simple/boolean-xform.js +0 -27
- package/dist/es5/xlsx/xform/simple/boolean-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/simple/date-xform.js +0 -58
- package/dist/es5/xlsx/xform/simple/date-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/simple/float-xform.js +0 -47
- package/dist/es5/xlsx/xform/simple/float-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/simple/integer-xform.js +0 -53
- package/dist/es5/xlsx/xform/simple/integer-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/simple/string-xform.js +0 -47
- package/dist/es5/xlsx/xform/simple/string-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/static-xform.js +0 -61
- package/dist/es5/xlsx/xform/static-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/strings/phonetic-text-xform.js +0 -98
- package/dist/es5/xlsx/xform/strings/phonetic-text-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/strings/rich-text-xform.js +0 -92
- package/dist/es5/xlsx/xform/strings/rich-text-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/strings/shared-string-xform.js +0 -99
- package/dist/es5/xlsx/xform/strings/shared-string-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/strings/shared-strings-xform.js +0 -114
- package/dist/es5/xlsx/xform/strings/shared-strings-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/strings/text-xform.js +0 -39
- package/dist/es5/xlsx/xform/strings/text-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/style/alignment-xform.js +0 -139
- package/dist/es5/xlsx/xform/style/alignment-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/style/border-xform.js +0 -185
- package/dist/es5/xlsx/xform/style/border-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/style/color-xform.js +0 -66
- package/dist/es5/xlsx/xform/style/color-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/style/dxf-xform.js +0 -106
- package/dist/es5/xlsx/xform/style/dxf-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/style/fill-xform.js +0 -307
- package/dist/es5/xlsx/xform/style/fill-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/style/font-xform.js +0 -175
- package/dist/es5/xlsx/xform/style/font-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/style/numfmt-xform.js +0 -58
- package/dist/es5/xlsx/xform/style/numfmt-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/style/protection-xform.js +0 -53
- package/dist/es5/xlsx/xform/style/protection-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/style/style-xform.js +0 -118
- package/dist/es5/xlsx/xform/style/style-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/style/styles-xform.js +0 -611
- package/dist/es5/xlsx/xform/style/styles-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/style/underline-xform.js +0 -46
- package/dist/es5/xlsx/xform/style/underline-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/table/auto-filter-xform.js +0 -75
- package/dist/es5/xlsx/xform/table/auto-filter-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/table/custom-filter-xform.js +0 -30
- package/dist/es5/xlsx/xform/table/custom-filter-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/table/filter-column-xform.js +0 -89
- package/dist/es5/xlsx/xform/table/filter-column-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/table/filter-xform.js +0 -28
- package/dist/es5/xlsx/xform/table/filter-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/table/table-column-xform.js +0 -42
- package/dist/es5/xlsx/xform/table/table-column-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/table/table-style-info-xform.js +0 -40
- package/dist/es5/xlsx/xform/table/table-style-info-xform.js.map +0 -1
- package/dist/es5/xlsx/xform/table/table-xform.js +0 -122
- package/dist/es5/xlsx/xform/table/table-xform.js.map +0 -1
- package/dist/es5/xlsx/xlsx.js +0 -775
- package/dist/es5/xlsx/xlsx.js.map +0 -1
- package/dist/es5/xlsx/xml/theme1.js +0 -5
- package/dist/es5/xlsx/xml/theme1.js.map +0 -1
- package/dist/exceljs.bare.js +0 -57759
- package/dist/exceljs.bare.js.map +0 -777
- package/dist/exceljs.bare.min.js +0 -45
- package/dist/exceljs.bare.min.js.map +0 -1
- package/dist/exceljs.js +0 -62398
- package/dist/exceljs.js.map +0 -1095
- package/dist/exceljs.min.js +0 -45
- package/dist/exceljs.min.js.map +0 -1
package/lib/utils/stream-buf.js
CHANGED
|
@@ -1,364 +1,364 @@
|
|
|
1
|
-
/* eslint-disable max-classes-per-file */
|
|
2
|
-
const Stream = require('readable-stream');
|
|
3
|
-
|
|
4
|
-
const utils = require('./utils');
|
|
5
|
-
const StringBuf = require('./string-buf');
|
|
6
|
-
|
|
7
|
-
// =============================================================================
|
|
8
|
-
// data chunks - encapsulating incoming data
|
|
9
|
-
class StringChunk {
|
|
10
|
-
constructor(data, encoding) {
|
|
11
|
-
this._data = data;
|
|
12
|
-
this._encoding = encoding;
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
get length() {
|
|
16
|
-
return this.toBuffer().length;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
// copy to target buffer
|
|
20
|
-
copy(target, targetOffset, offset, length) {
|
|
21
|
-
return this.toBuffer().copy(target, targetOffset, offset, length);
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
toBuffer() {
|
|
25
|
-
if (!this._buffer) {
|
|
26
|
-
this._buffer = Buffer.from(this._data, this._encoding);
|
|
27
|
-
}
|
|
28
|
-
return this._buffer;
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
class StringBufChunk {
|
|
33
|
-
constructor(data) {
|
|
34
|
-
this._data = data;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
get length() {
|
|
38
|
-
return this._data.length;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
// copy to target buffer
|
|
42
|
-
copy(target, targetOffset, offset, length) {
|
|
43
|
-
// eslint-disable-next-line no-underscore-dangle
|
|
44
|
-
return this._data._buf.copy(target, targetOffset, offset, length);
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
toBuffer() {
|
|
48
|
-
return this._data.toBuffer();
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
class BufferChunk {
|
|
53
|
-
constructor(data) {
|
|
54
|
-
this._data = data;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
get length() {
|
|
58
|
-
return this._data.length;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
// copy to target buffer
|
|
62
|
-
copy(target, targetOffset, offset, length) {
|
|
63
|
-
this._data.copy(target, targetOffset, offset, length);
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
toBuffer() {
|
|
67
|
-
return this._data;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
// =============================================================================
|
|
72
|
-
// ReadWriteBuf - a single buffer supporting simple read-write
|
|
73
|
-
class ReadWriteBuf {
|
|
74
|
-
constructor(size) {
|
|
75
|
-
this.size = size;
|
|
76
|
-
// the buffer
|
|
77
|
-
this.buffer = Buffer.alloc(size);
|
|
78
|
-
// read index
|
|
79
|
-
this.iRead = 0;
|
|
80
|
-
// write index
|
|
81
|
-
this.iWrite = 0;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
toBuffer() {
|
|
85
|
-
if (this.iRead === 0 && this.iWrite === this.size) {
|
|
86
|
-
return this.buffer;
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
const buf = Buffer.alloc(this.iWrite - this.iRead);
|
|
90
|
-
this.buffer.copy(buf, 0, this.iRead, this.iWrite);
|
|
91
|
-
return buf;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
get length() {
|
|
95
|
-
return this.iWrite - this.iRead;
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
get eod() {
|
|
99
|
-
return this.iRead === this.iWrite;
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
get full() {
|
|
103
|
-
return this.iWrite === this.size;
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
read(size) {
|
|
107
|
-
let buf;
|
|
108
|
-
// read size bytes from buffer and return buffer
|
|
109
|
-
if (size === 0) {
|
|
110
|
-
// special case - return null if no data requested
|
|
111
|
-
return null;
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
if (size === undefined || size >= this.length) {
|
|
115
|
-
// if no size specified or size is at least what we have then return all of the bytes
|
|
116
|
-
buf = this.toBuffer();
|
|
117
|
-
this.iRead = this.iWrite;
|
|
118
|
-
return buf;
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
// otherwise return a chunk
|
|
122
|
-
buf = Buffer.alloc(size);
|
|
123
|
-
this.buffer.copy(buf, 0, this.iRead, size);
|
|
124
|
-
this.iRead += size;
|
|
125
|
-
return buf;
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
write(chunk, offset, length) {
|
|
129
|
-
// write as many bytes from data from optional source offset
|
|
130
|
-
// and return number of bytes written
|
|
131
|
-
const size = Math.min(length, this.size - this.iWrite);
|
|
132
|
-
chunk.copy(this.buffer, this.iWrite, offset, offset + size);
|
|
133
|
-
this.iWrite += size;
|
|
134
|
-
return size;
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
// =============================================================================
|
|
139
|
-
// StreamBuf - a multi-purpose read-write stream
|
|
140
|
-
// As MemBuf - write as much data as you like. Then call toBuffer() to consolidate
|
|
141
|
-
// As StreamHub - pipe to multiple writables
|
|
142
|
-
// As readable stream - feed data into the writable part and have some other code read from it.
|
|
143
|
-
|
|
144
|
-
// Note: Not sure why but StreamBuf does not like JS "class" sugar. It fails the
|
|
145
|
-
// integration tests
|
|
146
|
-
const StreamBuf = function(options) {
|
|
147
|
-
options = options || {};
|
|
148
|
-
this.bufSize = options.bufSize || 1024 * 1024;
|
|
149
|
-
this.buffers = [];
|
|
150
|
-
|
|
151
|
-
// batch mode fills a buffer completely before passing the data on
|
|
152
|
-
// to pipes or 'readable' event listeners
|
|
153
|
-
this.batch = options.batch || false;
|
|
154
|
-
|
|
155
|
-
this.corked = false;
|
|
156
|
-
// where in the current writable buffer we're up to
|
|
157
|
-
this.inPos = 0;
|
|
158
|
-
|
|
159
|
-
// where in the current readable buffer we've read up to
|
|
160
|
-
this.outPos = 0;
|
|
161
|
-
|
|
162
|
-
// consuming pipe streams go here
|
|
163
|
-
this.pipes = [];
|
|
164
|
-
|
|
165
|
-
// controls emit('data')
|
|
166
|
-
this.paused = false;
|
|
167
|
-
|
|
168
|
-
this.encoding = null;
|
|
169
|
-
};
|
|
170
|
-
|
|
171
|
-
utils.inherits(StreamBuf, Stream.Duplex, {
|
|
172
|
-
toBuffer() {
|
|
173
|
-
switch (this.buffers.length) {
|
|
174
|
-
case 0:
|
|
175
|
-
return null;
|
|
176
|
-
case 1:
|
|
177
|
-
return this.buffers[0].toBuffer();
|
|
178
|
-
default:
|
|
179
|
-
return Buffer.concat(this.buffers.map(rwBuf => rwBuf.toBuffer()));
|
|
180
|
-
}
|
|
181
|
-
},
|
|
182
|
-
|
|
183
|
-
// writable
|
|
184
|
-
// event drain - if write returns false (which it won't), indicates when safe to write again.
|
|
185
|
-
// finish - end() has been called
|
|
186
|
-
// pipe(src) - pipe() has been called on readable
|
|
187
|
-
// unpipe(src) - unpipe() has been called on readable
|
|
188
|
-
// error - duh
|
|
189
|
-
|
|
190
|
-
_getWritableBuffer() {
|
|
191
|
-
if (this.buffers.length) {
|
|
192
|
-
const last = this.buffers[this.buffers.length - 1];
|
|
193
|
-
if (!last.full) {
|
|
194
|
-
return last;
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
const buf = new ReadWriteBuf(this.bufSize);
|
|
198
|
-
this.buffers.push(buf);
|
|
199
|
-
return buf;
|
|
200
|
-
},
|
|
201
|
-
|
|
202
|
-
async _pipe(chunk) {
|
|
203
|
-
const write = function(pipe) {
|
|
204
|
-
return new Promise(resolve => {
|
|
205
|
-
pipe.write(chunk.toBuffer(), () => {
|
|
206
|
-
resolve();
|
|
207
|
-
});
|
|
208
|
-
});
|
|
209
|
-
};
|
|
210
|
-
await Promise.all(this.pipes.map(write));
|
|
211
|
-
},
|
|
212
|
-
_writeToBuffers(chunk) {
|
|
213
|
-
let inPos = 0;
|
|
214
|
-
const inLen = chunk.length;
|
|
215
|
-
while (inPos < inLen) {
|
|
216
|
-
// find writable buffer
|
|
217
|
-
const buffer = this._getWritableBuffer();
|
|
218
|
-
|
|
219
|
-
// write some data
|
|
220
|
-
inPos += buffer.write(chunk, inPos, inLen - inPos);
|
|
221
|
-
}
|
|
222
|
-
},
|
|
223
|
-
async write(data, encoding, callback) {
|
|
224
|
-
if (encoding instanceof Function) {
|
|
225
|
-
callback = encoding;
|
|
226
|
-
encoding = 'utf8';
|
|
227
|
-
}
|
|
228
|
-
callback = callback || utils.nop;
|
|
229
|
-
|
|
230
|
-
// encapsulate data into a chunk
|
|
231
|
-
let chunk;
|
|
232
|
-
if (data instanceof StringBuf) {
|
|
233
|
-
chunk = new StringBufChunk(data);
|
|
234
|
-
} else if (data instanceof Buffer) {
|
|
235
|
-
chunk = new BufferChunk(data);
|
|
236
|
-
} else if (typeof data === 'string' || data instanceof String || data instanceof ArrayBuffer) {
|
|
237
|
-
chunk = new StringChunk(data, encoding);
|
|
238
|
-
} else {
|
|
239
|
-
throw new Error('Chunk must be one of type String, Buffer or StringBuf.');
|
|
240
|
-
}
|
|
241
|
-
|
|
242
|
-
// now, do something with the chunk
|
|
243
|
-
if (this.pipes.length) {
|
|
244
|
-
if (this.batch) {
|
|
245
|
-
this._writeToBuffers(chunk);
|
|
246
|
-
while (!this.corked && this.buffers.length > 1) {
|
|
247
|
-
this._pipe(this.buffers.shift());
|
|
248
|
-
}
|
|
249
|
-
} else if (!this.corked) {
|
|
250
|
-
await this._pipe(chunk);
|
|
251
|
-
callback();
|
|
252
|
-
} else {
|
|
253
|
-
this._writeToBuffers(chunk);
|
|
254
|
-
process.nextTick(callback);
|
|
255
|
-
}
|
|
256
|
-
} else {
|
|
257
|
-
if (!this.paused) {
|
|
258
|
-
this.emit('data', chunk.toBuffer());
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
this._writeToBuffers(chunk);
|
|
262
|
-
this.emit('readable');
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
return true;
|
|
266
|
-
},
|
|
267
|
-
cork() {
|
|
268
|
-
this.corked = true;
|
|
269
|
-
},
|
|
270
|
-
_flush(/* destination */) {
|
|
271
|
-
// if we have comsumers...
|
|
272
|
-
if (this.pipes.length) {
|
|
273
|
-
// and there's stuff not written
|
|
274
|
-
while (this.buffers.length) {
|
|
275
|
-
this._pipe(this.buffers.shift());
|
|
276
|
-
}
|
|
277
|
-
}
|
|
278
|
-
},
|
|
279
|
-
uncork() {
|
|
280
|
-
this.corked = false;
|
|
281
|
-
this._flush();
|
|
282
|
-
},
|
|
283
|
-
end(chunk, encoding, callback) {
|
|
284
|
-
const writeComplete = error => {
|
|
285
|
-
if (error) {
|
|
286
|
-
callback(error);
|
|
287
|
-
} else {
|
|
288
|
-
this._flush();
|
|
289
|
-
this.pipes.forEach(pipe => {
|
|
290
|
-
pipe.end();
|
|
291
|
-
});
|
|
292
|
-
this.emit('finish');
|
|
293
|
-
}
|
|
294
|
-
};
|
|
295
|
-
if (chunk) {
|
|
296
|
-
this.write(chunk, encoding, writeComplete);
|
|
297
|
-
} else {
|
|
298
|
-
writeComplete();
|
|
299
|
-
}
|
|
300
|
-
},
|
|
301
|
-
|
|
302
|
-
// readable
|
|
303
|
-
// event readable - some data is now available
|
|
304
|
-
// event data - switch to flowing mode - feeds chunks to handler
|
|
305
|
-
// event end - no more data
|
|
306
|
-
// event close - optional, indicates upstream close
|
|
307
|
-
// event error - duh
|
|
308
|
-
read(size) {
|
|
309
|
-
let buffers;
|
|
310
|
-
// read min(buffer, size || infinity)
|
|
311
|
-
if (size) {
|
|
312
|
-
buffers = [];
|
|
313
|
-
while (size && this.buffers.length && !this.buffers[0].eod) {
|
|
314
|
-
const first = this.buffers[0];
|
|
315
|
-
const buffer = first.read(size);
|
|
316
|
-
size -= buffer.length;
|
|
317
|
-
buffers.push(buffer);
|
|
318
|
-
if (first.eod && first.full) {
|
|
319
|
-
this.buffers.shift();
|
|
320
|
-
}
|
|
321
|
-
}
|
|
322
|
-
return Buffer.concat(buffers);
|
|
323
|
-
}
|
|
324
|
-
|
|
325
|
-
buffers = this.buffers.map(buf => buf.toBuffer()).filter(Boolean);
|
|
326
|
-
this.buffers = [];
|
|
327
|
-
return Buffer.concat(buffers);
|
|
328
|
-
},
|
|
329
|
-
setEncoding(encoding) {
|
|
330
|
-
// causes stream.read or stream.on('data) to return strings of encoding instead of Buffer objects
|
|
331
|
-
this.encoding = encoding;
|
|
332
|
-
},
|
|
333
|
-
pause() {
|
|
334
|
-
this.paused = true;
|
|
335
|
-
},
|
|
336
|
-
resume() {
|
|
337
|
-
this.paused = false;
|
|
338
|
-
},
|
|
339
|
-
isPaused() {
|
|
340
|
-
return !!this.paused;
|
|
341
|
-
},
|
|
342
|
-
pipe(destination) {
|
|
343
|
-
// add destination to pipe list & write current buffer
|
|
344
|
-
this.pipes.push(destination);
|
|
345
|
-
if (!this.paused && this.buffers.length) {
|
|
346
|
-
this.end();
|
|
347
|
-
}
|
|
348
|
-
},
|
|
349
|
-
unpipe(destination) {
|
|
350
|
-
// remove destination from pipe list
|
|
351
|
-
this.pipes = this.pipes.filter(pipe => pipe !== destination);
|
|
352
|
-
},
|
|
353
|
-
unshift(/* chunk */) {
|
|
354
|
-
// some numpty has read some data that's not for them and they want to put it back!
|
|
355
|
-
// Might implement this some day
|
|
356
|
-
throw new Error('Not Implemented');
|
|
357
|
-
},
|
|
358
|
-
wrap(/* stream */) {
|
|
359
|
-
// not implemented
|
|
360
|
-
throw new Error('Not Implemented');
|
|
361
|
-
},
|
|
362
|
-
});
|
|
363
|
-
|
|
364
|
-
module.exports = StreamBuf;
|
|
1
|
+
/* eslint-disable max-classes-per-file */
|
|
2
|
+
const Stream = require('readable-stream');
|
|
3
|
+
|
|
4
|
+
const utils = require('./utils');
|
|
5
|
+
const StringBuf = require('./string-buf');
|
|
6
|
+
|
|
7
|
+
// =============================================================================
|
|
8
|
+
// data chunks - encapsulating incoming data
|
|
9
|
+
class StringChunk {
|
|
10
|
+
constructor(data, encoding) {
|
|
11
|
+
this._data = data;
|
|
12
|
+
this._encoding = encoding;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
get length() {
|
|
16
|
+
return this.toBuffer().length;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
// copy to target buffer
|
|
20
|
+
copy(target, targetOffset, offset, length) {
|
|
21
|
+
return this.toBuffer().copy(target, targetOffset, offset, length);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
toBuffer() {
|
|
25
|
+
if (!this._buffer) {
|
|
26
|
+
this._buffer = Buffer.from(this._data, this._encoding);
|
|
27
|
+
}
|
|
28
|
+
return this._buffer;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
class StringBufChunk {
|
|
33
|
+
constructor(data) {
|
|
34
|
+
this._data = data;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
get length() {
|
|
38
|
+
return this._data.length;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
// copy to target buffer
|
|
42
|
+
copy(target, targetOffset, offset, length) {
|
|
43
|
+
// eslint-disable-next-line no-underscore-dangle
|
|
44
|
+
return this._data._buf.copy(target, targetOffset, offset, length);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
toBuffer() {
|
|
48
|
+
return this._data.toBuffer();
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
class BufferChunk {
|
|
53
|
+
constructor(data) {
|
|
54
|
+
this._data = data;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
get length() {
|
|
58
|
+
return this._data.length;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
// copy to target buffer
|
|
62
|
+
copy(target, targetOffset, offset, length) {
|
|
63
|
+
this._data.copy(target, targetOffset, offset, length);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
toBuffer() {
|
|
67
|
+
return this._data;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
// =============================================================================
|
|
72
|
+
// ReadWriteBuf - a single buffer supporting simple read-write
|
|
73
|
+
class ReadWriteBuf {
|
|
74
|
+
constructor(size) {
|
|
75
|
+
this.size = size;
|
|
76
|
+
// the buffer
|
|
77
|
+
this.buffer = Buffer.alloc(size);
|
|
78
|
+
// read index
|
|
79
|
+
this.iRead = 0;
|
|
80
|
+
// write index
|
|
81
|
+
this.iWrite = 0;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
toBuffer() {
|
|
85
|
+
if (this.iRead === 0 && this.iWrite === this.size) {
|
|
86
|
+
return this.buffer;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
const buf = Buffer.alloc(this.iWrite - this.iRead);
|
|
90
|
+
this.buffer.copy(buf, 0, this.iRead, this.iWrite);
|
|
91
|
+
return buf;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
get length() {
|
|
95
|
+
return this.iWrite - this.iRead;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
get eod() {
|
|
99
|
+
return this.iRead === this.iWrite;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
get full() {
|
|
103
|
+
return this.iWrite === this.size;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
read(size) {
|
|
107
|
+
let buf;
|
|
108
|
+
// read size bytes from buffer and return buffer
|
|
109
|
+
if (size === 0) {
|
|
110
|
+
// special case - return null if no data requested
|
|
111
|
+
return null;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
if (size === undefined || size >= this.length) {
|
|
115
|
+
// if no size specified or size is at least what we have then return all of the bytes
|
|
116
|
+
buf = this.toBuffer();
|
|
117
|
+
this.iRead = this.iWrite;
|
|
118
|
+
return buf;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
// otherwise return a chunk
|
|
122
|
+
buf = Buffer.alloc(size);
|
|
123
|
+
this.buffer.copy(buf, 0, this.iRead, size);
|
|
124
|
+
this.iRead += size;
|
|
125
|
+
return buf;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
write(chunk, offset, length) {
|
|
129
|
+
// write as many bytes from data from optional source offset
|
|
130
|
+
// and return number of bytes written
|
|
131
|
+
const size = Math.min(length, this.size - this.iWrite);
|
|
132
|
+
chunk.copy(this.buffer, this.iWrite, offset, offset + size);
|
|
133
|
+
this.iWrite += size;
|
|
134
|
+
return size;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
// =============================================================================
|
|
139
|
+
// StreamBuf - a multi-purpose read-write stream
|
|
140
|
+
// As MemBuf - write as much data as you like. Then call toBuffer() to consolidate
|
|
141
|
+
// As StreamHub - pipe to multiple writables
|
|
142
|
+
// As readable stream - feed data into the writable part and have some other code read from it.
|
|
143
|
+
|
|
144
|
+
// Note: Not sure why but StreamBuf does not like JS "class" sugar. It fails the
|
|
145
|
+
// integration tests
|
|
146
|
+
const StreamBuf = function(options) {
|
|
147
|
+
options = options || {};
|
|
148
|
+
this.bufSize = options.bufSize || 1024 * 1024;
|
|
149
|
+
this.buffers = [];
|
|
150
|
+
|
|
151
|
+
// batch mode fills a buffer completely before passing the data on
|
|
152
|
+
// to pipes or 'readable' event listeners
|
|
153
|
+
this.batch = options.batch || false;
|
|
154
|
+
|
|
155
|
+
this.corked = false;
|
|
156
|
+
// where in the current writable buffer we're up to
|
|
157
|
+
this.inPos = 0;
|
|
158
|
+
|
|
159
|
+
// where in the current readable buffer we've read up to
|
|
160
|
+
this.outPos = 0;
|
|
161
|
+
|
|
162
|
+
// consuming pipe streams go here
|
|
163
|
+
this.pipes = [];
|
|
164
|
+
|
|
165
|
+
// controls emit('data')
|
|
166
|
+
this.paused = false;
|
|
167
|
+
|
|
168
|
+
this.encoding = null;
|
|
169
|
+
};
|
|
170
|
+
|
|
171
|
+
utils.inherits(StreamBuf, Stream.Duplex, {
|
|
172
|
+
toBuffer() {
|
|
173
|
+
switch (this.buffers.length) {
|
|
174
|
+
case 0:
|
|
175
|
+
return null;
|
|
176
|
+
case 1:
|
|
177
|
+
return this.buffers[0].toBuffer();
|
|
178
|
+
default:
|
|
179
|
+
return Buffer.concat(this.buffers.map(rwBuf => rwBuf.toBuffer()));
|
|
180
|
+
}
|
|
181
|
+
},
|
|
182
|
+
|
|
183
|
+
// writable
|
|
184
|
+
// event drain - if write returns false (which it won't), indicates when safe to write again.
|
|
185
|
+
// finish - end() has been called
|
|
186
|
+
// pipe(src) - pipe() has been called on readable
|
|
187
|
+
// unpipe(src) - unpipe() has been called on readable
|
|
188
|
+
// error - duh
|
|
189
|
+
|
|
190
|
+
_getWritableBuffer() {
|
|
191
|
+
if (this.buffers.length) {
|
|
192
|
+
const last = this.buffers[this.buffers.length - 1];
|
|
193
|
+
if (!last.full) {
|
|
194
|
+
return last;
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
const buf = new ReadWriteBuf(this.bufSize);
|
|
198
|
+
this.buffers.push(buf);
|
|
199
|
+
return buf;
|
|
200
|
+
},
|
|
201
|
+
|
|
202
|
+
async _pipe(chunk) {
|
|
203
|
+
const write = function(pipe) {
|
|
204
|
+
return new Promise(resolve => {
|
|
205
|
+
pipe.write(chunk.toBuffer(), () => {
|
|
206
|
+
resolve();
|
|
207
|
+
});
|
|
208
|
+
});
|
|
209
|
+
};
|
|
210
|
+
await Promise.all(this.pipes.map(write));
|
|
211
|
+
},
|
|
212
|
+
_writeToBuffers(chunk) {
|
|
213
|
+
let inPos = 0;
|
|
214
|
+
const inLen = chunk.length;
|
|
215
|
+
while (inPos < inLen) {
|
|
216
|
+
// find writable buffer
|
|
217
|
+
const buffer = this._getWritableBuffer();
|
|
218
|
+
|
|
219
|
+
// write some data
|
|
220
|
+
inPos += buffer.write(chunk, inPos, inLen - inPos);
|
|
221
|
+
}
|
|
222
|
+
},
|
|
223
|
+
async write(data, encoding, callback) {
|
|
224
|
+
if (encoding instanceof Function) {
|
|
225
|
+
callback = encoding;
|
|
226
|
+
encoding = 'utf8';
|
|
227
|
+
}
|
|
228
|
+
callback = callback || utils.nop;
|
|
229
|
+
|
|
230
|
+
// encapsulate data into a chunk
|
|
231
|
+
let chunk;
|
|
232
|
+
if (data instanceof StringBuf) {
|
|
233
|
+
chunk = new StringBufChunk(data);
|
|
234
|
+
} else if (data instanceof Buffer) {
|
|
235
|
+
chunk = new BufferChunk(data);
|
|
236
|
+
} else if (typeof data === 'string' || data instanceof String || data instanceof ArrayBuffer) {
|
|
237
|
+
chunk = new StringChunk(data, encoding);
|
|
238
|
+
} else {
|
|
239
|
+
throw new Error('Chunk must be one of type String, Buffer or StringBuf.');
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
// now, do something with the chunk
|
|
243
|
+
if (this.pipes.length) {
|
|
244
|
+
if (this.batch) {
|
|
245
|
+
this._writeToBuffers(chunk);
|
|
246
|
+
while (!this.corked && this.buffers.length > 1) {
|
|
247
|
+
this._pipe(this.buffers.shift());
|
|
248
|
+
}
|
|
249
|
+
} else if (!this.corked) {
|
|
250
|
+
await this._pipe(chunk);
|
|
251
|
+
callback();
|
|
252
|
+
} else {
|
|
253
|
+
this._writeToBuffers(chunk);
|
|
254
|
+
process.nextTick(callback);
|
|
255
|
+
}
|
|
256
|
+
} else {
|
|
257
|
+
if (!this.paused) {
|
|
258
|
+
this.emit('data', chunk.toBuffer());
|
|
259
|
+
}
|
|
260
|
+
|
|
261
|
+
this._writeToBuffers(chunk);
|
|
262
|
+
this.emit('readable');
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
return true;
|
|
266
|
+
},
|
|
267
|
+
cork() {
|
|
268
|
+
this.corked = true;
|
|
269
|
+
},
|
|
270
|
+
_flush(/* destination */) {
|
|
271
|
+
// if we have comsumers...
|
|
272
|
+
if (this.pipes.length) {
|
|
273
|
+
// and there's stuff not written
|
|
274
|
+
while (this.buffers.length) {
|
|
275
|
+
this._pipe(this.buffers.shift());
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
},
|
|
279
|
+
uncork() {
|
|
280
|
+
this.corked = false;
|
|
281
|
+
this._flush();
|
|
282
|
+
},
|
|
283
|
+
end(chunk, encoding, callback) {
|
|
284
|
+
const writeComplete = error => {
|
|
285
|
+
if (error) {
|
|
286
|
+
callback(error);
|
|
287
|
+
} else {
|
|
288
|
+
this._flush();
|
|
289
|
+
this.pipes.forEach(pipe => {
|
|
290
|
+
pipe.end();
|
|
291
|
+
});
|
|
292
|
+
this.emit('finish');
|
|
293
|
+
}
|
|
294
|
+
};
|
|
295
|
+
if (chunk) {
|
|
296
|
+
this.write(chunk, encoding, writeComplete);
|
|
297
|
+
} else {
|
|
298
|
+
writeComplete();
|
|
299
|
+
}
|
|
300
|
+
},
|
|
301
|
+
|
|
302
|
+
// readable
|
|
303
|
+
// event readable - some data is now available
|
|
304
|
+
// event data - switch to flowing mode - feeds chunks to handler
|
|
305
|
+
// event end - no more data
|
|
306
|
+
// event close - optional, indicates upstream close
|
|
307
|
+
// event error - duh
|
|
308
|
+
read(size) {
|
|
309
|
+
let buffers;
|
|
310
|
+
// read min(buffer, size || infinity)
|
|
311
|
+
if (size) {
|
|
312
|
+
buffers = [];
|
|
313
|
+
while (size && this.buffers.length && !this.buffers[0].eod) {
|
|
314
|
+
const first = this.buffers[0];
|
|
315
|
+
const buffer = first.read(size);
|
|
316
|
+
size -= buffer.length;
|
|
317
|
+
buffers.push(buffer);
|
|
318
|
+
if (first.eod && first.full) {
|
|
319
|
+
this.buffers.shift();
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
return Buffer.concat(buffers);
|
|
323
|
+
}
|
|
324
|
+
|
|
325
|
+
buffers = this.buffers.map(buf => buf.toBuffer()).filter(Boolean);
|
|
326
|
+
this.buffers = [];
|
|
327
|
+
return Buffer.concat(buffers);
|
|
328
|
+
},
|
|
329
|
+
setEncoding(encoding) {
|
|
330
|
+
// causes stream.read or stream.on('data) to return strings of encoding instead of Buffer objects
|
|
331
|
+
this.encoding = encoding;
|
|
332
|
+
},
|
|
333
|
+
pause() {
|
|
334
|
+
this.paused = true;
|
|
335
|
+
},
|
|
336
|
+
resume() {
|
|
337
|
+
this.paused = false;
|
|
338
|
+
},
|
|
339
|
+
isPaused() {
|
|
340
|
+
return !!this.paused;
|
|
341
|
+
},
|
|
342
|
+
pipe(destination) {
|
|
343
|
+
// add destination to pipe list & write current buffer
|
|
344
|
+
this.pipes.push(destination);
|
|
345
|
+
if (!this.paused && this.buffers.length) {
|
|
346
|
+
this.end();
|
|
347
|
+
}
|
|
348
|
+
},
|
|
349
|
+
unpipe(destination) {
|
|
350
|
+
// remove destination from pipe list
|
|
351
|
+
this.pipes = this.pipes.filter(pipe => pipe !== destination);
|
|
352
|
+
},
|
|
353
|
+
unshift(/* chunk */) {
|
|
354
|
+
// some numpty has read some data that's not for them and they want to put it back!
|
|
355
|
+
// Might implement this some day
|
|
356
|
+
throw new Error('Not Implemented');
|
|
357
|
+
},
|
|
358
|
+
wrap(/* stream */) {
|
|
359
|
+
// not implemented
|
|
360
|
+
throw new Error('Not Implemented');
|
|
361
|
+
},
|
|
362
|
+
});
|
|
363
|
+
|
|
364
|
+
module.exports = StreamBuf;
|