mirror of
https://github.com/electron/node-gyp.git
synced 2025-09-16 14:03:39 +02:00
Add 'fstream' as a dependency.
This commit is contained in:
parent
301f8b82ec
commit
72fa76e585
88 changed files with 156 additions and 708 deletions
67
node_modules/fstream/examples/deep-copy/lib/collect.js
generated
vendored
Normal file
67
node_modules/fstream/examples/deep-copy/lib/collect.js
generated
vendored
Normal file
|
@ -0,0 +1,67 @@
|
|||
module.exports = collect
|
||||
|
||||
function collect (stream) {
|
||||
if (stream._collected) return
|
||||
|
||||
stream._collected = true
|
||||
stream.pause()
|
||||
|
||||
stream.on("data", save)
|
||||
stream.on("end", save)
|
||||
var buf = []
|
||||
function save (b) {
|
||||
if (typeof b === "string") b = new Buffer(b)
|
||||
if (Buffer.isBuffer(b) && !b.length) return
|
||||
buf.push(b)
|
||||
}
|
||||
|
||||
stream.on("entry", saveEntry)
|
||||
var entryBuffer = []
|
||||
function saveEntry (e) {
|
||||
collect(e)
|
||||
entryBuffer.push(e)
|
||||
}
|
||||
|
||||
stream.on("proxy", proxyPause)
|
||||
function proxyPause (p) {
|
||||
p.pause()
|
||||
}
|
||||
|
||||
|
||||
// replace the pipe method with a new version that will
|
||||
// unlock the buffered stuff. if you just call .pipe()
|
||||
// without a destination, then it'll re-play the events.
|
||||
stream.pipe = (function (orig) { return function (dest) {
|
||||
// console.error(" === open the pipes", dest && dest.path)
|
||||
|
||||
// let the entries flow through one at a time.
|
||||
// Once they're all done, then we can resume completely.
|
||||
var e = 0
|
||||
;(function unblockEntry () {
|
||||
var entry = entryBuffer[e++]
|
||||
// console.error(" ==== unblock entry", entry && entry.path)
|
||||
if (!entry) return resume()
|
||||
entry.on("end", unblockEntry)
|
||||
if (dest) dest.add(entry)
|
||||
else stream.emit("entry", entry)
|
||||
})()
|
||||
|
||||
function resume () {
|
||||
stream.removeListener("entry", saveEntry)
|
||||
stream.removeListener("data", save)
|
||||
stream.removeListener("end", save)
|
||||
|
||||
stream.pipe = orig
|
||||
if (dest) stream.pipe(dest)
|
||||
|
||||
buf.forEach(function (b) {
|
||||
if (b) stream.emit("data", b)
|
||||
else stream.emit("end")
|
||||
})
|
||||
|
||||
stream.resume()
|
||||
}
|
||||
|
||||
return dest
|
||||
}})(stream.pipe)
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue