mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-01 02:38:43 -05:00
89 lines
3.1 KiB
JavaScript
89 lines
3.1 KiB
JavaScript
/*
|
|
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
|
|
* http://paperjs.org/
|
|
*
|
|
* Copyright (c) 2011 - 2016, Juerg Lehni & Jonathan Puckey
|
|
* http://scratchdisk.com/ & https://puckey.studio/
|
|
*
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
*
|
|
* All rights reserved.
|
|
*/
|
|
|
|
var gulp = require('gulp'),
|
|
del = require('del'),
|
|
rename = require('gulp-rename'),
|
|
shell = require('gulp-shell'),
|
|
options = require('../utils/options.js'),
|
|
run = require('run-sequence');
|
|
|
|
var docOptions = {
|
|
local: 'docs', // Generates the offline docs
|
|
server: 'serverdocs' // Generates the website templates for the online docs
|
|
};
|
|
|
|
gulp.task('docs', ['docs:local', 'docs:typescript', 'build:full'], function() {
|
|
return gulp.src('dist/paper-full.js')
|
|
.pipe(rename({ basename: 'paper' }))
|
|
.pipe(gulp.dest('dist/docs/assets/js/'));
|
|
});
|
|
|
|
Object.keys(docOptions).forEach(function(name) {
|
|
gulp.task('docs:' + name, ['clean:docs:' + name], function() {
|
|
var mode = docOptions[name];
|
|
return gulp.src('src')
|
|
.pipe(shell(
|
|
[
|
|
'java -cp jsrun.jar:lib/* JsRun app/run.js',
|
|
' -c=conf/', name, '.conf ',
|
|
' -D="renderMode:', mode, '" ',
|
|
' -D="version:', options.version, '"'
|
|
].join(''),
|
|
{ cwd: 'gulp/jsdoc' })
|
|
);
|
|
});
|
|
|
|
gulp.task('clean:docs:' + name, function() {
|
|
return del(['dist/' + docOptions[name] + '/**']);
|
|
});
|
|
});
|
|
|
|
// The goal of the typescript task is to automatically generate a type
|
|
// definition for the library.
|
|
gulp.task('docs:typescript', function() {
|
|
return run(
|
|
'docs:typescript:clean:before',
|
|
'docs:typescript:build',
|
|
'docs:typescript:clean:after'
|
|
);
|
|
});
|
|
// First clean eventually existing type definition...
|
|
gulp.task('docs:typescript:clean:before', function() {
|
|
return del('dist/paper.d.ts');
|
|
});
|
|
// ...then build the definition...
|
|
gulp.task('docs:typescript:build', function() {
|
|
// First parse JSDoc comments and store parsed data in a temporary file...
|
|
return gulp.src('src')
|
|
.pipe(shell(
|
|
[
|
|
'java -cp jsrun.jar:lib/* JsRun app/run.js',
|
|
' -c=conf/typescript.conf ',
|
|
' -D="file:../../gulp/typescript/typescript-definition-data.json"',
|
|
' -D="version:', options.version, '"',
|
|
' -D="date:', options.date, '"'
|
|
].join(''),
|
|
{ cwd: 'gulp/jsdoc' })
|
|
)
|
|
// ...then generate definition from parsed data...
|
|
.pipe(shell('node gulp/typescript/typescript-definition-generator.js'))
|
|
// ...finally test the definition by compiling a typescript file.
|
|
.pipe(shell('node node_modules/typescript/bin/tsc gulp/typescript/typescript-definition-test.ts'));
|
|
});
|
|
// ...finally remove all unneeded temporary files that were used for building.
|
|
gulp.task('docs:typescript:clean:after', function() {
|
|
return del([
|
|
'gulp/typescript/typescript-definition-data.json',
|
|
'gulp/typescript/typescript-definition-test.js'
|
|
]);
|
|
});
|