diff options
author | Starscouts <starscouts@equestria.dev> | 2024-07-02 22:23:01 +0200 |
---|---|---|
committer | Starscouts <starscouts@equestria.dev> | 2024-07-02 22:23:01 +0200 |
commit | 04527db1831299fb3cba5c3127fd462939b448cf (patch) | |
tree | f4893e7b64faf9e23adf36f676fc6e30e745a784 /sql/mac/lib/trace.js | |
parent | ce613801c07c90d3e886fd6002f6e8f833589632 (diff) | |
download | faunerie-04527db1831299fb3cba5c3127fd462939b448cf.tar.gz faunerie-04527db1831299fb3cba5c3127fd462939b448cf.tar.bz2 faunerie-04527db1831299fb3cba5c3127fd462939b448cf.zip |
Cancel Rust rewrite3.1.0
Diffstat (limited to 'sql/mac/lib/trace.js')
-rwxr-xr-x | sql/mac/lib/trace.js | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/sql/mac/lib/trace.js b/sql/mac/lib/trace.js new file mode 100755 index 0000000..1d84cb0 --- /dev/null +++ b/sql/mac/lib/trace.js @@ -0,0 +1,38 @@ +// Inspired by https://github.com/tlrobinson/long-stack-traces +const util = require('util'); + +function extendTrace(object, property, pos) { + const old = object[property]; + object[property] = function() { + const error = new Error(); + const name = object.constructor.name + '#' + property + '(' + + Array.prototype.slice.call(arguments).map(function(el) { + return util.inspect(el, false, 0); + }).join(', ') + ')'; + + if (typeof pos === 'undefined') pos = -1; + if (pos < 0) pos += arguments.length; + const cb = arguments[pos]; + if (typeof arguments[pos] === 'function') { + arguments[pos] = function replacement() { + const err = arguments[0]; + if (err && err.stack && !err.__augmented) { + err.stack = filter(err).join('\n'); + err.stack += '\n--> in ' + name; + err.stack += '\n' + filter(error).slice(1).join('\n'); + err.__augmented = true; + } + return cb.apply(this, arguments); + }; + } + return old.apply(this, arguments); + }; +} +exports.extendTrace = extendTrace; + + +function filter(error) { + return error.stack.split('\n').filter(function(line) { + return line.indexOf(__filename) < 0; + }); +} |