/*
* 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.
*/
// This file uses Prepro.js to preprocess the paper.js source code on the fly in
// the browser, avoiding the step of having to manually preprocess it after each
// change. This is very useful during development of the library itself.
if (typeof window === 'object') {
// Browser based loading through Prepro.js:
if (!window.include) {
var scripts = document.getElementsByTagName('script');
var src = scripts[scripts.length - 1].getAttribute('src');
// Assume that we're loading browser.js from a root folder, either
// through dist/paper-full.js, or directly through src/load.js, and
// match root as all the parts of the path that lead to that folder.
var root = src.match(/^(.*\/)\w*\//)[1];
// First load the prepro's browser.js file, which provides the include()
// function for the browser.
document.write('');
// Now that we have include(), load this file again, which will execute
// the lower part of the code the 2nd time around.
document.write('');
} else {
include('options.js');
include('paper.js');
}
} else {
// Node based loading through Prepro.js:
var prepro = require('prepro/lib/node.js');
// Include deafult browser options.
// Step out and back into src in case this is loaded from dist/paper-node.js
prepro.include('../src/options.js');
// Override node specific options.
prepro.setup(function() {
// This object will be merged into the Prepro.js VM scope, which already
// holds a __options object from the above include statement.
return {
__options: { environment: 'node' }
};
});
// Load Paper.js library files.
prepro.include('../src/paper.js');
}