You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cordova.apache.org by ag...@apache.org on 2012/08/20 20:05:49 UTC

js commit: Make circular require()'s and exception.

Updated Branches:
  refs/heads/master aece7e97f -> 188232f42


Make circular require()'s and exception.


Project: http://git-wip-us.apache.org/repos/asf/incubator-cordova-js/repo
Commit: http://git-wip-us.apache.org/repos/asf/incubator-cordova-js/commit/188232f4
Tree: http://git-wip-us.apache.org/repos/asf/incubator-cordova-js/tree/188232f4
Diff: http://git-wip-us.apache.org/repos/asf/incubator-cordova-js/diff/188232f4

Branch: refs/heads/master
Commit: 188232f42e60745c961363638560ad3c41b6590c
Parents: aece7e9
Author: Andrew Grieve <ag...@chromium.org>
Authored: Mon Aug 20 14:05:03 2012 -0400
Committer: Andrew Grieve <ag...@chromium.org>
Committed: Mon Aug 20 14:05:03 2012 -0400

----------------------------------------------------------------------
 lib/scripts/require.js |   21 +++++++++++++++++++--
 test/test.require.js   |   32 ++++++++++++++++++++++++++++++++
 2 files changed, 51 insertions(+), 2 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/incubator-cordova-js/blob/188232f4/lib/scripts/require.js
----------------------------------------------------------------------
diff --git a/lib/scripts/require.js b/lib/scripts/require.js
index 5ae09e2..9736dad 100644
--- a/lib/scripts/require.js
+++ b/lib/scripts/require.js
@@ -3,6 +3,10 @@ var require,
 
 (function () {
     var modules = {};
+    // Stack of moduleIds currently being built.
+    var requireStack = [];
+    // Map of module ID -> index into requireStack of modules currently being built.
+    var inProgressModules = {};
 
     function build(module) {
         var factory = module.factory;
@@ -15,8 +19,21 @@ var require,
     require = function (id) {
         if (!modules[id]) {
             throw "module " + id + " not found";
+        } else if (id in inProgressModules) {
+            var cycle = requireStack.slice(inProgressModules[id]).join('->') + '->' + id;
+            throw "Cycle in require graph: " + cycle;
         }
-        return modules[id].factory ? build(modules[id]) : modules[id].exports;
+        if (modules[id].factory) {
+            try {
+                inProgressModules[id] = requireStack.length;
+                requireStack.push(id);
+                return build(modules[id]);
+            } finally {
+                delete inProgressModules[id];
+                requireStack.pop();
+            }
+        }
+        return modules[id].exports;
     };
 
     define = function (id, factory) {
@@ -40,4 +57,4 @@ var require,
 if (typeof module === "object" && typeof require === "function") {
     module.exports.require = require;
     module.exports.define = define;
-}
\ No newline at end of file
+}

http://git-wip-us.apache.org/repos/asf/incubator-cordova-js/blob/188232f4/test/test.require.js
----------------------------------------------------------------------
diff --git a/test/test.require.js b/test/test.require.js
index b79dec4..566ae05 100644
--- a/test/test.require.js
+++ b/test/test.require.js
@@ -35,6 +35,38 @@ describe("require + define", function () {
             }).toThrow("module your mom not found");
         });
 
+        it("throws an exception when modules depend on each other", function () {
+            define("ModuleA", function(require, exports, module) {
+                require("ModuleB");
+            });
+            define("ModuleB", function(require, exports, module) {
+                require("ModuleA");
+            });
+            expect(function () {
+                require("ModuleA");
+            }).toThrow("Cycle in require graph: ModuleA->ModuleB->ModuleA");
+            define.remove("ModuleA");
+            define.remove("ModuleB");
+        });
+
+        it("throws an exception when a cycle of requires occurs", function () {
+            define("ModuleA", function(require, exports, module) {
+                require("ModuleB");
+            });
+            define("ModuleB", function(require, exports, module) {
+                require("ModuleC");
+            });
+            define("ModuleC", function(require, exports, module) {
+                require("ModuleA");
+            });
+            expect(function () {
+                require("ModuleA");
+            }).toThrow("Cycle in require graph: ModuleA->ModuleB->ModuleC->ModuleA");
+            define.remove("ModuleA");
+            define.remove("ModuleB");
+            define.remove("ModuleC");
+        });
+
         it("calls the factory method when requiring", function () {
             var factory = jasmine.createSpy();
             define("dino", factory);