Fix #91
This commit is contained in:
@ -1,15 +1,17 @@
|
||||
/*eslint-disable block-scoped-var, id-length, no-control-regex, no-magic-numbers, no-prototype-builtins, no-redeclare, no-shadow, no-var, sort-vars*/
|
||||
(function(global, factory) { /* global define, require, module */
|
||||
|
||||
/* AMD */ if (typeof define === 'function' && define.amd)
|
||||
define(["protobufjs/minimal"], factory);
|
||||
/* CommonJS */if (typeof require === 'function' && typeof module === 'object' && module && module.exports)
|
||||
module.exports = factory(require("protobufjs/minimal"), require("../utils/modules"));
|
||||
|
||||
/* CommonJS */ else if (typeof require === 'function' && typeof module === 'object' && module && module.exports)
|
||||
module.exports = factory(require("protobufjs/minimal"));
|
||||
|
||||
})(this, function($protobuf) {
|
||||
})(this, function($protobuf, $moduleUtil) {
|
||||
"use strict";
|
||||
|
||||
// This fixes bug #91 by giving us an isolate copy of protobufjs library so any tampering with it doesn't affect us
|
||||
var old = $moduleUtil.uncache(require.resolve('protobufjs/minimal'));
|
||||
$protobuf = require('protobufjs/minimal');
|
||||
$moduleUtil.recache(old);
|
||||
|
||||
// Common aliases
|
||||
var $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;
|
||||
|
||||
|
17
src/utils/modules.js
Normal file
17
src/utils/modules.js
Normal file
@ -0,0 +1,17 @@
|
||||
exports.uncache = function uncache(id) {
|
||||
var mod = require.cache[id];
|
||||
if (!mod) return;
|
||||
delete require.cache[id];
|
||||
if (mod.children)
|
||||
for(var i = 0; i < mod.children.length; i++)
|
||||
uncache(mod.children[i].id);
|
||||
return mod;
|
||||
};
|
||||
|
||||
exports.recache = function recache(mod) {
|
||||
if (require.cache[mod.id] === mod) return;
|
||||
require.cache[mod.id] = mod;
|
||||
if (mod.children)
|
||||
for(var i = 0; i < mod.children.length; i++)
|
||||
recache(mod.children[i]);
|
||||
};
|
Reference in New Issue
Block a user