Prebuilt module for commit 29de03dc30

This commit is contained in:
Paper.js Bot 2017-03-20 11:44:32 +00:00
parent d871c104b0
commit ba892deda2
8 changed files with 81 additions and 48 deletions

View file

@ -9,7 +9,7 @@
* *
* All rights reserved. * All rights reserved.
* *
* Date: Mon Mar 20 01:02:12 2017 +0100 * Date: Mon Mar 20 12:38:52 2017 +0100
* *
*** ***
* *
@ -16416,8 +16416,9 @@ paper = new (PaperScope.inject(Base.exports, {
PlacedSymbol: SymbolItem PlacedSymbol: SymbolItem
}))(); }))();
if (paper.agent.node) if (paper.agent.node) {
require('./node/extend.js')(paper); require('./node/extend.js')(paper);
}
if (typeof define === 'function' && define.amd) { if (typeof define === 'function' && define.amd) {
define('paper', paper); define('paper', paper);

13
dist/node/canvas.js vendored
View file

@ -15,7 +15,7 @@
// - Various Node Canvas methods, routed through from HTMLCanvasElement: // - Various Node Canvas methods, routed through from HTMLCanvasElement:
// toBuffer, pngStream, createPNGStream, jpgStream, createJPGStream // toBuffer, pngStream, createPNGStream, jpgStream, createJPGStream
module.exports = function(self) { module.exports = function(self, requireName) {
var Canvas; var Canvas;
try { try {
Canvas = require('canvas'); Canvas = require('canvas');
@ -26,13 +26,16 @@ module.exports = function(self) {
// - On Node.js, it basically means the canvas is missing or not working // - On Node.js, it basically means the canvas is missing or not working
// which can be treated the same way. // which can be treated the same way.
delete self.window; delete self.window;
console.info( // Check the required module's name to see if it contains canvas, and
'Canvas module not found, running in a headless context.'); // only complain about its lack if the module requires it.
if (/\bcanvas\b/.test(requireName)) {
throw new Error('Unable to load canvas module.');
}
return; return;
} }
var idlUtils = require('jsdom/lib/jsdom/living/generated/utils'), var HTMLCanvasElement = self.HTMLCanvasElement,
HTMLCanvasElement = self.HTMLCanvasElement; idlUtils = require('jsdom/lib/jsdom/living/generated/utils');
// Add fake HTMLCanvasElement#type property: // Add fake HTMLCanvasElement#type property:
Object.defineProperty(HTMLCanvasElement.prototype, 'type', { Object.defineProperty(HTMLCanvasElement.prototype, 'type', {

57
dist/node/self.js vendored
View file

@ -13,11 +13,28 @@
// Node.js emulation layer of browser environment, based on jsdom with node- // Node.js emulation layer of browser environment, based on jsdom with node-
// canvas integration. // canvas integration.
var self; var path = require('path');
// Determine the name by which name the module was required (either 'paper',
// 'paper-jsdom' or 'paper-jsdom-canvas'), and use this to determine if error
// exceptions should be thrown or if loading should fail silently.
var parent = module.parent.parent,
requireName = parent && path.basename(path.dirname(parent.filename));
requireName = /^paper/.test(requireName) ? requireName : 'paper';
var jsdom,
self;
try { try {
var jsdom = require('jsdom'); jsdom = require('jsdom');
} catch(e) {
// Check the required module's name to see if it contains jsdom, and only
// complain about its lack if the module requires it.
if (/\bjsdom\b/.test(requireName)) {
throw new Error('Unable to load jsdom module.');
}
}
if (jsdom) {
// Create our document and window objects through jsdom. // Create our document and window objects through jsdom.
/* global document:true, window:true */ /* global document:true, window:true */
var document = jsdom.jsdom('<html><body></body></html>', { var document = jsdom.jsdom('<html><body></body></html>', {
@ -29,39 +46,9 @@ try {
} }
}); });
self = document.defaultView; self = document.defaultView;
require('./canvas.js')(self, requireName);
require('./canvas.js')(self); require('./xml.js')(self);
} else {
// Define XMLSerializer shim, to emulate browser behavior.
// Effort to bring XMLSerializer to jsdom:
// https://github.com/tmpvar/jsdom/issues/1368
/*jshint -W082 */
function XMLSerializer() {
}
XMLSerializer.prototype.serializeToString = function(node) {
if (!node)
return '';
// Fix a jsdom issue where all SVG tagNames are lowercased:
// https://github.com/tmpvar/jsdom/issues/620
var text = node.outerHTML,
tagNames = ['linearGradient', 'radialGradient', 'clipPath',
'textPath'];
for (var i = 0, l = tagNames.length; i < l; i++) {
var tagName = tagNames[i];
text = text.replace(
new RegExp('(<|</)' + tagName.toLowerCase() + '\\b', 'g'),
function(match, start) {
return start + tagName;
});
}
return text;
};
self.XMLSerializer = XMLSerializer;
} catch(e) {
console.info(
'JSDom module not found, running in a headless context without DOM.');
self = { self = {
navigator: { navigator: {
userAgent: 'Node.js (' + process.platform + '; U; rv:' + userAgent: 'Node.js (' + process.platform + '; U; rv:' +

40
dist/node/xml.js vendored Normal file
View file

@ -0,0 +1,40 @@
/*
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
* http://paperjs.org/
*
* Copyright (c) 2011 - 2016, Juerg Lehni & Jonathan Puckey
* http://scratchdisk.com/ & http://jonathanpuckey.com/
*
* Distributed under the MIT license. See LICENSE file for details.
*
* All rights reserved.
*/
module.exports = function(self) {
// Define XMLSerializer shim, to emulate browser behavior.
// Effort to bring XMLSerializer to jsdom:
// https://github.com/tmpvar/jsdom/issues/1368
self.XMLSerializer = function XMLSerializer() {
};
self.XMLSerializer.prototype = {
serializeToString: function(node) {
if (!node)
return '';
// Fix a jsdom issue where all SVG tagNames are lowercased:
// https://github.com/tmpvar/jsdom/issues/620
var text = node.outerHTML,
tagNames = ['linearGradient', 'radialGradient', 'clipPath',
'textPath'];
for (var i = 0, l = tagNames.length; i < l; i++) {
var tagName = tagNames[i];
text = text.replace(
new RegExp('(<|</)' + tagName.toLowerCase() + '\\b', 'g'),
function(match, start) {
return start + tagName;
});
}
return text;
}
};
};

5
dist/paper-core.js vendored
View file

@ -9,7 +9,7 @@
* *
* All rights reserved. * All rights reserved.
* *
* Date: Mon Mar 20 01:02:12 2017 +0100 * Date: Mon Mar 20 12:38:52 2017 +0100
* *
*** ***
* *
@ -14718,8 +14718,9 @@ paper = new (PaperScope.inject(Base.exports, {
PlacedSymbol: SymbolItem PlacedSymbol: SymbolItem
}))(); }))();
if (paper.agent.node) if (paper.agent.node) {
require('./node/extend.js')(paper); require('./node/extend.js')(paper);
}
if (typeof define === 'function' && define.amd) { if (typeof define === 'function' && define.amd) {
define('paper', paper); define('paper', paper);

View file

@ -9,7 +9,7 @@
* *
* All rights reserved. * All rights reserved.
* *
* Date: Mon Mar 20 01:02:12 2017 +0100 * Date: Mon Mar 20 12:38:52 2017 +0100
* *
*** ***
* *

5
dist/paper-full.js vendored
View file

@ -9,7 +9,7 @@
* *
* All rights reserved. * All rights reserved.
* *
* Date: Mon Mar 20 01:02:12 2017 +0100 * Date: Mon Mar 20 12:38:52 2017 +0100
* *
*** ***
* *
@ -16416,8 +16416,9 @@ paper = new (PaperScope.inject(Base.exports, {
PlacedSymbol: SymbolItem PlacedSymbol: SymbolItem
}))(); }))();
if (paper.agent.node) if (paper.agent.node) {
require('./node/extend.js')(paper); require('./node/extend.js')(paper);
}
if (typeof define === 'function' && define.amd) { if (typeof define === 'function' && define.amd) {
define('paper', paper); define('paper', paper);

View file

@ -9,7 +9,7 @@
* *
* All rights reserved. * All rights reserved.
* *
* Date: Mon Mar 20 01:02:12 2017 +0100 * Date: Mon Mar 20 12:38:52 2017 +0100
* *
*** ***
* *