From b5c837bb87bbaade77ca9280692412e46275483f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Wed, 17 Feb 2016 19:06:29 +0100 Subject: [PATCH] Fix #982: Make sure `self` points to the global scope on Webpack. --- src/init.js | 8 ++++---- src/paper.js | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/init.js b/src/init.js index b9034ee8..dec12155 100644 --- a/src/init.js +++ b/src/init.js @@ -17,10 +17,10 @@ // their shared scope. /* global document:true, window:true */ -// Use typeof self to detect both browsers and web-workers. -// In workers, window will then be null, so we can use the validity of the -// window object to decide if we're in a worker-like context in the rest of -// the library. +// Create a window variable valid in the paper.js scope, that points to the +// native window in browsers and the emulated JSDom one in node.js +// In workers, window is null (but self is defined), so we can use the validity +// of the local window object to detect a worker-like context in the library. var window = self ? self.window : require('./node/window'), document = window && window.document; // Make sure 'self' always points to a window object, also on Node.js. diff --git a/src/paper.js b/src/paper.js index dcc902dc..7b44d3a3 100644 --- a/src/paper.js +++ b/src/paper.js @@ -123,4 +123,4 @@ var paper = function(self, undefined) { /*#*/ include('export.js'); return paper; -}(this.self); +}(typeof self === 'object' ? self : null);