Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/twbs/rewire.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorJohannes Ewald <johannes.ewald@peerigon.com>2015-02-05 23:30:15 +0300
committerJohannes Ewald <johannes.ewald@peerigon.com>2015-02-05 23:30:15 +0300
commit75ebdd4647c7cde033fd6d3c843d7235d69145bc (patch)
tree455302383f60b2497781557c467329d9a64a9da2 /lib
parent972972e405ee6aace9959723a2221c7e46fc7225 (diff)
Fix issues with reverting nested properties
Fixes #39
Diffstat (limited to 'lib')
-rw-r--r--lib/__set__.js13
1 files changed, 7 insertions, 6 deletions
diff --git a/lib/__set__.js b/lib/__set__.js
index 3fcfbdb..83671a1 100644
--- a/lib/__set__.js
+++ b/lib/__set__.js
@@ -13,18 +13,19 @@ function __set__() {
arguments.varName = arguments[0];
arguments.varValue = arguments[1];
arguments.src = "";
- arguments.snapshot = {};
+ arguments.revertArgs = [];
if (typeof arguments[0] === "object" && arguments.length === 1) {
arguments.env = arguments.varName;
if (!arguments.env || Array.isArray(arguments.env)) {
throw new TypeError("__set__ expects an object as env");
}
+ arguments.revertArgs[0] = {};
for (arguments.varName in arguments.env) {
if (arguments.env.hasOwnProperty(arguments.varName)) {
arguments.varValue = arguments.env[arguments.varName];
arguments.src += arguments.varName + " = arguments.env." + arguments.varName + "; ";
- arguments.snapshot[arguments.varName] = eval(arguments.varName);
+ arguments.revertArgs[0][arguments.varName] = eval(arguments.varName);
}
}
} else if (typeof arguments.varName === "string" && arguments.length === 2) {
@@ -32,16 +33,16 @@ function __set__() {
throw new TypeError("__set__ expects a non-empty string as a variable name");
}
arguments.src = arguments.varName + " = arguments.varValue;";
- arguments.snapshot[arguments.varName] = eval(arguments.varName);
+ arguments.revertArgs = [arguments.varName, eval(arguments.varName)];
} else {
throw new TypeError("__set__ expects an environment object or a non-empty string as a variable name");
}
eval(arguments.src);
- return function (snapshot) {
- module.exports.__set__(snapshot);
- }.bind(null, arguments.snapshot);
+ return function (revertArgs) {
+ __set__.apply(null, revertArgs);
+ }.bind(null, arguments.revertArgs);
}
module.exports = __set__;