diff options
author | cel <cel@f/6sQ6d2CMxRUhLpspgGIulDxDCwYD7DzFzPNr7u5AU=.ed25519> | 2017-06-03 12:16:56 -1000 |
---|---|---|
committer | cel <cel@f/6sQ6d2CMxRUhLpspgGIulDxDCwYD7DzFzPNr7u5AU=.ed25519> | 2017-06-03 12:36:49 -1000 |
commit | 81e06ce58a3a4a09b7c6c2837e8076ecec6e38e3 (patch) | |
tree | dfb54627171c2375d8fb0a49b4457586f3834cbd | |
parent | 2aa94754c9a09e5ea707a30c6e937b7bfb3dd05a (diff) | |
download | patchfoo-81e06ce58a3a4a09b7c6c2837e8076ecec6e38e3.tar.gz patchfoo-81e06ce58a3a4a09b7c6c2837e8076ecec6e38e3.zip |
Protect against too much recursion
-rw-r--r-- | lib/git.js | 11 | ||||
-rw-r--r-- | package.json | 1 |
2 files changed, 9 insertions, 3 deletions
@@ -7,6 +7,7 @@ var packidx = require('pull-git-packidx-parser') var Reader = require('pull-reader') var toPull = require('stream-to-pull-stream') var zlib = require('zlib') +var looper = require('looper') var ObjectNotFoundError = u.customError('ObjectNotFoundError') @@ -501,12 +502,16 @@ Git.prototype.getTag = function (obj, cb) { function readCString(reader, cb) { var chars = [] - reader.read(1, function next(err, ch) { + var loop = looper(function () { + reader.read(1, next) + }) + function next(err, ch) { if (err) return cb(err) if (ch[0] === 0) return cb(null, Buffer.concat(chars).toString('utf8')) chars.push(ch) - reader.read(1, next) - }) + loop() + } + loop() } Git.prototype.readTree = function (obj) { diff --git a/package.json b/package.json index 465e93f..42311a4 100644 --- a/package.json +++ b/package.json @@ -10,6 +10,7 @@ "human-time": "^0.0.1", "hyperscript": "^2.0.2", "hashlru": "^2.1.0", + "looper": "^4.0.0", "mime-types": "^2.1.12", "multicb": "^1.2.1", "pull-cat": "^1.1.11", |